/* =====================================================================
   TRISKAEL — editorial challenger landing
   ===================================================================== */
:root{
  --ivory:#f7f1e8;
  --paper:#fffdf8;
  --ink:#161412;
  --ink-2:#2b2620;
  --orange:#ff5a1f;
  --orange-d:#e84711;
  --green:#b8ff2c;
  --aubergine:#3b123f;
  --aubergine-2:#561b5c;
  --stone:#d8cec0;
  --display:"Bricolage Grotesque",sans-serif;
  --serif:"Fraunces",Georgia,serif;
  --body:"Inter",system-ui,sans-serif;
  --hand:"Caveat",cursive;
  --wrap:1240px;
  --r:18px;
  --r-lg:28px;
  --e1:cubic-bezier(.22,1,.36,1);
  --e2:cubic-bezier(.34,1.56,.64,1);
  --shadow:0 26px 60px -28px rgba(22,20,18,.42);
  --shadow-sm:0 14px 30px -18px rgba(22,20,18,.4);
  --hard:6px 6px 0 var(--ink);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background-color:var(--ivory);color:var(--ink);
  background-image:radial-gradient(rgba(22,20,18,.045) 1px,transparent 1.4px);
  background-size:27px 27px;
  font-family:var(--body);font-size:17px;line-height:1.6;font-weight:400;
  overflow-x:clip;-webkit-font-smoothing:antialiased;
}
html{overflow-x:clip}
a{color:inherit;text-decoration:none}
img{max-width:100%}
::selection{background:var(--orange);color:#fff}
.wrap{width:min(100% - 40px,var(--wrap));margin-inline:auto}

/* ---------- Typography ---------- */
.section-title{
  font-family:var(--display);font-weight:800;line-height:.96;letter-spacing:-.02em;
  font-size:clamp(34px,5vw,68px);margin:0;
}
.section-title .hl{color:var(--orange)}
.section-title .hl-green{color:var(--green);-webkit-text-stroke:1px rgba(0,0,0,.0)}
.section-title.light{color:var(--paper)}
.kicker,.eyebrow,.kicker,.final-eyebrow,.pack-flag,.doc-tag,.section .kicker{font-family:var(--body)}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--ink);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 24px;border-radius:999px;background:var(--bg);color:var(--fg);
  font-weight:700;font-size:15px;letter-spacing:-.01em;border:1.5px solid var(--ink);
  cursor:pointer;transition:transform .25s var(--e1),box-shadow .25s var(--e1),background .2s;
  box-shadow:0 0 0 rgba(0,0,0,0);white-space:nowrap;
}
.btn span{transition:transform .3s var(--e2)}
.btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.btn:hover span{transform:translateX(5px)}
.btn:active{transform:translateY(0)}
.btn-dark{--bg:var(--ink);--fg:#fff}
.btn-orange{--bg:var(--orange);--fg:#fff;border-color:var(--orange)}
.btn-orange:hover{--bg:var(--orange-d)}
.btn-light{--bg:var(--paper);--fg:var(--ink)}
.btn-ghost{--bg:transparent;--fg:var(--ink);box-shadow:none}
.btn-ghost:hover{--bg:var(--ink);--fg:#fff}
.btn-sm{padding:10px 18px;font-size:13.5px}
.btn-lg{padding:17px 30px;font-size:16px}
.btn-block{width:100%}

/* =====================================================================
   NAV
   ===================================================================== */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;padding:18px 0;transition:padding .35s var(--e1)}
.nav-inner{
  width:min(100% - 32px,var(--wrap));margin-inline:auto;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:10px 12px 10px 22px;border-radius:999px;
  background:rgba(255,253,248,.72);backdrop-filter:blur(16px) saturate(1.3);
  border:1.5px solid rgba(22,20,18,.08);
  transition:box-shadow .35s var(--e1),background .35s,border-color .35s,padding .35s var(--e1);
}
.nav.scrolled{padding:10px 0}
.nav.scrolled .nav-inner{box-shadow:var(--shadow-sm);background:rgba(255,253,248,.92);border-color:rgba(22,20,18,.12)}
.brand{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:800;font-size:22px;letter-spacing:-.03em}
.brand img{transition:transform .6s var(--e2)}
.brand:hover img{transform:rotate(120deg)}
.nav-links{display:flex;gap:26px;font-size:14px;font-weight:600}
.nav-links a{position:relative;color:var(--ink-2);transition:color .2s}
.nav-links a:after{content:"";position:absolute;left:0;bottom:-4px;width:100%;height:2px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .28s var(--e1)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover:after{transform:scaleX(1)}
.nav-actions{display:flex;align-items:center;gap:10px}
.wa-pill{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;background:var(--green);color:var(--ink);box-shadow:0 8px 18px -8px rgba(22,20,18,.45);transition:transform .25s var(--e2),box-shadow .25s}
.wa-pill:hover{transform:rotate(-8deg) scale(1.06)}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{position:relative;padding:150px 0 58px;overflow:hidden}
.hero:before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(70% 60% at 78% 12%,rgba(255,90,31,.10),transparent 60%),
             radial-gradient(50% 50% at 8% 90%,rgba(59,18,63,.07),transparent 60%);}
.sec-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.liquid-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:0;transition:opacity .9s ease}
.liquid-on .liquid-canvas,.has-liquid .liquid-canvas{opacity:1}
.hero-bg{filter:saturate(1.02)}
.hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none;
  -webkit-mask:radial-gradient(120% 100% at 70% 35%,#000 35%,transparent 78%);
          mask:radial-gradient(120% 100% at 70% 35%,#000 35%,transparent 78%)}
.eyebrow .scram{display:inline-block;min-width:6.4em;text-align:left;color:var(--orange);font-weight:800;letter-spacing:.01em}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.02fr .98fr;gap:40px;align-items:center}
.hero-copy{max-width:560px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:700;letter-spacing:.01em;
  padding:8px 16px;border-radius:999px;background:var(--paper);border:1px solid rgba(22,20,18,.12);box-shadow:0 8px 20px -12px rgba(22,20,18,.3)}
.eyebrow i{width:9px;height:9px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 4px rgba(255,90,31,.2)}
.hero-title{font-family:var(--display);font-weight:800;letter-spacing:-.03em;line-height:.9;
  font-size:clamp(48px,7.4vw,104px);margin:22px 0 22px}
.hero-title .line{display:block;overflow:hidden;padding-bottom:.02em}
.hero-title .line>span{display:inline-block}
.hero-title em{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--orange);letter-spacing:-.01em}
.hero-title b{position:relative;font-weight:800;z-index:1}
.hero-title b:after{content:"";position:absolute;left:-3%;right:-5%;bottom:.08em;height:.42em;z-index:-1;background:var(--green);transform:scaleX(0);transform-origin:left;border-radius:3px}
.hero.in .hero-title b:after{animation:swipe .6s .7s var(--e1) forwards}
@keyframes swipe{to{transform:scaleX(1)}}
.hero-sub{font-size:18px;color:var(--ink-2);max-width:480px;margin:0 0 28px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:24px}
.reassure{display:flex;flex-wrap:wrap;gap:8px 10px;list-style:none;padding:0;margin:0;font-size:13px;font-weight:600}
.reassure li{display:inline-flex;align-items:center;gap:7px;padding:6px 13px;background:var(--paper);border:1px solid rgba(22,20,18,.12);border-radius:999px}
.reassure li:before{content:"✓";display:grid;place-items:center;width:15px;height:15px;border-radius:50%;background:var(--ink);color:var(--green);font-size:9px;font-weight:900}

/* hero collage */
.hero-art{position:relative;min-height:520px}
.tiger{position:absolute;right:-7%;bottom:-185px;top:auto;width:114%;max-width:800px;height:auto;z-index:1;
  mix-blend-mode:multiply;filter:contrast(1.12) saturate(.9) drop-shadow(0 22px 32px rgba(22,20,18,.22));
  -webkit-mask:none;mask:none}
.doc-form{position:absolute;left:0;bottom:0;width:300px;background:var(--paper);border:1px solid rgba(22,20,18,.1);
  border-radius:var(--r);padding:18px;box-shadow:0 30px 60px -22px rgba(22,20,18,.5);z-index:6}
.doc-tag{display:inline-block;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;
  color:#fff;background:var(--orange);padding:4px 10px;border-radius:999px;margin-bottom:12px}
.mini-form label{display:block;font-size:12px;font-weight:700;margin-bottom:10px;color:var(--ink-2)}
.mini-form input{display:block;width:100%;margin-top:5px;padding:11px 13px;border:1.5px solid rgba(22,20,18,.25);
  border-radius:11px;font:inherit;font-size:13px;background:#fff;transition:border-color .2s,box-shadow .2s}
.mini-form input:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,90,31,.16)}
.mini-form .btn{margin-top:4px;font-size:14px;padding:12px}
.doc-fine{display:block;text-align:center;font-size:11px;color:#8a8275;margin-top:9px}

.sticky{position:absolute;z-index:5;display:flex;flex-direction:column;gap:3px;padding:11px 13px;
  border-radius:12px;box-shadow:var(--shadow-sm);font-weight:800;transition:transform .3s var(--e2),box-shadow .3s}
.sticky b{font-family:var(--display);font-size:15px;line-height:1}
.sticky span{font-size:10.5px;font-weight:600;opacity:.8}
.sticky strong{font-size:24px;line-height:1}
.sticky:hover{box-shadow:0 20px 30px -10px rgba(22,20,18,.5);z-index:9}
.note-lime{background:var(--green)}
.note-dark{background:var(--ink);color:var(--paper)}
.note-dark span{opacity:.7}
.note-paper{background:var(--paper);border:1px solid rgba(22,20,18,.1)}
.note-violet{background:radial-gradient(120% 120% at 30% 25%,var(--aubergine-2),var(--aubergine));color:#fff;
  width:104px;height:104px;border-radius:50%;align-items:center;justify-content:center;text-align:center}
.note-violet b{color:var(--green);font-size:16px}
.n1{top:6px;right:0;transform:rotate(5deg);--rot:5deg}
.n2{top:96px;right:30%;transform:rotate(-6deg);--rot:-6deg}
.n3{top:150px;right:4%;transform:rotate(7deg);--rot:7deg}
.n4{top:230px;right:30%;transform:rotate(-4deg);--rot:-4deg}
.n5{top:312px;right:6%;transform:rotate(6deg);--rot:6deg}
.sticky.float.n1{animation:fl 6s ease-in-out infinite}
.sticky.float.n2{animation:fl 7s .4s ease-in-out infinite}
.sticky.float.n3{animation:fl 6.5s .8s ease-in-out infinite}
.sticky.float.n4{animation:fl 7.2s .2s ease-in-out infinite}
.sticky.float.n5{animation:fl 6.8s .6s ease-in-out infinite}
@keyframes fl{0%,100%{transform:translateY(0) rotate(var(--rot))}50%{transform:translateY(-8px) rotate(calc(var(--rot) + 1.5deg))}}
.stamp{position:absolute;left:8%;top:6px;max-width:170px;z-index:7;
  font-family:var(--hand);font-size:21px;font-weight:700;line-height:1.05;color:var(--ink);
  padding:10px 15px;border:1px solid rgba(22,20,18,.12);border-radius:14px;background:rgba(255,253,248,.82);backdrop-filter:blur(4px);box-shadow:0 12px 26px -16px rgba(22,20,18,.4);transform:rotate(-5deg)}
.stamp i{color:var(--orange)}
.art-arrow{position:absolute;width:96px;z-index:4}
.art-arrow.a1{left:24%;top:120px;transform:rotate(8deg)}

/* =====================================================================
   MARQUEE
   ===================================================================== */
.marquee{position:relative;z-index:6;background:var(--ink);color:var(--paper);overflow:hidden;padding:22px 0;
  border-block:1px solid rgba(247,241,232,.12);transform:scale(1.05);
  margin:-46px 0 0;box-shadow:0 22px 44px -20px rgba(8,8,7,.65)}
.marquee-track{display:inline-flex;align-items:center;gap:26px;white-space:nowrap;
  font-family:var(--display);font-weight:700;font-size:24px;text-transform:uppercase;letter-spacing:-.01em;
  animation:scroll 26s linear infinite}
.marquee-track i{color:var(--green);font-style:normal;font-size:16px}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scroll{to{transform:translateX(-50%)}}

/* =====================================================================
   SHIFT — avant / après "décryptage"
   ===================================================================== */
.shift{position:relative;overflow:hidden;background:var(--ink);color:var(--paper);padding:92px 0;margin:26px 0}
.shift-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none;opacity:.85;
  -webkit-mask:linear-gradient(100deg,transparent 30%,#000 58%);mask:linear-gradient(100deg,transparent 30%,#000 58%)}
.shift:after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(100deg,rgba(8,8,7,.86) 18%,rgba(8,8,7,.45) 46%,transparent 70%),
             radial-gradient(60% 80% at 16% 30%,rgba(59,18,63,.4),transparent 62%)}
.shift-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.04fr .96fr;gap:56px;align-items:center}
.shift-kicker{display:inline-block;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:var(--green);margin-bottom:16px}
.shift-head .section-title{margin:0}
.shift-head p{margin:20px 0 0;font-size:17px;color:rgba(247,241,232,.74);max-width:430px}

.ledger{display:grid;gap:13px}
.led-cols{display:flex;justify-content:space-between;padding:0 26px 2px}
.led-tag{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.12em}
.led-tag.before{color:rgba(247,241,232,.42)}
.led-tag.after{color:var(--green)}
.led-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:20px;
  background:rgba(247,241,232,.045);border:1px solid rgba(247,241,232,.12);border-radius:16px;
  padding:18px 26px;backdrop-filter:blur(2px);transition:border-color .35s,background .35s}
.led-row:hover{border-color:rgba(184,255,44,.5);background:rgba(247,241,232,.07)}
.led-before{font-family:var(--display);font-size:clamp(24px,2.4vw,32px);font-weight:800;letter-spacing:-.02em;
  color:rgba(247,241,232,.4);text-decoration:line-through;text-decoration-color:var(--orange);text-decoration-thickness:3px}
.led-after{font-family:var(--display);font-size:clamp(26px,2.8vw,38px);font-weight:800;letter-spacing:-.02em;
  color:var(--green);text-align:right;font-variant-numeric:tabular-nums}
.led-beam{position:relative;width:clamp(40px,6vw,80px);height:2px;border-radius:2px;
  background:linear-gradient(90deg,rgba(247,241,232,.18),rgba(184,255,44,.7))}
.led-beam i{position:absolute;top:50%;left:0;width:9px;height:9px;border-radius:50%;background:var(--green);
  transform:translate(-50%,-50%);box-shadow:0 0 14px 2px rgba(184,255,44,.8);animation:beam 2.6s var(--e1) infinite}
.led-row:nth-child(3) .led-beam i{animation-delay:.5s}
.led-row:nth-child(4) .led-beam i{animation-delay:1s}
@keyframes beam{0%{left:0;opacity:0}12%{opacity:1}88%{opacity:1}100%{left:100%;opacity:0}}

/* =====================================================================
   RÉALISATIONS + SHOWREEL
   ===================================================================== */
.work-reel{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/9;
  margin-bottom:20px;box-shadow:var(--shadow);background:#161412;border:1px solid rgba(22,20,18,.1)}
.reel{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.reel-cap{position:absolute;inset:auto 0 0 0;display:flex;flex-direction:column;align-items:flex-start;gap:13px;
  padding:clamp(22px,3.5vw,40px);color:#fff;
  background:linear-gradient(0deg,rgba(8,8,7,.82),rgba(8,8,7,.25) 55%,transparent)}
.reel-badge{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.02em;
  padding:6px 13px;border-radius:999px;background:rgba(255,253,248,.12);border:1px solid rgba(255,253,248,.25);backdrop-filter:blur(6px)}
.reel-badge i{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.reel-cap b{font-family:var(--display);font-weight:800;letter-spacing:-.02em;line-height:1;font-size:clamp(24px,3.4vw,46px);max-width:16ch}
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.work-card{margin:0;background:var(--paper);border:1px solid rgba(22,20,18,.12);border-radius:var(--r-lg);overflow:hidden;
  transition:transform .35s var(--e1),box-shadow .35s var(--e1),border-color .35s}
.work-card:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:var(--ink)}
.work-card img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.work-card figcaption{padding:16px 20px;display:flex;flex-direction:column;gap:2px}
.work-card b{font-family:var(--display);font-size:19px;font-weight:800;letter-spacing:-.01em}
.work-card span{font-size:13px;color:var(--ink-2)}

/* =====================================================================
   DUO — IA + humain (bloc éditorial chic)
   ===================================================================== */
.duo{padding:100px 0}
.duo-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:center}
.duo-img{position:relative;margin:0;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);
  border:1px solid rgba(22,20,18,.08)}
.duo-img img{width:100%;height:auto;display:block}
.duo-chip{position:absolute;left:18px;bottom:18px;display:inline-flex;align-items:center;gap:9px;
  padding:9px 16px;border-radius:999px;background:rgba(8,8,7,.5);backdrop-filter:blur(10px);
  color:#fff;font-size:13px;font-weight:700;border:1px solid rgba(255,255,255,.22)}
.duo-chip i{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 9px var(--green)}
.duo-copy .section-title em{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--orange)}
.duo-copy>p{font-size:18px;color:var(--ink-2);margin:22px 0 28px;max-width:490px;line-height:1.65}
.duo-copy>p i{font-style:italic;font-family:var(--serif);color:var(--ink)}
.duo-points{list-style:none;margin:0;padding:0;display:grid;gap:0}
.duo-points li{font-size:16px;color:var(--ink-2);padding:18px 0;border-top:1px solid rgba(22,20,18,.12)}
.duo-points li:last-child{border-bottom:1px solid rgba(22,20,18,.12)}
.duo-points b{display:inline-block;font-family:var(--display);font-size:13px;color:var(--ink);background:var(--green);
  padding:3px 13px;border-radius:999px;margin-right:12px;font-weight:800;letter-spacing:.02em}

/* ----- raffinement : kicker serif + filet doré ----- */
.kicker.serif{font-family:var(--serif);font-style:italic;font-weight:500;font-size:20px;letter-spacing:0;
  text-transform:none;color:var(--orange);display:inline-flex;align-items:center;gap:13px;margin-bottom:18px}
.kicker.serif:before{content:"";width:36px;height:1.5px;background:linear-gradient(90deg,var(--gold),transparent)}
.kicker.serif.on-dark{color:#f3e9d8}
.kicker.serif.on-dark:before{background:linear-gradient(90deg,var(--gold),transparent)}
/* en-têtes harmonisés : kicker au-dessus du titre */
.section-head>.kicker.serif{align-self:flex-start}
.section-head.center{align-items:center}
.section-head.center>.kicker.serif{align-self:center}
.services .section-head{flex-direction:column;align-items:flex-start;gap:0}
.services .section-intro{text-align:left;margin:14px 0 0}

/* =====================================================================
   CURSEUR CUSTOM
   ===================================================================== */
.has-cursor,.has-cursor a,.has-cursor button,.has-cursor summary,.has-cursor input,.has-cursor .magnetic,.has-cursor label{cursor:none}
.cursor-ring,.cursor-dot{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;border-radius:50%;will-change:transform}
.cursor-dot{width:7px;height:7px;margin:-3.5px 0 0 -3.5px;background:var(--orange)}
.cursor-ring{width:36px;height:36px;margin:-18px 0 0 -18px;border:1.5px solid #fff;mix-blend-mode:difference;
  transition:width .25s var(--e1),height .25s var(--e1),margin .25s var(--e1),background .25s,border-color .25s}
.cursor-ring.hot{width:58px;height:58px;margin:-29px 0 0 -29px;background:rgba(255,255,255,.12)}
@media(pointer:coarse){.cursor-ring,.cursor-dot{display:none}}

/* =====================================================================
   SECTION SHELL
   ===================================================================== */
.section{padding:94px 0}
.section-head{max-width:760px;margin-bottom:52px}
.section-head.center{margin-inline:auto;text-align:center}
.section-intro{font-size:17px;color:var(--ink-2);margin:18px 0 0;max-width:540px}
.section-head.center .section-intro{margin-inline:auto}
.kicker{display:inline-block;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--orange);margin-bottom:14px}

/* ---------- PROBLEM ---------- */
.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:42px 0 28px}
.prob{position:relative;background:var(--paper);border:1px solid rgba(22,20,18,.09);border-radius:var(--r-lg);padding:30px 26px 26px;box-shadow:0 10px 30px -18px rgba(22,20,18,.28);
  transition:transform .35s var(--e1),box-shadow .35s var(--e1)}
.prob:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:rgba(22,20,18,.25)}
.prob-x{font-family:var(--display);font-size:42px;font-weight:800;color:var(--orange);line-height:1;display:block;margin-bottom:14px}
.prob h3{font-family:var(--display);font-size:24px;font-weight:800;letter-spacing:-.02em;margin:0 0 8px;line-height:1.02}
.prob p{margin:0;color:var(--ink-2);font-size:15px}
.method-block{display:grid;grid-template-columns:1.1fr 1.3fr;gap:34px;align-items:center;
  background:var(--ink);color:var(--paper);border-radius:var(--r-lg);padding:42px 44px}
.method-lead h3{font-family:var(--display);font-size:clamp(24px,2.6vw,34px);font-weight:800;line-height:1.04;margin:0;letter-spacing:-.02em}
.method-lead h3 span{color:var(--green)}
.method-list{list-style:none;margin:0;padding:0;display:grid;gap:14px}
.method-list li{display:flex;align-items:center;gap:14px;font-size:18px;font-weight:600;padding-bottom:14px;border-bottom:1px solid rgba(255,253,248,.14)}
.method-list li:last-child{border-bottom:0;padding-bottom:0}
.method-list b{font-family:var(--display);font-size:18px;color:var(--ink);background:var(--green);padding:5px 14px;border-radius:999px;flex:0 0 auto}
.vs{display:flex;align-items:stretch;gap:16px;margin-top:30px;flex-wrap:wrap}
.vs>div{flex:1;min-width:200px;border-radius:var(--r);padding:20px 24px}
.vs-before{background:var(--stone)}
.vs-before span{font-family:var(--display);font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-2)}
.vs-before p{margin:6px 0 0;font-size:20px;font-weight:700;text-decoration:line-through;text-decoration-color:var(--orange);text-decoration-thickness:3px;color:var(--ink-2)}
.vs-after{background:var(--green)}
.vs-after span{font-family:var(--display);font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:.06em}
.vs-after p{margin:6px 0 0;font-size:20px;font-weight:800;font-family:var(--display)}
.vs-arrow{display:grid;place-items:center;flex:0 0 auto;font-size:30px;color:var(--orange);min-width:auto}

/* ---------- SERVICES ---------- */
.section-head{display:flex;flex-direction:column}
.services .section-head{flex-direction:row;justify-content:space-between;align-items:flex-end;max-width:none;gap:40px}
.services .section-intro{margin:0;text-align:right}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.srv{position:relative;background:var(--paper);border:1.5px solid rgba(22,20,18,.12);border-radius:var(--r-lg);
  padding:30px 28px 26px;overflow:hidden;transition:transform .35s var(--e1),box-shadow .35s var(--e1),border-color .35s}
.srv:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:var(--ink)}
.srv-num{position:absolute;top:18px;right:24px;font-family:var(--display);font-size:34px;font-weight:800;color:rgba(22,20,18,.08)}
.srv-ic{width:54px;height:54px;margin-bottom:18px;transition:transform .4s var(--e2)}
.srv:hover .srv-ic{transform:rotate(-8deg) scale(1.08)}
.srv h3{font-family:var(--display);font-size:23px;font-weight:800;letter-spacing:-.02em;line-height:1.04;margin:0 0 10px}
.srv p{margin:0;color:var(--ink-2);font-size:15px}
.srv-arr{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;border:1.5px solid var(--ink);
  font-size:18px;margin-top:20px;transition:transform .3s var(--e2),background .25s,color .25s}
.srv:hover .srv-arr{background:var(--orange);color:#fff;border-color:var(--orange);transform:rotate(-8deg)}

/* ---------- TUILE VEDETTE : Studio créatif ---------- */
.srv-feature{grid-column:1/-1;background:var(--ink);color:var(--paper);border-color:var(--ink);
  display:grid;grid-template-columns:1.25fr .85fr;gap:34px;align-items:center;padding:42px 46px;overflow:hidden}
.srv-feature:hover{transform:translateY(-7px);border-color:var(--ink);box-shadow:0 30px 70px -30px rgba(255,90,31,.5)}
.srv-feature .srv-num{color:rgba(255,253,248,.10);position:static;font-size:30px;display:block;margin-bottom:6px}
.srv-feature-main{position:relative;z-index:2}
.srv-feature h3{font-size:clamp(30px,4vw,42px);color:var(--paper);margin:8px 0 12px;line-height:.98}
.srv-feature h3 .amp{color:var(--green);font-style:italic}
.srv-feature p{color:rgba(255,253,248,.66);font-size:16px;max-width:48ch;margin:0}
.feat-badge{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;font-weight:800;
  letter-spacing:.08em;text-transform:uppercase;color:var(--green)}
.feat-badge i{width:8px;height:8px;border-radius:50%;background:var(--green);animation:featpulse 2.2s infinite}
@keyframes featpulse{0%{box-shadow:0 0 0 0 rgba(184,255,44,.55)}70%{box-shadow:0 0 0 11px rgba(184,255,44,0)}100%{box-shadow:0 0 0 0 rgba(184,255,44,0)}}
.feat-tags{list-style:none;display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:18px 0 24px}
.feat-tags li{font-size:13px;font-weight:600;padding:7px 14px;border-radius:999px;
  border:1px solid rgba(255,253,248,.20);color:rgba(255,253,248,.9);transition:border-color .25s,color .25s,transform .25s var(--e2)}
.feat-tags li:hover{border-color:var(--green);color:var(--green);transform:translateY(-2px)}
.srv-feature-glow{position:absolute;top:-45%;right:-12%;width:440px;height:440px;z-index:1;pointer-events:none;
  background:radial-gradient(circle,rgba(255,90,31,.55),transparent 62%);filter:blur(18px);animation:featdrift 16s ease-in-out infinite}
@keyframes featdrift{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-44px,34px) scale(1.12)}}
.srv-feature-art{position:relative;z-index:2;display:grid;place-items:center;width:100%;aspect-ratio:16/9;
  border-radius:18px;overflow:hidden;background:#0c0b0a;box-shadow:inset 0 0 0 1px rgba(255,253,248,.08)}
.feat-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .8s var(--e1)}
.feat-video.is-on{opacity:.92}
.srv-feature-art::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(circle at 50% 50%,transparent 30%,rgba(12,11,10,.55))}
.feat-play{position:relative;z-index:2;width:96px;height:96px;border-radius:50%;display:grid;place-items:center;color:#fff;
  background:linear-gradient(140deg,var(--orange),var(--orange-d));box-shadow:0 22px 54px -16px rgba(255,90,31,.85)}
.feat-play svg{width:44px;height:44px;margin-left:5px}
.feat-play::before,.feat-play::after{content:"";position:absolute;inset:0;border-radius:50%;
  border:2px solid rgba(255,90,31,.55);animation:featring 3s var(--e1) infinite}
.feat-play::after{animation-delay:1.5s}
@keyframes featring{0%{transform:scale(1);opacity:.7}100%{transform:scale(2);opacity:0}}
@media (prefers-reduced-motion:reduce){
  .feat-badge i,.srv-feature-glow,.feat-play::before,.feat-play::after{animation:none}
}

/* ---------- AMATEUR ---------- */
.amateur{background:var(--aubergine);color:var(--paper);margin:0;border-radius:var(--r-lg);
  width:min(100% - 28px,calc(var(--wrap) + 80px));margin-inline:auto;padding:74px 56px}
.amateur-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center;width:100%;max-width:none}
.amateur .kicker{color:var(--green)}
.amateur-copy p{font-size:18px;color:rgba(255,253,248,.78);margin:22px 0 26px;max-width:460px}
.amateur .section-title{margin-bottom:0}
.budget-badge{display:inline-block;background:var(--orange);color:#fff;font-weight:800;
  padding:13px 20px;border-radius:14px;transform:rotate(-1.5deg);box-shadow:0 18px 34px -14px rgba(255,90,31,.6)}
.proofs{list-style:none;margin:0;padding:0;display:grid;gap:14px}
.proofs li{display:flex;align-items:center;gap:18px;background:rgba(255,253,248,.06);border:1px solid rgba(255,253,248,.14);
  border-radius:16px;padding:20px 22px;transition:transform .3s var(--e1),background .3s}
.proofs li:hover{transform:translateX(6px);background:rgba(255,253,248,.1)}
.proofs b{font-family:var(--display);font-size:24px;color:var(--green);flex:0 0 auto}
.proofs span{font-size:17px;font-weight:600}

/* ---------- OFFRES ---------- */
.packs{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start}
.pack{position:relative;background:var(--paper);border:1px solid rgba(22,20,18,.09);border-radius:var(--r-lg);padding:34px 30px;box-shadow:0 12px 34px -20px rgba(22,20,18,.26);
  transition:transform .35s var(--e1),box-shadow .35s var(--e1)}
.pack:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.pack-pro{background:var(--ink);color:var(--paper);transform:scale(1.04)}
.pack-pro:hover{transform:scale(1.04) translateY(-8px);box-shadow:0 34px 64px -26px rgba(255,90,31,.55)}
.pack-flag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--green);color:var(--ink);
  font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:6px 16px;border-radius:999px;box-shadow:0 8px 18px -8px rgba(184,255,44,.7);white-space:nowrap}
.pack h3{font-family:var(--display);font-size:30px;font-weight:800;letter-spacing:-.02em;margin:0 0 6px}
.pack-desc{margin:0 0 20px;font-size:15px;color:var(--ink-2)}
.pack-pro .pack-desc{color:rgba(255,253,248,.7)}
.pack-price{padding:18px 0;border-block:1px solid rgba(22,20,18,.14);margin-bottom:20px}
.pack-pro .pack-price{border-color:rgba(255,253,248,.16)}
.pack-price b{display:block;font-family:var(--display);font-size:22px;color:var(--orange)}
.pack-price small{display:block;font-size:12.5px;color:var(--ink-2);margin-top:3px}
.pack-pro .pack-price small{color:rgba(255,253,248,.6)}
.pack ul{list-style:none;margin:0 0 24px;padding:0;display:grid;gap:11px}
.pack li{position:relative;padding-left:26px;font-size:15px;font-weight:500}
.pack li:before{content:"";position:absolute;left:0;top:3px;width:16px;height:16px;border-radius:50%;background:var(--green);
  box-shadow:inset 0 0 0 2px var(--ink)}
.pack-pro li:before{box-shadow:none}

/* ---------- TUNNEL ---------- */
.tunnel{background:var(--ink);color:var(--paper);margin:0;padding:84px 0}
.funnel{list-style:none;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:12px 16px;padding:0;margin:0 0 44px}
.funnel li{display:flex;flex-direction:column;align-items:center;gap:10px;font-family:var(--display);font-weight:700;font-size:16px}
.funnel .f-ic{display:block;width:88px;height:88px;border-radius:22px;overflow:hidden;
  border:1px solid rgba(247,241,232,.14);box-shadow:0 14px 30px -14px rgba(0,0,0,.7);
  transition:transform .35s var(--e2),box-shadow .35s,border-color .35s}
.funnel .f-ic img{width:100%;height:100%;object-fit:cover;display:block}
.funnel li:hover .f-ic{transform:translateY(-6px) scale(1.05);border-color:rgba(184,255,44,.6);box-shadow:0 18px 34px -12px rgba(184,255,44,.35)}
.funnel .f-sep{font-size:24px;color:var(--green);align-self:center;margin-top:-22px}
.benefits{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:12px;padding:0;margin:0}
.benefits li{font-size:15px;font-weight:600;padding:10px 20px;border-radius:999px;background:rgba(255,253,248,.06);border:1px solid rgba(255,253,248,.16)}
.benefits li:before{content:"●";color:var(--green);margin-right:8px;font-size:9px;vertical-align:middle}

/* ---------- PROCESS ---------- */
.steps{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:22px;padding:0;margin:0;counter-reset:s}
.steps li{position:relative;padding-top:24px;border-top:3px solid var(--ink)}
.steps li:before{content:"";position:absolute;top:-9px;left:0;width:15px;height:15px;border-radius:50%;background:var(--orange);border:3px solid var(--ivory);box-shadow:0 0 0 3px var(--ink)}
.steps b{font-family:var(--display);font-size:40px;font-weight:800;color:var(--orange);line-height:1}
.steps h3{font-family:var(--display);font-size:22px;font-weight:800;letter-spacing:-.02em;margin:8px 0 8px}
.steps p{margin:0;color:var(--ink-2);font-size:15px}

/* ---------- FAQ ---------- */
.faq-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:start}
.faq-head .btn{margin-top:26px}
.faq-list details{border:1px solid rgba(22,20,18,.1);border-radius:16px;margin-bottom:14px;background:var(--paper);overflow:hidden;
  transition:box-shadow .3s}
.faq-list details[open]{box-shadow:var(--shadow);border-color:rgba(22,20,18,.3)}
.faq-list summary{display:flex;align-items:center;justify-content:space-between;gap:16px;cursor:pointer;list-style:none;
  padding:22px 24px;font-family:var(--display);font-size:19px;font-weight:700;letter-spacing:-.01em}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary i{position:relative;flex:0 0 auto;width:22px;height:22px}
.faq-list summary i:before,.faq-list summary i:after{content:"";position:absolute;background:var(--orange);border-radius:2px;transition:transform .3s var(--e1)}
.faq-list summary i:before{left:0;top:9.5px;width:22px;height:3px}
.faq-list summary i:after{left:9.5px;top:0;width:3px;height:22px}
.faq-list details[open] summary i:after{transform:scaleY(0)}
.faq-list details p{margin:0;padding:0 24px 24px;color:var(--ink-2);font-size:16px;max-width:60ch}

/* ---------- FINAL CTA ---------- */
.final{padding:30px 0 70px}
.final-inner{position:relative;overflow:hidden;background:var(--orange);color:#fff;border-radius:var(--r-lg);
  padding:74px 60px;text-align:center;box-shadow:var(--shadow)}
.final-inner:before{content:"";position:absolute;inset:0;z-index:2;background:radial-gradient(70% 120% at 100% 0,rgba(255,255,255,.18),transparent 55%);pointer-events:none}
.final-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:0;transition:opacity 1s ease}
.final-vid.is-on{opacity:1}
.final-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(120deg,rgba(224,71,17,.8) 22%,rgba(180,52,12,.62) 52%,rgba(59,18,63,.66))}
.final-inner>:not(.final-vid):not(.final-scrim){position:relative;z-index:3}
.final-eyebrow{display:inline-block;font-family:var(--hand);font-size:26px;font-weight:700;margin-bottom:8px;color:#fff}
.final h2{font-family:var(--display);font-weight:800;font-size:clamp(36px,5.4vw,72px);line-height:.96;letter-spacing:-.02em;margin:0 auto;max-width:14ch}
.final h2 em{font-family:var(--serif);font-style:italic;font-weight:500}
.final p{font-size:19px;max-width:560px;margin:18px auto 30px;color:rgba(255,255,255,.92)}
.final-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:26px}
.final .reassure{justify-content:center}
.final .reassure.light li{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.35);color:#fff}
.final .reassure.light li:before{background:#fff;color:var(--orange)}
.final-badge{position:absolute;right:34px;bottom:30px;width:104px;transform:rotate(-12deg);
  animation:wob 5s ease-in-out infinite;filter:drop-shadow(0 8px 14px rgba(0,0,0,.25))}
@keyframes wob{0%,100%{transform:rotate(-12deg)}50%{transform:rotate(-3deg) scale(1.04)}}

/* ---------- FOOTER ---------- */
.footer{background:var(--ink);color:var(--paper);padding:60px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px}
.footer .brand{font-size:24px;color:var(--paper);margin-bottom:14px}
.footer-brand p{color:rgba(255,253,248,.6);font-size:16px;max-width:240px;margin:0}
.footer h3{font-family:var(--display);font-size:15px;text-transform:uppercase;letter-spacing:.05em;margin:0 0 14px}
.footer-grid a:not(.brand){display:block;color:rgba(255,253,248,.62);font-size:15px;margin:8px 0;transition:color .2s,padding-left .2s}
.footer-grid a:not(.brand):hover{color:var(--green);padding-left:5px}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-top:46px;padding-top:22px;
  border-top:1px solid rgba(255,253,248,.12);font-size:13px;color:rgba(255,253,248,.5)}

/* =====================================================================
   REVEAL
   ===================================================================== */
.r{opacity:0;transform:translateY(30px);transition:opacity .7s var(--e1),transform .7s var(--e1)}
.r.in{opacity:1;transform:none}
.r-stagger>*{opacity:0;transform:translateY(26px);transition:opacity .6s var(--e1),transform .6s var(--e1)}
.r-stagger.in>*{opacity:1;transform:none}
.r-stagger.in>*:nth-child(1){transition-delay:.05s}
.r-stagger.in>*:nth-child(2){transition-delay:.11s}
.r-stagger.in>*:nth-child(3){transition-delay:.17s}
.r-stagger.in>*:nth-child(4){transition-delay:.23s}
.r-stagger.in>*:nth-child(5){transition-delay:.29s}
.r-stagger.in>*:nth-child(6){transition-delay:.35s}
.r-stagger.in>*:nth-child(7){transition-delay:.41s}
.r-stagger.in>*:nth-child(8){transition-delay:.47s}
.r-stagger.in>*:nth-child(9){transition-delay:.53s}

/* hero intro */
.hero-title .line>span{transform:translateY(112%);transition:transform .75s var(--e1)}
.hero.in .hero-title .line>span{transform:none}
.hero.in .hero-title .line:nth-child(2)>span{transition-delay:.07s}
.hero.in .hero-title .line:nth-child(3)>span{transition-delay:.14s}
.hero.in .hero-title .line:nth-child(4)>span{transition-delay:.21s}
.hero .eyebrow,.hero-sub,.hero-cta,.reassure{opacity:0;transform:translateY(18px);transition:opacity .6s var(--e1),transform .6s var(--e1)}
.hero.in .eyebrow{opacity:1;transform:none;transition-delay:.1s}
.hero.in .hero-sub{opacity:1;transform:none;transition-delay:.34s}
.hero.in .hero-cta{opacity:1;transform:none;transition-delay:.44s}
.hero.in .reassure{opacity:1;transform:none;transition-delay:.54s}
.hero-art .tiger,.hero-art .doc-form,.hero-art .sticky,.hero-art .stamp,.hero-art .art-arrow{opacity:0}
.hero.in .tiger{animation:pop 1s .2s var(--e1) forwards}
.hero.in .doc-form{animation:pop .6s .5s var(--e1) forwards}
.hero.in .stamp{animation:pop .6s .6s var(--e2) forwards}
.hero.in .art-arrow{animation:pop .6s 1s var(--e1) forwards}
.hero.in .sticky{animation:pop .55s var(--e2) forwards}
.hero.in .n1{animation-delay:.6s}.hero.in .n2{animation-delay:.68s}.hero.in .n3{animation-delay:.76s}
.hero.in .n4{animation-delay:.84s}.hero.in .n5{animation-delay:.92s}
@keyframes pop{from{opacity:0;transform:translateY(16px) scale(.94)}to{opacity:1;transform:none}}

@media(prefers-reduced-motion:reduce){
  *,*:before,*:after{animation:none!important;transition:none!important}
  .r,.r-stagger>*,.hero-title .line>span,.hero .eyebrow,.hero-sub,.hero-cta,.reassure,
  .hero-art .tiger,.hero-art .doc-form,.hero-art .sticky,.hero-art .stamp,.hero-art .art-arrow{opacity:1;transform:none}
  .hero-title b:after{transform:scaleX(1)}
}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media(max-width:1000px){
  .hero-grid{grid-template-columns:1fr;gap:0}
  .hero-art{margin-top:24px;min-height:560px}
  .services .section-head{flex-direction:column;align-items:flex-start}
  .services .section-intro{text-align:left}
  .srv-grid,.problem-grid,.packs,.steps{grid-template-columns:repeat(2,1fr)}
  .srv-feature{grid-template-columns:1fr;gap:8px;padding:36px 34px}
  .srv-feature-art{margin-top:10px}
  .method-block,.amateur-grid,.faq-grid,.shift-inner,.duo-grid{grid-template-columns:1fr;gap:34px}
  .duo{padding:64px 0}.duo-img{max-width:460px}
  .amateur{padding:54px 36px}
  .pack-pro{transform:none}.pack-pro:hover{transform:translateY(-8px)}
}
@media(max-width:620px){
  body{font-size:16px}
  .nav{padding:12px 0}
  .nav-links{display:none}
  .hero{padding:120px 0 50px}
  .hero-title{font-size:clamp(44px,12vw,68px)}
  .hero-art{min-height:0;margin-top:30px;display:flex;flex-direction:column;align-items:center}
  .hero-art .sticky,.hero-art .stamp,.hero-art .art-arrow{display:none}
  .tiger{position:relative;right:auto;top:0;bottom:auto;width:82%;max-width:340px;margin:0 auto -44px;-webkit-mask:none;mask:none;z-index:1}
  .doc-form{position:relative;left:auto;bottom:auto;width:100%;max-width:360px}
  .srv-grid,.problem-grid,.packs,.steps,.work-grid{grid-template-columns:1fr}
  .srv-feature{padding:30px 26px}
  .feat-play{width:88px;height:88px}.feat-play svg{width:34px;height:34px}
  .work-reel{aspect-ratio:4/3}
  .shift{padding:60px 0}
  .led-row{padding:14px 18px;gap:12px}
  .led-cols{padding:0 18px}
  .marquee-track{font-size:20px}
  .vs-arrow{transform:rotate(90deg)}
  .section{padding:60px 0}
  .amateur{padding:44px 24px;border-radius:var(--r-lg)}
  .final-inner{padding:50px 26px}
  .final-badge{position:static;display:block;margin:24px auto 0}
  .footer-grid{grid-template-columns:1fr 1fr}
  .btn-lg{padding:15px 24px}
}

/* ================= SOUS-PAGES (services / légal / contact) ================= */
.subhero{position:relative;padding:140px 0 56px;overflow:hidden;background:var(--ivory)}
.subhero-liquid{position:absolute;inset:0;width:100%;height:100%;opacity:.5;pointer-events:none}
.subhero .wrap{position:relative;z-index:2}
.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:11.5px;line-height:1.2;font-weight:700;color:rgba(22,20,18,.62);margin-bottom:12px}
.breadcrumb a,.breadcrumb b{display:inline-flex;align-items:center;min-height:24px;padding:5px 9px;border-radius:999px;border:1px solid rgba(22,20,18,.08);background:rgba(255,253,248,.58);backdrop-filter:blur(8px)}
.breadcrumb a{color:rgba(22,20,18,.64);text-decoration:none;transition:color .2s,border-color .2s,background .2s}
.breadcrumb a:hover{color:var(--orange);border-color:rgba(255,90,31,.28);background:rgba(255,253,248,.88)}
.breadcrumb span{margin:0 1px;opacity:.38;font-weight:800;color:var(--ink)}
.breadcrumb b{color:var(--ink);background:rgba(255,90,31,.08);border-color:rgba(255,90,31,.18)}
.sub-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:800;letter-spacing:.01em;
  padding:7px 14px;border-radius:999px;background:var(--paper);border:1px solid rgba(22,20,18,.12);box-shadow:0 8px 20px -12px rgba(22,20,18,.3)}
.sub-eyebrow i{width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 4px rgba(255,90,31,.18)}
.sub-h1{font-family:var(--display);font-weight:800;letter-spacing:-.03em;line-height:.96;
  font-size:clamp(36px,5.6vw,72px);margin:20px 0 18px;max-width:16ch}
.sub-lead{font-size:18px;color:var(--ink-2);max-width:560px;margin:0 0 26px}
.sub-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:24px}

/* livrables */
.deliv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.deliv{position:relative;background:var(--paper);border:1.5px solid rgba(22,20,18,.12);border-radius:var(--r-lg);
  padding:28px 26px;transition:transform .35s var(--e1),box-shadow .35s var(--e1),border-color .35s}
.deliv:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--ink)}
.deliv-num{font-family:var(--display);font-size:15px;font-weight:800;color:var(--orange)}
.deliv h3{font-family:var(--display);font-size:20px;font-weight:800;letter-spacing:-.02em;line-height:1.05;margin:10px 0 8px}
.deliv p{margin:0;color:var(--ink-2);font-size:15px}

/* maillage / autres prestations */
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.related-card{display:flex;align-items:center;justify-content:space-between;gap:16px;
  background:var(--paper);border:1.5px solid rgba(22,20,18,.12);border-radius:var(--r-lg);padding:22px 24px;
  text-decoration:none;color:var(--ink);font-family:var(--display);transition:transform .3s var(--e1),border-color .3s,background .3s}
.related-card b{font-size:18px;font-weight:800;letter-spacing:-.01em}
.related-card .related-arr{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;border:1.5px solid var(--ink);transition:transform .3s var(--e2),background .25s,color .25s}
.related-card:hover{transform:translateY(-5px);border-color:var(--ink)}
.related-card:hover .related-arr{background:var(--orange);color:#fff;border-color:var(--orange);transform:translateX(2px)}
.related-all{background:var(--ink);color:var(--paper)}
.related-all .related-arr{border-color:rgba(255,253,248,.4)}

/* pages légales */
.legal-wrap{max-width:760px}
.legal-wrap h2{font-family:var(--display);font-size:24px;font-weight:800;letter-spacing:-.02em;margin:34px 0 10px}
.legal-wrap h2:first-child{margin-top:0}
.legal-wrap p{color:var(--ink-2);font-size:16px;line-height:1.65;margin:0}
.legal-wrap a{color:var(--orange)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:start}
.contact-list{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:2px}
.contact-list li{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:16px 4px;border-bottom:1px solid rgba(22,20,18,.12)}
.contact-list span{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-2)}
.contact-list a,.contact-list b{font-family:var(--display);font-weight:800;font-size:18px;color:var(--ink);text-decoration:none}
.contact-list a:hover{color:var(--orange)}

/* formulaire dans la CTA finale */
.final-form{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;max-width:620px;margin:8px auto 18px}
.final-form input{flex:1 1 200px;padding:14px 16px;border-radius:12px;border:1px solid rgba(255,253,248,.25);background:rgba(255,253,248,.10);color:var(--paper);font-size:15px}
.final-form input::placeholder{color:rgba(255,253,248,.55)}
.final-form button{flex:0 0 auto}

@media(max-width:1000px){
  .deliv-grid,.related-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr;gap:34px}
}
@media(max-width:620px){
  .subhero{padding:118px 0 44px}
  .breadcrumb{font-size:10.5px;gap:5px;margin-bottom:10px}
  .breadcrumb a,.breadcrumb b{min-height:22px;padding:4px 8px}
  .sub-eyebrow{font-size:12px;padding:7px 12px}
  .deliv-grid,.related-grid{grid-template-columns:1fr}
}

/* ================= MÉGA-MENU (maillage nav) ================= */
a.srv{display:block;text-decoration:none;color:inherit}
.mega-item{position:relative;display:flex;align-items:center}
.mega-trigger{display:inline-flex;align-items:center;gap:6px}
.mega-caret{width:6px;height:6px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);opacity:.55;transition:transform .25s var(--e1)}
.mega-item:hover .mega-caret,.mega-item:focus-within .mega-caret{transform:rotate(45deg) translateY(1px);opacity:.9}
.mega{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(6px);
  min-width:232px;max-width:300px;background:var(--paper);border:1.5px solid rgba(22,20,18,.10);border-radius:16px;
  box-shadow:var(--shadow);padding:8px;display:flex;flex-direction:column;gap:1px;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s var(--e1),transform .2s var(--e1);z-index:60}
.mega:before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.mega a{padding:9px 13px;border-radius:9px;font-size:13.5px;font-weight:600;color:var(--ink-2);white-space:nowrap;transition:background .2s,color .2s}
.mega a:after{display:none}
.mega a:hover{background:var(--ivory);color:var(--orange)}
.mega-item:hover .mega,.mega-item:focus-within .mega{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}

/* chips cliquables de la tuile vedette */
.feat-tags li{padding:0}
.feat-tags li a{display:block;padding:7px 14px;color:inherit;text-decoration:none}

/* ================= BANDE VILLES (maillage local) ================= */
.cities-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.city-card{position:relative;display:flex;align-items:center;gap:12px;
  background:var(--paper);border:1.5px solid rgba(22,20,18,.12);border-radius:var(--r-lg);
  padding:20px 22px;text-decoration:none;color:var(--ink);font-family:var(--display);
  transition:transform .3s var(--e1),border-color .3s,box-shadow .3s}
.city-card b{font-size:18px;font-weight:800;letter-spacing:-.01em;flex:1}
.city-pin{width:11px;height:11px;border-radius:50% 50% 50% 0;background:var(--orange);transform:rotate(-45deg);flex:0 0 auto;box-shadow:0 0 0 4px rgba(255,90,31,.15)}
.city-arr{opacity:0;transform:translateX(-6px);transition:opacity .25s,transform .25s var(--e2);color:var(--orange);font-weight:700}
.city-card:hover{transform:translateY(-5px);border-color:var(--ink);box-shadow:var(--shadow)}
.city-card:hover .city-arr{opacity:1;transform:translateX(0)}
.city-card.is-current{border-color:var(--ink);background:var(--ink);color:var(--paper)}
.city-card.is-current .city-arr{opacity:1;transform:none;color:var(--green)}
@media(max-width:1000px){.cities-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:620px){.cities-grid{grid-template-columns:repeat(2,1fr)}}

/* ================= CONTENU SEO (textes générés) ================= */
.seo-content{padding-top:64px}
.seo-content-wrap{max-width:760px;margin-inline:auto}
.seo-content-wrap h2{font-family:var(--display);font-weight:800;letter-spacing:-.02em;line-height:1.05;font-size:clamp(24px,3vw,32px);margin:38px 0 12px}
.seo-content-wrap h3{font-family:var(--display);font-weight:800;letter-spacing:-.01em;font-size:21px;margin:26px 0 10px}
.seo-content-wrap h2:first-child,.seo-content-wrap h3:first-child{margin-top:0}
.seo-content-wrap p{color:var(--ink-2);font-size:17px;line-height:1.7;margin:0 0 16px}
.seo-content-wrap strong{color:var(--ink);font-weight:700}
.seo-content-wrap ul,.seo-content-wrap ol{margin:0 0 18px;padding-left:4px;list-style:none}
.seo-content-wrap li{position:relative;padding-left:26px;margin:0 0 10px;color:var(--ink-2);font-size:17px;line-height:1.6}
.seo-content-wrap ul li:before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;border-radius:50% 50% 50% 0;background:var(--orange);transform:rotate(-45deg)}
.seo-content-wrap ol{counter-reset:c}
.seo-content-wrap ol li{counter-increment:c}
.seo-content-wrap ol li:before{content:counter(c);position:absolute;left:0;top:0;font-family:var(--display);font-weight:800;font-size:14px;color:var(--orange)}
.seo-content-wrap table{width:100%;border-collapse:collapse;margin:0 0 20px;font-size:15px}
.seo-content-wrap th,.seo-content-wrap td{border:1px solid rgba(22,20,18,.14);padding:10px 12px;text-align:left}
.seo-content-wrap a{color:var(--orange)}

/* ================= PAGE 404 ================= */
.error404{min-height:68vh;display:flex;align-items:center}
.err-code{display:block;font-family:var(--display);font-weight:800;font-size:clamp(78px,15vw,170px);line-height:.9;letter-spacing:-.04em;color:var(--orange);margin-bottom:4px}
.err-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.err-links a{padding:9px 16px;border-radius:999px;background:var(--paper);border:1.5px solid rgba(22,20,18,.12);font-size:14px;font-weight:600;color:var(--ink-2);text-decoration:none;transition:border-color .25s,color .25s,transform .25s var(--e2)}
.err-links a:hover{border-color:var(--orange);color:var(--orange);transform:translateY(-2px)}

/* ================= BOUTON WHATSAPP FLOTTANT ================= */
.wa-fab{position:fixed;right:22px;bottom:22px;z-index:80;display:inline-flex;align-items:center;height:60px;
  border-radius:999px;background:#25D366;color:#fff;text-decoration:none;font-family:var(--display);
  box-shadow:0 16px 38px -12px rgba(37,211,102,.8),0 4px 12px rgba(0,0,0,.18);
  transition:transform .25s var(--e2),box-shadow .3s}
.wa-fab .wa-ic{position:relative;z-index:2;flex:0 0 60px;height:60px;display:grid;place-items:center}
.wa-fab .wa-ic svg{width:31px;height:31px}
.wa-fab-label{position:relative;z-index:2;max-width:0;opacity:0;overflow:hidden;white-space:nowrap;
  font-weight:800;font-size:15px;letter-spacing:-.01em;
  transition:max-width .4s var(--e1),opacity .25s,padding .4s var(--e1)}
.wa-fab:hover{transform:translateY(-3px);box-shadow:0 22px 46px -12px rgba(37,211,102,.85),0 6px 14px rgba(0,0,0,.2)}
.wa-fab:hover .wa-fab-label{max-width:220px;opacity:1;padding-right:26px}
.wa-fab:before{content:"";position:absolute;inset:0;border-radius:999px;pointer-events:none;
  box-shadow:0 0 0 0 rgba(37,211,102,.5);animation:waPulse 2.6s var(--e1) infinite}
@keyframes waPulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 18px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
@media(max-width:620px){.wa-fab{right:15px;bottom:15px;width:58px;height:58px;justify-content:center}.wa-fab .wa-ic{flex:0 0 58px;width:58px;height:58px}.wa-fab .wa-ic svg{width:30px;height:30px}.wa-fab-label{display:none}}
@media(prefers-reduced-motion:reduce){.wa-fab:before{animation:none}}

/* ================= MENU MOBILE ================= */
.nav-burger{display:none;position:relative;z-index:71;width:46px;height:46px;border:0;background:transparent;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:0}
.nav-burger span{display:block;width:24px;height:2.5px;border-radius:2px;background:var(--ink);transition:transform .3s var(--e1),opacity .2s}
body.mm-open .nav-burger span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
body.mm-open .nav-burger span:nth-child(2){opacity:0}
body.mm-open .nav-burger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;z-index:70;background:var(--ivory);padding:92px 22px 28px;overflow-y:auto;
  opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity .3s var(--e1),transform .35s var(--e1),visibility .3s}
body.mm-open{overflow:hidden}
body.mm-open .mobile-menu{opacity:1;visibility:visible;transform:none}
.mm-close{position:fixed;top:20px;right:22px;z-index:72;display:inline-flex;align-items:center;gap:10px;height:44px;padding:0 14px;border:1px solid rgba(22,20,18,.12);border-radius:999px;background:var(--paper);color:var(--ink);font:800 14px/1 var(--font);box-shadow:0 14px 30px -22px rgba(22,20,18,.6);cursor:pointer}
.mm-close i{position:relative;width:16px;height:16px;display:block}
.mm-close i:before,.mm-close i:after{content:"";position:absolute;left:0;top:7px;width:16px;height:2px;border-radius:2px;background:currentColor}
.mm-close i:before{transform:rotate(45deg)}
.mm-close i:after{transform:rotate(-45deg)}
.mm-close:hover,.mm-close:focus{border-color:var(--orange);color:var(--orange)}
.mm-inner{display:flex;flex-direction:column;gap:4px;max-width:520px;margin:0 auto}
.mm-link{font-family:var(--display);font-weight:800;font-size:21px;letter-spacing:-.02em;color:var(--ink);text-decoration:none;padding:11px 0;border-bottom:1px solid rgba(22,20,18,.1)}
.mm-group{padding:11px 0;border-bottom:1px solid rgba(22,20,18,.1)}
.mm-title{display:block;font-family:var(--display);font-weight:800;font-size:21px;letter-spacing:-.02em;color:var(--ink);margin-bottom:9px}
.mm-subs{display:flex;flex-wrap:wrap;gap:8px}
.mm-sub{font-size:14px;font-weight:600;color:var(--ink-2);text-decoration:none;padding:7px 13px;border-radius:999px;background:var(--paper);border:1px solid rgba(22,20,18,.12)}
.mm-sub:hover,.mm-sub:focus{border-color:var(--orange);color:var(--orange)}
.mm-cta{display:flex;flex-direction:column;gap:10px;margin-top:20px}
@media(max-width:620px){ .nav-actions{display:none} .nav-burger{display:flex} }
@media(min-width:621px){ .mobile-menu,.nav-burger{display:none} }

/* ================= CONTENU SEO — mise en page éditoriale ================= */
.seo-content-wrap{counter-reset:h2sec}
/* image d'illustration flottante */
.seo-illu{float:right;width:330px;max-width:42%;margin:6px 0 22px 32px;border-radius:20px;overflow:hidden;
  background:var(--paper);box-shadow:0 26px 54px -22px rgba(22,20,18,.42);border:1px solid rgba(22,20,18,.06)}
.seo-illu img{display:block;width:100%;height:auto;aspect-ratio:1/1;object-fit:cover}
/* intro : lettrine + texte plus grand */
.seo-content-wrap>p:first-of-type{font-size:19px;line-height:1.65;color:var(--ink-2)}
.seo-content-wrap>p:first-of-type::first-letter{float:left;font-family:var(--display);font-weight:800;
  font-size:66px;line-height:.66;margin:6px 12px 0 0;color:var(--orange)}
/* titres H2 numérotés, façon magazine */
.seo-content-wrap h2{counter-increment:h2sec;position:relative;padding-top:22px;margin-top:36px;border-top:1px solid rgba(22,20,18,.1)}
.seo-content-wrap h2::before{content:counter(h2sec,decimal-leading-zero);display:inline-block;
  font-family:var(--display);font-size:13px;font-weight:800;letter-spacing:.12em;color:var(--orange);
  margin-bottom:6px;padding:2px 9px;border:1.5px solid rgba(255,90,31,.35);border-radius:999px}
.seo-content-wrap h2:first-of-type{margin-top:8px;border-top:0;padding-top:0}
.seo-content-wrap h3{margin-top:22px}
@media(max-width:760px){
  .seo-illu{float:none;width:100%;max-width:100%;margin:0 0 22px}
  .seo-content-wrap>p:first-of-type::first-letter{font-size:54px}
}

/* ===== CONTENU SEO — restructuration éditoriale (v2) ===== */
.seo-content-wrap h2::before{content:none!important}              /* supprime l'ancienne numérotation */
.seo-content-wrap{counter-reset:none}
/* INTRO 2 colonnes (texte + image) */
.seo-leadwrap{margin-bottom:14px}
.seo-leadwrap.has-fig{display:grid;grid-template-columns:1fr 340px;gap:40px;align-items:start}
.seo-leadwrap .seo-illu{float:none;width:100%;max-width:100%;margin:0;position:sticky;top:96px}
.seo-lead{font-size:0}
.seo-lead p{font-size:19px;line-height:1.72;color:var(--ink-2);margin:0 0 16px}
.seo-lead>p:first-child::first-letter{float:left;font-family:var(--display);font-weight:800;font-size:78px;line-height:.64;margin:9px 14px 0 0;color:var(--orange)}
/* SECTIONS */
.seo-sec{margin:26px 0}
.seo-sec h2{font-family:var(--display);font-weight:800;font-size:clamp(23px,2.6vw,31px);letter-spacing:-.02em;line-height:1.08;margin:0 0 14px;padding-left:18px;border-left:4px solid var(--orange);border-top:0}
.seo-sec h3{margin-top:20px}
.seo-sec p{margin:0 0 15px}
.seo-sec--alt{background:var(--paper);border:1px solid rgba(22,20,18,.1);border-radius:24px;padding:30px 32px;box-shadow:0 24px 56px -34px rgba(22,20,18,.3);margin:30px 0}
.seo-sec--alt h2{border-left-color:var(--green)}
/* LISTES -> CARTES */
.seo-sec--cards ul,.seo-sec--cards ol{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;list-style:none;padding:0;margin:18px 0}
.seo-sec--cards li{position:relative;padding:15px 16px 15px 48px;background:var(--ivory);border:1px solid rgba(22,20,18,.12);border-radius:16px;font-size:15px;line-height:1.5;color:var(--ink-2);margin:0}
.seo-sec--alt.seo-sec--cards li{background:#fff}
.seo-sec--cards li::before{content:"✓";position:absolute;left:14px;top:14px;width:22px;height:22px;display:grid;place-items:center;background:var(--orange);color:#fff;border-radius:8px;font-size:12px;font-weight:800;transform:none}
/* CITATION mise en avant */
.seo-quote{position:relative;margin:40px 0;padding:6px 0 6px 32px;border-left:3px solid var(--orange);
  font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(23px,3.1vw,31px);line-height:1.32;color:var(--ink);max-width:none}
.seo-quote::before{content:"“";position:absolute;left:-2px;top:-26px;font-family:var(--serif);font-size:80px;color:var(--orange);opacity:.22;line-height:1}
@media(max-width:820px){
  .seo-leadwrap.has-fig{grid-template-columns:1fr;gap:20px}
  .seo-leadwrap .seo-illu{position:static;max-width:440px;margin:0 auto}
  .seo-sec--cards ul,.seo-sec--cards ol{grid-template-columns:1fr}
  .seo-sec--alt{padding:24px 22px}
  .seo-lead>p:first-child::first-letter{font-size:60px}
}

/* ===== Section vedette sombre (breakout + aurora animée) ===== */
.seo-sec--feature{position:relative;overflow:hidden;width:min(100% + 280px, calc(100vw - 36px));
  margin:42px 0 42px 50%;transform:translateX(-50%);
  background:var(--ink);color:var(--paper);border-radius:28px;padding:44px 48px;
  box-shadow:0 44px 96px -44px rgba(22,20,18,.65)}
.seo-sec--feature::before{content:"";position:absolute;inset:-35%;z-index:0;pointer-events:none;
  background:radial-gradient(38% 38% at 18% 22%,rgba(255,90,31,.55),transparent 60%),radial-gradient(42% 42% at 86% 72%,rgba(184,255,44,.3),transparent 62%);
  filter:blur(34px);animation:auroraDrift 17s ease-in-out infinite}
@keyframes auroraDrift{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(44px,-32px) scale(1.16)}}
.seo-sec--feature>*{position:relative;z-index:1}
.seo-sec--feature h2{color:var(--paper);border-left-color:var(--green)}
.seo-sec--feature h3{color:var(--paper)}
.seo-sec--feature p{color:rgba(255,253,248,.8)}
.seo-sec--feature strong{color:#fff}
.seo-sec--feature.seo-sec--cards li{background:rgba(255,253,248,.07);border-color:rgba(255,253,248,.16);color:rgba(255,253,248,.86)}
@media(prefers-reduced-motion:reduce){.seo-sec--feature::before{animation:none}}
@media(max-width:820px){.seo-sec--feature{width:100%;margin-left:0;transform:none;padding:30px 24px}}

/* ===== CONTENU SEO — refinements (v4) ===== */
.seo-content-wrap{max-width:880px}
/* image flottée quand pas d'intro */
.seo-illu--float{float:right;width:340px;max-width:42%;margin:4px 0 22px 34px}
@media(max-width:760px){.seo-illu--float{float:none;width:100%;max-width:100%;margin:0 0 22px}}
/* puces des cartes alignées (flex au lieu d'absolu) */
.seo-sec--cards li{display:flex;align-items:flex-start;gap:12px;padding:14px 16px}
.seo-sec--cards li::before{position:static;left:auto;top:auto;flex:0 0 22px;margin-top:1px;transform:none}
/* bloc "background" clair en pleine largeur (alterné) */
.seo-sec--alt{position:relative;width:min(100% + 220px, calc(100vw - 36px));margin:30px 0 30px 50%;transform:translateX(-50%);
  background:linear-gradient(180deg,#fff,var(--paper));border:1px solid rgba(22,20,18,.09);border-radius:26px;padding:34px 42px;box-shadow:0 26px 60px -38px rgba(22,20,18,.28)}
@media(max-width:820px){.seo-sec--alt{width:100%;margin-left:0;transform:none;padding:24px 22px}}

/* ===== FIX cartes liste : texte inline normal, marqueur absolu ===== */
.seo-sec--cards li{display:block;position:relative;align-items:initial;gap:0;padding:14px 16px 14px 48px}
.seo-sec--cards li::before{position:absolute;left:14px;top:14px;flex:none;margin:0}
/* canvas WebGL dans la bande vedette */
.seo-sec--feature .liquid-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block}
.seo-sec--feature::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(95deg,rgba(18,16,14,.86),rgba(18,16,14,.5))}
.seo-sec--feature>*:not(.liquid-canvas){position:relative;z-index:1}

/* ================= FAQ PREMIUM ================= */
.faq2-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:56px;align-items:start}
.faq2-head{position:sticky;top:96px}
.faq2-head .section-title{margin:14px 0 16px}
.faq2-list{display:flex;flex-direction:column;gap:14px}
.faq2-item{background:var(--paper);border:1.5px solid rgba(22,20,18,.1);border-radius:20px;overflow:hidden;transition:border-color .3s,box-shadow .35s var(--e1),transform .25s var(--e1)}
.faq2-item:hover{border-color:rgba(22,20,18,.28)}
.faq2-item[open]{border-color:var(--ink);box-shadow:0 26px 56px -34px rgba(22,20,18,.42)}
.faq2-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:18px;padding:21px 24px;font-family:var(--display);font-weight:800;font-size:18px;letter-spacing:-.01em;line-height:1.25;color:var(--ink)}
.faq2-item summary::-webkit-details-marker{display:none}
.faq2-q{flex:1}
.faq2-ic{flex:0 0 34px;width:34px;height:34px;border-radius:50%;border:1.5px solid var(--ink);position:relative;transition:background .3s,border-color .3s,transform .35s var(--e2)}
.faq2-ic::before,.faq2-ic::after{content:"";position:absolute;left:50%;top:50%;background:var(--ink);border-radius:2px;transition:transform .35s var(--e2),background .3s}
.faq2-ic::before{width:13px;height:2px;transform:translate(-50%,-50%)}
.faq2-ic::after{width:2px;height:13px;transform:translate(-50%,-50%)}
.faq2-item[open] .faq2-ic{background:var(--orange);border-color:var(--orange);transform:rotate(135deg)}
.faq2-item[open] .faq2-ic::before,.faq2-item[open] .faq2-ic::after{background:#fff}
.faq2-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .4s var(--e1)}
.faq2-item[open] .faq2-a{grid-template-rows:1fr}
.faq2-a>div{overflow:hidden}
.faq2-a p{margin:0;padding:0 24px 24px 24px;color:var(--ink-2);font-size:16px;line-height:1.65}
@media(max-width:900px){.faq2-grid{grid-template-columns:1fr;gap:26px}.faq2-head{position:static}}

/* ===== Fix header section "services" (accueil) : kicker+titre à gauche, intro à droite ===== */
@media(min-width:1001px){
  .services .section-head{display:grid;grid-template-columns:minmax(0,1fr) minmax(240px,360px);column-gap:48px;align-items:end}
  .services .section-head>.kicker.serif{grid-column:1;grid-row:1;align-self:start;margin-bottom:6px}
  .services .section-title{grid-column:1;grid-row:2;margin:0}
  .services .section-intro{grid-column:2;grid-row:2;align-self:end;text-align:left;margin:0 0 6px}
}

/* ===== FIX puces des cartes : surclasse l'ancienne goutte (.seo-content-wrap ul li) ===== */
.seo-content-wrap .seo-sec--cards ul li::before,
.seo-content-wrap .seo-sec--cards ol li::before{
  content:"\2713";left:16px;top:14px;width:22px;height:22px;border-radius:8px;background:var(--orange);
  transform:none;display:grid;place-items:center;color:#fff;font-size:12px;font-weight:800}
.seo-content-wrap .seo-sec--cards li{padding:14px 16px 14px 50px}
.seo-sec--feature.seo-sec--cards li::before{background:var(--green);color:var(--ink)}

/* ================= FAQ "CHAT IA" (disruptive) ================= */
.faqai{position:relative;overflow:hidden;background:var(--ink);color:var(--paper)}
.faqai-bg{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block;opacity:.9}
.faqai-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(100deg,rgba(18,16,14,.92),rgba(18,16,14,.55))}
.faqai-inner{position:relative;z-index:2;display:grid;grid-template-columns:.82fr 1.18fr;gap:52px;align-items:start}
.faqai-head{position:sticky;top:96px}
.faqai-badge{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--green)}
.faqai-badge i{width:8px;height:8px;border-radius:50%;background:var(--green);animation:featpulse 2.2s infinite}
.faqai-title{font-family:var(--display);font-weight:800;letter-spacing:-.02em;line-height:1.02;font-size:clamp(30px,4vw,48px);margin:16px 0 14px;color:var(--paper)}
.faqai-title .hl-green{color:var(--green)}
.faqai-sub{color:rgba(255,253,248,.72);font-size:16px;line-height:1.55;margin:0 0 22px;max-width:34ch}
.faqai-qs{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:22px}
.faqai-chip{font-family:var(--body);font-size:13.5px;font-weight:600;color:rgba(255,253,248,.82);background:rgba(255,253,248,.07);border:1px solid rgba(255,253,248,.18);border-radius:999px;padding:9px 15px;cursor:pointer;transition:background .22s,border-color .22s,color .22s,transform .22s var(--e2);text-align:left;line-height:1.2}
.faqai-chip:hover{border-color:rgba(255,253,248,.45);color:#fff;transform:translateY(-1px)}
.faqai-chip.is-active{background:var(--orange);border-color:var(--orange);color:#fff;box-shadow:0 10px 24px -10px rgba(255,90,31,.7)}
.faqai-thread{display:flex;flex-direction:column;gap:14px;min-height:180px}
.faqai-bubble{border-radius:20px;padding:15px 19px;font-size:15px;line-height:1.62;max-width:92%;animation:faqaiPop .4s var(--e1)}
@keyframes faqaiPop{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.faqai-bubble.user{align-self:flex-end;background:var(--orange);color:#fff;font-weight:600;border-bottom-right-radius:6px}
.faqai-bubble.bot{align-self:flex-start;background:rgba(255,253,248,.08);border:1px solid rgba(255,253,248,.15);border-bottom-left-radius:6px;display:flex;gap:14px;color:rgba(255,253,248,.92)}
.faqai-ava{flex:0 0 32px;width:32px;height:32px;border-radius:50%;background:linear-gradient(140deg,var(--orange),var(--green));box-shadow:0 0 0 4px rgba(184,255,44,.12);position:relative}
.faqai-ava::after{content:"";position:absolute;inset:9px;border-radius:50% 50% 50% 0;background:var(--ink);transform:rotate(-45deg)}
.faqai-a{flex:1;min-width:0}
.faqai-a.typing::after{content:"\258B";color:var(--green);margin-left:1px;animation:faqaiCaret .8s steps(1) infinite}
@keyframes faqaiCaret{50%{opacity:0}}
@media(max-width:900px){.faqai-inner{grid-template-columns:1fr;gap:26px}.faqai-head{position:static}}
@media(prefers-reduced-motion:reduce){.faqai-badge i{animation:none}.faqai-a.typing::after{animation:none}}
