/* ============================================================
   Falcoverage — Site vitrine · Design system
   Palette : violet #7C3AED / profond #6D28D9 / clair #A78BFA /
   reverse #C4B5FD / encre #211C35 · Typo : Poppins
   ============================================================ */

:root{
  --ink:#211C35;
  --ink-soft:#2b2542;
  --violet:#7C3AED;
  --violet-deep:#6D28D9;
  --violet-light:#A78BFA;
  --violet-soft:#C4B5FD;
  --bg:#FAFAF7;
  --surface:#ffffff;
  --line:#ece9f3;
  --text:#1d1a29;
  --muted:#6b6780;
  --muted-2:#9a96ab;
  --radius:18px;
  --radius-sm:12px;
  --shadow-sm:0 1px 3px rgba(33,28,53,.06),0 6px 16px rgba(33,28,53,.05);
  --shadow:0 10px 40px rgba(33,28,53,.10);
  --shadow-violet:0 18px 50px rgba(124,58,237,.30);
  --maxw:1180px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Poppins',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- Typography ---------- */
h1,h2,h3{font-weight:700;letter-spacing:-.02em;line-height:1.1;color:var(--ink)}
.display{font-size:clamp(2.4rem,5.4vw,4.3rem);font-weight:700;letter-spacing:-.035em;line-height:1.04}
.h2{font-size:clamp(1.8rem,3.6vw,2.8rem)}
.lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--muted);font-weight:400}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.74rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--violet-deep)}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--violet);border-radius:2px}
.grad{background:linear-gradient(100deg,var(--violet-light),var(--violet) 55%,var(--violet-deep));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.95rem;
  padding:13px 22px;border-radius:999px;border:1px solid transparent;cursor:pointer;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--violet);color:#fff;box-shadow:var(--shadow-violet)}
.btn-primary:hover{background:var(--violet-deep)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--violet-light);color:var(--violet-deep)}
.btn-light{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.22)}
.btn-light:hover{background:rgba(255,255,255,.18)}
.btn-arrow{font-weight:600;color:var(--violet-deep);display:inline-flex;align-items:center;gap:6px}
.btn-arrow span{transition:transform .25s var(--ease)}
.btn-arrow:hover span{transform:translateX(4px)}

/* ============================================================
   Bandeau d'annonce (campagne Stocky) — injecté par main.js
   ============================================================ */
.announce{background:linear-gradient(100deg,var(--violet-deep),var(--violet));color:#fff;font-size:.86rem;position:relative;z-index:201}
.announce .container{display:flex;align-items:center;justify-content:center;gap:14px;min-height:42px;padding-top:7px;padding-bottom:7px;text-align:center}
.announce-msg{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center;color:#fff}
.announce-msg b{font-weight:700}
.announce-cta{font-weight:600;color:var(--violet-soft);text-decoration:underline;text-underline-offset:3px;white-space:nowrap}
.announce-msg:hover .announce-cta{color:#fff}
.announce-x{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:none;border:0;color:rgba(255,255,255,.7);
  font-size:1.4rem;line-height:1;cursor:pointer;padding:4px 8px;border-radius:8px;transition:color .2s,background .2s}
.announce-x:hover{color:#fff;background:rgba(255,255,255,.12)}
@media(max-width:600px){
  .announce{font-size:.78rem}
  .announce .container{padding-right:44px}
  .announce-cta{width:100%}
}

/* ============================================================
   Header / Méga-menu  (injecté par main.js)
   ============================================================ */
.site-header{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.72);
  backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s,box-shadow .3s}
.site-header.scrolled{border-color:var(--line);background:rgba(255,255,255,.92);
  box-shadow:0 1px 0 rgba(33,28,53,.04),0 10px 30px -18px rgba(33,28,53,.25)}
.nav{display:flex;align-items:center;gap:18px;height:78px}
.brand{display:flex;align-items:center;gap:11px;font-weight:700;font-size:1.26rem;letter-spacing:-.02em;color:var(--ink);flex-shrink:0}
.brand .mark{width:38px;height:38px;border-radius:12px;background:linear-gradient(150deg,var(--violet),var(--violet-deep));
  display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(124,58,237,.38);flex-shrink:0}
.brand b{color:var(--violet-deep);font-weight:700}

/* barre de liens */
.nav-links{display:flex;align-items:center;gap:2px;margin:0 auto;list-style:none}
.nav-item{position:relative}
.nav-link{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;border-radius:11px;
  font-family:inherit;font-weight:500;font-size:.95rem;color:var(--ink);background:none;border:0;cursor:pointer;
  transition:background .2s,color .2s}
.nav-link:hover,.nav-item:hover .nav-link,.nav-link[aria-current]{background:rgba(124,58,237,.07);color:var(--violet-deep)}
.nav-link .caret{opacity:.55;transition:transform .25s var(--ease)}
.nav-item:hover .caret,.nav-item.open .caret{transform:rotate(180deg);opacity:1}
.nav-demo{font-weight:600;color:var(--violet-deep)}
.nav-demo::before{content:"";width:7px;height:7px;border-radius:50%;background:#22c55e;
  box-shadow:0 0 0 3px rgba(34,197,94,.18);animation:demoPulse 2s infinite}
@keyframes demoPulse{0%,100%{opacity:1}50%{opacity:.35}}
.nav-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}

/* panneau méga-menu */
.mega{position:absolute;top:calc(100% + 14px);left:50%;width:720px;
  transform:translateX(-50%) translateY(10px);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .24s var(--ease),transform .24s var(--ease);z-index:210}
.mega--sm{width:380px}
.nav-item:hover .mega,.nav-item:focus-within .mega,.nav-item.open .mega{
  opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
/* pont invisible pour ne pas perdre le survol */
.mega::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.mega-inner{display:grid;grid-template-columns:1fr 270px;gap:10px;
  background:var(--surface);border:1px solid var(--line);border-radius:20px;
  box-shadow:0 24px 60px -24px rgba(33,28,53,.32),0 6px 18px -10px rgba(33,28,53,.18);
  padding:16px}
.mega--sm .mega-inner{grid-template-columns:1fr}
.mega-cols{padding:6px}
.mega-label{display:block;font-size:.68rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;
  color:var(--muted-2);padding:4px 10px 12px}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.mega-grid--one{grid-template-columns:1fr}
.mega-item{display:flex;gap:12px;align-items:center;padding:11px 12px;border-radius:13px;transition:background .18s}
.mega-item:hover{background:#f6f3fe}
.mega-ic{width:38px;height:38px;border-radius:11px;flex-shrink:0;font-size:18px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(140deg,#f3edff,#e7dbff);box-shadow:inset 0 0 0 1px rgba(124,58,237,.08)}
.mega-txt{display:flex;flex-direction:column;gap:1px;min-width:0}
.mega-txt b{font-size:.92rem;font-weight:600;color:var(--ink);letter-spacing:-.01em}
.mega-txt small{font-size:.78rem;color:var(--muted);line-height:1.3}
.mega-foot{display:inline-flex;align-items:center;gap:7px;margin:8px 0 2px;padding:8px 10px;border-radius:10px;
  font-size:.84rem;font-weight:600;color:var(--violet-deep);transition:gap .2s,background .2s}
.mega-foot:hover{gap:11px;background:rgba(124,58,237,.06)}
.mega-foot .caret{transform:rotate(-90deg)}

/* carte mise en avant (emplacement image) */
.mega-feature{position:relative;display:flex;flex-direction:column;overflow:hidden;border-radius:16px;
  background:var(--ink);color:#fff;text-decoration:none;isolation:isolate}
.mega-feature-media{position:relative;display:block;aspect-ratio:16/10;overflow:hidden}
.mega-feature-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.mega-feature:hover .mega-feature-media img{transform:scale(1.05)}
.mega-feature-live{position:absolute;top:10px;left:10px;display:inline-flex;align-items:center;gap:6px;
  background:rgba(17,14,30,.55);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.18);
  padding:4px 10px;border-radius:999px;font-size:.68rem;font-weight:600;color:#fff}
.mega-feature-live i{width:6px;height:6px;border-radius:50%;background:#34d399;box-shadow:0 0 0 3px rgba(52,211,153,.25)}
.mega-feature-body{display:flex;flex-direction:column;gap:6px;padding:16px}
.mega-feature-tag{font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--violet-soft)}
.mega-feature-body strong{font-size:.98rem;font-weight:600;line-height:1.3;letter-spacing:-.01em}
.mega-cta{display:inline-flex;align-items:center;gap:6px;margin-top:2px;font-size:.85rem;font-weight:600;color:var(--violet-soft);transition:gap .2s}
.mega-cta .caret{transform:rotate(-90deg)}
.mega-feature:hover .mega-cta{gap:10px}

/* Burger + tiroir mobile */
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;
  background:none;border:0;cursor:pointer;padding:0}
.burger span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease),opacity .2s;margin:0 auto}
.burger.is-active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.is-active span:nth-child(2){opacity:0}
.burger.is-active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none}
.mobile-menu[hidden]{display:none}
/* repli sans JS : neutralise les anciens panneaux inline avant injection */
.dropdown{display:none}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden;padding:clamp(70px,11vw,130px) 0 clamp(80px,12vw,140px)}
.hero::before{content:"";position:absolute;inset:0;
  background:radial-gradient(900px 500px at 72% -10%,rgba(124,58,237,.55),transparent 60%),
             radial-gradient(700px 500px at 10% 110%,rgba(109,40,217,.35),transparent 55%)}
.hero::after{content:"";position:absolute;inset:0;opacity:.4;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:54px 54px;mask-image:radial-gradient(70% 60% at 50% 30%,#000,transparent)}
.hero .container{position:relative;z-index:2;text-align:center;max-width:900px}
.hero h1{color:#fff}
.hero .lead{color:rgba(255,255,255,.72);max-width:680px;margin:22px auto 34px}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero-pill{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
  padding:7px 16px;border-radius:999px;font-size:.82rem;color:rgba(255,255,255,.85);margin-bottom:26px}
.hero-pill .dot{width:7px;height:7px;border-radius:50%;background:#34d399;box-shadow:0 0 0 4px rgba(52,211,153,.2)}
.hero-note{margin-top:20px;font-size:.82rem;color:rgba(255,255,255,.5)}

/* Hero stat band */
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:64px;position:relative;z-index:2}
.hero-stat{text-align:center}
.hero-stat .num{font-size:clamp(1.6rem,3vw,2.3rem);font-weight:700;color:#fff;letter-spacing:-.03em}
.hero-stat .lbl{font-size:.78rem;color:rgba(255,255,255,.55);margin-top:2px}

/* ---------- Sections ---------- */
section{padding:clamp(64px,9vw,110px) 0}
.section-head{max-width:680px;margin:0 0 50px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head .lead{margin-top:16px}
.bg-ink{background:var(--ink);color:#fff}
.bg-ink h1,.bg-ink h2,.bg-ink h3{color:#fff}
.bg-soft{background:#f4f1fb}

/* ---------- Cards / feature grid ---------- */
.grid{display:grid;gap:22px}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:#e0d8f5}
.card .ic{width:48px;height:48px;border-radius:13px;background:linear-gradient(135deg,#f1ebff,#e2d4ff);
  display:flex;align-items:center;justify-content:center;font-size:23px;margin-bottom:18px}
.card h3{font-size:1.18rem;margin-bottom:9px}
.card p{color:var(--muted);font-size:.95rem}
.card .tag{display:inline-block;margin-top:14px;font-size:.72rem;font-weight:600;color:var(--violet-deep);
  background:rgba(124,58,237,.08);padding:4px 10px;border-radius:999px}

/* Feature detail rows */
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:clamp(40px,6vw,72px) 0;border-top:1px solid var(--line)}
.feature-row:first-of-type{border-top:none}
.feature-row.flip .feat-visual{order:-1}
.feature-row h3{font-size:clamp(1.5rem,2.6vw,2rem);margin:14px 0 16px}
.feature-row ul{list-style:none;margin-top:20px;display:grid;gap:11px}
.feature-row li{display:flex;gap:11px;align-items:flex-start;color:var(--text);font-size:.97rem}
.feature-row li .chk{width:21px;height:21px;border-radius:7px;background:rgba(124,58,237,.12);color:var(--violet-deep);
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;margin-top:2px}
.feat-visual{background:var(--ink);border-radius:24px;padding:30px;box-shadow:var(--shadow);position:relative;overflow:hidden;min-height:300px}
.feat-visual::before{content:"";position:absolute;inset:0;background:radial-gradient(500px 300px at 80% 0,rgba(124,58,237,.5),transparent 60%)}

/* Mock UI elements for visuals */
.mock{position:relative;z-index:2;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:16px;backdrop-filter:blur(4px)}
.mock+.mock{margin-top:12px}
.mock-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.07);font-size:.82rem;color:rgba(255,255,255,.8)}
.mock-row:last-child{border-bottom:none}
.mbadge{font-size:.66rem;font-weight:700;padding:3px 9px;border-radius:999px}
.mb-red{background:rgba(248,113,113,.2);color:#fca5a5}
.mb-amber{background:rgba(251,191,36,.18);color:#fcd34d}
.mb-teal{background:rgba(45,212,191,.18);color:#5eead4}
.mb-violet{background:rgba(167,139,250,.22);color:#c4b5fd}
.mono{font-family:'IBM Plex Mono','SF Mono',monospace}

/* ---------- Steps / how it works ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:s}
.step{position:relative;padding-top:14px}
.step .n{width:40px;height:40px;border-radius:11px;background:var(--violet);color:#fff;font-weight:700;
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;box-shadow:var(--shadow-violet)}
.step h4{font-size:1.05rem;margin-bottom:7px}
.step p{color:var(--muted);font-size:.9rem}

/* ---------- Pricing ---------- */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.price-card{background:var(--surface);border:1px solid var(--line);border-radius:22px;padding:34px 30px;display:flex;flex-direction:column;transition:transform .3s var(--ease),box-shadow .3s}
.price-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.price-card.featured{background:var(--ink);color:#fff;border-color:var(--ink);box-shadow:var(--shadow-violet);position:relative}
.price-card.featured h3{color:#fff}
.price-card.featured .price-sub,.price-card.featured .price-feat li{color:rgba(255,255,255,.78)}
.price-flag{position:absolute;top:18px;right:18px;background:var(--violet);color:#fff;font-size:.68rem;font-weight:700;padding:5px 12px;border-radius:999px;letter-spacing:.04em}
.price-card h3{font-size:1.3rem}
.price-sub{color:var(--muted);font-size:.88rem;margin:6px 0 20px;min-height:40px}
.price-amount{font-size:2.6rem;font-weight:700;letter-spacing:-.03em;color:inherit}
.price-amount small{font-size:.95rem;font-weight:500;color:var(--muted-2)}
.price-card.featured .price-amount small{color:rgba(255,255,255,.6)}
.price-feat{list-style:none;margin:24px 0;display:grid;gap:12px;flex:1}
.price-feat li{display:flex;gap:10px;align-items:flex-start;font-size:.92rem;color:var(--text)}
.price-feat .chk{color:var(--violet);font-weight:700;flex-shrink:0}
.price-card.featured .price-feat .chk{color:var(--violet-soft)}
/* prix fondateur + ancrage cible barré */
.price-was{font-size:1.15rem;font-weight:600;color:var(--muted-2);text-decoration:line-through;text-decoration-thickness:2px;margin-right:11px;letter-spacing:-.01em}
.price-card.featured .price-was{color:rgba(255,255,255,.5)}
.price-note{font-size:.82rem;color:var(--muted-2);margin:8px 0 0}
.price-card.featured .price-note{color:rgba(255,255,255,.62)}
.price-onboard{display:flex;gap:9px;align-items:flex-start;font-size:.82rem;line-height:1.4;color:var(--muted);
  background:rgba(124,58,237,.06);border:1px solid var(--line);border-radius:12px;padding:11px 13px;margin:20px 0 2px}
.price-card.featured .price-onboard{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.14);color:rgba(255,255,255,.82)}
.price-onboard b{color:var(--violet-deep);font-weight:700}
.price-card.featured .price-onboard b{color:var(--violet-soft)}
/* bandeau « tarif fondateur » */
.founding-banner{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px 18px;
  background:linear-gradient(120deg,var(--violet-deep),var(--violet));color:#fff;border-radius:18px;
  padding:16px 24px;margin-bottom:30px;text-align:center;font-size:.93rem;box-shadow:var(--shadow-violet)}
.founding-banner .fb-tag{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.28);
  padding:5px 13px;border-radius:999px;font-size:.76rem;font-weight:700;letter-spacing:.03em;white-space:nowrap}
.founding-banner b{font-weight:700}
/* bloc ROI */
.roi{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;
  background:var(--ink);color:#fff;border-radius:26px;padding:clamp(30px,5vw,54px);position:relative;overflow:hidden}
.roi::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 400px at 88% 0,rgba(124,58,237,.5),transparent 60%)}
.roi>*{position:relative;z-index:2}
.roi h2{color:#fff}
.roi .lead{color:rgba(255,255,255,.74);margin-top:14px}
.roi-calc{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);border-radius:18px;padding:24px 26px;display:grid;gap:12px}
.roi-line{display:flex;align-items:baseline;justify-content:space-between;gap:14px;font-size:.95rem;color:rgba(255,255,255,.8);padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.08)}
.roi-line:last-child{border-bottom:none;padding-bottom:0}
.roi-line .v{font-family:'IBM Plex Mono',monospace;font-weight:500;white-space:nowrap}
.roi-line.win{color:#fff;font-size:1.05rem;font-weight:600}
.roi-line.win .v{color:#5eead4;font-weight:700}

/* ---------- Resource cards ---------- */
.res-feature{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;background:var(--ink);color:#fff;border-radius:26px;padding:clamp(30px,5vw,56px);overflow:hidden;position:relative}
.res-feature::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 400px at 90% 10%,rgba(124,58,237,.5),transparent 60%)}
.res-feature>*{position:relative;z-index:2}
.res-feature h2{color:#fff}
.res-list{list-style:none;display:grid;gap:10px;margin:22px 0}
.res-list li{display:flex;gap:10px;align-items:center;color:rgba(255,255,255,.82);font-size:.95rem}
.res-doc-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);border-radius:18px;padding:26px}
.res-doc-card .toc{list-style:none;display:grid;gap:9px;margin-top:16px}
.res-doc-card .toc li{display:flex;align-items:center;gap:9px;font-size:.88rem;color:rgba(255,255,255,.78)}
.coming{position:relative}
.coming .card{opacity:.96}
.coming-flag{position:absolute;top:16px;right:16px;font-size:.66rem;font-weight:700;color:var(--muted);background:var(--bg);border:1px solid var(--line);padding:4px 10px;border-radius:999px}

/* ---------- Sector tabs ---------- */
.tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:44px}
.tab{padding:11px 22px;border-radius:999px;border:1px solid var(--line);background:var(--surface);font-weight:600;font-size:.92rem;cursor:pointer;transition:.2s;color:var(--muted)}
.tab.active{background:var(--violet);color:#fff;border-color:var(--violet);box-shadow:var(--shadow-violet)}
.tab-panel{display:none}
.tab-panel.active{display:block;animation:fade .4s var(--ease)}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(120deg,var(--violet-deep),var(--violet));border-radius:28px;color:#fff;
  padding:clamp(40px,6vw,68px);text-align:center;position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;inset:0;opacity:.5;
  background:radial-gradient(500px 300px at 15% 120%,rgba(255,255,255,.25),transparent 55%)}
.cta-band>*{position:relative;z-index:2}
.cta-band h2{color:#fff}
.cta-band .lead{color:rgba(255,255,255,.85);max-width:560px;margin:16px auto 30px}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:rgba(255,255,255,.62);padding:64px 0 30px;font-size:.9rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-grid h5{color:#fff;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px;font-weight:600}
.footer-grid ul{list-style:none;display:grid;gap:10px}
.footer-grid a:hover{color:var(--violet-soft)}
.footer-brand .brand{color:#fff;margin-bottom:14px}
.footer-brand .brand b{color:var(--violet-soft)}
.footer-brand p{max-width:300px;font-size:.9rem}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;font-size:.82rem;color:rgba(255,255,255,.4);flex-wrap:wrap;gap:10px}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ---------- Page hero (interior) ---------- */
.page-hero{background:var(--ink);color:#fff;padding:clamp(70px,9vw,120px) 0 clamp(50px,7vw,80px);position:relative;overflow:hidden;text-align:center}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(800px 400px at 50% -20%,rgba(124,58,237,.45),transparent 60%)}
.page-hero .container{position:relative;z-index:2;max-width:760px}
.page-hero h1{color:#fff;font-size:clamp(2.1rem,4.4vw,3.4rem)}
.page-hero .lead{color:rgba(255,255,255,.72);margin:18px auto 0}

/* ============================================================
   Emplacements image · cadres produit · galerie
   ============================================================ */
/* Cadre « capture produit » réutilisable (figure.shot) */
.shot{position:relative;border-radius:20px;overflow:hidden;background:#15111f;
  border:1px solid rgba(255,255,255,.08);box-shadow:0 40px 80px -40px rgba(33,28,53,.55)}
.shot img{width:100%;height:100%;object-fit:cover;display:block}
.shot figcaption{font-size:0;position:absolute}
/* barre fenêtre (chrome) optionnelle */
.shot.framed{padding-top:38px;background:#15111f}
.shot.framed::before{content:"";position:absolute;top:0;left:0;right:0;height:38px;background:#1d1830;border-bottom:1px solid rgba(255,255,255,.07)}
.shot.framed::after{content:"";position:absolute;top:15px;left:16px;width:9px;height:9px;border-radius:50%;
  background:#ff5f57;box-shadow:16px 0 0 #febc2e,32px 0 0 #28c840}

/* Hero visuel (capture sous le CTA) */
.hero-visual{position:relative;z-index:2;max-width:980px;margin:62px auto 0}
.hero-visual .shot{transform:perspective(1600px) rotateX(4deg);transform-origin:top center}
.hero-visual::after{content:"";position:absolute;left:50%;bottom:-30px;width:70%;height:60px;transform:translateX(-50%);
  background:radial-gradient(50% 100% at 50% 0,rgba(124,58,237,.5),transparent 70%);filter:blur(14px);z-index:-1}

/* Bandeau confiance / logos */
.trust{padding:42px 0 0}
.trust p{text-align:center;font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);margin-bottom:22px}
.trust-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:18px 40px}
.logo-slot{height:30px;min-width:120px;display:flex;align-items:center;justify-content:center;
  color:var(--muted-2);font-weight:700;letter-spacing:.02em;opacity:.65;
  filter:grayscale(1);transition:opacity .25s,filter .25s}
.logo-slot:hover{opacity:1;filter:grayscale(0)}
.logo-slot img{max-height:100%;width:auto}

/* Galerie d'aperçus produit */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.gallery .shot{aspect-ratio:4/3}
.shot-label{position:absolute;left:14px;bottom:14px;z-index:2;display:inline-flex;align-items:center;gap:7px;
  background:rgba(17,14,30,.55);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.16);
  color:#fff;font-size:.74rem;font-weight:600;padding:6px 12px;border-radius:999px}

/* Repère visuel pour un emplacement vide (si l'image manque) */
.img-slot{display:flex;align-items:center;justify-content:center;min-height:140px;
  background:repeating-linear-gradient(135deg,#efeafb,#efeafb 12px,#f6f3fe 12px,#f6f3fe 24px);
  color:var(--violet-deep);font-size:.8rem;font-weight:600;border-radius:14px;border:1px dashed #cdbdf3}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .cols-3,.steps{grid-template-columns:repeat(2,1fr)}
  .pricing{grid-template-columns:1fr;max-width:440px;margin:0 auto}
  .feature-row,.res-feature,.roi{grid-template-columns:1fr;gap:30px}
  .feature-row.flip .feat-visual{order:0}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-stats{grid-template-columns:repeat(2,1fr);gap:30px}
}
@media(max-width:860px){
  .nav-links,.nav-actions .btn-ghost{display:none}
  .burger{display:flex}
  .nav{justify-content:space-between}
}
@media(max-width:560px){
  .nav-actions .btn-primary{display:none}
}
@media(max-width:980px){
  .gallery{grid-template-columns:1fr 1fr}
  .hero-visual{margin-top:46px}
  .hero-visual .shot{transform:none}
}
@media(max-width:760px){
  .cols-3,.cols-2,.steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .trust-row{gap:16px 28px}
}
@media(max-width:860px){
  .mobile-menu.open{display:block;position:fixed;inset:78px 0 0;background:var(--bg);z-index:190;padding:20px 22px 32px;overflow-y:auto;
    animation:fade .3s var(--ease)}
  .mobile-menu .m-group{border-bottom:1px solid var(--line)}
  .mobile-menu summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;
    padding:16px 2px;font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--violet-deep)}
  .mobile-menu summary::-webkit-details-marker{display:none}
  .mobile-menu summary::after{content:"";width:9px;height:9px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;
    transform:rotate(45deg);transition:transform .25s;opacity:.7}
  .mobile-menu details[open] summary::after{transform:rotate(225deg)}
  .mobile-menu .m-group a{display:flex;align-items:center;gap:12px;padding:11px 2px 11px 4px;font-size:1.02rem;font-weight:500;color:var(--ink)}
  .mobile-menu .m-group a span{font-size:18px}
  .mobile-menu .m-group:last-of-type a{padding-bottom:18px}
  .mobile-menu .m-flat{display:flex;flex-direction:column;padding:8px 0}
  .mobile-menu .m-flat a{padding:14px 2px;font-size:1.06rem;font-weight:600;border-bottom:1px solid var(--line)}
  .mobile-menu .m-demo{color:var(--violet-deep)}
  .mobile-menu .m-actions{display:grid;gap:10px;margin-top:22px}
  .mobile-menu .btn{width:100%;justify-content:center;padding:15px}
}
