:root{
  --black:#050505;
  --ink:#10100f;
  --paper:#f6f4ef;
  --soft:#eceae6;
  --muted:#8d8981;
  --petrol:rgb(45,79,109);
  --petrol-dark:rgb(13,84,95);
  --gold:rgb(228,189,22);
  --gold-soft:rgb(246,222,116);
  --brick:rgb(176,61,43);
  --greige:rgb(156,151,141);
  --radius:28px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--black)}
body{margin:0;font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;color:var(--ink);background:var(--black);}
a{color:inherit;text-decoration:none}

/* =====================================================
   TRANSITIONS DE PAGE — fondu entre pages internes
   ===================================================== */
@media (prefers-reduced-motion: no-preference){
  body{
    opacity:0;
    transition:opacity .34s ease;
  }

  body.tb-page-ready{
    opacity:1;
  }

  body.tb-page-leaving{
    opacity:0;
    pointer-events:none;
  }
}

@media (prefers-reduced-motion: reduce){
  body{
    opacity:1 !important;
    transition:none !important;
  }
}

.site{min-height:100vh;background:radial-gradient(circle at 70% 15%, rgba(228,189,22,.15), transparent 34%), linear-gradient(180deg,#050505 0%,#0a0a09 35%,#eceae6 36%,#f7f5f1 100%);}
.nav{position:fixed;top:18px;left:50%;transform:translateX(-50%);width:min(calc(100% - 34px), var(--max));height:68px;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:10px 14px 10px 18px;border-radius:20px;border:1px solid transparent;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 18px 48px rgba(0,0,0,.18);transition:background-color .24s ease,border-color .24s ease,box-shadow .24s ease}

.nav-brand{
  --tb-nav-logo-y:-6px;
  display:inline-flex;
  align-items:center;
  height:48px;
  position:relative;
  min-width:86px;
}

.nav-logo{
  height:84px;
  width:auto;
  display:block;
  transition:opacity .18s ease;
}

.nav-logo-dark{
  transform:translateY(var(--tb-nav-logo-y));
}

.nav-logo-light{
  position:absolute;
  left:0;
  top:50%;
  transform:translateY(calc(-50% + var(--tb-nav-logo-y)));
  opacity:0;
  pointer-events:none;
}

.nav.nav-dark{background:rgba(7,7,7,.64);border-color:rgba(255,255,255,.14);box-shadow:0 18px 48px rgba(0,0,0,.24)}
.nav.nav-light{background:rgba(255,255,255,.74);border-color:rgba(0,0,0,.08);box-shadow:0 18px 46px rgba(0,0,0,.10)}
.nav.nav-dark .nav-logo-dark{opacity:0}
.nav.nav-dark .nav-logo-light{opacity:1}
.nav.nav-light .nav-logo-dark{opacity:1}
.nav.nav-light .nav-logo-light{opacity:0}

.navlinks{
  display:flex;
  align-items:center;
  gap:10px;
  color:rgba(255,255,255,.76);
  font-size:13px;
  font-weight:750;
  letter-spacing:.02em;
  transition:color .24s ease;
}

.nav-link{
  height:30px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 12px;
  border-radius:999px;
  color:inherit;
  text-decoration:none;
  opacity:.92;
  border:1px solid transparent;
  transition:
    background-color .16s ease,
    color .16s ease,
    border-color .16s ease,
    opacity .16s ease,
    transform .16s ease;
}

.nav-link-one-logo{
  min-width:54px;
  padding:0 11px;
}

.nav-one-logo{
  display:block;
  height:40px;
  width:auto;
  object-fit:contain;
  transition:opacity .16s ease, transform .16s ease;
}

.nav-link-one-logo:hover .nav-one-logo,
.nav-link-one-logo:focus-visible .nav-one-logo{
  transform:translateY(-.5px);
}

.nav-link:hover,
.nav-link:focus-visible{
  opacity:1;
  color:var(--gold-soft);
  background:rgba(228,189,22,.13);
  border-color:rgba(228,189,22,.24);
  transform:translateY(-1px);
  outline:none;
}

.nav-link.is-active,
body.page-conseil .nav-link-conseil,
body.page-methode-one .nav-link-methode,
body.page-one .nav-link-one{
  opacity:1;
  color:var(--gold-soft);
  background:rgba(228,189,22,.16);
  border-color:rgba(228,189,22,.26);
}

.nav.nav-light .navlinks{
  color:rgba(0,0,0,.68);
}

.nav.nav-light .nav-link:hover,
.nav.nav-light .nav-link:focus-visible,
.nav.nav-light .nav-link.is-active,
body.page-conseil .nav.nav-light .nav-link-conseil,
body.page-methode-one .nav.nav-light .nav-link-methode,
body.page-one .nav.nav-light .nav-link-one{
  color:#000;
  background:rgba(228,189,22,.22);
  border-color:rgba(228,189,22,.34);
}

.nav-cta{height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:0 16px;background:var(--gold);color:#090909;font-weight:900;border:1px solid rgba(255,255,255,.1)}

/* =====================================================
   NAV — hovers différenciés Conseil / Méthode / One / Contact
   ===================================================== */

/* Méthode : bleu clair dérivé du bleu Trust Board */
.nav-link-methode:hover,
.nav-link-methode:focus-visible,
body.page-methode-one .nav-link-methode{
  opacity:1;
  color:var(--gold-soft);
  background:rgba(45,79,109,.34);
  border-color:rgba(45,79,109,.46);
}

.nav.nav-light .nav-link-methode:hover,
.nav.nav-light .nav-link-methode:focus-visible,
body.page-methode-one .nav.nav-light .nav-link-methode{
  color:var(--petrol);
  background:rgba(45,79,109,.16);
  border-color:rgba(45,79,109,.30);
}

/* One : pas de pastille ; le logo porte seul l'interaction */
.nav-link-one-logo,
.nav-link-one-logo:hover,
.nav-link-one-logo:focus-visible,
.nav-link-one-logo.is-active,
body.page-one .nav-link-one-logo,
body.page-one .nav.nav-light .nav-link-one-logo,
body.page-one .nav.nav-dark .nav-link-one-logo{
  background:transparent !important;
  border-color:transparent !important;
  box-shadow:none !important;
}

.nav-link-one-logo:hover,
.nav-link-one-logo:focus-visible{
  transform:none;
}

.nav-link-one-logo:hover .nav-one-logo,
.nav-link-one-logo:focus-visible .nav-one-logo{
  transform:translateY(-.5px);
}

/* Menu clair : logo One noir au survol */
.nav.nav-light .nav-link-one-logo:hover .nav-one-logo,
.nav.nav-light .nav-link-one-logo:focus-visible .nav-one-logo{
  filter:brightness(0) saturate(100%);
}

/* Menu sombre : on conserve le doré, sinon le logo devient illisible */
.nav.nav-dark .nav-link-one-logo:hover .nav-one-logo,
.nav.nav-dark .nav-link-one-logo:focus-visible .nav-one-logo{
  filter:none;
}

/* Contact : inversion nette */
.nav-cta{
  transition:
    background-color .16s ease,
    color .16s ease,
    border-color .16s ease,
    transform .16s ease;
}

.nav-cta:hover,
.nav-cta:focus-visible{
  background:#000;
  color:var(--gold);
  border-color:#000;
  transform:translateY(-1px);
  outline:none;
}

.hero{min-height:100vh;position:relative;display:flex;align-items:center;overflow:hidden;padding:116px 26px 70px}
.hero-inner{width:min(100%,var(--max));margin:0 auto;position:relative;z-index:2;display:grid;grid-template-columns:1.02fr .98fr;gap:42px;align-items:center}
.kicker{display:inline-flex;align-items:center;gap:10px;border:1px solid rgba(228,189,22,.35);background:rgba(228,189,22,.08);color:var(--gold-soft);border-radius:999px;padding:8px 13px;font-size:12px;text-transform:uppercase;font-weight:900;letter-spacing:.14em;margin-bottom:22px}
.kicker:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 22px rgba(228,189,22,.75)}
h1{font-size:clamp(44px,7vw,80px);line-height:.95;margin:0;color:#fff;letter-spacing:-.055em;font-weight:940}
h1 .gold{color:var(--gold)}
.hero p{max-width:660px;color:rgba(255,255,255,.88);font-size:clamp(18px,2vw,23px);line-height:1.42;margin:28px 0 0;font-weight:560}
.hero p strong{
  font-weight:760;
  color:rgba(255,255,255,.90);
}
.hero-actions{display:flex;align-items:center;gap:14px;margin-top:34px;flex-wrap:wrap}
.btn{height:48px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:0 22px;font-weight:900;border:1px solid rgba(255,255,255,.16)}
.btn-primary{background:var(--gold);color:#0a0a0a}
.btn-secondary{background:rgba(255,255,255,.05);color:#fff}

.hero-scroll-cue{
  position:absolute;
  left:50%;
  bottom:-45px;
  transform:translateX(-50%);
  z-index:5;

  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2px;

  color:var(--gold);
  text-decoration:none;
  font-weight:950;
  letter-spacing:.02em;

  filter:drop-shadow(0 0 16px rgba(228,189,22,.28));
  animation:scrollNeon 1.85s ease-in-out infinite;
}

.hero-scroll-cue{
  transition: opacity .28s ease, transform .28s ease, filter .28s ease;
}

.hero-scroll-cue.is-hidden{
  opacity:0;
  pointer-events:none;
  filter:none;
  animation:none;
  transform:translateX(-50%) translateY(10px);
}

.hero-scroll-word{
  font-size:18px;
  line-height:1;
}

.hero-scroll-arrows{
  display:flex;
  flex-direction:column;
  align-items:center;
  line-height:.62;
  font-size:24px;
  font-weight:950;
}

.hero-scroll-arrows span{
  display:block;
  animation:scrollArrowPulse 1.85s ease-in-out infinite;
}

.hero-scroll-arrows span:nth-child(2){
  animation-delay:.12s;
}

.hero-scroll-arrows span:nth-child(3){
  animation-delay:.24s;
}

.hero-scroll-cue:hover{
  color:var(--gold-soft);
}

@keyframes scrollNeon{
  0%,100%{
    opacity:.48;
    text-shadow:0 0 4px rgba(228,189,22,.22);
  }
  45%{
    opacity:1;
    text-shadow:
      0 0 8px rgba(228,189,22,.70),
      0 0 18px rgba(228,189,22,.36);
  }
}

@keyframes scrollArrowPulse{
  0%,100%{
    opacity:.35;
    transform:translateY(0);
  }
  45%{
    opacity:1;
    transform:translateY(3px);
  }
}


.hero-side{position:relative;min-height:490px;display:flex;align-items:center;justify-content:center;perspective:1000px}
.one-bg{
  position:absolute;
  inset:auto 5% 55% auto;
  width:78%;
  max-width:560px;
  opacity:.90;
  filter:drop-shadow(0 18px 40px rgba(228,189,22,.16));
  transform:rotate(-4deg);
}

.command-card{
  position:relative;
  margin-top:130px;
  width:min(96%,620px);
  border-radius:32px;
  background:transparent;
  box-shadow:0 38px 90px rgba(0,0,0,.45);
  border:0;
  padding:0;
  transform:rotateY(-11deg) rotateX(6deg);
  transform-style:preserve-3d;
  overflow:visible;
}

.command-card-image{
  padding:0;
  background:transparent;
  border:0;
}

.command-card-img{
  position:relative;
  z-index:1;
  display:block;
  width:100%;
  height:auto;
  border-radius:28px;
  opacity:.94;
  box-shadow:0 18px 42px rgba(0,0,0,.22);
}

.command-card:before{
  content:"";
  position:absolute;
  inset:18px;
  transform:translateZ(-60px);
  border-radius:28px;
  background:rgba(45,79,109,.42);
  filter:blur(16px);
}

.card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.card-logo{height:34px!important}
.status{font-size:12px;font-weight:900;color:var(--petrol);display:flex;align-items:center;gap:7px}
.status:before{content:"";width:9px;height:9px;border-radius:50%;background:#4fae4e}
.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}
.metric{border-radius:18px;background:#fff;border:1px solid rgba(0,0,0,.08);padding:16px 14px;min-height:88px}
.metric b{display:block;font-size:32px;line-height:1;color:var(--petrol);letter-spacing:-.04em}
.metric span{display:block;margin-top:8px;font-size:12px;color:#68645d;font-weight:800;line-height:1.18}
.rows{display:flex;flex-direction:column;gap:9px}
.row{height:36px;border-radius:12px;background:#fff;border:1px solid rgba(0,0,0,.06);display:grid;grid-template-columns:70px 1fr 52px;align-items:center;gap:10px;padding:0 12px;font-size:12px;font-weight:800;color:#5b5852}
.pill{display:inline-flex;align-items:center;justify-content:center;height:20px;border-radius:999px;background:var(--gold-soft);color:#111;font-size:10px;font-weight:900}
.bar{height:7px;border-radius:99px;background:linear-gradient(90deg,var(--petrol) var(--w), rgba(45,79,109,.12) var(--w))}
.chapter{min-height:100vh;position:relative;padding:9vh 24px;display:flex;align-items:center;justify-content:center;background:var(--paper)}
.chapter.dark{background:#070707;color:#fff}
.depth-wrap{width:min(100%,var(--max));perspective:1200px}
.depth-card{position:sticky;top:95px;min-height:72vh;border-radius:34px;background:rgba(255,255,255,.82);border:1px solid rgba(0,0,0,.07);box-shadow:0 30px 90px rgba(0,0,0,.12);overflow:hidden;display:grid;grid-template-columns:.9fr 1.1fr;transform-origin:50% 80%;will-change:transform,opacity;backdrop-filter:blur(20px)}
.dark .depth-card{background:rgba(236,234,230,.08);border:1px solid rgba(255,255,255,.12);box-shadow:0 36px 120px rgba(0,0,0,.45)}

/* ===== Cartes de séquence : Le problème / La réponse One ===== */

.sequence-section{
  min-height:72vh;
}

.sequence-card.depth-card{
  min-height:42vh;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  padding:64px;
  grid-template-columns:1fr;
}

.sequence-card h2{
  font-size:clamp(54px,8vw,110px);
  line-height:.9;
  letter-spacing:-.07em;
}

.sequence-title-with-logo{
  display:flex;
  align-items:center;
  gap:.24em;
  flex-wrap:wrap;
}

.sequence-title-with-logo span{
  display:inline-block;
}

.sequence-one-logo{
  height:1.5em;
  width:auto;
  display:inline-block;
  transform:translateY(-.25em);
  filter:drop-shadow(0 10px 22px rgba(228,189,22,.18));
}

.sequence-card p{
  max-width:760px;
  margin:24px 0 0;
  font-size:clamp(20px,2vw,28px);
  line-height:1.35;
  font-weight:650;
}

.sequence-subtitle{
  margin-top:16px !important; /* réduit l'espace sous le titre */
}

.sequence-subtitle span{
  color:var(--gold);
  font-weight:850;
}

.sequence-subtitle{
  max-width:1120px !important;
  margin-top:12px !important;
}

.sequence-kicker{
  margin-bottom:22px;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:13px;
  font-weight:950;
  color:var(--gold);
}

.sequence-card-dark{
  background:rgba(255,255,255,.06);
  color:#fff;
}

.sequence-card-light{
  background:rgba(255,255,255,.84);
  color:#050505;
}

.sequence-card-light .sequence-kicker{
  color:var(--petrol);
}

.sequence-card-light p{
  color:rgba(0,0,0,.62);
}

.copy{padding:52px;display:flex;flex-direction:column;justify-content:center}

.eyebrow{
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:14px;
  font-weight:950;
  color:var(--gold);
  margin-bottom:18px;
}

h2{margin:0;font-size:clamp(36px,5vw,68px);line-height:.96;letter-spacing:-.055em;font-weight:940}

.chapter.dark .copy h2{
  line-height:1.05;
}

.chapter.dark .copy h2 .title-end{
  white-space:nowrap;
}

.chapter.dark .copy h2 .title-end::after{
  content:".";
  font-size:.65em;
  line-height:0;
  vertical-align:.00em;
  margin-left:.03em;
}

.copy p{font-size:19px;line-height:1.46;color:rgba(0,0,0,.66);font-weight:570;margin:22px 0 0;max-width:530px}
.dark .copy p{color:rgba(255,255,255,.80)}
.proof{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:28px;max-width:540px}

.proof div{
  border-radius:16px;
  padding:13px 12px;
  background:rgba(45,79,109,.08);
  color:var(--petrol);
  font-size:12px;
  font-weight:900;
  line-height:1.2;

  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}


.dark .proof div{
  background:rgba(255,255,255,.07);
  color:var(--gold);
  font-size:15px;
  line-height:1.08;
}

/* ===== Pastilles interactives + infobulles ===== */

.copy,
.proof{
  overflow:visible;
}

.copy{
  position:relative;
  z-index:4;
}

.proof div[data-tip]{
  position:relative;
  cursor:help;
  transition:
    background-color .16s ease,
    color .16s ease,
    transform .16s ease,
    box-shadow .16s ease;
}

.proof div[data-tip]:hover,
.proof div[data-tip]:focus-visible{
  background:var(--gold);
  color:var(--petrol);
  transform:translateY(-2px);
  box-shadow:0 14px 34px rgba(0,0,0,.12);
  outline:none;
}

.dark .proof div[data-tip]:hover,
.dark .proof div[data-tip]:focus-visible{
  background:var(--gold);
  color:#050505;
}

.proof div[data-tip]::after{
  content:attr(data-tip);
  position:absolute;
  left:50%;
  bottom:calc(100% + 13px);
  transform:translateX(-50%) translateY(4px);

  width:max-content;
  max-width:285px;
  padding:12px 14px;
  border-radius:16px;

  background:rgba(255,244,217,.94);
  border:1px solid rgba(228,189,22,.34);
  box-shadow:0 18px 46px rgba(0,0,0,.16);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);

  color:rgba(0,0,0,.82);
  font-size:13px;
  line-height:1.32;
  font-weight:760;
  letter-spacing:0;
  text-align:left;
  white-space:normal;

  opacity:0;
  pointer-events:none;
  z-index:30;
  transition:opacity .16s ease, transform .16s ease;
}

.proof div[data-tip]::before{
  content:"";
  position:absolute;
  left:50%;
  bottom:calc(100% + 6px);
  transform:translateX(-50%) translateY(4px) rotate(45deg);

  width:12px;
  height:12px;
  background:rgba(255,244,217,.94);
  border-right:1px solid rgba(228,189,22,.34);
  border-bottom:1px solid rgba(228,189,22,.34);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);

  opacity:0;
  pointer-events:none;
  z-index:29;
  transition:opacity .16s ease, transform .16s ease;
}

.proof div[data-tip]:hover::after,
.proof div[data-tip]:focus-visible::after,
.proof div[data-tip]:hover::before,
.proof div[data-tip]:focus-visible::before{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}

.proof div[data-tip]:hover::before,
.proof div[data-tip]:focus-visible::before{
  transform:translateX(-50%) translateY(0) rotate(45deg);
}

.dark .proof div[data-tip]::after{
  background:rgba(255,244,217,.96);
  border:1px solid rgba(228,189,22,.38);
  color:rgba(0,0,0,.82);
  box-shadow:0 18px 46px rgba(0,0,0,.28);
}

.dark .proof div[data-tip]::before{
  background:rgba(255,244,217,.96);
  border-right:1px solid rgba(228,189,22,.38);
  border-bottom:1px solid rgba(228,189,22,.38);
}

/* Correction : éviter que les infobulles des pastilles latérales soient tronquées */

.proof div[data-tip]:first-child::after{
  left:0;
  transform:translateY(4px);
}

.proof div[data-tip]:first-child:hover::after,
.proof div[data-tip]:first-child:focus-visible::after{
  transform:translateY(0);
}

.proof div[data-tip]:last-child::after{
  left:auto;
  right:0;
  transform:translateY(4px);
}

.proof div[data-tip]:last-child:hover::after,
.proof div[data-tip]:last-child:focus-visible::after{
  transform:translateY(0);
}

/* On garde la petite pointe centrée sur la pastille */
.proof div[data-tip]:first-child::before,
.proof div[data-tip]:last-child::before{
  left:50%;
  right:auto;
}


.visual{position:relative;display:flex;align-items:center;justify-content:center;padding:40px;background:linear-gradient(135deg,rgba(45,79,109,.08),rgba(228,189,22,.12))}
.dark .visual{background:linear-gradient(135deg,rgba(45,79,109,.26),rgba(228,189,22,.08))}


/* ===== Carte problème : flux d'informations autour du dirigeant ===== */

.data-chaos{
  width:min(86%,560px);
  aspect-ratio:1.12/1;
  border-radius:32px;
  background:
    radial-gradient(circle at 50% 48%, rgba(228,189,22,.08), transparent 34%),
    rgba(255,255,255,.94);
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 24px 70px rgba(0,0,0,.14);
  position:relative;
  overflow:hidden;
  isolation:isolate;
}

/* Overlay de verdict : assombrit et floute la scène quand "TROP TARD" apparaît */
.data-chaos::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:11;
  background:rgba(0,0,0,.38);
  backdrop-filter:blur(3px);
  -webkit-backdrop-filter:blur(3px);
  opacity:0;
  pointer-events:none;
  animation:lateSceneVeil 9.2s ease-in-out infinite;
}

@keyframes lateSceneVeil{
  0%,74%{
    opacity:0;
  }
  78%,90%{
    opacity:1;
  }
  100%{
    opacity:0;
  }
}

.data-chaos::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.82) 0%, transparent 8%, transparent 92%, rgba(255,255,255,.82) 100%),
    linear-gradient(180deg, rgba(255,255,255,.72) 0%, transparent 7%, transparent 93%, rgba(255,255,255,.72) 100%);
  z-index:1;
  pointer-events:none;
}

/* ===== Texte de fond : listing continu façon télex ===== */

.data-rain{
  position:absolute;
  inset:0;
  z-index:0;
  overflow:hidden;
  pointer-events:none;
  padding:0;
}

.data-rain-track{
  position:absolute;
  left:0;
  top:0;
  width:100%;
  height:200%;
  animation:dataRainTape 4.2s linear infinite;
  will-change:transform;
}

.data-rain-panel{
  height:50%;
  width:100%;
  box-sizing:border-box;
  padding:10px 5px;

  display:flex;
  flex-direction:column;
  justify-content:space-between;

  overflow:hidden;
}

.data-rain-panel span{
  display:block;
  width:100%;
  white-space:nowrap;
  overflow:hidden;

  color:rgba(45,79,109,.25);
  font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size:18px;
  line-height:1;
  font-weight:850;
  letter-spacing:.002em;

  text-align:left;
  text-shadow:0 0 1px rgba(45,79,109,.10);
}

@keyframes dataRainTape{
  0%{
    transform:translateY(0);
  }
  100%{
    transform:translateY(-50%);
  }
}


/* ===== Pastille dirigeant + désorientation ===== */

.leader-node{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  z-index:8;

  width:172px;
  height:92px;
  border-radius:22px;
  background:#060606;
  color:var(--gold);
  box-shadow:
    0 18px 42px rgba(0,0,0,.28),
    0 0 0 1px rgba(255,255,255,.06) inset;

  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
  box-sizing:border-box;
  padding:14px 12px 13px;

  font-weight:950;
  letter-spacing:-.02em;
}

.leader-label{
  font-size:20px;
  line-height:1;
}

.leader-windvane{
  position:absolute;
  left:50%;
  top:11px;                 /* descend la girouette d’environ 5px */
  width:62px;
  height:54px;
  transform:translateX(-50%);
  opacity:.98;
}

.wv-mast{
  position:absolute;
  left:50%;
  top:7px;
  width:4px;
  height:42px;              /* mât un peu plus long */
  transform:translateX(-50%);
  border-radius:999px;
  background:rgba(228,189,22,.82);
  z-index:1;
}

.wv-mast::before{
  content:"";
  position:absolute;
  left:50%;
  top:-5px;
  width:12px;               /* boule réduite */
  height:12px;              /* boule réduite */
  transform:translateX(-50%);
  border-radius:999px;
  background:var(--gold);
  box-shadow:0 0 10px rgba(228,189,22,.18);
}

.wv-rotor{
  position:absolute;
  left:50%;
  top:12px;
  width:50px;               /* flèche un peu plus longue */
  height:18px;
  transform-origin:50% 50%;
  transform:translateX(-50%) rotate(14deg);
  animation:windVane 6.6s cubic-bezier(.55,.02,.27,1) infinite;
  z-index:2;
}

.wv-rotor::before,
.wv-rotor::after{
  content:"";
  position:absolute;
  top:50%;
  width:9px;
  height:9px;
  box-sizing:border-box;

  border:solid var(--gold);
  border-width:0 3px 3px 0;

  transform:translateY(-50%) rotate(-45deg);
  transform-origin:center;
}

.wv-rotor::before{
  left:-5px;
}

.wv-rotor::after{
  left:3px;
}

.wv-arrow{
  position:absolute;
  left:12px;   /* tige plus longue côté chevrons */
  right:6px;
  top:8px;
  height:3px;
  border-radius:999px;
  background:var(--gold);
  box-shadow:0 0 10px rgba(228,189,22,.18);
}

.wv-arrow::after{
  content:"";
  position:absolute;
  right:-7px;
  top:50%;
  transform:translateY(-50%);
  width:0;
  height:0;
  border-left:9px solid var(--gold);
  border-top:5px solid transparent;
  border-bottom:5px solid transparent;
}

.wv-arrow::before{
  display:none;
}

@keyframes windVane{
  0%,10%{ transform:translateX(-50%) rotate(14deg); }
  23%,31%{ transform:translateX(-50%) rotate(-62deg); }
  43%,50%{ transform:translateX(-50%) rotate(68deg); }
  58%{ transform:translateX(-50%) rotate(-34deg); }
  64%{ transform:translateX(-50%) rotate(388deg); }
  69%{ transform:translateX(-50%) rotate(742deg); }
  74%{ transform:translateX(-50%) rotate(24deg); }
  78%{ transform:translateX(-50%) rotate(-12deg); }
  82%{ transform:translateX(-50%) rotate(8deg); }
  86%{ transform:translateX(-50%) rotate(-5deg); }
  91%,100%{ transform:translateX(-50%) rotate(14deg); }
}

/* ===== Compte à rebours + verdict ===== */

.chaos-timer{
  --timer-cycle:9.2s;
  position:absolute;
  top:18px;
  right:18px;
  z-index:9;
  width:54px;
  height:54px;
  display:grid;
  place-items:center;
  filter:drop-shadow(0 10px 22px rgba(0,0,0,.12));
}

.timer-svg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  transform:rotate(-90deg);
}

.timer-bg,
.timer-fg{
  fill:none;
  stroke-width:4.2;
}

.timer-bg{
  stroke:rgba(45,79,109,.16);
}

.timer-fg{
  stroke:rgb(176,61,43);
  stroke-linecap:round;
  stroke-dasharray:100;
  stroke-dashoffset:0;
  animation:timerConsume var(--timer-cycle) linear infinite;
}

.timer-count{
  position:relative;
  z-index:1;
  width:100%;
  height:100%;
  display:grid;
  place-items:center;
  color:rgb(176,61,43);
  font-size:16px;
  line-height:1;
  font-weight:950;
  font-variant-numeric:tabular-nums;
}

.timer-count span{
  grid-area:1 / 1;
  opacity:0;
}

.timer-n7{ animation:timerDigit7 var(--timer-cycle) linear infinite; }
.timer-n6{ animation:timerDigit6 var(--timer-cycle) linear infinite; }
.timer-n5{ animation:timerDigit5 var(--timer-cycle) linear infinite; }
.timer-n4{ animation:timerDigit4 var(--timer-cycle) linear infinite; }
.timer-n3{ animation:timerDigit3 var(--timer-cycle) linear infinite; }
.timer-n2{ animation:timerDigit2 var(--timer-cycle) linear infinite; }
.timer-n1{ animation:timerDigit1 var(--timer-cycle) linear infinite; }

@keyframes timerConsume{
  0%{ stroke-dashoffset:0; }
  76.1%{ stroke-dashoffset:100; }
  100%{ stroke-dashoffset:100; }
}

@keyframes timerDigit7{ 0%,10.7%{opacity:1} 10.8%,100%{opacity:0} }
@keyframes timerDigit6{ 0%,10.7%{opacity:0} 10.8%,21.6%{opacity:1} 21.7%,100%{opacity:0} }
@keyframes timerDigit5{ 0%,21.6%{opacity:0} 21.7%,32.5%{opacity:1} 32.6%,100%{opacity:0} }
@keyframes timerDigit4{ 0%,32.5%{opacity:0} 32.6%,43.4%{opacity:1} 43.5%,100%{opacity:0} }
@keyframes timerDigit3{ 0%,43.4%{opacity:0} 43.5%,54.3%{opacity:1} 54.4%,100%{opacity:0} }
@keyframes timerDigit2{ 0%,54.3%{opacity:0} 54.4%,65.2%{opacity:1} 65.3%,100%{opacity:0} }
@keyframes timerDigit1{ 0%,65.2%{opacity:0} 65.3%,76.1%{opacity:1} 76.2%,100%{opacity:0} }

.late-warning{
  position:absolute;
  left:50%;
  top:50%;
  z-index:12;
  transform:translate(-50%,-50%) scale(.94);

  width:min(62%,320px);
  min-height:92px;
  padding:12px 22px 15px;
  box-sizing:border-box;
  border-radius:18px;

  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  text-align:center;

  background:rgba(176,61,43,.96);
  color:#fff;

  box-shadow:
    0 18px 46px rgba(0,0,0,.26),
    0 0 26px rgba(176,61,43,.20);

  opacity:0;
  pointer-events:none;
  animation:lateWarning 9.2s ease-in-out infinite;
}

.late-main{
  display:block;
  margin-top:4px;
  font-size:clamp(24px,3.4vw,38px);
  line-height:.98;
  font-weight:950;
  letter-spacing:-.04em;
}

.late-reason{
  display:block;
  position:absolute;
  left:18px;
  right:18px;
  bottom:15px;

  font-size:clamp(11px,1.45vw,15px);
  line-height:1.12;
  font-weight:800;
  letter-spacing:.015em;

  text-transform:none;
  font-variant:normal;

  color:rgba(255,255,255,.84);
  opacity:0;
}

.late-r1{ animation:lateReason1 55.2s linear infinite; }
.late-r2{ animation:lateReason2 55.2s linear infinite; }
.late-r3{ animation:lateReason3 55.2s linear infinite; }
.late-r4{ animation:lateReason4 55.2s linear infinite; }
.late-r5{ animation:lateReason5 55.2s linear infinite; }
.late-r6{ animation:lateReason6 55.2s linear infinite; }

@keyframes lateReason1{
  0%,15.8%{opacity:1}
  16.0%,100%{opacity:0}
}

@keyframes lateReason2{
  0%,16.5%{opacity:0}
  16.7%,32.5%{opacity:1}
  32.7%,100%{opacity:0}
}

@keyframes lateReason3{
  0%,33.2%{opacity:0}
  33.4%,49.2%{opacity:1}
  49.4%,100%{opacity:0}
}

@keyframes lateReason4{
  0%,49.9%{opacity:0}
  50.1%,65.9%{opacity:1}
  66.1%,100%{opacity:0}
}

@keyframes lateReason5{
  0%,66.6%{opacity:0}
  66.8%,82.6%{opacity:1}
  82.8%,100%{opacity:0}
}

@keyframes lateReason6{
  0%,83.3%{opacity:0}
  83.5%,99.2%{opacity:1}
  99.4%,100%{opacity:0}
}

@keyframes lateWarning{
  0%,74%{
    opacity:0;
    transform:translate(-50%,-50%) scale(.94);
  }
  78%,90%{
    opacity:1;
    transform:translate(-50%,-50%) scale(1);
  }
  100%{
    opacity:0;
    transform:translate(-50%,-50%) scale(.98);
  }
}

/* ===== Pastilles animées ===== */

.data-token{
  position:absolute;
  left:50%;
  top:50%;
  z-index:4;

  height:42px;
  min-width:104px;
  padding:0 18px;
  border-radius:16px;

  display:inline-flex;
  align-items:center;
  justify-content:center;

  font-size:12px;
  font-weight:950;
  white-space:nowrap;

  box-shadow:0 12px 28px rgba(0,0,0,.13);
  border:1px solid rgba(0,0,0,.08);

  animation:dataDrive 8.4s ease-in-out infinite;
  animation-delay:var(--delay,0s);
}

@keyframes dataDrive{
  0%{
    opacity:0;
    transform:translate3d(calc(var(--dir) * -460px), var(--y), 0) scale(.96);
  }

  8%{
    opacity:1;
  }

  34%{
    transform:translate3d(calc(var(--dir) * -140px), var(--y), 0) scale(1);
    opacity:1;
  }

  46%{
    transform:translate3d(calc(var(--dir) * -108px), var(--y), 0) scale(1.025);
    opacity:1;
  }

  58%{
    transform:translate3d(calc(var(--dir) * -126px), var(--y), 0) scale(.99);
    opacity:1;
  }

  70%{
    transform:translate3d(calc(var(--dir) * -84px), var(--y), 0) scale(1.01);
    opacity:1;
  }

  82%{
    opacity:.92;
  }

  92%{
    opacity:.45;
  }

  100%{
    opacity:0;
    transform:translate3d(calc(var(--dir) * 460px), var(--y), 0) scale(.96);
  }
}

.token-mail{
  background:rgb(45,79,109);
  color:#fff;
}

.token-doc{
  background:rgb(228,189,22);
  color:rgb(45,79,109);
}

.token-report{
  background:rgb(39,83,23);
  color:#fff;
}

.token-alert{
  background:rgb(176,61,43);
  color:#fff;
  box-shadow:
    0 12px 28px rgba(0,0,0,.14),
    0 0 24px rgba(176,61,43,.18);
}


.screen{width:100%;max-width:650px;border-radius:24px;background:#fff;box-shadow:0 34px 82px rgba(0,0,0,.18);border:1px solid rgba(0,0,0,.08);overflow:hidden;transform:rotateY(-8deg) rotateX(4deg)}
.screen img{display:block;width:100%;height:auto}
.abstract{width:min(86%,550px);aspect-ratio:1.1/1;border-radius:32px;background:#fff;border:1px solid rgba(0,0,0,.08);box-shadow:0 24px 70px rgba(0,0,0,.14);position:relative;overflow:hidden}
.abstract:before{content:"";position:absolute;inset:38px;border:2px solid rgba(45,79,109,.14);border-radius:24px}
.node{position:absolute;width:116px;height:66px;border-radius:18px;background:#fff;border:1px solid rgba(0,0,0,.08);box-shadow:0 10px 30px rgba(0,0,0,.1);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:950;color:var(--petrol)}
.n1{left:44px;top:48px;background:var(--petrol);color:#fff}.n2{right:48px;top:78px;background:var(--gold)}.n3{left:80px;bottom:80px;background:#f4f0e7}.n4{right:62px;bottom:56px;background:#fff}.n5{left:50%;top:50%;transform:translate(-50%,-50%);background:#090909;color:var(--gold);width:138px;height:78px}
.line{position:absolute;height:2px;background:rgba(45,79,109,.18);transform-origin:left top}
.l1{left:150px;top:84px;width:215px;transform:rotate(8deg)}.l2{left:180px;top:244px;width:210px;transform:rotate(-20deg)}.l3{left:188px;top:96px;width:180px;transform:rotate(47deg)}.l4{left:260px;top:255px;width:180px;transform:rotate(30deg)}
.transition{background:#0a0a09;color:#fff;text-align:center;padding:120px 24px}
.transition .inner{width:min(100%,980px);margin:0 auto}

.transition h2{font-size:clamp(42px,7vw,70px)}

.manifesto-title{
  display:flex;
  flex-direction:column;
  align-items:center;
}

.manifesto-title span{
  display:block;
  line-height:.92;
}

.manifesto-title .manifesto-break{
  margin-top:.35em;
}

/* Coloration progressive de "système de pilotage" */
.manifesto-title{
  --pilotage-progress:0;
}

.pilotage-reveal{
  display:inline-block;

  color:transparent;
  background:
    linear-gradient(
      90deg,
      var(--gold) 0%,
      var(--gold) var(--pilotage-progress-pct),
      #fff var(--pilotage-progress-pct),
      #fff 100%
    );

  -webkit-background-clip:text;
  background-clip:text;

  line-height:1.12;
  padding:.04em .06em .20em .06em;
  margin:-.04em -.06em -.20em -.06em;

  text-shadow:
    0 0 calc(10px * var(--pilotage-progress)) rgba(228,189,22,.28);
}

.transition p{margin:26px auto 0;max-width:720px;color:rgba(255,255,255,.65);font-size:20px;line-height:1.45;font-weight:560}

/* ===== Avant-dernière carte — garanties One ===== */

.security-chapter{
  min-height:82vh;
  background:rgb(246,245,241);
  padding:96px 24px;
  display:flex;
  align-items:center;
}

.security{
  width:min(100%,var(--max));
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:46px;
}

.security-head{
  max-width:980px;
  margin:0 auto;
  text-align:center;
}

.security-head h2{
  margin:0;
  color:#080808;
  font-size:clamp(40px,5.1vw,74px);
  line-height:.96;
  letter-spacing:-.06em;
  font-weight:950;
}

.security-head p{
  margin:22px auto 0;
  max-width:760px;
  color:rgba(0,0,0,.58);
  font-size:clamp(18px,1.55vw,24px);
  line-height:1.35;
  font-weight:720;
}

.security-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:16px;
}

.security-card{
  min-height:255px;
  border-radius:26px;
  padding:26px 22px 24px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(0,0,0,.07);
  box-shadow:0 24px 70px rgba(0,0,0,.08);
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}

.security-card > svg{
  width:76px;
  height:76px;
  display:block;
  margin:0 0 24px 0;
  color:#080808;
  flex:0 0 auto;
}

.security-card > svg *{
  vector-effect:non-scaling-stroke;
}


.security-icon{
  width:42px;
  height:42px;
  border-radius:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-bottom:20px;
  background:rgba(228,189,22,.13);
  color:rgb(176,61,43);
  font-size:25px;
  font-weight:900;
  line-height:1;
}

.security-icon-text{
  font-size:15px;
  letter-spacing:-.04em;
  color:rgb(45,79,109);
}

.security-card h3{
  margin:0 0 12px 0;
  color:#080808;
  font-size:22px;
  line-height:1;
  letter-spacing:-.045em;
  font-weight:900;
}

.security-card p{
  margin:0;
  color:rgba(0,0,0,.58);
  font-size:15.5px;
  line-height:1.48;
  font-weight:620;
}


/* ===== Page One — apparition progressive des cartes Architecture ===== */
body.page-one .security-card{
  opacity:0 !important;
  transform:translateY(86px) scale(.985) !important;
  transition:
    opacity .75s cubic-bezier(.18,.78,.24,1),
    transform .75s cubic-bezier(.18,.78,.24,1),
    background-color .18s ease,
    box-shadow .18s ease;
  will-change:opacity, transform;
}

body.page-one .security-chapter.is-visible .security-card{
  opacity:1 !important;
  transform:translateY(0) scale(1) !important;
}

body.page-one .security-chapter.is-visible .security-card:nth-child(1){ transition-delay:.00s; }
body.page-one .security-chapter.is-visible .security-card:nth-child(2){ transition-delay:.08s; }
body.page-one .security-chapter.is-visible .security-card:nth-child(3){ transition-delay:.16s; }
body.page-one .security-chapter.is-visible .security-card:nth-child(4){ transition-delay:.24s; }
body.page-one .security-chapter.is-visible .security-card:nth-child(5){ transition-delay:.32s; }

@media (prefers-reduced-motion: reduce){
  body.page-one .security-card{
    opacity:1 !important;
    transform:none !important;
    transition:none !important;
  }
}

@media (max-width:1180px){
  .security-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .security-card{
    min-height:220px;
  }
}

@media (max-width:720px){
  .security-chapter{
    padding:76px 18px;
  }

  .security-grid{
    grid-template-columns:1fr;
  }

  .security-head{
    text-align:left;
  }

  .security-head p{
    margin-left:0;
  }
}



.final{min-height:88vh;background:#050505;color:#fff;padding:120px 24px 80px;display:flex;align-items:center}
.final .inner{width:min(100%,var(--max));margin:0 auto;display:grid;grid-template-columns:1.08fr .92fr;gap:60px;align-items:center}

.hero-small-word{
  display:inline-block;
  font-size:.72em;
  letter-spacing:-.025em;
  margin:0 .30em 0 0;
  transform:translateY(-.02em);
}

.final h2{
  font-size:clamp(42px,7vw,80px);
  line-height:.90;
  letter-spacing:-.050em;
  font-weight:940;
}

.final h2 .title-small-word{
  display:inline-block;
  font-size:.38em;
  letter-spacing:-.035em;
  transform:translateY(-.03em);
  margin:0 .50em 0 0;
}

.hero-subtitle{
  display:block;
}

.hero-inline-one-logo{
  display:inline-block;
  height:1.5em;
  width:auto;
  vertical-align:-0.15em;
  margin-right:-.2em;
  filter:drop-shadow(0 0 10px rgba(228,189,22,.16));
}

/* Logo One inline dans les textes de cartes */
.tb-inline-one-logo{
  display:inline-block;
  height:1.22em;
  width:auto;
  vertical-align:-0.18em;
  margin:0 -.10em 0 .06em;
  filter:drop-shadow(0 0 8px rgba(228,189,22,.12));
}


/* ===== Carte 3 — L’exécution : animation du fil Pilotage ===== */
.pilotage-screen{
  max-width:680px;
  min-height:438px;
  color:#111;
  background:#fff;
  transform:rotateY(-8deg) rotateX(4deg);
}

.pilotage-topbar{
  height:52px;
  display:flex;
  align-items:center;
  gap:18px;
  padding:0 18px;
  border-bottom:1px solid rgba(0,0,0,.10);
  background:#fff;
}

.pilotage-brand{
  flex:0 0 116px;
  width:116px;
  min-width:116px;
  height:42px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  overflow:visible;
}

.pilotage-brand .pilotage-brand-logo{
  display:block;
  height:40px;
  width:auto;
  max-width:116px;
  object-fit:contain;
  object-position:left center;
}


.pilotage-nav{
  display:flex;
  align-items:center;
  gap:22px;
  min-width:0;
  color:#111;
  font-size:11px;
  font-weight:950;
  white-space:nowrap;
  transform:translateY(4px);
}

.pilotage-nav span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1;
}

.pilotage-nav .is-active{
  min-height:28px;
  padding:0 13px;
  border-radius:8px;
  background:#000;
  color:rgb(228,189,22);
  box-shadow:0 2px 7px rgba(0,0,0,.16);
}

.pilotage-top-indicators{
  margin-left:auto;
  display:flex;
  align-items:center;
  gap:16px;
  color:rgb(59,125,35);
  font-size:11px;
  font-weight:950;
  white-space:nowrap;
  transform:translateY(4px);
}

.pilotage-system,
.pilotage-capacity{
  display:inline-flex;
  align-items:center;
  gap:6px;
}

.pilotage-system-ico{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:15px;
  height:14px;
  flex:0 0 15px;
  color:currentColor;
  transform:translateY(-1px);
}

.pilotage-system-ico::before{
  content:"☰";
  display:block;
  font-size:15px;
  font-weight:1000;
  line-height:1;
  color:currentColor;
  transform:scaleX(.82);
}

.pilotage-system-ico::after{
  content:none !important;
}

.pilotage-capacity-pie{
  display:inline-block;
  width:14px;
  height:14px;
  border-radius:50%;
  background:conic-gradient(currentColor 0 24%, rgb(222,220,216) 24% 100%);
}

.pilotage-action-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  padding:16px 20px 12px;
  background:#fff;
}

.pilotage-code-row{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:8px;
  font-size:11px;
  font-weight:900;
}

.pilotage-code-row span{
  color:#111;
}

.pilotage-code-row b{
  color:rgb(59,125,35);
}

.pilotage-action-head h3{
  margin:0;
  font-size:18px;
  line-height:1.08;
  letter-spacing:-.03em;
  font-weight:950;
  color:#111;
}

.pilotage-owner{
  flex:0 0 auto;
  max-width:210px;
  height:28px;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:4px;
  padding:0 10px;
  border-radius:8px;
  background:rgba(0,0,0,.025);
  border:1px solid rgba(0,0,0,.08);
  color:rgba(0,0,0,.58);
  font-size:10px;
  font-weight:850;
  white-space:nowrap;
}

.pilotage-owner b{
  color:#111;
}

.pilotage-title-row{
  position:relative;
  z-index:3;
  display:grid;
  grid-template-columns:78px 1fr 1fr;
  gap:12px;
  align-items:center;
  padding:9px 18px;
  border-top:1px solid rgba(0,0,0,.04);
  border-bottom:1px solid rgba(0,0,0,.16);
  background:#fff;
  font-size:11px;
  font-weight:950;
  color:#111;
}

.pilotage-title-row span:first-child{
  color:rgba(0,0,0,.62);
}

.pilotage-flow-window{
  height:272px;
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(180deg,#fff 0%,rgba(255,255,255,0) 14%,rgba(255,255,255,0) 86%,#fff 100%),
    radial-gradient(circle at 76% 26%, rgba(228,189,22,.10), transparent 35%),
    #fff;
}

.pilotage-flow-window::before{
  content:"";
  position:absolute;
  left:96px;
  top:0;
  bottom:0;
  width:1px;
  background:rgba(0,0,0,.18);
  z-index:2;
}

.pilotage-flow-track{
  position:relative;
  z-index:1;
  animation:pilotageFlowScroll 34s linear infinite;
}

.pilotage-flow-group{
  padding:0 18px 10px;
}

.pilotage-row{
  min-height:84px;
  display:grid;
  grid-template-columns:78px 1fr 1fr;
  gap:12px;
  align-items:start;
  padding:12px 0;
}

.pilotage-date{
  position:relative;
  padding-right:18px;
  color:rgba(0,0,0,.62);
  font-size:10px;
  font-weight:800;
  line-height:1.2;
  text-align:right;
  white-space:nowrap;
}

.pilotage-date span{
  position:absolute;
  top:1px;
  right:-5px;
  width:9px;
  height:9px;
  border-radius:999px;
  background:rgb(116,116,116);
  box-shadow:0 0 0 3px #fff;
  z-index:4;
}

.pilotage-col{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.pilotage-bubble{
  position:relative;
  min-height:42px;
  border-radius:10px;
  padding:8px 10px 9px;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 8px 20px rgba(0,0,0,.055);
  overflow:hidden;
}

.pilotage-bubble::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:4px;
  background:rgba(0,0,0,.08);
}

.pilotage-bubble-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-width:0;
  margin-bottom:5px;
}

.pilotage-bubble-head b{
  display:inline-flex;
  align-items:center;
  min-width:0;
  max-width:72%;
  height:16px;
  padding:0 8px;
  border-radius:999px;
  background:rgba(0,0,0,.12);
  color:#111;
  font-size:9px;
  font-weight:950;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.pilotage-bubble-head span{
  color:rgba(0,0,0,.50);
  font-size:8px;
  font-weight:900;
  white-space:nowrap;
}

.pilotage-bubble p{
  margin:0;
  color:#111;
  font-size:10px;
  line-height:1.2;
  font-weight:850;
}

.pilotage-bubble.is-jalon{
  background:rgb(246,222,116);
}

.pilotage-bubble.is-jalon .pilotage-bubble-head b{
  background:rgb(228,189,22);
  color:#fff;
}

.pilotage-bubble.is-message{
  background:rgb(255,244,217);
}

.pilotage-bubble.is-message .pilotage-bubble-head b{
  background:rgb(228,189,22);
  color:#111;
}

.pilotage-bubble.is-rapport{
  background:rgb(195,211,223);
}

.pilotage-bubble.is-rapport .pilotage-bubble-head b{
  background:rgb(13,84,95);
  color:#fff;
}

.pilotage-bubble.is-reunion,
.pilotage-bubble.is-start{
  background:rgb(205,224,181);
}

.pilotage-bubble.is-reunion .pilotage-bubble-head b,
.pilotage-bubble.is-start .pilotage-bubble-head b{
  background:rgb(59,125,35);
  color:#fff;
}

.pilotage-bubble.is-blocked{
  background:rgb(241,218,214);
}

.pilotage-bubble.is-blocked .pilotage-bubble-head b{
  background:rgb(176,61,43);
  color:#fff;
}

.pilotage-bubble.is-restart{
  background:rgb(226,237,235);
}

.pilotage-bubble.is-restart .pilotage-bubble-head b{
  background:#111;
  color:#fff;
}

.pilotage-bubble.is-doc{
  background:rgb(222,231,238);
}

.pilotage-bubble.is-doc .pilotage-bubble-head b{
  background:rgb(45,79,109);
  color:rgb(246,222,116);
}

.pilotage-bubble.is-done{
  background:rgb(220,236,213);
}

.pilotage-bubble.is-done .pilotage-bubble-head b{
  background:rgb(59,125,35);
  color:#fff;
}

.pilotage-bubble.is-close{
  background:rgb(236,234,230);
}

.pilotage-bubble.is-close .pilotage-bubble-head b{
  background:rgb(178,140,20);
  color:#fff;
}

.pilotage-bubble.late .pilotage-bubble-head span{
  color:rgb(176,61,43);
  font-weight:950;
}

.pilotage-bubble.is-real{
  margin-left:8px;
}

.pilotage-bubble.is-plan{
  margin-right:8px;
}

.security-card-icon svg{
  width:22px;
  height:22px;
  display:block;
  color:rgb(176,61,43);
}


@keyframes pilotageFlowScroll{
  0%{ transform:translateY(0); }
  100%{ transform:translateY(-50%); }
}

@media (prefers-reduced-motion: reduce){
  .pilotage-flow-track{
    animation:none !important;
    transform:translateY(-18%);
  }
}

@media (max-width:900px){
  .pilotage-screen{
    min-height:400px;
  }

  .pilotage-owner{
    display:none;
  }

  .pilotage-title-row,
  .pilotage-row{
    grid-template-columns:66px 1fr 1fr;
    gap:8px;
  }

  .pilotage-flow-window::before{
    left:82px;
  }

  .pilotage-flow-window{
    height:244px;
  }
}

/* ===== Carte 2 — Le Temps : alternance image agenda ===== */
.tb-agenda-fade-frame{
  display: grid;
  width: 100%;
  overflow: hidden;
}

.tb-agenda-fade-img{
  grid-area: 1 / 1;
  display: block;
  width: 100%;
  height: auto;
  opacity: 0;
  animation-duration: 8s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
  will-change: opacity;
}

.tb-agenda-fade-img-1{
  animation-name: tbAgendaFadeOne;
}

.tb-agenda-fade-img-2{
  animation-name: tbAgendaFadeTwo;
}

@keyframes tbAgendaFadeOne{
  0%, 42%{
    opacity: 1;
  }
  50%, 92%{
    opacity: 0;
  }
  100%{
    opacity: 1;
  }
}

@keyframes tbAgendaFadeTwo{
  0%, 42%{
    opacity: 0;
  }
  50%, 92%{
    opacity: 1;
  }
  100%{
    opacity: 0;
  }
}

@media (prefers-reduced-motion: reduce){
  .tb-agenda-fade-img{
    animation: none;
  }

  .tb-agenda-fade-img-1{
    opacity: 1;
  }

  .tb-agenda-fade-img-2{
    opacity: 0;
  }
}



.final p{font-size:20px;line-height:1.45;color:rgba(255,255,255,.7);max-width:640px}
.final-logo{width:100%;max-width:520px;opacity:.98;filter:drop-shadow(0 18px 50px rgba(228,189,22,.16))}

.contact-stage{
  display:grid;
  align-items:start;
  justify-items:center;
  min-width:0;
  padding-top:250px;
}

.contact-logo-panel{
  align-self:center;
}

.contact-stage > *{
  grid-area:1 / 1;
}

.contact-logo-panel,
.contact-form{
  transition:
    opacity .42s ease,
    transform .42s ease,
    visibility .42s ease;
}

.contact-logo-panel{
  opacity:.98;
  visibility:visible;
  pointer-events:auto;
  transform:translateY(-80px) scale(1);
}

.contact-form{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateY(18px) scale(.985);
}

.contact-section.is-contact-open .contact-logo-panel{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateY(-10px) scale(.96);
}

.contact-section.is-contact-open .contact-form{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateY(0) scale(1);
}

.footer{
  background:#050505;
  color:rgba(255,255,255,.64);
  border-top:1px solid rgba(255,255,255,.10);
  padding:15px 24px;
  font-size:13px;
}

.footer .inner{
  width:min(100%,var(--max));
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}

.footer-legal-btn{
  appearance:none;
  border:0;
  background:transparent;
  padding:0;
  margin:0;
  font:inherit;
  color:rgba(255,255,255,.70);
  cursor:pointer;
  transition:color .14s ease;
}

.footer-legal-btn:hover,
.footer-legal-btn:focus-visible{
  color:rgb(246,222,116);
  outline:none;
}

.legal-modal{
  position:fixed;
  inset:0;
  z-index:1000;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .18s ease, visibility .18s ease;
}

.legal-modal.is-open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.legal-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.28);
  backdrop-filter:blur(5px);
  -webkit-backdrop-filter:blur(5px);
}

.legal-modal-card{
  position:relative;
  width:min(860px, calc(100vw - 36px));
  max-height:min(84vh, 820px);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  border:1px solid rgba(255,255,255,.32);
  border-radius:22px;
  background:rgba(246,245,242,.92);
  box-shadow:0 24px 70px rgba(0,0,0,.28);
  transform:translateY(10px) scale(.985);
  transition:transform .18s ease;
}

.legal-modal.is-open .legal-modal-card{
  transform:translateY(0) scale(1);
}

.legal-modal-close{
  position:absolute;
  top:14px;
  right:16px;
  z-index:2;
  width:32px;
  height:32px;
  border:0;
  border-radius:999px;
  background:transparent;
  color:rgba(0,0,0,.58);
  font-size:24px;
  line-height:1;
  cursor:pointer;
  transition:background-color .14s ease, color .14s ease;
}

.legal-modal-close:hover,
.legal-modal-close:focus-visible{
  background:rgb(246,222,116);
  color:#000;
  outline:none;
}

.legal-modal-head{
  padding:26px 34px 18px;
  border-bottom:1px solid rgba(0,0,0,.10);
}

.legal-modal-kicker{
  margin:0 0 8px;
  color:rgb(45,79,109);
  font-size:12px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.legal-modal-head h2{
  margin:0;
  font-size:clamp(32px,4vw,56px);
  line-height:.95;
  letter-spacing:-.055em;
}

.legal-modal-body{
  padding:24px 34px 32px;
  overflow:auto;
  color:rgba(0,0,0,.76);
}

.legal-modal-body h3{
  margin:26px 0 8px;
  color:#000;
  font-size:17px;
  line-height:1.15;
}

.legal-modal-body h3:first-child{
  margin-top:0;
}

.legal-modal-body p{
  margin:0;
  max-width:76ch;
  font-size:15px;
  line-height:1.6;
  font-weight:450;
}

.legal-modal-body a{
  color:rgb(45,79,109);
  font-weight:650;
  text-decoration:none;
}

.legal-modal-body a:hover{
  color:#000;
  text-decoration:underline;
  text-decoration-thickness:1px;
  text-underline-offset:3px;
}

body.legal-modal-lock{
  overflow:hidden;
}

.mobile-note{display:none}

@media (prefers-reduced-motion: reduce){
  .data-rain-track,
  .data-token,
  .wv-rotor,
  .timer-fg,
  .timer-count span,
  .late-warning{
    animation:none !important;
  }

  .data-token{
    opacity:.78;
  }

  .timer-n5{ opacity:1; }
  .late-warning{ opacity:0; }
}




@media (max-width: 900px){
  .sequence-title-with-logo{
    gap:.18em;
  }

  .sequence-one-logo{
    height:.68em;
  }

  .hero-scroll-cue{
    position:relative;
    left:auto;
    bottom:auto;
    transform:none;
    margin:28px auto 0;
  }

  .navlinks .nav-link{display:none}
  
  .nav-brand{min-width:74px}.nav-logo{height:34px}.hero-inner,.depth-card,.final .inner{grid-template-columns:1fr}.hero-side{min-height:380px}.copy{padding:34px}.visual{padding:26px}.depth-card{position:relative;top:auto}.chapter{padding:70px 18px;min-height:auto}.security{grid-template-columns:1fr}.proof{grid-template-columns:1fr}.nav{top:10px;height:60px}.one-bg{opacity:.7}.mobile-note{display:block;color:rgba(255,255,255,.6);font-size:13px;margin-top:16px}}


/* ===== Formulaire de contact — réglage stable page One ===== */

body.page-one #contact{
  /* Réglages fins centralisés */
  --tb-contact-logo-y: -70px;
  --tb-contact-form-max-h: min(620px, calc(100vh - 210px));
}

body.page-one #contact.final{
  min-height:calc(100vh - 54px);
  box-sizing:border-box;
  padding:96px 24px 50px;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
}

body.page-one #contact .contact-inner{
  align-items:end;
  grid-template-columns:1.10fr .90fr;
  gap:54px;
}

body.page-one #contact .final-copy{
  min-width:0;
  transform:none !important;
  margin:0;
}

body.page-one #contact .contact-stage{
  padding-top:0 !important;
  align-self:stretch;
  align-items:end;
  justify-items:center;
  min-height:0;
  overflow:visible;
}

/* Logo One fermé : réglage indépendant */
body.page-one #contact .contact-logo-panel{
  transform:translateY(var(--tb-contact-logo-y)) scale(1) !important;
  margin:0 !important;
}

/* Formulaire : il reste dans la colonne droite, mais scrolle intérieurement */
body.page-one #contact .contact-form{
  transform:scale(.985);
  margin:0 !important;
  max-height:var(--tb-contact-form-max-h);
  overflow-y:auto;
  overflow-x:hidden;
  overscroll-behavior:contain;
  scrollbar-gutter:auto;
  -webkit-overflow-scrolling:touch;
  touch-action:pan-y;
}

/* Formulaire ouvert : pas de déplacement artificiel */
body.page-one #contact.is-contact-open .contact-form{
  transform:scale(1) !important;
  margin:0 !important;
}

/* Formulaire contact — scroll actif, ascenseur masqué */
body.page-one #contact .contact-form{
  scrollbar-width:none;        /* Firefox */
  -ms-overflow-style:none;     /* Edge ancien / IE */
}

body.page-one #contact .contact-form::-webkit-scrollbar{
  width:0;
  height:0;
  display:none;                /* Chrome / Safari / Edge */
}

.contact-form{
  width:100%;
  border:1px solid rgba(255,255,255,.12);
  border-radius:28px;
  padding:26px;
  background:linear-gradient(180deg, rgba(255,255,255,.095), rgba(255,255,255,.045));
  box-shadow:0 24px 70px rgba(0,0,0,.30);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}

.contact-form-head{
  margin-bottom:20px;
}

.contact-kicker{
  display:inline-flex;
  align-items:center;
  height:26px;
  padding:0 11px;
  border-radius:999px;
  background:var(--gold);
  color:#070707;
  font-size:12px;
  font-weight:950;
  letter-spacing:.04em;
}

.contact-form h3{
  margin:14px 0 8px;
  color:#fff;
  font-size:30px;
  line-height:1;
  letter-spacing:-.035em;
}

.contact-form p{
  margin:0;
  font-size:15px;
  line-height:1.45;
  color:rgba(255,255,255,.66);
}

.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.contact-form label{
  display:block;
  margin-bottom:14px;
}

.contact-form label span{
  display:block;
  margin-bottom:7px;
  color:rgba(255,255,255,.78);
  font-size:13px;
  font-weight:850;
}

.contact-form input,
.contact-form select,
.contact-form textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.16);
  border-radius:14px;
  background:rgba(255,255,255,.92);
  color:#10100f;
  font:inherit;
  font-size:15px;
  outline:none;
  box-shadow:none;
}

.contact-form input,
.contact-form select{
  height:44px;
  padding:0 13px;
}

.contact-form textarea{
  min-height:136px;
  resize:vertical;
  padding:12px 13px;
  line-height:1.45;
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(228,189,22,.18);
}

.contact-privacy{
  display:flex !important;
  align-items:flex-start;
  gap:10px;
  margin:2px 0 18px !important;
}

.contact-privacy input{
  width:17px;
  height:17px;
  min-width:17px;
  margin:2px 0 0;
  accent-color:var(--gold);
}

.contact-privacy span{
  color:rgba(0,0,0,.62);
  font-size:13px;
  line-height:1.35;
  font-weight:600;
}

body.page-one .contact-privacy > span{
  font-weight:450 !important;
}

.contact-hp{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
  pointer-events:none !important;
}

.contact-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin-top:8px;
}

.contact-status{
  min-height:20px;
  color:rgba(255,255,255,.72) !important;
  font-size:14px !important;
  line-height:1.35 !important;
  font-weight:750 !important;
}

.contact-status.is-ok{
  color:var(--gold-soft) !important;
}

.contact-status.is-error{
  color:#ffb2a6 !important;
}

.contact-submit{
  border:0;
  cursor:pointer;
  white-space:nowrap;
}

.contact-submit:disabled{
  opacity:.62;
  cursor:default;
}

@media (max-width: 900px){
  .contact-inner{
    grid-template-columns:1fr;
  }

  .contact-grid{
    grid-template-columns:1fr;
  }

  .contact-form{
    padding:22px;
  }
}



/* =====================================================
   PAGE CONTACT — formulaire dédié général
   ===================================================== */
body.page-contact{
  background:#f6f4ef;
}

body.page-contact .site{
  min-height:100vh;
  background:#f6f4ef;
}

.contact-page{
  position:relative;
  min-height:calc(100vh - 54px);
  padding:126px 26px 62px;
  overflow:hidden;
  background:#f6f4ef;
}

.contact-page-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(246,244,239,.96) 0%, rgba(246,244,239,.82) 38%, rgba(246,244,239,.34) 62%, rgba(246,244,239,.08) 100%),
    url("../img/backgrounds/conseil-gallery-04-bg.png") right center / cover no-repeat;
  filter:saturate(1.10) contrast(1.04);
}

.contact-page::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(rgba(45,79,109,.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(45,79,109,.045) 1px, transparent 1px);
  background-size:72px 72px;
  opacity:.40;
}

.contact-page-inner{
  position:relative;
  z-index:1;
  width:min(100%,var(--max));
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(360px,.62fr) minmax(320px,.48fr);
  grid-template-areas:
    "copy info"
    "form info";
  gap:26px 52px;
  align-items:start;
}

.contact-page-copy{
  grid-area:copy;
  max-width:640px;
}

.contact-page-kicker{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(246,222,116,.82);
  border:1px solid rgba(228,189,22,.42);
  color:#050505;
  font-size:12px;
  font-weight:950;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:18px;
}

.contact-page-copy h1{
  margin:0;
  color:#050505;
  font-size:clamp(38px,4.25vw,60px);
  line-height:.94;
  letter-spacing:-.058em;
  font-weight:950;
}

.contact-page-copy p{
  margin:22px 0 0;
  max-width:620px;
  color:rgba(0,0,0,.68);
  font-size:20px;
  line-height:1.42;
  font-weight:560;
}

body.page-contact .contact-page-form{
  grid-area:form;
  width:100%;
  max-width:690px;
  margin:0;
  border:1px solid rgba(0,0,0,.10);
  background:rgba(255,255,255,.84);
  box-shadow:0 24px 70px rgba(0,0,0,.10);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);

  /* Page contact : neutralise l'état masqué du formulaire animé de la page One */
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:none;
}

body.page-contact .contact-kicker{
  background:rgba(246,222,116,.82);
  border:1px solid rgba(228,189,22,.42);
  color:#050505;
}

body.page-contact .contact-form h3{
  color:#050505;
}

body.page-contact .contact-form p{
  color:rgba(0,0,0,.62);
}

body.page-contact .contact-form label span{
  color:rgba(0,0,0,.68);
}

body.page-contact .contact-form input,
body.page-contact .contact-form select,
body.page-contact .contact-form textarea{
  border:1px solid rgba(45,79,109,.18);
  background:rgba(255,255,255,.96);
}

body.page-contact .contact-form input:focus,
body.page-contact .contact-form select:focus,
body.page-contact .contact-form textarea:focus{
  border-color:rgba(45,79,109,.46);
  box-shadow:0 0 0 3px rgba(45,79,109,.10);
}

body.page-contact .contact-privacy > span{
  color:rgba(0,0,0,.60) !important;
  font-weight:500 !important;
}

.contact-privacy-link{
  appearance:none;
  -webkit-appearance:none;
  border:0;
  background:transparent;
  padding:0;
  margin:0;
  font:inherit;
  font-weight:700;
  line-height:inherit;
  color:inherit;
  text-decoration:underline;
  text-underline-offset:2px;
  cursor:pointer;
}

.contact-privacy-link:hover,
.contact-privacy-link:focus-visible{
  color:var(--petrol);
  outline:none;
}

body.page-contact .contact-status{
  color:rgba(0,0,0,.58) !important;
}

body.page-contact .contact-status.is-ok{
  color:rgb(45,79,109) !important;
}

body.page-contact .contact-status.is-error{
  color:var(--brick) !important;
}

body.page-contact .contact-submit:hover,
body.page-contact .contact-submit:focus-visible{
  background:#050505;
  color:var(--gold);
  outline:none;
}

.contact-info-card{
  grid-area:info;
  justify-self:end;
  align-self:center;
  width:min(100%,360px);
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:24px 26px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.48);
  background:rgba(255,255,255,.58);
  box-shadow:0 24px 70px rgba(0,0,0,.12);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  color:rgba(0,0,0,.68); right:max(26px, calc((100vw - var(--max)) / 2 + 26px));
  font-size:16px;
  line-height:1.42;
  font-weight:650;

  /* Page contact : coordonnées flottantes */
  position:fixed;
  right:max(26px, calc((100vw - var(--max)) / 2 + 26px));
  bottom:58px;
  z-index:20;
}

.contact-info-label{
  color:var(--petrol);
  font-size:12px;
  font-weight:950;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.contact-info-card strong{
  color:#050505;
  font-size:22px;
  line-height:1.05;
  font-weight:950;
}

.contact-info-card a{
  color:var(--petrol);
  font-weight:850;
}

.contact-info-card a:hover,
.contact-info-card a:focus-visible{
  color:#050505;
  text-decoration:underline;
  text-decoration-thickness:1px;
  text-underline-offset:3px;
  outline:none;
}

@media (max-width: 980px){
  .contact-page{
    padding:112px 20px 48px;
  }

  .contact-page-inner{
    grid-template-columns:1fr;
    grid-template-areas:
      "copy"
      "form"
      "info";
    gap:24px;
  }

  .contact-info-card{
    position:relative;
    right:auto;
    bottom:auto;
    z-index:1;
    justify-self:start;
    align-self:start;
  }
}

@media (max-width: 620px){
  .contact-page-copy h1{
    font-size:clamp(38px,13vw,56px);
  }

  .contact-page-copy p{
    font-size:17px;
  }
}

#contactRevealBtn{
  cursor:pointer;
  transition:
    background-color .16s ease,
    color .16s ease,
    border-color .16s ease,
    transform .16s ease,
    box-shadow .16s ease;
}

#contactRevealBtn:hover,
#contactRevealBtn:focus-visible{
  background:rgb(246,222,116);
  color:#000;
  border-color:rgb(246,222,116);
  transform:translateY(-1px);
  box-shadow:0 10px 26px rgba(228,189,22,.18);
}

/* ===== Page Méthode One — page-livre éditoriale ===== */

body.page-methode-one{
  --max:1180px;
  background:#fff;
}

body.page-methode-one .site{
  background:#fff;
}

body.page-methode-one .footer{
  position:relative;
  z-index:4;
  background:#050505;
}

.method-page{
  position:relative;
  overflow:hidden;
  background:#fff;
  color:#090909;
}

.method-showcase{
  position:relative;
  min-height:224vh;
  padding:126px 26px 72px;
  isolation:isolate;
  background:#fff;
}

.method-paper-grid{
  position:absolute;
  inset:0;
  z-index:-3;
  pointer-events:none;
  opacity:.46;
  background-image:
    linear-gradient(rgba(45,79,109,.09) 1px, transparent 1px),
    linear-gradient(90deg, rgba(45,79,109,.08) 1px, transparent 1px);
  background-size:72px 72px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.72), rgba(0,0,0,.24) 58%, rgba(0,0,0,.08));
  -webkit-mask-image:linear-gradient(180deg, rgba(0,0,0,.72), rgba(0,0,0,.24) 58%, rgba(0,0,0,.08));
}

.method-orbit{
  position:absolute;
  z-index:-2;
  border:1px solid rgba(45,79,109,.12);
  border-radius:999px;
  pointer-events:none;
}

.method-orbit-one{
  width:430px;
  height:430px;
  right:-120px;
  top:210px;
}

.method-orbit-two{
  width:640px;
  height:640px;
  left:-230px;
  bottom:20vh;
  border-color:rgba(228,189,22,.20);
}

.method-shell{
  width:min(100%,var(--max));
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(360px,440px);
  gap:78px;
  align-items:start;
  position:relative;
  z-index:2;
}

.method-copy-stack{
  min-width:0;
}

.method-panel{
  min-height:76vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  scroll-margin-top:120px;
}

.method-hero-panel{
  min-height:calc(100vh - 132px);
  padding-top:12px;
}

.method-kicker,
.method-section-tag,
.method-final-kicker{
  display:inline-flex;
  align-items:center;
  width:max-content;
  min-height:30px;
  padding:0 13px;
  border-radius:999px;
  font-size:12px;
  line-height:1;
  font-weight:950;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.method-kicker{
  background:rgba(45,79,109,.12);
  border:1px solid rgba(45,79,109,.28);
  color:var(--petrol);
  margin-bottom:30px;
  text-transform:none;
  letter-spacing:.01em;
  font-size:14px;
  font-weight:850;
}

.method-kicker::before{
  content:none;
}

.method-hero-panel h1{
  max-width:760px;
  margin:0;
  color:#050505;
  font-size:clamp(38px,4vw,60px);
  line-height:1.02;
  letter-spacing:-.058em;
  font-weight:940;
}

.method-subtitle{
  margin:22px 0 0;
  max-width:620px;
  color:rgba(0,0,0,.78);
  font-size:clamp(22px,2.35vw,32px);
  line-height:1.12;
  font-weight:760;
  letter-spacing:-.035em;
}

.method-lead{
  max-width:640px;
  margin:28px 0 0;
  color:var(--petrol);
  font-size:clamp(24px,2.85vw,40px);
  line-height:1.02;
  font-weight:940;
  letter-spacing:-.055em;
}

.method-intro{
  max-width:630px;
  margin:24px 0 0;
  color:rgba(0,0,0,.64);
  font-size:19px;
  line-height:1.52;
  font-weight:560;
}

.method-actions{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  margin-top:34px;
}

.method-btn{
  min-height:48px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 22px;
  border-radius:999px;
  font-weight:930;
  font-size:14px;
  border:1px solid transparent;
  transition:background-color .16s ease, color .16s ease, border-color .16s ease, transform .16s ease, box-shadow .16s ease;
}

.method-btn:hover,
.method-btn:focus-visible{
  transform:translateY(-1px);
  outline:none;
}

.method-btn-primary{
  background:#050505;
  color:#fff;
  border-color:#050505;
  box-shadow:0 16px 34px rgba(0,0,0,.12);
}

.method-btn-primary:hover,
.method-btn-primary:focus-visible{
  background:var(--gold);
  border-color:var(--gold);
  color:#050505;
  box-shadow:0 16px 34px rgba(228,189,22,.22);
}

.method-btn-secondary{
  background:rgba(255,255,255,.58);
  color:var(--petrol);
  border-color:rgba(45,79,109,.24);
}

.method-btn-secondary:hover,
.method-btn-secondary:focus-visible{
  background:var(--petrol);
  color:var(--gold);
  border-color:var(--petrol);
}

/* CTA hero Méthode : hover bleu pétrole + texte bleu clair */
.method-btn.method-btn-scroll:hover,
.method-btn.method-btn-scroll:focus-visible,
.method-btn.method-btn-app:hover,
.method-btn.method-btn-app:focus-visible{
  background:var(--petrol);
  color:rgb(255,255,255);
  border-color:var(--petrol);
}

.method-book-pane{
  position:relative;
  min-height:calc(224vh - 198px);
}

.method-book-sticky{
  position:sticky;
  top:106px;
  min-height:calc(100vh - 132px);
  display:flex;
  align-items:center;
  justify-content:center;
}

.method-book-stage{
  position:relative;
  width:min(100%,475px);
  transform:translateX(22px) translateY(-16px);
  transform-origin:center center;
}

.method-book-object{
  position:relative;
  width:100%;
  transform:rotateY(-13deg) rotateX(4deg) rotateZ(-1.2deg);
  transform-origin:50% 50%;
  border-radius:8px 14px 14px 8px;
  box-shadow:
    0 34px 72px rgba(0,0,0,.32),
    0 2px 0 rgba(255,255,255,.20) inset;
  overflow:visible;
  transition:transform .25s ease;
}

.method-book-object::before{
  content:"";
  position:absolute;
  left:-17px;
  top:10px;
  bottom:12px;
  width:18px;
  border-radius:7px 0 0 7px;
  background:linear-gradient(90deg,#040404 0%,#151514 42%,#050505 100%);
  transform:skewY(-1.5deg);
  box-shadow:inset -1px 0 0 rgba(255,255,255,.06), -12px 16px 34px rgba(0,0,0,.20);
}

.method-book-object::after{
  content:"";
  position:absolute;
  right:-16px;
  top:12px;
  bottom:14px;
  width:18px;
  border-radius:0 9px 9px 0;
  background:linear-gradient(90deg,rgba(255,255,255,.46),rgba(210,202,183,.82) 36%,rgba(255,255,255,.30));
  transform:skewY(1.8deg);
  opacity:.84;
}

.method-book-object img{
  display:block;
  width:100%;
  height:auto;
  border-radius:7px 12px 12px 7px;
  position:relative;
  z-index:2;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.10);
}

.method-book-spine{
  position:absolute;
  left:-11px;
  top:5px;
  bottom:6px;
  width:13px;
  z-index:3;
  border-radius:6px 0 0 6px;
  background:linear-gradient(90deg,rgba(0,0,0,.92),rgba(38,36,31,.98),rgba(0,0,0,.76));
  box-shadow:inset -1px 0 0 rgba(228,189,22,.22);
}

.method-book-shadow{
  position:absolute;
  left:6%;
  right:1%;
  bottom:-30px;
  height:44px;
  border-radius:50%;
  background:radial-gradient(ellipse at center, rgba(0,0,0,.34), transparent 70%);
  filter:blur(7px);
  transform:rotate(-2deg);
  z-index:-1;
}

.method-section-tag{
  background:rgba(45,79,109,.10);
  border:1px solid rgba(45,79,109,.18);
  color:var(--petrol);
  margin-bottom:22px;
}

.method-text-panel{
  max-width:735px;
  padding:34px 0;
}

.method-text-panel h2{
  margin:0;
  max-width:760px;
  color:#000;
  font-size:clamp(34px,4.2vw,56px);
  line-height:.98;
  letter-spacing:-.055em;
  font-weight:950;
}

.method-text-panel p{
  max-width:690px;
  margin:26px 0 0;
  color:rgba(0,0,0,.67);
  font-size:18.5px;
  line-height:1.58;
  font-weight:560;
}

.method-text-panel p + p{
  margin-top:18px;
}

.method-application-bridge{
  --method-bridge-text:690px;

  width:min(calc(100vw - 52px), var(--max));
  max-width:var(--max);
  margin-top:30px;
  padding-right:14px;
  box-sizing:border-box;

  display:grid;
  grid-template-columns:minmax(0,var(--method-bridge-text)) minmax(220px,1fr);
  column-gap:34px;
  align-items:end;
}

.method-text-panel .method-application-bridge p{
  margin:0;
  width:100%;
  max-width:var(--method-bridge-text);
}

.method-btn.method-btn-app{
  white-space:nowrap;
  justify-self:end;
  align-self:end;
}

.method-btn.method-btn-app{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:11px;
}

.method-btn-app-logo{
  display:block;
  height:24px;
  width:auto;
  object-fit:contain;
  transform:translateY(1px);
  transition:transform .16s ease, filter .16s ease;
}

.method-btn.method-btn-app:hover .method-btn-app-logo,
.method-btn.method-btn-app:focus-visible .method-btn-app-logo{
  transform:translateY(0);
}


.method-pillars{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  max-width:760px;
  margin-top:34px;
}

.method-pillars div{
  min-height:138px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:17px 16px;
  border-radius:22px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 18px 42px rgba(0,0,0,.05);
}

.method-pillars span{
  color:var(--gold);
  font-weight:950;
  font-size:13px;
  letter-spacing:.10em;
}

.method-pillars strong{
  color:#000;
  font-size:20px;
  line-height:1;
  font-weight:940;
  letter-spacing:-.035em;
}

.method-pillars em{
  color:rgba(0,0,0,.58);
  font-size:13px;
  line-height:1.26;
  font-style:normal;
  font-weight:720;
}

.method-final{
  position:relative;
  padding:58px 26px 62px;
  margin-bottom:34px;
  background:
    radial-gradient(circle at 82% 22%, rgba(255,255,255,.58), transparent 30%),
    linear-gradient(180deg, rgba(45,79,109,.12) 0%, rgba(45,79,109,.08) 100%);
  color:#050505;
}

.method-final::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(45,79,109,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(45,79,109,.07) 1px, transparent 1px);
  background-size:72px 72px;
  opacity:.34;
  pointer-events:none;
}

.method-final-inner{
  position:relative;
  z-index:1;
  width:min(100%,var(--max));
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(250px,.42fr) 150px;
  gap:34px;
  align-items:center;
}

.method-final-kicker{
  background:rgba(255,255,255,.54);
  border:1px solid rgba(45,79,109,.20);
  color:var(--petrol);
  margin-bottom:22px;
}

.method-final-copy h2{
  margin:0;
  color:#050505;
  font-size:clamp(40px,5vw,68px);
  line-height:.88;
  letter-spacing:-.06em;
  font-weight:950;
  display:flex;
  align-items:flex-end;
  gap:14px;
  flex-wrap:wrap;
}

.method-final-one-logo{
  display:inline-block;
  height:clamp(64px,7vw,104px);
  width:auto;
  object-fit:contain;
  transform:translateY(4px);
}

.method-final-copy p{
  margin:18px 0 0;
  color:rgba(0,0,0,.66);
  font-size:20px;
  line-height:1.2;
  font-weight:700;
}

.method-final-meta{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:18px;
  padding:0;
  background:transparent;
  color:rgba(0,0,0,.66);
  font-size:14px;
  line-height:1.35;
  font-weight:760;
}

.method-final-meta-lines{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.method-final-meta span:first-child{
  color:rgba(0,0,0,.70);
}

.method-final-btn{
  min-height:48px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 24px;
  border-radius:999px;
  background:var(--gold);
  color:#050505;
  font-weight:950;
  border:1px solid var(--gold);
  white-space:nowrap;
  box-shadow:0 18px 38px rgba(228,189,22,.18);
  transition:background-color .16s ease, color .16s ease, transform .16s ease, box-shadow .16s ease;
}

.method-final-btn:hover,
.method-final-btn:focus-visible{
  background:#050505;
  color:var(--gold);
  border-color:#050505;
  transform:translateY(-1px);
  box-shadow:0 18px 38px rgba(0,0,0,.16);
  outline:none;
}

.method-final-cover{
  margin:0;
  justify-self:end;
  align-self:center;
  width:174px;
}

.method-final-cover img{
  display:block;
  width:100%;
  height:auto;
  object-fit:contain;
  filter:drop-shadow(0 18px 28px rgba(0,0,0,.16));
}

@media (hover:hover){
  .method-book-stage:hover .method-book-object{
    transform:rotateY(-10deg) rotateX(2deg) rotateZ(-.6deg) translateY(-4px);
  }
}

@media (max-width: 980px){
  .method-showcase{
    min-height:auto;
    padding-top:118px;
  }

  .method-shell{
    grid-template-columns:1fr;
    gap:28px;
  }

  .method-book-pane{
    order:-1;
    min-height:auto;
  }

  .method-book-sticky{
    position:relative;
    top:auto;
    min-height:auto;
    padding:8px 0 18px;
  }

  .method-book-stage{
    width:min(78vw,330px);
  }

  .method-panel,
  .method-hero-panel{
    min-height:auto;
    padding:58px 0;
  }

  .method-hero-panel{
    padding-top:18px;
  }

  .method-pillars{
    grid-template-columns:1fr;
  }

  .method-pillars div{
    min-height:112px;
  }

  .method-final-inner{
    grid-template-columns:1fr;
    align-items:start;
  }

  .method-final-cover{
    justify-self:start;
    width:150px;
  }
}

@media (max-width: 640px){
  .method-showcase{
    padding-left:20px;
    padding-right:20px;
  }

  .method-hero-panel h1{
    font-size:clamp(52px,17vw,78px);
  }

  .method-actions{
    align-items:stretch;
  }

  .method-btn,
  .method-final-btn{
    width:100%;
  }

  .method-final{
    padding-left:20px;
    padding-right:20px;
  }
}

/* ===== Page Conseil — fonds croisés + parallaxe texte ===== */

body.page-conseil{
  --max: 1400px;
}

body.page-conseil .site{
  background:#f6f4ef;
}

body.page-conseil .footer{
  position:relative;
  z-index:4;
  background:#050505;
}

body.page-conseil .tb-conseil-scroll{
  position:relative;
  overflow:hidden;
  background:#f6f4ef;
  color:#000;
  isolation:isolate;

  --tb-bg2-opacity:0;
}

/* Fonds superposés : fondu croisé simple, sans voile éclaircissant */
body.page-conseil .tb-conseil-fixed-bg{
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  overflow:hidden;
  background:#f6f4ef;
}

body.page-conseil .tb-conseil-bg-layer{
  position:absolute;
  inset:0;
  background-size:cover;
  background-repeat:no-repeat;
  background-position:center center;
  will-change:opacity, transform;
}

body.page-conseil .tb-conseil-bg-layer-1{
  background-image:url("../img/backgrounds/conseil-hero-bg.png");
  opacity:var(--tb-bg1-opacity, 1);
  transform:scale(var(--tb-bg1-scale, 1.036));
  transform-origin:center center;
}

body.page-conseil .tb-conseil-bg-layer-2{
  background-image:url("../img/backgrounds/conseil-gallery-02-bg.png");
  opacity:var(--tb-bg2-opacity, 0);
  transform:scale(var(--tb-bg2-scale, 1.006));
  transform-origin:center center;
}

body.page-conseil .tb-conseil-bg-layer-3{
  background-image:url("../img/backgrounds/conseil-gallery-03-bg.png");
  opacity:var(--tb-bg3-opacity, 0);
  transform:scale(var(--tb-bg3-scale, 1.006));
  transform-origin:center center;
}

body.page-conseil .tb-conseil-bg-layer-4{
  background-image:url("../img/backgrounds/conseil-gallery-04-bg.png");
  opacity:var(--tb-bg4-opacity, 0);
  transform:scale(var(--tb-bg4-scale, 1.006));
  transform-origin:center center;
}

/* On neutralise les anciens fonds par section et les filtres/voiles */
body.page-conseil .tb-conseil-bg,
body.page-conseil .tb-conseil-scene::before,
body.page-conseil .tb-conseil-scene::after,
body.page-conseil .tb-conseil-scene-2 .tb-conseil-copy::before{
  display:none !important;
}

/* Scènes */
body.page-conseil .tb-conseil-scene{
  position:relative;
  z-index:1;
  min-height:108vh;
  overflow:hidden;
  isolation:isolate;

  display:flex;
  align-items:flex-end;

  padding:0 26px 90px;
}

/* Scène 2 : plus de chevauchement vertical artificiel */
body.page-conseil .tb-conseil-scene-2{
  min-height:116vh;
  margin-top:0;
  padding-top:0;
  align-items:center;
}

body.page-conseil .tb-conseil-scene-3{
  min-height:116vh;
  margin-top:0;
  padding-top:0;
  align-items:center;
}

body.page-conseil .tb-conseil-scene-4{
  min-height:118vh;
  margin-top:0;
  padding-top:0;
  align-items:center;
}

/* Blocs texte */
body.page-conseil .tb-conseil-copy{
  position:relative;
  z-index:2;
  width:min(100%, var(--max));
  margin:0 auto;

  transform:translateY(var(--tb-copy-y, 0px));
  opacity:var(--tb-copy-opacity, 1);

  will-change:transform, opacity;
}

body.page-conseil .tb-conseil-copy-left{
  transform:translateY(calc(var(--tb-copy-y, 0px) - 4px));
}

body.page-conseil .tb-conseil-copy-3{
  width:min(680px, 42vw);
  max-width:680px;
  margin-left:auto;
  margin-right:clamp(280px, 50vw, 1200px);
  transform:translateY(calc(var(--tb-copy-y, 0px) + 150px));
}

body.page-conseil .tb-conseil-copy-right{
  width:min(560px, 42vw);
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  margin-left:auto;
  margin-right:clamp(48px, 7vw, 132px);
  transform:translateY(calc(var(--tb-copy-y, 0px) + 82px));
}

body.page-conseil .tb-conseil-copy-right .tb-conseil-kicker{
  width:auto;
  align-self:flex-start;
  margin-right:0;
  margin-bottom:18px;
}

body.page-conseil .tb-conseil-copy-right h2,
body.page-conseil .tb-conseil-copy-right p{
  width:100%;
  margin-left:0;
  margin-right:0;
}

body.page-conseil .tb-conseil-copy-gallery{
  width:min(1080px, 76vw);
  max-width:1080px;

  /* repositionnement vers la gauche */
  margin-left:clamp(120px, 20vw, -200px);
  margin-right:auto;

  /* garde le bloc plus bas en fin de scroll */
  transform:translateY(calc(var(--tb-copy-y, 0px) + 200px));
}

body.page-conseil .tb-conseil-copy-gallery h2{
  max-width:760px;
}

/* Réglage spécifique scène 4 — bloc Expertises ancré à gauche */
body.page-conseil .tb-conseil-scene-4 .tb-conseil-copy-gallery{
  width:min(1120px, 72vw);
  max-width:1120px;

  margin-left:clamp(28px, 4vw, 72px) !important;
  margin-right:auto !important;

  transform:translateY(calc(var(--tb-copy-y, 0px) + 200px));
}


body.page-conseil .tb-conseil-gallery-lead{
  max-width:720px;
}

body.page-conseil .tb-conseil-cards{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
  margin-top:34px;
  max-width:920px;
}

body.page-conseil .tb-conseil-card{
  min-height:188px;
  padding:20px 20px 18px;
  border-radius:20px;
  background:rgba(246,244,239,.74);
  border:1px solid rgba(255,255,255,.42);
  box-shadow:0 18px 48px rgba(0,0,0,.14);
  -webkit-backdrop-filter:blur(10px);
  backdrop-filter:blur(10px);
}

body.page-conseil .tb-conseil-card h3{
  margin:16px 0 10px;
  color:#000;
  font-size:18px;
  line-height:1.08;
  font-weight:950;
  letter-spacing:-.03em;
}

body.page-conseil .tb-conseil-card p{
  margin:0;
  color:rgba(0,0,0,.66);
  font-size:14.5px;
  line-height:1.42;
  font-weight:560;
}

body.page-conseil .tb-conseil-card-ico{
  position:relative;
  display:block;
  width:42px;
  height:42px;
  border-radius:14px;
  background:rgba(228,189,22,.22);
  box-shadow:inset 0 0 0 1px rgba(228,189,22,.38);
}

body.page-conseil .tb-ico-radar::before,
body.page-conseil .tb-ico-radar::after{
  content:"";
  position:absolute;
  border-radius:999px;
}

body.page-conseil .tb-ico-radar::before{
  inset:10px;
  border:2px solid rgb(45,79,109);
}

body.page-conseil .tb-ico-radar::after{
  width:8px;
  height:8px;
  left:17px;
  top:17px;
  background:rgb(176,61,43);
  box-shadow:
    11px -7px 0 -2px rgb(45,79,109),
    -9px 10px 0 -2px rgb(45,79,109);
}

body.page-conseil .tb-ico-timeline::before{
  content:"";
  position:absolute;
  left:20px;
  top:9px;
  bottom:9px;
  width:2px;
  background:rgb(45,79,109);
}

body.page-conseil .tb-ico-timeline::after{
  content:"";
  position:absolute;
  left:15px;
  top:10px;
  width:12px;
  height:12px;
  border-radius:999px;
  background:rgb(228,189,22);
  box-shadow:
    0 11px 0 rgb(45,79,109),
    0 22px 0 rgb(176,61,43);
}

body.page-conseil .tb-ico-signal::before{
  content:"";
  position:absolute;
  left:11px;
  right:11px;
  bottom:10px;
  height:22px;
  background:
    linear-gradient(to top, rgb(45,79,109) 0 100%) left bottom / 4px 12px no-repeat,
    linear-gradient(to top, rgb(228,189,22) 0 100%) center bottom / 4px 20px no-repeat,
    linear-gradient(to top, rgb(176,61,43) 0 100%) right bottom / 4px 28px no-repeat;
  border-radius:3px;
}

body.page-conseil .tb-conseil-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;

  height:32px;
  padding:0 15px;
  margin-bottom:22px;

  border-radius:999px;
  background:rgba(246,222,116,.64);
  color:#000;

  font-size:12px;
  font-weight:950;
  letter-spacing:.06em;
  text-transform:uppercase;
}

body.page-conseil .tb-conseil-copy h1,
body.page-conseil .tb-conseil-copy h2{
  margin:0;
  color:#000;
  font-weight:950;
  line-height:.93;
  letter-spacing:-.065em;
}

body.page-conseil .tb-conseil-copy h1{
  max-width:760px;
  font-size:clamp(42px, 4.5vw, 62px);
}

body.page-conseil .tb-conseil-copy h2{
  font-size:clamp(38px, 4vw, 58px);
}

body.page-conseil .tb-conseil-copy p{
  max-width:650px;
  margin:26px 0 0;
  color:rgba(0,0,0,.72);
  font-size:clamp(17px, 1.35vw, 20px);
  line-height:1.46;
  font-weight:540;
}

body.page-conseil .tb-conseil-copy h1::after,
body.page-conseil .tb-conseil-copy h2::after{
  content:"";
  display:block;
  width:70px;
  height:2px;
  margin-top:20px;
  background:rgb(228,189,22);
}


/* ===== Page Conseil — section Expertises ===== */

body.page-conseil .tb-expertises-scene{
  min-height:130vh;
  align-items:center;
  padding-bottom:72px;
}

body.page-conseil .tb-expertises-copy{
  width:min(94vw, 1480px);
  max-width:1480px;
  transform:translateY(calc(var(--tb-copy-y, 0px) + 220px));
}

/* Réglage alignement bloc titre Expertises */
body.page-conseil .tb-expertises-copy .tb-conseil-kicker,
body.page-conseil .tb-expertises-copy h2,
body.page-conseil .tb-expertises-copy .tb-expertises-intro{
  margin-left:clamp(34px, 3.7vw, 68px);
}

body.page-conseil .tb-expertises-copy h2{
  max-width:900px;
}


body.page-conseil .tb-expertises-intro{
  max-width:820px !important;
  margin-top:24px !important;
}

/* grille élargie : les cartes respirent */
body.page-conseil .tb-expertises-grid{
  width:min(94vw, 1480px);
  max-width:1480px;
  display:grid;
  grid-template-columns:repeat(5, minmax(190px, 1fr));
  gap:18px;
  margin-top:34px;
}

/* cartes : moins hautes, plus larges, texte mieux tenu */
body.page-conseil .tb-expertise-card{
  min-height:220px;
  border-radius:24px;
  padding:24px 22px 22px;
  background:rgba(255,255,255,.85);
  border:1px solid rgba(255,255,255,.34);
  box-shadow:0 22px 60px rgba(0,0,0,.10);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);

  display:flex;
  flex-direction:column;
  justify-content:flex-start;

  opacity:0 !important;
  transform:translateY(86px) scale(.985) !important;
  transition:
    opacity .75s cubic-bezier(.18,.78,.24,1),
    transform .75s cubic-bezier(.18,.78,.24,1),
    background-color .18s ease,
    box-shadow .18s ease;
  will-change:opacity, transform;
}

/* apparition déclenchée par la section */
body.page-conseil .tb-expertises-scene.is-visible .tb-expertise-card{
  opacity:1 !important;
  transform:translateY(0) scale(1) !important;
}

body.page-conseil .tb-expertises-scene.is-visible .tb-expertise-card:nth-child(1){ transition-delay:.00s; }
body.page-conseil .tb-expertises-scene.is-visible .tb-expertise-card:nth-child(2){ transition-delay:.08s; }
body.page-conseil .tb-expertises-scene.is-visible .tb-expertise-card:nth-child(3){ transition-delay:.16s; }
body.page-conseil .tb-expertises-scene.is-visible .tb-expertise-card:nth-child(4){ transition-delay:.24s; }
body.page-conseil .tb-expertises-scene.is-visible .tb-expertise-card:nth-child(5){ transition-delay:.32s; }

body.page-conseil .tb-expertise-card:hover{
  background:rgba(255,255,255,.95);
  box-shadow:0 26px 68px rgba(0,0,0,.13);
}

body.page-conseil .tb-expertise-card-head{
  display:flex;
  align-items:center;
  gap:14px;
  min-height:58px;
  margin-bottom:18px;
}

body.page-conseil .tb-expertise-icon{
  width:58px;
  height:58px;
  flex:0 0 58px;
  border-radius:17px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(246,222,116,.34);
  color:rgb(45,79,109);
  border:1px solid rgba(228,189,22,.42);
}

body.page-conseil .tb-expertise-icon svg{
  width:36px;
  height:36px;
  display:block;
}

body.page-conseil .tb-expertise-icon svg *{
  vector-effect:non-scaling-stroke;
}

body.page-conseil .tb-expertise-card h3{
  margin:0;
  color:#000;
  font-size:clamp(17px, 1.05vw, 20px);
  line-height:1.02;
  letter-spacing:-.045em;
  font-weight:950;
}

body.page-conseil .tb-expertise-card p{
  margin:0;
  color:rgba(0,0,0,.72);
  font-size:15px;
  line-height:1.34;
  font-weight:620;
}

/* Test lisibilité titre Expertises sur fond sombre */
body.page-conseil .tb-expertises-copy h2{
  text-shadow:
    0 0 18px rgba(246,244,239,.62),
    0 2px 0 rgba(246,244,239,.22);
}

body.page-conseil .tb-expertises-copy p{
  text-shadow:
    0 1px 0 rgba(255,255,255,.18),
    0 10px 34px rgba(246,244,239,.42);
}

/* Test lisibilité sous-titre Expertises sur fond sombre */
body.page-conseil .tb-expertises-copy .tb-expertises-intro{
  text-shadow:
    0 0 18px rgba(246,244,239,.62),
    0 2px 0 rgba(246,244,239,.22);
}

@media (max-width: 1280px){
  body.page-conseil .tb-expertises-grid{
    grid-template-columns:repeat(5, minmax(170px, 1fr));
    gap:14px;
  }

  body.page-conseil .tb-expertise-card{
    padding:22px 18px 20px;
  }

  body.page-conseil .tb-expertise-card p{
    font-size:14px;
  }
}

@media (max-width: 1080px){
  body.page-conseil .tb-expertises-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  body.page-conseil .tb-expertise-card{
    min-height:200px;
  }
}

@media (max-width: 720px){
  body.page-conseil .tb-expertises-grid{
    grid-template-columns:1fr;
  }

  body.page-conseil .tb-expertise-card{
    min-height:0;
  }

  body.page-conseil .tb-expertise-card-head{
    margin-bottom:12px;
  }
}


@media (max-width: 900px){
  body.page-conseil .tb-conseil-fixed-bg{
    position:absolute;
    inset:0;
    height:100%;
  }

  body.page-conseil .tb-conseil-scene{
    min-height:100vh;
    padding:118px 20px 54px;
  }

  body.page-conseil .tb-conseil-bg-layer-1{
    background-position:58% center;
  }

  body.page-conseil .tb-conseil-bg-layer-2{
    background-position:42% center;
  }

  body.page-conseil .tb-conseil-copy,
  body.page-conseil .tb-conseil-copy-left,
  body.page-conseil .tb-conseil-copy-right,
  body.page-conseil .tb-conseil-copy-gallery{
    transform:none !important;
    opacity:1 !important;
  }

  body.page-conseil .tb-conseil-copy-right{
    width:100%;
    display:block;
    margin-left:0;
    margin-right:0;
  }

  body.page-conseil .tb-conseil-copy-right > *{
    width:100%;
    margin-left:0;
    margin-right:0;
  }

  body.page-conseil .tb-conseil-copy-gallery{
    width:100%;
    max-width:100%;
    margin-left:0;
    margin-right:0;
  }

  body.page-conseil .tb-conseil-cards{
    grid-template-columns:1fr;
    max-width:100%;
  }

  body.page-conseil .tb-conseil-card{
    min-height:0;
  }

  body.page-conseil .tb-conseil-bg-layer-4{
    background-position:center center;
  }

  body.page-conseil .tb-conseil-copy h1,
  body.page-conseil .tb-conseil-copy h2{
    max-width:100%;
    font-size:clamp(38px, 12vw, 54px);
  }

  body.page-conseil .tb-conseil-copy p{
    max-width:100%;
    font-size:17px;
  }
}

/* ===== Page Méthode One — mockup image détourée ===== */
.method-book-stage{
  position:relative;
  width:min(100%,475px);
  transform:translateX(20px) translateY(-18px);
  transform-origin:center center;
}

.method-book-render{
  display:block;
  width:100%;
  height:auto;
  filter:
    drop-shadow(0 24px 34px rgba(0,0,0,.14))
    drop-shadow(0 6px 12px rgba(0,0,0,.08));
  transition:transform .25s ease, filter .25s ease;
}

/* neutralisation des anciens systèmes de mockup */
.method-book-paperback,
.method-book-cover,
.method-book-object,
.method-book-shadow,
.method-book-spine,
.method-book-mockup{
  display:none !important;
}

@media (hover:hover){
  .method-book-stage:hover .method-book-render{
    transform:translateY(-4px) scale(1.012);
    filter:
      drop-shadow(0 28px 38px rgba(0,0,0,.16))
      drop-shadow(0 8px 14px rgba(0,0,0,.09));
  }
}

@media (max-width: 980px){
  .method-book-stage{
    width:min(72vw,300px);
    transform:none;
  }
}

@media (max-width: 760px){
  .method-application-bridge{
    width:100%;
    max-width:100%;
    padding-right:0;
    grid-template-columns:1fr;
    row-gap:18px;
    align-items:start;
  }

  .method-btn.method-btn-app{
    justify-self:start;
  }
}

/* ===== Module démonstration One ===== */
.demo-form .demo-slot-note{
  margin:-6px 0 14px 0;
  color:rgba(255,255,255,.78);
  font-size:.92rem;
  line-height:1.35;
  font-weight:400 !important;
}
.demo-form select[disabled]{
  opacity:.72;
  cursor:not-allowed;
}

/* =====================================================
   PATCH MOBILE — 18/05/2026
   Objectif : corriger les vues smartphone sans modifier les vues laptop.
   Toutes les règles sont cantonnées aux breakpoints <= 900px / 640px.
   ===================================================== */

@media (max-width: 900px){
  html,
  body{
    overflow-x:hidden;
  }

  /* ---------- Navigation mobile : menu complet compact ---------- */
  .nav{
    top:10px;
    width:calc(100% - 18px);
    height:66px;
    padding:8px 10px 8px 12px;
    border-radius:20px;
    gap:8px;
  }

  .nav-brand{
    --tb-nav-logo-y:-3px;
    min-width:96px !important;
    height:50px;
    flex:0 0 96px;
  }

  .nav-logo{
    height:52px !important;
  }

  .navlinks{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:4px;
    min-width:0;
    flex:1 1 auto;
    font-size:11px;
    letter-spacing:0;
  }

  .navlinks .nav-link{
    display:inline-flex !important;
    height:28px;
    padding:0 6px;
    white-space:nowrap;
  }

  .nav-link-one-logo{
    min-width:38px;
    padding:0 3px !important;
  }

  .nav-one-logo{
    height:30px;
  }

  .nav-cta{
    height:36px;
    padding:0 13px;
    font-size:12px;
    white-space:nowrap;
  }

  /* ---------- Page Conseil : remplacer le fond fixe/parallax par des fonds par section ---------- */
  /* Fonds mobile dédiés : .webp 900x1400, cadrage vertical et poids réduit. */
  body.page-conseil .tb-conseil-fixed-bg{
    display:none !important;
  }

  body.page-conseil .tb-conseil-scroll{
    overflow:hidden;
    background:#f6f4ef;
  }

  body.page-conseil .tb-conseil-scene{
    min-height:auto !important;
    padding:118px 20px 64px !important;
    align-items:flex-start !important;
    background:#f6f4ef;
    overflow:hidden;
  }

  body.page-conseil .tb-conseil-scene::before,
  body.page-conseil .tb-conseil-scene::after{
    content:"";
    display:block !important;
    position:absolute;
    inset:0;
    pointer-events:none;
  }

  body.page-conseil .tb-conseil-scene::before{
    z-index:0;
    background-size:cover;
    background-repeat:no-repeat;
    filter:saturate(1.06) contrast(1.02);
    transform:none !important;
  }


  body.page-conseil .tb-conseil-scene-1::before{
    background-image:url("../img/backgrounds/mobile/conseil-hero-mobile.webp");
    background-position:center center;
  }

  body.page-conseil .tb-conseil-scene-2::before{
    background-image:url("../img/backgrounds/mobile/conseil-gallery-02-mobile.webp");
    background-position:center center;
  }

  body.page-conseil .tb-conseil-scene-3::before{
    background-image:url("../img/backgrounds/mobile/conseil-gallery-03-mobile.webp");
    background-position:center center;
  }

  body.page-conseil .tb-expertises-scene::before{
    background-image:url("../img/backgrounds/mobile/conseil-gallery-04-mobile.webp");
    background-position:center center;
  }

  body.page-conseil .tb-conseil-copy,
  body.page-conseil .tb-conseil-copy-left,
  body.page-conseil .tb-conseil-copy-right,
  body.page-conseil .tb-conseil-copy-3,
  body.page-conseil .tb-conseil-copy-gallery,
  body.page-conseil .tb-expertises-copy{
    width:100% !important;
    max-width:100% !important;
    margin-left:0 !important;
    margin-right:0 !important;
    transform:none !important;
    opacity:1 !important;
    position:relative;
    z-index:2;
  }

  body.page-conseil .tb-conseil-copy h1,
  body.page-conseil .tb-conseil-copy h2{
    max-width:100%;
    font-size:clamp(38px, 11.5vw, 54px);
    line-height:.94;
  }

  body.page-conseil .tb-conseil-copy p{
    max-width:100%;
    font-size:17px;
  }

  body.page-conseil .tb-expertises-copy .tb-conseil-kicker,
  body.page-conseil .tb-expertises-copy h2,
  body.page-conseil .tb-expertises-copy .tb-expertises-intro{
    margin-left:0 !important;
  }

  /* ---------- Page Méthode : neutraliser les filigranes trop visibles sur mobile ---------- */
  body.page-methode-one .method-paper-grid,
  body.page-methode-one .method-orbit{
    display:none !important;
  }

  body.page-methode-one .method-showcase{
    overflow:hidden;
  }

  /* ---------- Page One : suppression des débordements horizontaux ---------- */
  body.page-one .depth-wrap,
  body.page-one .depth-card,
  body.page-one .copy,
  body.page-one .visual,
  body.page-one .screen{
    min-width:0 !important;
    max-width:100% !important;
  }

  body.page-one .depth-card{
    width:100%;
    overflow:hidden;
    border-radius:28px;
  }

  body.page-one .visual{
    padding:18px;
    overflow:hidden;
  }

  body.page-one .screen,
  body.page-one .pilotage-screen{
    width:100% !important;
    max-width:100% !important;
    transform:none !important;
  }

  body.page-one .pilotage-screen{
    min-height:0;
  }

  body.page-one .pilotage-topbar{
    height:50px;
    gap:10px;
    padding:0 12px;
  }

  body.page-one .pilotage-brand{
    flex:0 0 104px;
    width:104px;
    min-width:104px;
  }

  body.page-one .pilotage-brand .pilotage-brand-logo{
    height:34px;
    max-width:104px;
  }

  body.page-one .pilotage-nav{
    gap:12px;
    font-size:10px;
  }

  body.page-one .pilotage-top-indicators,
  body.page-one .pilotage-owner{
    display:none !important;
  }

  body.page-one .pilotage-action-head{
    padding:14px 16px 12px;
  }

  body.page-one .pilotage-title-row,
  body.page-one .pilotage-row{
    grid-template-columns:58px 1fr 1fr;
    gap:8px;
  }

  body.page-one .pilotage-flow-window::before{
    left:70px;
  }

  body.page-one .proof{
    grid-template-columns:1fr;
    gap:8px;
  }

  /* ---------- Page One : dernière section/contact, sans clipping vertical ---------- */
  body.page-one #contact.final{
    min-height:auto;
    padding:88px 18px 56px;
    overflow:visible;
    align-items:flex-start;
  }

  body.page-one #contact .contact-inner{
    grid-template-columns:1fr !important;
    gap:28px !important;
    align-items:start !important;
  }

  body.page-one #contact .final-copy,
  body.page-one #contact .contact-stage,
  body.page-one #contact .contact-form{
    width:100%;
    max-width:100%;
    min-width:0;
  }

  body.page-one #contact .final-copy h2{
    font-size:clamp(38px, 12.5vw, 58px);
    line-height:.95;
  }

  body.page-one #contact .contact-stage{
    padding-top:0 !important;
    display:block;
    overflow:visible;
  }

  body.page-one #contact .contact-logo-panel{
    display:none;
  }

  body.page-one #contact .contact-form{
    max-height:none !important;
    overflow:visible !important;
    transform:none !important;
  }

  body.page-one #contact .contact-actions{
    flex-direction:column;
    align-items:stretch;
  }

  body.page-one #contact .contact-submit{
    width:100%;
  }
}

@media (max-width: 430px){
  .nav{
    width:calc(100% - 14px);
    padding-left:9px;
    padding-right:9px;
    gap:5px;
  }

  .nav-brand{
    min-width:86px !important;
    flex-basis:86px;
  }

  .nav-logo{
    height:48px !important;
  }

  .navlinks{
    gap:3px;
    font-size:10.5px;
  }

  .navlinks .nav-link{
    padding:0 4px;
  }

  .nav-one-logo{
    height:28px;
  }

  .nav-cta{
    padding:0 10px;
  }

  body.page-one .pilotage-nav span:not(.is-active){
    display:none;
  }

  body.page-one .pilotage-title-row,
  body.page-one .pilotage-row{
    grid-template-columns:52px 1fr 1fr;
  }

  body.page-one .pilotage-flow-window::before{
    left:63px;
  }

  body.page-one .pilotage-bubble-head span{
    display:none;
  }

  body.page-one .pilotage-bubble p{
    font-size:9.5px;
  }
}

/* Patch mobile One — évite le jank de scroll sur les cartes animées */
@media (max-width: 900px){
  body.page-one .depth-card{
    transform:none !important;
    opacity:1 !important;
    will-change:auto !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
  }
}

/* Patch mobile — fond spécifique section Expertises */
@media (max-width: 900px){
  body.page-conseil .tb-conseil-scene.tb-expertises-scene::before{
    background-image: url("../img/backgrounds/mobile/conseil-gallery-04-mobile.webp") !important;
    background-position: center center !important;
    background-size: cover !important;
  }
}

/* Patch mobile — lisibilité texte sans voile ni halo */
@media (max-width: 900px){

  body.page-conseil .tb-conseil-scene::after{
    display:none !important;
    background:none !important;
  }

  body.page-conseil .tb-conseil-copy h1,
  body.page-conseil .tb-conseil-copy h2,
  body.page-conseil .tb-expertises-copy h2{
    text-shadow:
      0 1px 0 rgba(255,255,255,.70),
      0 -1px 0 rgba(255,255,255,.55),
      1px 0 0 rgba(255,255,255,.55),
      -1px 0 0 rgba(255,255,255,.55),
      0 6px 18px rgba(255,255,255,.55);
  }

  body.page-conseil .tb-conseil-copy p,
  body.page-conseil .tb-expertises-copy p{
    color:rgba(0,0,0,.78);
    text-shadow:
      0 1px 0 rgba(255,255,255,.85),
      0 0 8px rgba(255,255,255,.80),
      0 0 18px rgba(255,255,255,.45);
  }
}

/* Par défaut : les retours desktop fonctionnent */
.desktop-br{
  display:block;
}

/* Sur mobile : on les neutralise */
@media (max-width: 900px){
  .desktop-br{
    display:none;
  }
}

@media (max-width: 900px){
  body.page-conseil .tb-conseil-copy p br{
    display:none;
  }
}

/* =====================================================
   PATCH MOBILE GLOBAL — réglages finaux smartphone
   Sans impact laptop : règles cantonnées à max-width 900px
   ===================================================== */

@media (max-width: 900px){

  /* 1 — Page Index : recentrer les cartes Expertises */
  body.page-conseil .tb-expertises-copy{
    width:100% !important;
    max-width:100% !important;
    box-sizing:border-box !important;
  }

  body.page-conseil .tb-expertises-grid{
    width:100% !important;
    max-width:100% !important;
    margin-left:0 !important;
    margin-right:0 !important;
    box-sizing:border-box !important;
    justify-items:stretch !important;
  }

  body.page-conseil .tb-expertise-card{
    width:100% !important;
    max-width:100% !important;
    box-sizing:border-box !important;
  }


  /* 2 — Page Méthode One : titre principal trop large sur Android */
  body.page-methode-one .method-hero-panel h1{
    font-size:clamp(38px, 12.2vw, 52px) !important;
    line-height:.98 !important;
    letter-spacing:-.058em !important;
    max-width:100% !important;
    overflow-wrap:normal !important;
    word-break:normal !important;
  }


  /* 3 / 4 / 5 — Page One : bulles des trois boutons toujours centrées */
  body.page-one .proof{
    overflow:visible !important;
  }

  body.page-one .proof div[data-tip]{
    position:relative !important;
    overflow:visible !important;
  }

  body.page-one .proof div[data-tip]::after{
    left:50% !important;
    right:auto !important;
    width:min(310px, calc(100vw - 70px)) !important;
    max-width:calc(100vw - 70px) !important;
    transform:translateX(-50%) translateY(4px) !important;
    text-align:left !important;
  }

  body.page-one .proof div[data-tip]:hover::after,
  body.page-one .proof div[data-tip]:focus-visible::after{
    transform:translateX(-50%) translateY(0) !important;
  }

  body.page-one .proof div[data-tip]::before{
    left:50% !important;
    right:auto !important;
    transform:translateX(-50%) translateY(4px) rotate(45deg) !important;
  }

  body.page-one .proof div[data-tip]:hover::before,
  body.page-one .proof div[data-tip]:focus-visible::before{
    transform:translateX(-50%) translateY(0) rotate(45deg) !important;
  }


  /* 6 — Animation dirigeant girouette : pastilles plus petites */
  body.page-one .data-chaos{
    width:min(100%, 360px) !important;
  }

  body.page-one .leader-node{
    width:132px !important;
    height:72px !important;
    border-radius:18px !important;
    padding:10px 10px 10px !important;
  }

  body.page-one .leader-label{
    font-size:16px !important;
  }

  body.page-one .leader-windvane{
    top:8px !important;
    width:48px !important;
    height:42px !important;
  }

  body.page-one .wv-mast{
    height:31px !important;
    width:3px !important;
  }

  body.page-one .wv-mast::before{
    width:9px !important;
    height:9px !important;
  }

  body.page-one .wv-rotor{
    width:39px !important;
    height:15px !important;
    top:10px !important;
  }

  body.page-one .wv-arrow{
    left:10px !important;
    right:5px !important;
    height:2.5px !important;
  }

  body.page-one .data-token{
    height:32px !important;
    min-width:78px !important;
    padding:0 12px !important;
    border-radius:12px !important;
    font-size:9.5px !important;
  }

  body.page-one .chaos-timer{
    width:42px !important;
    height:42px !important;
    top:14px !important;
    right:14px !important;
  }

  body.page-one .timer-count{
    font-size:13px !important;
  }


  /* 7 — Carte “La réponse One” : logo plus présent + lignes stables Android */
  body.page-one .sequence-title-with-logo{
    gap:.10em !important;
    align-items:flex-end !important;
  }

  body.page-one .sequence-one-logo{
    height:1.02em !important;
    transform:translateY(-.08em) !important;
  }

  body.page-one .sequence-subtitle{
    font-size:clamp(24px, 7.2vw, 30px) !important;
    line-height:1.25 !important;
    white-space:nowrap !important;
    letter-spacing:-.02em !important;
  }

  body.page-one .sequence-subtitle span{
    display:inline !important;
    white-space:nowrap !important;
  }


  /* 8 — Animation “Pilotage du projet sécurité” : pastilles moins tronquées */
  body.page-one .pilotage-bubble{
    padding-left:8px !important;
    padding-right:8px !important;
  }

  body.page-one .pilotage-bubble-head{
    display:block !important;
    margin-bottom:5px !important;
  }

  body.page-one .pilotage-bubble-head b{
    max-width:100% !important;
    min-width:0 !important;
    height:18px !important;
    padding:0 7px !important;
    font-size:8.8px !important;
    line-height:18px !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }

  body.page-one .pilotage-bubble-head span{
    display:none !important;
  }


  /* 9 — Mobile : afficher directement le formulaire final */
  body.page-one #contact .hero-actions{
    display:none !important;
  }

  body.page-one #contact .contact-logo-panel{
    display:none !important;
  }

  body.page-one #contact .contact-stage{
    display:block !important;
    margin-top:28px !important;
  }

  body.page-one #contact .contact-form{
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
    transform:none !important;
    max-height:none !important;
    overflow:visible !important;
  }
}

/* =====================================================
   PATCH MOBILE ONE — derniers réglages Android
   1) Carte "La réponse One"
   2) Pastilles pilotage : libellés courts mobile
   ===================================================== */

@media (max-width: 900px){

  /* 1 — Carte “La réponse One” : réduire les 3 lignes pour éviter le débordement */
  body.page-one .sequence-card-light .sequence-subtitle{
    font-size:clamp(17px, 4.9vw, 20px) !important;
    line-height:1.34 !important;
    letter-spacing:-.035em !important;
    white-space:nowrap !important;
    max-width:100% !important;
    margin-left:auto !important;
    margin-right:auto !important;
  }

  body.page-one .sequence-card-light .sequence-subtitle span{
    display:inline !important;
    white-space:nowrap !important;
  }


  /* 2 — Animation “Pilotage du projet sécurité” :
     libellés courts sur mobile pour éviter les mots composés tronqués */
  body.page-one .pilotage-bubble-head b{
    width:auto !important;
    max-width:96px !important;
    min-width:58px !important;
    padding:0 8px !important;
    font-size:0 !important;       /* masque le texte HTML original */
    line-height:18px !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:clip !important;
  }

  body.page-one .pilotage-bubble-head b::before{
    font-size:8.8px !important;
    line-height:18px !important;
    font-weight:900 !important;
    white-space:nowrap !important;
  }

  body.page-one .pilotage-bubble.is-message .pilotage-bubble-head b::before{
    content:"Message";
  }

  body.page-one .pilotage-bubble.is-rapport .pilotage-bubble-head b::before{
    content:"Rapport";
  }

  body.page-one .pilotage-bubble.is-jalon .pilotage-bubble-head b::before{
    content:"Jalon";
  }

  body.page-one .pilotage-bubble.is-start .pilotage-bubble-head b::before{
    content:"Départ";
  }

  body.page-one .pilotage-bubble.is-blocked .pilotage-bubble-head b::before{
    content:"Incident";
  }

  body.page-one .pilotage-bubble.is-restart .pilotage-bubble-head b::before{
    content:"Reprise";
  }

  body.page-one .pilotage-bubble.is-doc .pilotage-bubble-head b::before{
    content:"Doc.";
  }

  body.page-one .pilotage-bubble.is-done .pilotage-bubble-head b::before{
    content:"Fait";
  }

  body.page-one .pilotage-bubble.is-close .pilotage-bubble-head b::before{
    content:"Clôture";
  }
}

.method-book-picture{
  display:block;
  width:100%;
}

/* =====================================================
   Démonstration One — pastilles de créneaux publics
   ===================================================== */

.demo-slot-field{
  margin-bottom:14px;
}

.demo-field-label{
  display:block;
  margin-bottom:7px;
  color:rgba(255,255,255,.78);
  font-size:13px;
  font-weight:850;
}

.demo-slot-picker{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(138px, 1fr));
  gap:10px;
  width:100%;
}

.demo-slot-loading{
  display:inline-flex;
  align-items:center;
  min-height:44px;
  color:rgba(255,255,255,.62);
  font-weight:750;
  font-size:14px;
}

.demo-slot-pill{
  appearance:none;
  -webkit-appearance:none;
  border:1px solid rgba(255,255,255,.18);
  border-radius:16px;
  background:rgba(255,255,255,.92);
  color:#10100f;
  min-height:58px;
  padding:9px 11px;
  cursor:pointer;
  text-align:left;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:3px;
  box-shadow:none;
  transition:
    background-color .15s ease,
    border-color .15s ease,
    color .15s ease,
    transform .15s ease;
}

.demo-slot-pill:hover{
  transform:translateY(-1px);
  border-color:rgba(228,189,22,.85);
}

.demo-slot-pill.is-selected{
  background:rgb(228,189,22);
  border-color:rgb(228,189,22);
  color:#050505;
}

.demo-slot-day{
  display:block;
  font-size:14px;
  font-weight:950;
  line-height:1.12;
}

.demo-slot-time{
  display:block;
  font-size:12px;
  font-weight:850;
  line-height:1.12;
  color:rgba(0,0,0,.62);
}

.demo-slot-pill.is-selected .demo-slot-time{
  color:rgba(0,0,0,.72);
}

.demo-slot-custom{
  background:rgba(0,0,0,.28);
  color:#fff;
  border-color:rgba(228,189,22,.42);
}

.demo-slot-custom .demo-slot-time{
  color:rgba(246,222,116,.82);
}

.demo-slot-custom.is-selected{
  background:rgb(45,79,109);
  border-color:rgb(246,222,116);
  color:#fff;
}

.demo-slot-custom.is-selected .demo-slot-time{
  color:rgb(246,222,116);
}

@media (max-width: 640px){
  .demo-slot-picker{
    grid-template-columns:1fr;
  }

  .demo-slot-pill{
    min-height:54px;
  }
}

.demo-slot-note{
  white-space:pre-line;
}