/* ============ DigitalAM — Design System ============ */
:root{
  --bg:#0A0A0B;
  --bg-2:#101012;
  --ink:#F6F6F3;
  --dim:rgba(246,246,243,.58);
  --dim-2:rgba(246,246,243,.58);
  --line:rgba(246,246,243,.12);
  --accent:#C6FF3D;
  --accent-dim:rgba(198,255,61,.14);
  --radius:2px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto}
::selection{background:var(--accent);color:#0A0A0B}
body{
  background:var(--bg);color:var(--ink);
  font-family:'Manrope',sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
.mono{font-family:'Space Mono',monospace}

/* ---------- Ex-sections claires → surfaces sombres élevées ----------
   Le crème #F6F5F1 éblouissait sur un site dark ; on garde le contraste
   de rythme avec un gris élevé + textes/CTA aux couleurs de la charte. */
.theme-light{
  --bg:#141416; --bg-2:#1B1B1E; --ink:#F6F6F3;
  --dim:rgba(246,246,243,.62); --dim-2:rgba(246,246,243,.55);
  --line:rgba(246,246,243,.13); --accent-dim:rgba(198,255,61,.14);
  background:var(--bg);color:var(--ink);
  border-top:1px solid var(--line);
}
.cta-band.theme-light{background:radial-gradient(ellipse 70% 90% at 50% 110%,rgba(198,255,61,.10),transparent 60%),#141416}

.wrap{max-width:1360px;margin:0 auto;padding:0 46px}
.label{font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:var(--accent);font-weight:700;margin-bottom:20px;font-family:'Space Mono',monospace}
.theme-light .label{color:var(--accent)}

h1,h2,h3{letter-spacing:-.03em;line-height:1.04;font-weight:700}
h2{font-size:clamp(30px,4vw,52px);max-width:820px}
p{color:var(--dim);line-height:1.65;font-size:15.5px}

/* ---------- Article / service long-form content ---------- */
.breadcrumb{font-size:12.5px;color:var(--dim-2);margin-bottom:24px;font-family:'Space Mono',monospace}
.breadcrumb a{color:var(--dim-2)}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .sep{margin:0 8px;opacity:.5}

.article{max-width:680px;margin:0 auto}
.article-wide{max-width:820px}
.article h2{font-size:clamp(24px,3vw,36px);margin:56px 0 20px}
.article h2:first-of-type{margin-top:0}
.article h3{font-size:19px;margin:32px 0 14px}
.article p{margin-bottom:18px;font-size:16px;color:var(--dim)}
.article ul,.article ol{margin:0 0 20px;padding-left:22px}
.article li{color:var(--dim);font-size:15.5px;line-height:1.7;margin-bottom:10px}
.article li strong{color:var(--ink)}
.article a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.article table{width:100%;border-collapse:collapse;margin:24px 0;font-size:14px}
.article th{background:var(--bg-2);text-align:left;padding:12px 14px;font-weight:700;border:1px solid var(--line)}
.article td{padding:12px 14px;border:1px solid var(--line);color:var(--dim)}

.lead-answer{border-left:3px solid var(--accent);padding:22px 26px;background:var(--bg-2);margin-bottom:44px;border-radius:0 4px 4px 0}
.lead-answer p{margin:0;font-size:16.5px;color:var(--ink)}
.lead-answer strong{color:var(--accent)}

.promo-box{border:1px solid var(--line);padding:32px;margin:40px 0;text-align:center;border-radius:2px}
.promo-box h3{margin-bottom:10px}
.promo-box p{margin-bottom:20px}

.article-meta{display:flex;gap:16px;font-size:12.5px;color:var(--dim-2);font-family:'Space Mono',monospace;margin-bottom:6px}

.content-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);margin-top:40px}
.content-card{background:var(--bg);padding:30px}
.content-card h3{font-size:15px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;color:var(--dim)}
.content-card ul{list-style:none;padding:0;margin:0}
.content-card li{margin-bottom:0}
.content-card a{display:block;padding:8px 0;border-top:1px solid var(--line);font-size:14.5px;color:var(--ink);text-decoration:none}
.content-card a:first-child{border-top:none}
.content-card a:hover{color:var(--accent)}

@media(max-width:760px){
  .content-grid-2{grid-template-columns:1fr}
}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 28px;border-radius:100px;
  font-size:13.5px;font-weight:700;letter-spacing:.01em;
  background:var(--accent);color:#0A0A0B;
  transition:transform .3s cubic-bezier(.16,1,.3,1);
}
.btn:hover{transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-outline:hover{border-color:var(--accent)}
.btn svg{width:14px;height:14px}

/* ---------- NAV ---------- */
header.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 46px;transition:background .4s,padding .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
header.site-nav.scrolled{
  background:rgba(10,10,11,.82);backdrop-filter:blur(14px);
  padding:16px 46px;border-color:var(--line);
}
.nav-logo{font-weight:800;font-size:16px;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}
.nav-logo .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}
.nav-links{display:flex;align-items:center;gap:38px}
.nav-links a{font-size:13.5px;font-weight:600;color:var(--dim);position:relative;padding:4px 0}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--accent);transition:width .35s}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--ink)}
.nav-cta{display:flex;align-items:center;gap:22px}
.nav-cta .btn{padding:12px 22px}
.burger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:44px;height:44px;margin:-10px -10px -10px 0}
.burger span{height:2px;background:var(--ink);width:26px}
.burger:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* ---------- HERO ---------- */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:140px 46px 80px;position:relative}
.hero-kicker{font-size:13px;color:var(--dim);margin-bottom:26px;font-family:'Space Mono',monospace;display:flex;align-items:center;gap:10px}
.hero-kicker .dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}
.hero h1{font-size:clamp(40px,6.6vw,96px);max-width:1180px}
.hero h1 .line{overflow:hidden;display:block}
.hero h1 .line span{display:inline-block;transform:translateY(105%)}
.hero-sub{margin-top:32px;font-size:17px;max-width:520px;color:var(--dim)}
.hero-actions{display:flex;gap:16px;margin-top:44px;align-items:center}
.hero-canvas{position:absolute;inset:0;z-index:0;opacity:.5;pointer-events:none}
.hero>*{position:relative;z-index:1}
.hero-scroll{position:absolute;bottom:36px;left:46px;font-size:11px;color:var(--dim-2);display:flex;align-items:center;gap:10px;font-family:'Space Mono',monospace}
.hero-scroll .l{width:24px;height:1px;background:var(--dim-2)}

/* Sub-page hero (shorter) */
.page-hero{padding:150px 46px 70px}
.page-hero .kicker{font-size:12px;color:var(--accent);text-transform:uppercase;letter-spacing:.16em;margin-bottom:20px;font-family:'Space Mono',monospace;font-weight:700}
.page-hero h1{font-size:clamp(34px,5.2vw,68px);max-width:900px}
.page-hero p{margin-top:22px;font-size:16px;max-width:560px}

/* ---------- MARQUEE ---------- */
.marquee-band{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;overflow:hidden;white-space:nowrap}
.marquee-track{display:inline-flex;gap:0}
.marquee-track span{font-family:'Space Mono',monospace;font-size:14px;padding:0 26px;color:var(--dim);display:inline-flex;align-items:center;gap:26px}
.marquee-track span::after{content:'—';color:var(--accent)}

/* ---------- SECTIONS ---------- */
section.block{padding:130px 46px}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:70px;flex-wrap:wrap}
.section-head .btn-outline{flex-shrink:0}

/* pillars / feature grid */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.pillar{background:var(--bg);padding:44px 36px;transition:background .4s}
.pillar:hover{background:var(--bg-2)}
.pillar .num{font-family:'Space Mono',monospace;font-size:12px;color:var(--accent);margin-bottom:26px}
.pillar h3{font-size:22px;margin-bottom:14px;letter-spacing:-.02em}
.pillar p{font-size:14.5px}
.pillar .tags{display:flex;gap:8px;margin-top:22px;flex-wrap:wrap}
.pillar .tags span{font-size:11px;font-family:'Space Mono',monospace;color:var(--dim-2);border:1px solid var(--line);padding:5px 10px;border-radius:100px}

/* stats */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stat{padding:50px 30px;text-align:left;background:var(--bg)}
.stat .n{font-size:clamp(32px,4vw,58px);font-weight:800;font-family:'Space Mono',monospace;color:var(--accent)}
.stat .l{font-size:13px;color:var(--dim);margin-top:10px}

/* work cards */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.work-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/5;background:var(--bg-2)}
.work-card img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .8s cubic-bezier(.16,1,.3,1);filter:grayscale(.4) brightness(.75)}
.work-card:hover img{transform:scale(1.06);filter:grayscale(0) brightness(.85)}
.work-card .overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:26px;background:linear-gradient(0deg,rgba(0,0,0,.75),transparent 60%)}
.work-card .tag{font-size:11px;font-family:'Space Mono',monospace;color:var(--accent);margin-bottom:8px}
.work-card h3{font-size:19px;color:#fff}
.work-card .yr{position:absolute;top:20px;right:20px;font-size:11px;font-family:'Space Mono',monospace;color:rgba(255,255,255,.7)}

/* method / process */
.method-track{display:flex;gap:1px;background:var(--line);border:1px solid var(--line);overflow-x:auto}
.method-step{flex:1 0 260px;background:var(--bg);padding:40px 30px;min-height:280px;display:flex;flex-direction:column;justify-content:space-between}
.method-step .num{font-family:'Space Mono',monospace;font-size:34px;color:var(--accent-dim);font-weight:800}
.method-step h3{font-size:19px;margin:20px 0 12px}
.method-step p{font-size:14px}

/* testimonial */
.testi{max-width:900px}
.testi blockquote{font-size:clamp(22px,3vw,38px);letter-spacing:-.02em;line-height:1.35;font-weight:600}
.testi .who{margin-top:32px;display:flex;align-items:center;gap:14px}
.testi .who .av{width:44px;height:44px;border-radius:50%;background:var(--accent);flex-shrink:0}
.testi .who .name{font-size:14px;font-weight:700}
.testi .who .role{font-size:13px;color:var(--dim)}

/* CTA band */
.cta-band{padding:120px 46px;text-align:center;border-top:1px solid var(--line)}
.cta-band h2{max-width:100%;font-size:clamp(30px,5.4vw,72px);margin:0 auto 40px}
.cta-band .btn{padding:18px 34px;font-size:15px}

/* ---------- PRESTATIONS / offers ---------- */
.offers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.offer{background:var(--bg);padding:44px 34px;display:flex;flex-direction:column}
.offer.featured{background:var(--bg-2)}
.offer .tag{font-size:11px;font-family:'Space Mono',monospace;color:var(--accent);text-transform:uppercase;letter-spacing:.1em}
.offer h3{font-size:26px;margin:18px 0 14px}
.offer .desc{font-size:14px;margin-bottom:26px}
.offer .feats{margin:10px 0 30px;flex-grow:1}
.offer .feats li{font-size:13.5px;color:var(--dim);padding:10px 0;border-top:1px solid var(--line);display:flex;gap:10px;align-items:flex-start}
.offer .feats li svg{width:13px;height:13px;flex-shrink:0;margin-top:3px;color:var(--accent)}
.offer .price{font-size:13px;color:var(--dim-2);margin-bottom:20px;font-family:'Space Mono',monospace}

/* services detail */
.service-row{display:grid;grid-template-columns:70px 1fr 1fr;gap:40px;padding:54px 0;border-top:1px solid var(--line);align-items:start}
.service-row:last-child{border-bottom:1px solid var(--line)}
.service-row .idx{font-family:'Space Mono',monospace;color:var(--accent);font-size:14px}
.service-row h3{font-size:24px;margin-bottom:14px}
.service-row .points{margin-top:18px}
.service-row .points li{font-size:13.5px;color:var(--dim);padding:8px 0;display:flex;gap:10px}
.service-row .points li::before{content:'—';color:var(--accent)}

/* blog */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.blog-card img{aspect-ratio:16/10;object-fit:cover;border-radius:var(--radius);filter:grayscale(.35);transition:filter .4s}
.blog-card:hover img{filter:grayscale(0)}
.blog-card .meta{display:flex;gap:14px;font-size:12px;color:var(--dim-2);margin:20px 0 10px;font-family:'Space Mono',monospace}
.blog-card h3{font-size:19px;margin-bottom:10px}
.blog-card p{font-size:13.5px}
.blog-card .read{margin-top:16px;font-size:13px;color:var(--accent);font-weight:700}

/* contact */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:80px}
.contact-form .row{margin-bottom:26px}
.contact-form label{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--dim);margin-bottom:10px;font-family:'Space Mono',monospace}
.contact-form input,.contact-form textarea{
  width:100%;background:transparent;border:none;border-bottom:1px solid var(--line);
  padding:12px 0;color:var(--ink);font-size:16px;font-family:'Manrope',sans-serif;
  transition:border-color .3s;
}
.contact-form input:focus-visible,.contact-form textarea:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-color:var(--accent)}
.contact-form textarea{resize:vertical;min-height:100px}
.info-card{border:1px solid var(--line);padding:36px;border-radius:var(--radius)}
.info-card .row2{padding:20px 0;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:20px;font-size:14px}
.info-card .row2:first-child{border-top:none;padding-top:0}
.info-card .row2 span:first-child{color:var(--dim)}
.big-email{font-size:clamp(24px,3.4vw,40px);font-weight:700;letter-spacing:-.02em;border-bottom:1px solid var(--ink);display:inline-block;padding-bottom:6px;margin-top:14px}
.faq-item{border-top:1px solid var(--line);padding:26px 0}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-q{display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-size:16px;font-weight:600;min-height:24px}
.faq-q:focus-visible{outline:2px solid var(--accent);outline-offset:4px}
.faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .4s ease}
.faq-a p{overflow:hidden;padding-top:0;max-width:600px;min-height:0}
.faq-item.open .faq-a{grid-template-rows:1fr}
.faq-item.open .faq-a p{padding-top:14px}
.faq-item .plus{transition:transform .3s}
.faq-item.open .plus{transform:rotate(45deg)}

/* ---------- FOOTER ---------- */
footer.site-footer{background:#08090A;border-top:1px solid var(--line);padding:100px 46px 30px}
.footer-cta{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap;padding-bottom:80px;border-bottom:1px solid var(--line);margin-bottom:50px}
.footer-cta h2{font-size:clamp(28px,4.6vw,56px)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr 1fr;gap:32px}
.footer-col .ftitle{font-size:12px;color:var(--dim-2);text-transform:uppercase;letter-spacing:.12em;margin-bottom:22px;font-family:'Space Mono',monospace}
.footer-col a,.footer-col p{display:block;font-size:14px;color:var(--dim);margin-bottom:12px}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;margin-top:80px;padding-top:26px;border-top:1px solid var(--line);font-size:12.5px;color:var(--dim-2);flex-wrap:wrap;gap:12px}

/* reveal helper */
.reveal{opacity:0;transform:translateY(24px)}

/* ---------- ACCESSIBILITY ---------- */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;top:-100px;left:12px;z-index:1000;background:var(--accent);color:#0A0A0B;padding:12px 20px;border-radius:4px;font-weight:700;font-size:14px;transition:top .2s}
.skip-link:focus{top:12px}
a:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.footer-bottom a{color:var(--dim-2)}
.footer-bottom a:hover{color:var(--accent)}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* pillar as link */
a.pillar{display:block;text-decoration:none;color:inherit;position:relative;border:1px solid transparent}
a.pillar:hover{border-color:var(--accent)}
a.pillar .go{position:absolute;top:38px;right:32px;width:34px;height:34px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .35s}
a.pillar .go svg{width:15px;height:15px;stroke:var(--dim);transition:stroke .35s}
a.pillar:hover .go{background:var(--accent);border-color:var(--accent);transform:rotate(-45deg)}
a.pillar:hover .go svg{stroke:#0A0A0B}

/* method v2 — connected numbered cards */
.method-wrap{position:relative}
.method-progress{position:absolute;top:0;left:0;right:0;height:2px;background:var(--line)}
.method-progress .fill{display:block;height:100%;width:100%;background:var(--accent);transform:scaleX(0);transform-origin:left}
.method-track{display:flex;gap:1px;background:var(--line);border:1px solid var(--line);border-top:none;overflow-x:auto}
.method-step .dur{font-family:'Space Mono',monospace;font-size:11px;color:var(--dim-2);border:1px solid var(--line);border-radius:100px;padding:5px 12px;align-self:flex-start;margin-top:22px}
.method-step .num{transition:color .4s}
.method-step:hover .num{color:var(--accent)}

/* studio / coulisses band */
.studio{padding:110px 0;overflow:hidden;border-top:1px solid var(--line)}
.studio .head{max-width:1200px;margin:0 auto 54px;padding:0 40px}
.studio-track{display:flex;gap:22px;padding-left:max(40px,calc((100vw - 1200px)/2));will-change:transform}
.studio-item{flex:0 0 460px}
.studio-item .frame{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:var(--bg-2);aspect-ratio:16/10}
.studio-item img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .8s cubic-bezier(.16,1,.3,1)}
.studio-item:hover img{transform:scale(1.04)}
.studio-item .cap{display:flex;justify-content:space-between;align-items:baseline;margin-top:14px;font-family:'Space Mono',monospace;font-size:12px}
.studio-item .cap .p{color:var(--ink)}
.studio-item .cap .t{color:var(--dim-2);font-size:11px}
.studio-item .cap .t::before{content:'● ';color:var(--accent);font-size:8px;vertical-align:2px}
@media(max-width:760px){.studio-item{flex-basis:78vw}.studio .head{padding:0 22px}.studio-track{padding-left:22px}}

/* cursor */
#cursor,#cursorRing{position:fixed;top:0;left:0;pointer-events:none;z-index:999;border-radius:50%;transform:translate(-50%,-50%)}
#cursor{width:6px;height:6px;background:var(--accent)}
#cursorRing{width:34px;height:34px;border:1px solid var(--accent);opacity:.5;transition:width .25s,height .25s}
body.has-cursor{cursor:none}
body.has-cursor a,body.has-cursor button{cursor:none}

@media(max-width:1024px){
  .wrap{padding:0 26px}
  .grid-3,.offers-grid,.work-grid,.blog-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr;gap:50px}
  .service-row{grid-template-columns:1fr;gap:16px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  #cursor,#cursorRing{display:none}
  body.has-cursor{cursor:auto}
}
/* ---------- Hero centré (articles + services) ---------- */
body[data-toc] .page-hero{text-align:center}
body[data-toc] .page-hero h1{margin-left:auto;margin-right:auto}
body[data-toc] .page-hero p{margin-left:auto;margin-right:auto}
body[data-toc] .page-hero .article-meta{justify-content:center}

/* ---------- Barre de progression de lecture ---------- */
#readbar{position:fixed;top:0;left:0;right:0;height:2px;z-index:220;background:var(--accent);transform:scaleX(0);transform-origin:left;pointer-events:none}

/* ---------- Header : masqué à la descente, révélé à la remontée ---------- */
header.site-nav{transition:background .4s,padding .4s,border-color .4s,transform .45s cubic-bezier(.16,1,.3,1)}
header.site-nav.hidden{transform:translateY(-110%)}

/* ---------- Footer : wordmark géant + micro-interactions ---------- */
.footer-word{overflow:hidden;margin-top:70px;pointer-events:none;user-select:none}
.footer-word span{display:block;font-weight:800;letter-spacing:-.04em;line-height:.82;font-size:clamp(64px,13.5vw,208px);text-align:center;color:transparent;-webkit-text-stroke:1px rgba(246,246,243,.22)}
.footer-word span em{font-style:normal;-webkit-text-stroke:1px var(--accent);color:transparent}
.footer-col a{position:relative;transition:color .25s,transform .3s cubic-bezier(.16,1,.3,1)}
.footer-col a:hover{transform:translateX(8px)}
.footer-col a::before{content:'—';position:absolute;left:-20px;color:var(--accent);opacity:0;transition:opacity .25s}
.footer-col a:hover::before{opacity:1}

/* ---------- Article figures ---------- */
.article figure{margin:34px 0}
.article figure img{width:100%;height:auto;border-radius:6px;border:1px solid var(--line)}
.article figcaption{font-family:'Space Mono',monospace;font-size:12px;color:var(--dim-2);margin-top:12px}

/* ---------- Sticky CTA « Réserver un appel » ---------- */
.sticky-cta{position:fixed;z-index:190;opacity:0;pointer-events:none;transform:translateY(16px);transition:opacity .4s,transform .5s cubic-bezier(.16,1,.3,1)}
.sticky-cta.visible{opacity:1;pointer-events:auto;transform:translateY(0)}
.sticky-cta a{display:inline-flex;align-items:center;gap:10px;font-weight:700;text-decoration:none}
.sticky-cta svg{width:16px;height:16px;flex-shrink:0}
@media(min-width:769px){
  .sticky-cta{bottom:24px;right:24px}
  .sticky-cta .cta-tel{display:none}
  .sticky-cta .cta-call{background:var(--accent);color:#0A0A0B;padding:15px 26px;border-radius:100px;font-size:13.5px;box-shadow:0 10px 34px rgba(198,255,61,.28);transition:transform .3s cubic-bezier(.16,1,.3,1)}
  .sticky-cta .cta-call:hover{transform:translateY(-2px)}
}
@media(max-width:768px){
  .sticky-cta{left:0;right:0;bottom:0;display:flex;transform:translateY(102%);background:rgba(10,10,11,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid var(--line);padding:10px 14px calc(10px + env(safe-area-inset-bottom))}
  .sticky-cta.visible{transform:translateY(0)}
  .sticky-cta .cta-tel{width:48px;height:48px;border:1px solid var(--line);border-radius:100px;display:inline-flex;align-items:center;justify-content:center;margin-right:10px;color:var(--accent)}
  .sticky-cta .cta-call{flex:1;justify-content:center;background:var(--accent);color:#0A0A0B;padding:14px 20px;border-radius:100px;font-size:14px}
  footer.site-footer{padding-bottom:110px}
}
@media print{.sticky-cta{display:none}}

/* ---------- Sommaire flottant (desktop) ---------- */
.toc{position:fixed;right:28px;top:50%;transform:translateY(-50%);z-index:150;width:230px;transition:opacity .35s}
.toc.dimmed{opacity:.14}
.toc:hover,.toc:focus-within{opacity:1}
.toc.gone{opacity:0;visibility:hidden;pointer-events:none}
.toc.gone:hover{opacity:0}
.toc .toc-title{font-family:'Space Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--dim-2);margin-bottom:12px}
.toc ol{list-style:none;margin:0;padding:0}
.toc a{display:block;font-size:12.5px;color:var(--dim-2);padding:5px 0 5px 14px;border-left:1px solid var(--line);line-height:1.45;text-decoration:none;transition:color .25s,border-color .25s}
.toc a:hover{color:var(--ink)}
.toc a.active{color:var(--accent);border-left-color:var(--accent)}
@media(max-width:1279px){.toc{display:none}}
@media print{.toc{display:none}}

/* ---------- Quiz interactif ---------- */
.quiz{border:1px solid var(--line);border-radius:6px;background:var(--bg-2);padding:30px;margin:40px 0}
.quiz-kicker{font-family:'Space Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);margin-bottom:16px;font-weight:700}
.quiz-progress{display:flex;gap:6px;margin-bottom:22px}
.quiz-progress span{height:3px;flex:1;background:var(--line);border-radius:2px;transition:background .3s}
.quiz-progress span.done{background:var(--accent)}
.quiz-q{font-size:17px;font-weight:700;margin-bottom:18px;color:var(--ink);letter-spacing:-.01em}
.quiz-opts{display:grid;gap:10px}
.quiz-opt{text-align:left;border:1px solid var(--line);border-radius:4px;padding:14px 18px;font-size:14.5px;color:var(--dim);background:var(--bg);transition:border-color .25s,color .25s;width:100%}
.quiz-opt:hover,.quiz-opt:focus-visible{border-color:var(--accent);color:var(--ink)}
.quiz-result .quiz-verdict{font-size:21px;font-weight:700;color:var(--accent);margin-bottom:12px;letter-spacing:-.02em}
.quiz-result p{font-size:15px;margin-bottom:20px}
.quiz-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.quiz-restart{font-family:'Space Mono',monospace;font-size:12px;color:var(--dim-2);text-decoration:underline;text-underline-offset:3px}
.quiz-restart:hover{color:var(--ink)}
.quiz-fallback{margin:0}

/* ---------- Bande stats services ---------- */
.service-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin:40px 0}
.service-stats .stat{padding:30px 24px}
.service-stats .stat .n{font-size:clamp(26px,3vw,40px)}
@media(max-width:760px){.service-stats{grid-template-columns:1fr}}

@media(max-width:760px){
  header.site-nav{padding:18px 20px}
  .nav-links{position:fixed;top:0;right:0;height:100vh;width:78%;background:var(--bg);flex-direction:column;justify-content:center;align-items:flex-start;padding:0 36px;gap:26px;transform:translateX(100%);transition:transform .5s cubic-bezier(.16,1,.3,1);border-left:1px solid var(--line)}
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:20px;padding:14px 0;display:block}
  .nav-cta .btn-outline{display:none}
  .burger{display:flex;z-index:210}
  .hero,.page-hero{padding-left:22px;padding-right:22px}
  section.block{padding:80px 22px}
  .footer-grid{grid-template-columns:1fr}
  footer.site-footer{padding:70px 22px 26px}
  .wrap{padding:0 22px}
}
