/* ============================================================
   ELI TECH — « Signal local »
   Encre profonde, ambre sodium (les devantures la nuit),
   lumen périwinkle (le signal tech). Prix & métriques en mono.
   ============================================================ */

:root{
  --encre:#070B1E;          /* fond */
  --encre-2:#0C1233;        /* surfaces élevées (navy de marque) */
  --ivoire:#EEF0FB;         /* texte principal */
  --brume:#A6ADD0;          /* texte secondaire */
  --sodium:#FFB454;         /* accent action — ambre lampadaire */
  --sodium-deep:#E89A33;
  --lumen:#6E8BFF;          /* accent signal — liens, focus, halos */
  --line:rgba(238,240,251,.10);
  --glass:rgba(238,240,251,.045);
  --radius:18px;
  --wrap:1140px;
  --font-display:"Archivo",system-ui,sans-serif;
  --font-body:"Instrument Sans",system-ui,sans-serif;
  --font-mono:"Spline Sans Mono",ui-monospace,monospace;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--encre);color:var(--ivoire);
  font-family:var(--font-body);font-size:1.0625rem;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,video{max-width:100%;height:auto;display:block}
a{color:var(--lumen);text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:3px}
:focus-visible{outline:2px solid var(--sodium);outline-offset:3px;border-radius:4px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip{position:absolute;left:1rem;top:-3rem;background:var(--sodium);color:var(--encre);padding:.5rem 1rem;border-radius:8px;z-index:100;font-weight:600;transition:top .2s}
.skip:focus{top:1rem}
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(1rem,4vw,2rem)}
.mono{font-family:var(--font-mono);font-weight:500;letter-spacing:-.01em}

/* ---------- Typo ---------- */
.h1{font-family:var(--font-display);font-weight:700;font-stretch:95%;
  font-size:clamp(2.1rem,5.2vw,3.6rem);line-height:1.06;letter-spacing:-.025em;margin:.4em 0 .45em}
.h2{font-family:var(--font-display);font-weight:650;font-stretch:96%;
  font-size:clamp(1.6rem,3.4vw,2.4rem);line-height:1.12;letter-spacing:-.02em;margin:.3em 0 .5em}
.h3{font-family:var(--font-display);font-weight:600;font-size:1.25rem;line-height:1.25;margin:.2em 0 .4em}
h3{font-family:var(--font-display);font-weight:600;font-size:1.15rem;margin:.2em 0 .45em}
.h1 em,.h2 em,.h3 em,h1 em{font-style:normal;color:var(--sodium)}
.eyebrow{font-family:var(--font-display);font-stretch:120%;font-weight:600;
  text-transform:uppercase;letter-spacing:.18em;font-size:.74rem;color:var(--lumen);margin:0 0 .6rem}
.lead{font-size:clamp(1.05rem,1.5vw,1.2rem);color:var(--brume);max-width:46em}
.lead a{color:var(--sodium)}
.micro{font-size:.84rem;color:var(--brume);line-height:1.55}
.ticks{color:var(--brume);font-size:.9rem;margin-top:1rem}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(7,11,30,.78);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.header-in{display:flex;align-items:center;gap:1.4rem;min-height:68px}
.brand{display:flex;align-items:center;gap:.6rem;color:var(--ivoire)}
.brand:hover{text-decoration:none}
.brand-name{font-family:var(--font-display);font-stretch:110%;font-weight:700;letter-spacing:.06em;font-size:1.05rem}
.brand-name em{font-style:normal;color:var(--sodium)}
.nav{display:flex;gap:1.3rem;margin-left:auto}
.nav a{color:var(--brume);font-size:.94rem;font-weight:500}
.nav a:hover,.nav a[aria-current]{color:var(--ivoire);text-decoration:none}
.nav a[aria-current]{color:var(--sodium)}
.burger{display:none;margin-left:auto;background:none;border:1px solid var(--line);border-radius:10px;
  width:44px;height:44px;cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:5px}
.burger span{display:block;width:20px;height:2px;background:var(--ivoire);transition:transform .25s,opacity .25s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Boutons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-display);
  font-weight:600;font-size:.97rem;padding:.78rem 1.35rem;border-radius:999px;border:1px solid transparent;
  cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease;white-space:nowrap}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn .arr{transition:transform .18s ease}
.btn:hover .arr{transform:translateX(3px)}
.btn-primary{background:linear-gradient(180deg,var(--sodium),var(--sodium-deep));color:#1A1206;
  box-shadow:0 0 0 1px rgba(255,180,84,.35),0 8px 28px -10px rgba(255,180,84,.45)}
.btn-primary:hover{box-shadow:0 0 0 1px rgba(255,180,84,.55),0 12px 34px -10px rgba(255,180,84,.6)}
.btn-ghost{background:rgba(238,240,251,.04);border-color:var(--line);color:var(--ivoire)}
.btn-ghost:hover{background:rgba(238,240,251,.09)}
.btn-lg{padding:.95rem 1.7rem;font-size:1.05rem}
.btn-sm{padding:.5rem .95rem;font-size:.85rem}
.btn-nav{margin-left:.4rem}
.cta-row{display:flex;flex-wrap:wrap;gap:.9rem;margin:1.4rem 0 .9rem}

/* ---------- Hero & radar (signature) ---------- */
.hero{position:relative;overflow:hidden;padding:clamp(4rem,9vw,7.5rem) 0 clamp(3rem,6vw,5rem);
  background:
    radial-gradient(900px 480px at 78% -10%,rgba(110,139,255,.16),transparent 65%),
    radial-gradient(700px 420px at 12% 110%,rgba(255,180,84,.08),transparent 60%),
    var(--encre)}
.hero-in{position:relative;z-index:2;max-width:820px}
.radar{position:absolute;right:max(-180px,calc(50% - 760px));top:50%;translate:0 -50%;
  width:640px;height:640px;z-index:1;pointer-events:none;opacity:.9}
.radar span{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(110,139,255,.28);
  animation:pulse 5.2s cubic-bezier(.2,.6,.3,1) infinite}
.radar span:nth-child(2){animation-delay:1.7s}
.radar span:nth-child(3){animation-delay:3.4s}
.radar-dot{position:absolute;left:50%;top:50%;translate:-50% -50%;width:10px;height:10px;border-radius:50%;
  background:var(--sodium);box-shadow:0 0 18px 4px rgba(255,180,84,.55),0 0 60px 18px rgba(255,180,84,.18)}
@keyframes pulse{0%{transform:scale(.12);opacity:0}12%{opacity:.85}100%{transform:scale(1);opacity:0}}

.page-hero{padding:clamp(3.5rem,7vw,6rem) 0 clamp(2rem,4vw,3rem);
  background:radial-gradient(800px 420px at 80% -20%,rgba(110,139,255,.14),transparent 65%),var(--encre)}
.page-hero-sm{padding-bottom:1.4rem}
.hero-split{display:grid;grid-template-columns:1.15fr .85fr;gap:2.6rem;align-items:center}

/* ---------- Sections ---------- */
.section{padding:clamp(2.6rem,6vw,4.6rem) 0}
.section-tight{padding-top:1.4rem}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;align-items:start}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;align-items:stretch}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.cols-2{columns:2;column-gap:2.4rem}

/* ---------- Glass ---------- */
.glass{background:var(--glass);border:1px solid var(--line);border-radius:var(--radius);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  box-shadow:0 18px 50px -28px rgba(0,0,0,.55)}
.mini{padding:1.5rem 1.5rem 1.35rem}
.mini p{color:var(--brume);margin:.3rem 0 .8rem}
.glass-accent{border-color:rgba(255,180,84,.35);box-shadow:0 0 0 1px rgba(255,180,84,.12),0 18px 50px -28px rgba(0,0,0,.55)}

/* ---------- Steps ---------- */
.steps{list-style:none;margin:1.6rem 0 0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.2rem;counter-reset:s}
.step{padding:1.5rem}
.step p{color:var(--brume);font-size:.95rem;margin:.4rem 0 0}
.step-n{display:inline-block;color:var(--sodium);font-size:.85rem;border:1px solid rgba(255,180,84,.35);
  border-radius:999px;padding:.15rem .7rem;margin-bottom:.7rem}

/* ---------- Secteurs ---------- */
.sector-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:1.8rem}
.sector-card{display:flex;flex-direction:column;gap:.3rem;padding:1rem;border-radius:var(--radius);
  background:var(--glass);border:1px solid var(--line);color:var(--ivoire);
  transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}
.sector-card:hover{text-decoration:none;transform:translateY(-4px);border-color:rgba(255,180,84,.4);
  box-shadow:0 22px 50px -24px rgba(255,180,84,.25)}
.sector-media{display:block;border-radius:12px;overflow:hidden;aspect-ratio:8/5;margin-bottom:.6rem;background:var(--encre-2)}
.sector-media img{width:100%;height:100%;object-fit:cover}
.sector-tags{font-size:.68rem;color:var(--lumen);text-transform:uppercase;letter-spacing:.12em}
.sector-name{font-family:var(--font-display);font-weight:650;font-size:1.08rem}
.sector-hook{color:var(--brume);font-size:.88rem;line-height:1.45}
.sector-go{margin-top:.55rem;color:var(--sodium);font-size:.86rem;font-weight:600}
.sector-card:hover .arr{transform:translateX(3px)}
.sector-card .arr{display:inline-block;transition:transform .18s}

.sector-video{margin:0;position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.sector-video video,.sector-video img{aspect-ratio:8/5;object-fit:cover;width:100%}
.sector-video figcaption{padding:.55rem .8rem;background:rgba(7,11,30,.7)}
.video-play{position:absolute;left:50%;top:42%;translate:-50% -50%;border:1px solid rgba(238,240,251,.35);
  background:rgba(7,11,30,.62);color:var(--ivoire);font:600 .95rem var(--font-display);
  padding:.7rem 1.3rem;border-radius:999px;cursor:pointer;backdrop-filter:blur(6px);transition:background .2s}
.video-play:hover{background:rgba(7,11,30,.85)}

/* ---------- Offres / plans ---------- */
.offer-card{display:flex;flex-direction:column;padding:1.7rem;color:var(--ivoire);transition:transform .2s,border-color .2s}
.offer-card:hover{text-decoration:none;transform:translateY(-4px);border-color:rgba(110,139,255,.45)}
.offer-card p{color:var(--brume);flex:1}
.offer-go{color:var(--sodium);font-weight:600;font-size:.92rem}
.plan-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;align-items:stretch}
.plan{position:relative;display:flex;flex-direction:column;padding:1.7rem 1.5rem;gap:.2rem}
.plan-best{border-color:rgba(255,180,84,.45);box-shadow:0 0 0 1px rgba(255,180,84,.15),0 26px 60px -30px rgba(255,180,84,.3)}
.plan-reco{position:absolute;top:-13px;left:50%;translate:-50% 0;background:var(--sodium);color:#1A1206;
  font:600 .76rem var(--font-display);padding:.28rem .85rem;border-radius:999px;white-space:nowrap}
.plan-name{font-family:var(--font-display);font-stretch:115%;letter-spacing:.14em;font-size:.86rem;
  color:var(--lumen);margin:0 0 .5rem}
.plan-price{margin:0 0 .6rem;display:flex;flex-direction:column;gap:.15rem}
.plan-price .mono{font-size:2rem;font-weight:600;color:var(--ivoire)}
.plan-tax{font-size:.78rem;color:var(--brume)}
.plan-pitch{color:var(--ivoire);font-weight:500;margin:.1rem 0 .7rem}
.plan-meta{margin:0 0 .6rem;font-size:.88rem}
.plan-meta dt{color:var(--lumen);font:600 .72rem var(--font-display);text-transform:uppercase;letter-spacing:.12em;margin-top:.5rem}
.plan-meta dd{margin:0;color:var(--brume)}
.plan-items{list-style:none;padding:0;margin:.2rem 0 1rem;flex:1}
.plan-items li{padding:.32rem 0 .32rem 1.4rem;position:relative;font-size:.93rem;color:var(--brume);border-bottom:1px dashed rgba(238,240,251,.07)}
.plan-items li::before{content:"✓";position:absolute;left:0;color:var(--sodium);font-weight:700}
.plan-items strong{color:var(--ivoire)}
.plan-delai{font-size:.8rem;color:var(--brume);margin:.2rem 0 .9rem}
.plan .btn{justify-content:center}
.plan .micro{text-align:center;margin-top:.5rem}

/* ---------- Tableau comparatif ---------- */
.table-scroll{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--line)}
.compare{width:100%;border-collapse:collapse;min-width:760px;background:var(--glass);font-size:.93rem}
.compare th,.compare td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--line)}
.compare thead th{font-family:var(--font-display);font-weight:650;background:rgba(12,18,51,.8)}
.compare thead .th-best{color:var(--sodium)}
.compare tbody th{font-weight:500;color:var(--brume)}
.compare td{color:var(--ivoire)}
.compare tr:last-child th,.compare tr:last-child td{border-bottom:0}

/* ---------- Listes ---------- */
.list-v,.list-x{list-style:none;padding:0;margin:.4rem 0}
.list-v li,.list-x li{padding:.34rem 0 .34rem 1.6rem;position:relative;color:var(--brume);font-size:.95rem;break-inside:avoid}
.list-v li::before{content:"✓";position:absolute;left:0;color:var(--sodium);font-weight:700}
.list-x li::before{content:"✕";position:absolute;left:0;color:#FF7A7A;font-weight:700}

/* ---------- Confiance ---------- */
.trust-list{display:flex;flex-direction:column;gap:1.2rem}
.trust-item{display:flex;gap:1.1rem;align-items:flex-start}
.trust-item p{color:var(--brume);margin:.2rem 0 0;font-size:.95rem}
.trust-k{flex:0 0 76px;text-align:center;color:var(--sodium);font-size:1.05rem;font-weight:600;
  border:1px solid rgba(255,180,84,.35);border-radius:12px;padding:.55rem .3rem}
.trust-side{padding:1.7rem;display:flex;flex-direction:column;gap:.7rem;align-self:start}
.trust-side p{color:var(--brume);margin:0}
.founder{display:flex;gap:1rem;align-items:flex-start;margin:.6rem 0}
.founder-photo{flex:0 0 96px;height:96px;border-radius:14px;border:1px dashed rgba(238,240,251,.3);
  display:grid;place-items:center;font-size:.66rem;color:var(--brume);text-align:center;padding:.4rem}
.portfolio-slot{grid-column:1/-1;margin-top:1.2rem;border-style:dashed}
.reco-band{display:flex;gap:2rem;align-items:center;justify-content:space-between;padding:1.8rem;flex-wrap:wrap}
.reco-band p{color:var(--brume);max-width:46em}

/* ---------- Agents IA ---------- */
.agent-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:1.6rem}
.agent{padding:1.6rem}
.agent-sub{display:block;font-size:.9rem;font-weight:500;color:var(--brume);margin-top:.2rem}
.agent p{color:var(--brume);font-size:.95rem}
.agent-meta{display:grid;grid-template-columns:auto 1fr;gap:.2rem .9rem;font-size:.88rem;margin:0}
.agent-meta dt{color:var(--lumen);font:600 .7rem var(--font-display);text-transform:uppercase;letter-spacing:.12em;align-self:center}
.agent-meta dd{margin:0;color:var(--brume)}

/* ---------- FAQ ---------- */
.faq-list{display:flex;flex-direction:column;gap:.8rem;max-width:860px}
.faq{padding:0}
.faq summary{cursor:pointer;list-style:none;padding:1.05rem 3rem 1.05rem 1.3rem;position:relative;
  font-family:var(--font-display);font-weight:600;font-size:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:1.2rem;top:50%;translate:0 -50%;
  color:var(--sodium);font-size:1.4rem;font-weight:400;transition:transform .25s}
.faq[open] summary::after{transform:rotate(45deg)}
.faq p{padding:0 1.3rem 1.2rem;margin:0;color:var(--brume);font-size:.96rem}

/* ---------- CTA band ---------- */
.cta-band{padding:clamp(3rem,7vw,5.5rem) 0;background:
  radial-gradient(640px 320px at 50% 120%,rgba(255,180,84,.13),transparent 70%),var(--encre-2);
  border-block:1px solid var(--line)}
.cta-band-in{text-align:center;max-width:760px}
.cta-band .lead{margin-inline:auto}
.cta-band .cta-row{justify-content:center}

/* ---------- Formulaire ---------- */
.contact-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:1.6rem;align-items:start}
.form{padding:1.8rem}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.f-field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}
.f-field label{font:600 .86rem var(--font-display);color:var(--ivoire)}
.f-field input,.f-field select,.f-field textarea{
  background:rgba(7,11,30,.6);border:1px solid var(--line);border-radius:10px;color:var(--ivoire);
  font:1rem var(--font-body);padding:.72rem .9rem;width:100%;transition:border-color .2s}
.f-field input:focus,.f-field select:focus,.f-field textarea:focus{border-color:var(--lumen);outline:none}
.f-field ::placeholder{color:rgba(166,173,208,.55)}
.f-field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23A6ADD0' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .9rem center}
.f-hint{font-size:.82rem;color:var(--brume);margin:-.4rem 0 1rem}
.f-consent{display:flex;gap:.7rem;align-items:flex-start;margin:.3rem 0 1.2rem}
.f-consent input{width:18px;height:18px;margin-top:.2rem;accent-color:var(--sodium)}
.f-consent label{font-size:.86rem;color:var(--brume)}
.f-error{background:rgba(255,122,122,.12);border:1px solid rgba(255,122,122,.4);color:#FFB3B3;
  border-radius:10px;padding:.7rem 1rem;font-size:.9rem}
.form .btn{width:100%;justify-content:center}
.form .micro{text-align:center;margin-top:.7rem}
.hp{position:absolute !important;left:-9999px;width:1px;height:1px;overflow:hidden}
.context-chip{background:rgba(110,139,255,.12);border:1px solid rgba(110,139,255,.4);
  border-radius:10px;padding:.65rem 1rem;font-size:.9rem;margin-bottom:1.1rem}
.contact-side{display:flex;flex-direction:column;gap:1.1rem}
.side-links{display:flex;flex-direction:column;gap:.4rem;margin:.4rem 0 0}
.side-links a{color:var(--sodium);font-weight:600}
.mini-steps{margin:.4rem 0 0;padding-left:1.2rem;color:var(--brume);font-size:.93rem}
.mini-steps li{margin:.45rem 0}
.mini-steps strong{color:var(--ivoire)}

/* ---------- Légal ---------- */
.legal{display:flex;flex-direction:column;gap:1rem;max-width:860px}
.legal-block{padding:1.5rem 1.6rem}
.legal-block p{color:var(--brume);margin:.4rem 0;font-size:.96rem}
.legal-block strong{color:var(--ivoire)}
mark.todo{background:rgba(255,180,84,.18);color:var(--sodium);border:1px dashed rgba(255,180,84,.5);
  border-radius:6px;padding:.06rem .4rem;font-size:.88em}

/* ---------- Footer ---------- */
.site-footer{border-top:1px solid var(--line);background:var(--encre-2);margin-top:2rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem;padding-block:3rem 2rem}
.foot-brand p{color:var(--brume);font-size:.92rem;max-width:30em}
.foot-col{display:flex;flex-direction:column;gap:.45rem}
.foot-col h3{font:600 .74rem var(--font-display);text-transform:uppercase;letter-spacing:.16em;color:var(--lumen);margin:0 0 .4rem}
.foot-col a{color:var(--brume);font-size:.92rem}
.foot-col a:hover{color:var(--ivoire);text-decoration:none}
.foot-note{color:var(--brume);font-size:.85rem;margin-top:.4rem}
.foot-legal{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;
  border-top:1px solid var(--line);padding-block:1.2rem;font-size:.84rem;color:var(--brume)}
.foot-legal p{margin:0}
.foot-legal nav{display:flex;gap:1.2rem}
.foot-legal a{color:var(--brume)}

/* ---------- Cookies ---------- */
.cookie-bar{position:fixed;inset-inline:1rem;bottom:1rem;z-index:90;max-width:560px;margin-inline:auto;
  background:rgba(12,18,51,.97);border:1px solid var(--line);border-radius:14px;padding:.8rem 1rem;
  backdrop-filter:blur(12px);box-shadow:0 24px 60px -20px rgba(0,0,0,.7);
  display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.cookie-bar p{margin:0;font-size:.82rem;color:var(--brume);flex:1 1 260px;line-height:1.4}
.cookie-bar strong{color:var(--ivoire)}
.cookie-actions{display:flex;gap:.5rem;flex-shrink:0}
@media (max-width:560px){
  .cookie-bar{inset-inline:.55rem;bottom:.55rem;padding:.6rem .75rem;gap:.5rem;border-radius:12px}
  .cookie-bar p{font-size:.72rem;line-height:1.3;flex:1 1 100%}
  .cookie-actions{width:100%;gap:.45rem}
  .cookie-actions .btn{flex:1;justify-content:center;padding:.42rem .7rem;font-size:.8rem}
}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .55s ease,transform .55s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .reveal{opacity:1;transform:none}
}

/* ---------- Responsive ---------- */
@media (max-width:1020px){
  .sector-grid,.plan-grid,.grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .radar{opacity:.45;right:-280px}
}
@media (max-width:760px){
  body{font-size:1rem}
  .nav{display:none;position:absolute;top:68px;left:0;right:0;background:var(--encre-2);
    flex-direction:column;gap:0;border-bottom:1px solid var(--line);padding:.6rem 0}
  .nav.open{display:flex}
  .nav a{padding:.85rem clamp(1rem,4vw,2rem);border-top:1px solid var(--line)}
  .burger{display:flex}
  .btn-nav{display:none}
  .grid-2,.grid-3,.sector-grid,.plan-grid,.agent-grid,.contact-grid,.f-row,.grid-4{grid-template-columns:1fr}
  .hero-split{grid-template-columns:1fr;gap:1.8rem}
  .cols-2{columns:1}
  .foot-grid{grid-template-columns:1fr;gap:1.6rem}
  .reco-band{flex-direction:column;align-items:flex-start}
  .trust-k{flex-basis:64px}
  .plan-grid .plan-best{order:-1}
}

/* ============================================================
   V3.5 — montée en gamme : hero vidéo, mockups, what-grid,
   portfolio, hover vidéo secteurs, thèmes métier, founder-mark
   ============================================================ */

/* ---------- Hero V3 : vidéo d'ambiance + mockups ---------- */
.hero-v3{position:relative;isolation:isolate;min-height:clamp(560px,82vh,760px);display:flex;flex-direction:column;justify-content:center}
.hero-v3 .hero-in{position:relative;z-index:3}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.34;filter:saturate(1.1) contrast(1.02)}
.hero-veil{position:absolute;inset:0;z-index:1;pointer-events:none;background:
  linear-gradient(180deg,rgba(7,11,30,.72) 0%,rgba(7,11,30,.55) 45%,rgba(7,11,30,.9) 100%),
  radial-gradient(820px 460px at 80% -8%,rgba(110,139,255,.22),transparent 65%),
  radial-gradient(620px 420px at 8% 108%,rgba(255,180,84,.12),transparent 60%)}
.hero-v3 .radar{z-index:2}
.hero-mocks{position:relative;z-index:3;display:flex;gap:1.2rem;margin-top:2.4rem;flex-wrap:wrap}
.mock{position:relative;padding:1rem;border-radius:16px;overflow:hidden;animation:floaty 7s ease-in-out infinite}
.mock-site{flex:1 1 320px;min-height:188px}
.mock-gmb{flex:0 1 250px;min-height:188px;animation-delay:1.6s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.mock-bar{display:block;height:9px;width:62%;border-radius:6px;background:rgba(238,240,251,.22);margin:.9rem 0 .8rem}
.mock-hero{display:block;height:64px;border-radius:10px;background:linear-gradient(120deg,rgba(110,139,255,.32),rgba(255,180,84,.22))}
.mock-cta{display:inline-block;margin-top:.8rem;background:var(--sodium);color:#1A1206;font-weight:700;font-size:.78rem;padding:.3rem .8rem;border-radius:999px}
.mock-lines{display:block;margin-top:.8rem}
.mock-lines i{display:block;height:7px;border-radius:5px;background:rgba(238,240,251,.14);margin:.4rem 0}
.mock-lines i:nth-child(2){width:80%}.mock-lines i:nth-child(3){width:55%}
.mock-gmb .mock-pin{font-size:1.4rem}
.mock-title{display:block;font-family:var(--font-display);font-weight:650;margin:.4rem 0 .2rem}
.mock-stars{display:block;color:var(--sodium);letter-spacing:2px;font-size:.95rem}
.mock-meta{display:block;color:var(--brume);font-size:.72rem;margin-top:.3rem}

/* ---------- Ce que vous obtenez ---------- */
.what-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-top:1.8rem}
.what{display:flex;flex-direction:column;gap:.3rem;padding:1.4rem 1.2rem;color:var(--ivoire);
  transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}
.what:hover{text-decoration:none;transform:translateY(-4px);border-color:rgba(110,139,255,.45);
  box-shadow:0 20px 44px -24px rgba(110,139,255,.35)}
.what-ic{font-size:1.6rem;color:var(--sodium);line-height:1;margin-bottom:.3rem}
.what h3{margin:.1rem 0 .2rem;font-size:1.02rem}
.what p{color:var(--brume);font-size:.88rem;margin:0}

/* ---------- Steps 5 ---------- */
.steps-5{grid-template-columns:repeat(auto-fit,minmax(186px,1fr))}

/* ---------- Cartes secteurs : hover vidéo ---------- */
.sector-media{position:relative}
.sector-media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;
  transition:opacity .45s ease;z-index:1}
.sector-media video.show{opacity:1}
.sector-media img{position:relative;z-index:0}

/* ---------- Portfolio ---------- */
.pf-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:1.8rem}
.pf-grid-page{grid-template-columns:repeat(3,1fr);margin-top:1.4rem}
.pf-card{display:flex;flex-direction:column;overflow:hidden;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}
.pf-card:hover{transform:translateY(-5px);border-color:var(--pf-hue,var(--sodium));
  box-shadow:0 26px 56px -26px color-mix(in srgb,var(--pf-hue,var(--sodium)) 55%,transparent)}
.pf-card[data-hue="sodium"]{--pf-hue:#FFB454}
.pf-card[data-hue="lumen"]{--pf-hue:#6E8BFF}
.pf-card[data-hue="rose"]{--pf-hue:#FF8FB8}
.pf-card[data-hue="teal"]{--pf-hue:#7FD8C9}
.pf-visual{display:block;background:var(--encre-2);border-bottom:1px solid var(--line)}
.pf-visual:hover{text-decoration:none}
.pf-browser{display:flex;align-items:center;gap:.6rem;padding:.55rem .8rem;background:rgba(7,11,30,.6);border-bottom:1px solid var(--line)}
.pf-dots{display:inline-flex;gap:4px}
.pf-dots i{width:8px;height:8px;border-radius:50%;background:rgba(238,240,251,.25)}
.pf-dots i:first-child{background:var(--pf-hue,var(--sodium))}
.pf-url{font-size:.7rem;color:var(--brume);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pf-screen{position:relative;display:grid;place-items:center;aspect-ratio:16/10;
  background:radial-gradient(120% 120% at 50% 0%,color-mix(in srgb,var(--pf-hue,var(--sodium)) 16%,transparent),transparent 70%),var(--encre)}
.pf-mono{font-family:var(--font-display);font-stretch:120%;font-weight:800;font-size:2.6rem;
  color:var(--pf-hue,var(--sodium));opacity:.92;letter-spacing:.04em}
.pf-lines{position:absolute;bottom:14px;left:14px;right:14px}
.pf-lines i{display:block;height:6px;border-radius:4px;background:rgba(238,240,251,.12);margin:.32rem 0}
.pf-lines i:nth-child(2){width:72%}.pf-lines i:nth-child(3){width:48%}
.pf-body{padding:1.1rem 1.2rem 1.3rem;display:flex;flex-direction:column;gap:.3rem;flex:1}
.pf-badge{font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--pf-hue,var(--sodium))}
.pf-body h3{margin:.1rem 0 .15rem;font-size:1.05rem}
.pf-body p{color:var(--brume);font-size:.88rem;margin:0;flex:1}
.pf-link{color:var(--pf-hue,var(--sodium));font-weight:600;font-size:.9rem;margin-top:.5rem}

/* ---------- Founder monogramme ---------- */
.founder-mark{display:inline-grid;place-items:center;width:54px;height:54px;border-radius:14px;
  font-family:var(--font-display);font-weight:800;letter-spacing:.04em;color:#1A1206;
  background:linear-gradient(135deg,var(--sodium),var(--lumen));box-shadow:0 8px 24px -10px rgba(255,180,84,.5)}
.founder-mark-lg{width:84px;height:84px;border-radius:20px;font-size:1.8rem}
.founder-card{padding:1.8rem;display:flex;flex-direction:column;gap:.5rem;align-items:flex-start}
.founder-role{color:var(--lumen);font-size:.82rem;margin:0}

/* ---------- Thèmes secteur : recoloration locale des accents ---------- */
[data-theme="lumen"]{--sodium:#6E8BFF;--sodium-deep:#5570E6}
[data-theme="rose"]{--sodium:#FF8FB8;--sodium-deep:#E86E9C}
[data-theme="energy"]{--sodium:#FF6B4A;--sodium-deep:#E5512F}
[data-theme="teal"]{--sodium:#7FD8C9;--sodium-deep:#5BBBAA}
[data-theme="ocre"]{--sodium:#E8A33D;--sodium-deep:#CE8A28}
/* le bouton primaire garde un texte lisible quelle que soit la teinte */
[data-theme] .btn-primary{color:#0B0F1E}

/* ---------- Sector video (page secteur) : bouton play ---------- */
.sector-video .video-play{cursor:pointer}

/* ---------- Responsive V3.5 ---------- */
@media (max-width:1020px){
  .what-grid{grid-template-columns:repeat(3,1fr)}
  .pf-grid{grid-template-columns:repeat(2,1fr)}
  .pf-grid-page{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .what-grid{grid-template-columns:1fr 1fr}
  .pf-grid,.pf-grid-page{grid-template-columns:1fr}
  .hero-mocks{display:none}
  .hero-v3{min-height:auto;padding-top:clamp(3rem,12vw,5rem)}
  .hero-video{opacity:.22}
}
@media (max-width:440px){
  .what-grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  .mock{animation:none}
  .hero-video,.sector-media video{transition:none}
}

/* ============================================================
   V5 — diagnostic, portfolio scènes, 404, vision, print PDF
   ============================================================ */

/* ---------- Diagnostic : choix de mode ---------- */
.diag-wrap{max-width:920px;margin-inline:auto}
.diag-modes{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.diag-mode{display:flex;flex-direction:column;gap:.35rem;padding:1.5rem 1.4rem;text-align:left;
  color:var(--ivoire);font:inherit;cursor:pointer;transition:transform .2s,border-color .2s,box-shadow .2s}
.diag-mode:hover:not(.diag-mode-locked){transform:translateY(-4px);border-color:rgba(255,180,84,.45);
  box-shadow:0 22px 48px -24px rgba(255,180,84,.3)}
.diag-mode p{color:var(--brume);font-size:.92rem;margin:.2rem 0 .6rem;flex:1}
.diag-mode-time{color:var(--lumen);font-size:.78rem}
.diag-mode-go{color:var(--sodium);font-weight:600;font-size:.9rem}
.diag-mode-best{border-color:rgba(255,180,84,.4)}
.diag-mode-locked{opacity:.55;cursor:not-allowed}
.diag-mode-lock{color:var(--brume)}

/* ---------- Diagnostic : panneau questions ---------- */
.diag-panel{margin-top:1.4rem;padding:1.6rem 1.7rem 1.4rem}
.diag-top{display:flex;align-items:center;gap:1rem;margin-bottom:1.4rem}
.diag-mode-label{color:var(--lumen);font-size:.78rem;white-space:nowrap}
.diag-progress{flex:1;height:6px;border-radius:4px;background:rgba(238,240,251,.1);overflow:hidden}
.diag-progress i{display:block;height:100%;width:0;border-radius:4px;
  background:linear-gradient(90deg,var(--lumen),var(--sodium));transition:width .35s ease}
.diag-quit{background:none;border:1px solid var(--line);color:var(--brume);width:34px;height:34px;
  border-radius:10px;cursor:pointer;font-size:.9rem}
.diag-quit:hover{color:var(--ivoire);border-color:var(--ivoire)}
.diag-count{color:var(--brume);font-size:.78rem;margin:0 0 .4rem}
.diag-q{font-family:var(--font-display);font-weight:650;font-size:clamp(1.25rem,2.6vw,1.7rem);
  letter-spacing:-.01em;margin:0 0 1.2rem;min-height:2.2em}
.diag-opts{display:flex;flex-wrap:wrap;gap:.7rem}
.diag-opt{font:500 .98rem var(--font-body);color:var(--ivoire);background:rgba(238,240,251,.05);
  border:1px solid var(--line);border-radius:999px;padding:.7rem 1.25rem;cursor:pointer;
  transition:border-color .15s,background .15s,transform .15s}
.diag-opt:hover{border-color:var(--lumen);background:rgba(110,139,255,.1)}
.diag-opt.sel{border-color:var(--sodium);background:rgba(255,180,84,.16);transform:scale(1.02)}
.diag-inputrow{display:flex;gap:.7rem;flex-wrap:wrap}
.diag-input{flex:1 1 260px;background:rgba(7,11,30,.6);border:1px solid var(--line);border-radius:12px;
  color:var(--ivoire);font:1.02rem var(--font-body);padding:.78rem 1rem}
.diag-input:focus{border-color:var(--lumen);outline:none}
.diag-skip{background:none;border:none;color:var(--brume);font:inherit;font-size:.86rem;
  cursor:pointer;margin-top:.8rem;text-decoration:underline;text-underline-offset:3px;padding:0}
.diag-skip:hover{color:var(--ivoire)}
.diag-nav{margin-top:1.2rem}

/* ---------- Diagnostic : rapport ---------- */
.diag-result{margin-top:1.4rem}
.diag-report{padding:1.9rem 1.9rem 1.6rem}
.diag-r-head{display:flex;justify-content:space-between;gap:1.4rem;align-items:flex-start;flex-wrap:wrap;margin-bottom:1.3rem}
.diag-level{font-family:var(--font-display);font-weight:700;padding:.55rem 1.1rem;border-radius:999px;
  font-size:.95rem;white-space:nowrap;border:1px solid}
.diag-level-a{color:#7FD8A8;border-color:rgba(127,216,168,.5);background:rgba(127,216,168,.1)}
.diag-level-b{color:var(--lumen);border-color:rgba(110,139,255,.5);background:rgba(110,139,255,.1)}
.diag-level-c{color:var(--sodium);border-color:rgba(255,180,84,.5);background:rgba(255,180,84,.1)}
.diag-level-d{color:#FF8A6B;border-color:rgba(255,138,107,.5);background:rgba(255,138,107,.12)}
.diag-pils{display:flex;flex-direction:column;gap:.55rem;margin:0 0 1.4rem}
.diag-pil{display:grid;grid-template-columns:130px 1fr 38px;gap:.9rem;align-items:center;font-size:.92rem}
.diag-pil>span:first-child{color:var(--brume)}
.diag-gauge{height:8px;border-radius:5px;background:rgba(238,240,251,.08);overflow:hidden}
.diag-gauge i{display:block;height:100%;border-radius:5px;background:linear-gradient(90deg,var(--lumen),var(--sodium))}
.diag-pil .mono{text-align:right;color:var(--ivoire)}
.diag-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin-bottom:1rem}
.diag-prio{margin:.4rem 0 1.4rem;padding-left:1.3rem;color:var(--ivoire)}
.diag-prio li{margin:.45rem 0}
.diag-reco{border:1px solid rgba(255,180,84,.4);border-radius:14px;padding:1.2rem 1.3rem;
  background:rgba(255,180,84,.06)}
.diag-reco-f{font-size:1.15rem;margin:.3rem 0 .5rem}
.diag-reco p{color:var(--brume);margin:.3rem 0}
.diag-reco .eyebrow{margin-bottom:.2rem}
.diag-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.2rem}

/* ---------- Promo diagnostic (home) ---------- */
.diag-promo{display:grid;grid-template-columns:1.2fr .8fr;gap:2rem;align-items:center;padding:2rem 2.1rem}
.diag-promo-demo{display:flex;flex-direction:column;gap:.8rem;padding:1.2rem;border:1px solid var(--line);
  border-radius:14px;background:rgba(7,11,30,.5)}
.diag-demo-q{color:var(--ivoire);font-size:.85rem}
.diag-demo-opts{display:flex;flex-wrap:wrap;gap:.5rem}
.diag-demo-opts span{font-size:.78rem;color:var(--brume);border:1px solid var(--line);
  border-radius:999px;padding:.35rem .8rem}
.diag-demo-opts span.on{color:var(--sodium);border-color:rgba(255,180,84,.55);background:rgba(255,180,84,.12)}
.diag-demo-bar{height:6px;border-radius:4px;background:rgba(238,240,251,.08);overflow:hidden}
.diag-demo-bar i{display:block;height:100%;width:46%;border-radius:4px;
  background:linear-gradient(90deg,var(--lumen),var(--sodium))}

/* ---------- Portfolio V5 : scènes + mobile mockup + zoom ---------- */
.pf-screen{overflow:hidden}
.pf-sc-nav{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;gap:.5rem;
  padding:.5rem .7rem;z-index:2}
.pf-sc-nav i{display:block;height:5px;width:26px;border-radius:3px;background:rgba(238,240,251,.22)}
.pf-sc-nav .pf-sc-logo{width:auto;height:auto;background:none;font:800 .72rem var(--font-display);
  color:var(--pf-hue,var(--sodium));letter-spacing:.06em;margin-right:auto}
.pf-sc-nav .pf-sc-cta{width:38px;height:12px;border-radius:7px;background:var(--pf-hue,var(--sodium));opacity:.9}
.pf-sc-hero{position:absolute;left:.8rem;top:32%;z-index:2;display:flex;flex-direction:column;gap:.45rem;width:52%}
.pf-sc-h1{display:block;height:10px;width:92%;border-radius:6px;background:rgba(238,240,251,.85)}
.pf-sc-h2{display:block;height:10px;width:64%;border-radius:6px;background:rgba(238,240,251,.45)}
.pf-sc-btn{display:block;height:16px;width:74px;border-radius:9px;background:var(--pf-hue,var(--sodium));margin-top:.35rem}
.pf-sc-art{position:absolute;right:5%;top:23%;width:42%;aspect-ratio:3/4;border-radius:11px;z-index:1;
  overflow:hidden;border:1px solid rgba(238,240,251,.16);box-shadow:0 18px 40px -18px rgba(0,0,0,.7);
  transition:transform .5s ease}
.pf-sc-art::after{content:"";position:absolute;left:9%;right:9%;bottom:9%;height:24%;border-radius:6px;
  background:rgba(7,11,30,.5);border:1px solid rgba(238,240,251,.22);
  box-shadow:inset 0 0 0 1px rgba(238,240,251,.04)}
.pf-phone{position:absolute;right:7%;bottom:-6%;width:21%;aspect-ratio:9/18;z-index:3;
  background:#0A0F26;border:2px solid rgba(238,240,251,.3);border-radius:12px;
  box-shadow:0 14px 30px -10px rgba(0,0,0,.65);padding:7% 5%;display:flex;flex-direction:column;gap:6%;
  transition:transform .45s ease}
.pf-phone i{display:block;border-radius:4px}
.pf-phone-notch{height:3px;width:42%;margin:0 auto;background:rgba(238,240,251,.3)}
.pf-phone-hero{flex:0 0 34%;background:linear-gradient(135deg,color-mix(in srgb,var(--pf-hue,var(--sodium)) 55%,transparent),rgba(238,240,251,.12))}
.pf-phone-line{height:4px;background:rgba(238,240,251,.25)}
.pf-phone-line.short{width:64%}
.pf-phone-btn{height:9px;width:74%;border-radius:6px;background:var(--pf-hue,var(--sodium))}
/* scènes par univers — l'image héro lit comme une vraie photo de site */
.pf-scene-resto{background:radial-gradient(90% 110% at 78% 30%,rgba(255,140,60,.22),transparent 60%),
  linear-gradient(160deg,#1A0F08 0%,#070B1E 70%)}
.pf-scene-resto .pf-sc-art{background:linear-gradient(150deg,#FFE0AE 0%,#E8893B 46%,#7A3414 100%)}
.pf-scene-garage{background:linear-gradient(160deg,#0B1430 0%,#070B1E 70%);
  background-image:repeating-linear-gradient(115deg,rgba(110,139,255,.07) 0 2px,transparent 2px 18px),linear-gradient(160deg,#0B1430,#070B1E)}
.pf-scene-garage .pf-sc-art{background:linear-gradient(150deg,#AEC0EC 0%,#41527E 50%,#19233F 100%)}
.pf-scene-spa{background:radial-gradient(100% 120% at 75% 22%,rgba(255,143,184,.18),transparent 62%),
  linear-gradient(165deg,#140D1E 0%,#070B1E 70%)}
.pf-scene-spa .pf-sc-art{background:linear-gradient(150deg,#FFE3EF 0%,#E89ABF 46%,#7A3A5A 100%)}
/* zoom hover */
.pf-visual .pf-screen{transition:transform .5s ease}
.pf-card:hover .pf-screen{transform:scale(1.06)}
.pf-card:hover .pf-sc-art{transform:scale(1.05)}
.pf-card:hover .pf-phone{transform:translateY(-5px) rotate(-2deg)}

/* ---------- Vision band (à propos) ---------- */
.vision-band{margin:0;padding:1.9rem 2rem;display:flex;flex-direction:column;gap:1rem}
.vision-band blockquote{margin:0;font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.1rem,2.2vw,1.4rem);line-height:1.45;color:var(--ivoire)}
.vision-band figcaption{display:flex;align-items:center;gap:.8rem;color:var(--brume);font-size:.92rem}

/* ---------- 404 ---------- */
.err-hero{min-height:72vh;display:flex;align-items:center}
.err-code{font-size:clamp(4rem,14vw,8rem);font-weight:600;line-height:1;margin:.2em 0 0;
  background:linear-gradient(120deg,var(--lumen),var(--sodium));
  -webkit-background-clip:text;background-clip:text;color:transparent;opacity:.9}
.err-hero .micro a{color:var(--sodium)}

/* ---------- Responsive V5 ---------- */
@media (max-width:1020px){
  .diag-modes{grid-template-columns:1fr}
  .diag-promo{grid-template-columns:1fr}
}
@media (max-width:760px){
  .diag-cols{grid-template-columns:1fr}
  .diag-pil{grid-template-columns:96px 1fr 34px}
  .diag-actions .btn{width:100%;justify-content:center}
  .diag-panel{padding:1.2rem}
  .pf-phone{right:4%}
}

/* ---------- Impression : rapport diagnostic → PDF ---------- */
@media print{
  body.diag-printing *{visibility:hidden}
  body.diag-printing #diagPrint,body.diag-printing #diagPrint *{visibility:visible}
  body.diag-printing #diagPrint{position:absolute;inset:0;margin:0;border:none;box-shadow:none;
    background:#fff;color:#111;border-radius:0;padding:24mm 18mm}
  body.diag-printing #diagPrint .eyebrow{color:#B26A00}
  body.diag-printing #diagPrint .h2,body.diag-printing #diagPrint h3{color:#0C1233}
  body.diag-printing #diagPrint .micro,body.diag-printing #diagPrint p,
  body.diag-printing #diagPrint li,body.diag-printing #diagPrint .diag-pil>span:first-child{color:#333}
  body.diag-printing #diagPrint .diag-gauge{background:#E8E8EE}
  body.diag-printing #diagPrint .diag-gauge i{background:#0C1233}
  body.diag-printing #diagPrint .diag-pil .mono{color:#0C1233}
  body.diag-printing #diagPrint .diag-level{border-color:#0C1233;color:#0C1233;background:none}
  body.diag-printing #diagPrint .diag-reco{border-color:#B26A00;background:#FFF7EC}
  body.diag-printing #diagPrint .list-v li::before{color:#B26A00}
  body.diag-printing #diagPrint .list-x li::before{color:#C0392B}
  body.diag-printing #diagPrint .list-v li,body.diag-printing #diagPrint .list-x li{color:#333}
}

/* ============================================================
   V5.1 — médias réels : hero photo, kenburns, tuiles photo,
   strip parallaxe, portfolio bannières réelles, tilt 3D
   ============================================================ */

/* ---------- Hero photo (home + secteurs) ---------- */
.hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.5}
.hero-v3 .hero-photo{opacity:.44}
.hero-v3 .hero-video{z-index:1;opacity:.25;mix-blend-mode:screen}
.kenburns{animation:kenburns 26s ease-in-out infinite alternate;transform-origin:60% 40%}
@keyframes kenburns{from{transform:scale(1)}to{transform:scale(1.09) translate(-1.5%,1%)}}

.sector-hero{position:relative;isolation:isolate;min-height:clamp(540px,78vh,720px);
  display:flex;align-items:flex-end;overflow:hidden;padding:clamp(4rem,8vw,6rem) 0 clamp(2.6rem,5vw,4rem)}
.sector-hero .hero-photo{opacity:.62}
.hero-photo-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;
  opacity:0;transition:opacity 1.2s ease;mix-blend-mode:screen}
.hero-photo-video.on{opacity:.3}
.hero-photo-veil{position:absolute;inset:0;z-index:2;pointer-events:none;background:
  linear-gradient(180deg,rgba(7,11,30,.62) 0%,rgba(7,11,30,.28) 40%,rgba(7,11,30,.94) 100%),
  radial-gradient(720px 420px at 82% 0%,color-mix(in srgb,var(--sodium) 16%,transparent),transparent 65%)}
.sector-hero-in{position:relative;z-index:3;max-width:760px}
.sector-hero .lead{max-width:38em}

/* ---------- Tuiles photo « ce que vous obtenez » ---------- */
.what-photo{position:relative;padding:0;overflow:hidden;aspect-ratio:3/4.1;display:block}
.what-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform .6s ease;z-index:0}
.what-photo:hover img{transform:scale(1.07)}
.what-veil{position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,rgba(7,11,30,.05) 30%,rgba(7,11,30,.92) 100%)}
.what-txt{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:1rem 1.1rem}
.what-txt h3{margin:0 0 .15rem;font-size:1rem}
.what-txt p{margin:0;color:var(--brume);font-size:.82rem;line-height:1.4}
.what-photo:hover{border-color:rgba(255,180,84,.5);box-shadow:0 22px 48px -22px rgba(255,180,84,.3)}

/* ---------- Cartes secteurs : photo réelle ---------- */
.sector-media img{filter:saturate(1.05)}
.sector-card:hover .sector-media img{transform:scale(1.05)}
.sector-media img{transition:transform .6s ease}

/* ---------- Strip parallaxe (pages secteurs) ---------- */
.strip{position:relative;height:clamp(220px,34vw,360px);overflow:hidden;isolation:isolate;
  border-block:1px solid var(--line)}
.strip-img{position:absolute;left:0;right:0;top:-18%;width:100%;height:136%;object-fit:cover;
  z-index:0;will-change:transform}
.strip-veil{position:absolute;inset:0;z-index:1;background:
  linear-gradient(90deg,rgba(7,11,30,.85) 0%,rgba(7,11,30,.25) 50%,rgba(7,11,30,.85) 100%)}
.strip-line{position:relative;z-index:2;display:flex;align-items:flex-end;height:100%;
  margin:0;padding-bottom:1.4rem;font-family:var(--font-display);font-stretch:112%;
  font-weight:650;letter-spacing:.06em;text-transform:uppercase;font-size:clamp(.8rem,1.6vw,1rem);
  color:var(--brume)}
.strip-line span{color:var(--sodium);margin-left:.5ch}

/* ---------- Constat compact ---------- */
.constat-list{max-width:46em;font-size:1.02rem}
.constat-list li{padding-block:.5rem}
.levier-grid .mini h3{font-size:1.08rem}
.agents-side{display:flex;flex-direction:column;gap:1rem}

/* ---------- Portfolio : bannières réelles ---------- */



.pf-screen::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(7,11,30,.45) 0%,transparent 30%,transparent 60%,rgba(7,11,30,.5) 100%)}
.pf-sc-nav{z-index:3}

.pf-phone{overflow:hidden}


.pf-phone-notch{position:relative;z-index:2}
.pf-phone-btn{position:relative;z-index:2;margin-top:auto}

/* ---------- Tilt 3D léger ---------- */
.tilt{transform-style:preserve-3d;will-change:transform}
@media (pointer:fine){
  .tilt{transition:transform .25s ease}
}

/* ---------- Responsive / motion V5.1 ---------- */
@media (max-width:760px){
  .what-photo{aspect-ratio:16/9}
  .sector-hero{min-height:64vh;align-items:flex-end}
  .strip{height:200px}
}
@media (prefers-reduced-motion:reduce){
  .kenburns{animation:none}
  .strip-img{transform:none !important}
  .tilt{transform:none !important}
}

/* ============================================================
   V5.2 — habillage des pages : page-hero photo + chips GMB neutres
   ============================================================ */
.page-hero.has-photo{position:relative;isolation:isolate;overflow:hidden}
.page-hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.34}
.page-hero.has-photo > .wrap{position:relative;z-index:2}
.page-hero-photo-veil{position:absolute;inset:0;z-index:1;pointer-events:none;background:
  linear-gradient(180deg,rgba(7,11,30,.74) 0%,rgba(7,11,30,.52) 45%,rgba(7,11,30,.92) 100%),
  radial-gradient(680px 360px at 80% 0%,color-mix(in srgb,var(--sodium) 14%,transparent),transparent 62%)}
.page-hero-quiet .page-hero-photo{opacity:.2}
.page-hero-quiet .page-hero-photo-veil{background:
  linear-gradient(180deg,rgba(7,11,30,.86) 0%,rgba(7,11,30,.72) 50%,rgba(7,11,30,.96) 100%)}
.err-hero.has-photo .radar{z-index:2}
.err-hero.has-photo .hero-in,.err-hero.has-photo .wrap{position:relative;z-index:3}

/* GMB mock : pin SVG + chips neutres (remplacent 📍 et ★★★★★) */
.mock-pin{display:inline-flex;color:var(--sodium)}
.mock-pin svg{display:block}
.mock-chips{display:flex;gap:.4rem;flex-wrap:wrap;margin:.1rem 0 .2rem}
.mock-chips i{font-style:normal;font-size:.62rem;letter-spacing:.02em;color:var(--brume);
  border:1px solid var(--line);border-radius:999px;padding:.2rem .5rem;background:rgba(238,240,251,.04)}

@media (prefers-reduced-motion:reduce){
  .page-hero-photo.kenburns{animation:none}
}

/* ============================================================
   V5.3 — Direction artistique : hero cinématique + Avant/Après
   ============================================================ */

/* ---------- Hero cinématique (profondeur, lumière volumétrique) ---------- */
.hero-cinematic{position:relative;min-height:100svh;display:flex;flex-direction:column;
  justify-content:center;align-items:center;text-align:center;overflow:hidden;isolation:isolate;
  padding:6rem 0 4rem}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden;background:
  radial-gradient(120% 90% at 50% -10%, #0e1538 0%, #070b1e 55%, #05081a 100%)}
.hero-grid{position:absolute;left:50%;bottom:-30%;width:200%;height:130%;transform:translateX(-50%) perspective(620px) rotateX(64deg);
  background-image:linear-gradient(rgba(110,139,255,.16) 1px,transparent 1px),linear-gradient(90deg,rgba(110,139,255,.16) 1px,transparent 1px);
  background-size:54px 54px;mask-image:radial-gradient(ellipse 60% 60% at 50% 35%,#000 0%,transparent 78%);
  animation:gridflow 18s linear infinite}
@keyframes gridflow{to{background-position:0 54px}}
.hero-glow{position:absolute;border-radius:50%;filter:blur(80px);opacity:.55;will-change:transform}
.hero-glow-a{width:560px;height:560px;top:-12%;left:8%;
  background:radial-gradient(circle,rgba(255,180,84,.42),transparent 68%);animation:floaty 14s ease-in-out infinite alternate}
.hero-glow-b{width:620px;height:620px;bottom:-18%;right:4%;
  background:radial-gradient(circle,rgba(110,139,255,.4),transparent 68%);animation:floaty 17s ease-in-out infinite alternate-reverse}
@keyframes floaty{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(28px,-26px,0) scale(1.08)}}
.hero-scan{position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(255,180,84,.05) 50%,transparent 100%);
  background-size:100% 8px;mix-blend-mode:overlay;opacity:.5}
.hero-cin-in{position:relative;z-index:2;max-width:880px}
.hero-title{font-size:clamp(2.6rem,7vw,5.2rem);line-height:1.02;letter-spacing:-.03em;margin:.2em 0 .4em}
.hero-title em{font-style:normal;background:linear-gradient(110deg,var(--sodium),#ffd9a0 50%,var(--lumen));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{font-size:clamp(1.05rem,2vw,1.4rem);max-width:38ch;margin-inline:auto;color:var(--brume)}
.hero-cinematic .cta-row{justify-content:center;margin-top:2rem}
.hero-proof{display:flex;gap:clamp(1.2rem,4vw,3.4rem);justify-content:center;margin-top:3rem;flex-wrap:wrap}
.hero-stat{display:flex;flex-direction:column;gap:.2rem}
.hero-stat-n{font-family:var(--font-display);font-weight:680;font-size:clamp(1.6rem,3.4vw,2.5rem);
  background:linear-gradient(120deg,#fff,var(--sodium));-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.hero-stat-l{font-size:.78rem;color:var(--mist,var(--brume));letter-spacing:.01em;opacity:.8}
.hero-scroll{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);z-index:2;
  width:24px;height:38px;border:2px solid rgba(238,240,251,.3);border-radius:14px}
.hero-scroll span{position:absolute;top:7px;left:50%;width:4px;height:7px;margin-left:-2px;border-radius:2px;
  background:var(--sodium);animation:scrolldot 1.7s ease-in-out infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(0)}30%{opacity:1}70%{opacity:1}100%{opacity:0;transform:translateY(13px)}}

/* reveal d'entrée plus cinématique */
.reveal-up{opacity:0;transform:translateY(26px);animation:revealUp .9s cubic-bezier(.16,.8,.3,1) forwards}
.hero-cin-in .reveal-up:nth-child(1){animation-delay:.05s}
.hero-cin-in .reveal-up:nth-child(2){animation-delay:.15s}
.hero-cin-in .reveal-up:nth-child(3){animation-delay:.28s}
.hero-cin-in .reveal-up:nth-child(4){animation-delay:.42s}
.hero-cin-in .reveal-up:nth-child(5){animation-delay:.56s}
@keyframes revealUp{to{opacity:1;transform:none}}

/* ---------- Avant / Après ---------- */
.ba-section{padding:clamp(3.5rem,8vw,6rem) 0;position:relative}
.ba{position:relative;margin-top:2rem;border-radius:20px;overflow:hidden;border:1px solid var(--line);
  min-height:clamp(280px,42vw,420px);cursor:ew-resize;user-select:none;
  box-shadow:0 40px 90px -50px rgba(0,0,0,.8)}
.ba-pane{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;
  padding:clamp(1.6rem,4vw,3rem)}
.ba-before{background:
  radial-gradient(120% 100% at 0% 0%,rgba(120,40,40,.22),transparent 60%),linear-gradient(135deg,#161a26,#0c0f1a);
  filter:saturate(.5)}
.ba-after{background:
  radial-gradient(120% 100% at 100% 0%,color-mix(in srgb,var(--sodium) 26%,transparent),transparent 55%),
  radial-gradient(120% 120% at 100% 100%,color-mix(in srgb,var(--lumen) 22%,transparent),transparent 60%),
  linear-gradient(135deg,#0e1638,#0a0f26);clip-path:inset(0 0 0 50%)}
.ba-tag{position:absolute;top:1rem;font-family:var(--font-display);font-weight:680;font-size:.74rem;
  letter-spacing:.14em;text-transform:uppercase;padding:.35rem .8rem;border-radius:999px}
.ba-tag-before{left:1rem;color:#ff9b8a;background:rgba(255,90,70,.12);border:1px solid rgba(255,120,100,.35)}
.ba-tag-after{right:1rem;color:#1a1206;background:var(--sodium)}
.ba-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7rem;max-width:30ch}
.ba-after .ba-list{margin-left:auto;text-align:right}
.ba-list li{position:relative;padding-left:1.6rem;font-size:clamp(.92rem,1.7vw,1.08rem);color:var(--brume)}
.ba-list li::before{content:"✕";position:absolute;left:0;color:#ff7a66;font-weight:700}
.ba-after .ba-list li{padding-left:0;padding-right:1.6rem;color:var(--ivoire)}
.ba-after .ba-list li::before{content:"✓";left:auto;right:0;color:var(--sodium)}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:3px;margin-left:-1.5px;z-index:5;
  background:linear-gradient(180deg,transparent,var(--sodium),transparent);border:none;cursor:ew-resize;padding:0}
.ba-handle-grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;
  border-radius:50%;background:var(--sodium);display:flex;align-items:center;justify-content:center;gap:3px;
  box-shadow:0 6px 24px -6px rgba(255,180,84,.7)}
.ba-handle-grip i{width:3px;height:14px;background:#1a1206;border-radius:2px}
.ba-handle:focus-visible{outline:2px solid #fff;outline-offset:3px}

@media (max-width:760px){
  /* Le slider draggable ne fonctionne pas avec du texte sur petit écran :
     on bascule en deux cartes empilées, claires et lisibles. */
  .ba{position:static;min-height:0;border:none;box-shadow:none;cursor:default;
    display:grid;grid-template-columns:1fr;gap:1rem;overflow:visible}
  .ba-pane{position:static;inset:auto;clip-path:none !important;filter:none;
    border:1px solid var(--line);border-radius:16px;padding:1.4rem 1.3rem 1.3rem}
  .ba-before{background:linear-gradient(135deg,#181c28,#0e1119);border-color:rgba(255,120,100,.28)}
  .ba-after{background:linear-gradient(135deg,#101a3e,#0a0f26);border-color:rgba(255,180,84,.35)}
  .ba-tag{position:static;display:inline-block;margin-bottom:1rem}
  .ba-tag-after{right:auto}
  .ba-list{max-width:none}
  .ba-after .ba-list{margin-left:0;text-align:left}
  .ba-after .ba-list li{padding-left:1.6rem;padding-right:0}
  .ba-after .ba-list li::before{left:0;right:auto}
  .ba-handle{display:none}
  .hero-proof{gap:1.4rem}
}
@media (prefers-reduced-motion:reduce){
  .hero-grid,.hero-glow,.hero-scan,.hero-scroll span{animation:none}
  .reveal-up{opacity:1;transform:none;animation:none}
}

/* ---------- Portfolio V5.3 : vraie capture plein cadre ---------- */

/* quand la capture mShots charge, on masque la scène décorative + le gros téléphone */


/* mShots renvoie parfois une image d'attente grise : léger fond pour éviter le flash blanc */
.pf-visual{background:linear-gradient(135deg,#0e1638,#0a0f26)}
.pf-card{transition:transform .4s cubic-bezier(.16,.8,.3,1),box-shadow .4s}
.pf-card:hover{transform:translateY(-8px);box-shadow:0 40px 80px -40px rgba(0,0,0,.7)}


/* ---------- Leviers en vignettes photo (remplace les listes) ---------- */
.levier-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.6rem}
.levier-ph{position:relative;aspect-ratio:4/5;border-radius:16px;overflow:hidden;display:block;
  border:1px solid var(--line);transition:transform .4s cubic-bezier(.16,.8,.3,1),box-shadow .4s}
.levier-ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s}
.levier-ph:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(255,180,84,.4);border-color:rgba(255,180,84,.4)}
.levier-ph:hover img{transform:scale(1.07)}
.levier-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,11,30,.15) 25%,rgba(7,11,30,.93) 100%)}
.levier-txt{position:absolute;left:0;right:0;bottom:0;padding:1.1rem;z-index:2}
.levier-txt .mono{color:var(--sodium);display:block;margin-bottom:.3rem}
.levier-txt h3{margin:0 0 .25rem;font-size:1.15rem}
.levier-txt p{margin:0;color:var(--brume);font-size:.86rem;line-height:1.4}
@media (max-width:760px){.levier-photos{grid-template-columns:1fr;gap:.8rem}.levier-ph{aspect-ratio:16/10}}

/* ============================================================
   V5.3 — Fonds de secours riches : aucune zone vide si une
   image externe ne charge pas. Chaque conteneur a un dégradé.
   ============================================================ */
.sector-hero{background:
  radial-gradient(90% 80% at 78% 12%, color-mix(in srgb,var(--sodium) 22%,transparent), transparent 60%),
  radial-gradient(80% 90% at 12% 90%, color-mix(in srgb,var(--lumen) 20%,transparent), transparent 60%),
  linear-gradient(160deg,#0e1638 0%,#070b1e 70%)}
.what-photo,.levier-ph{background:
  linear-gradient(150deg, color-mix(in srgb,var(--lumen) 26%,#0c1230), #0a0f26 75%)}
.strip{background:linear-gradient(120deg,#11183a,#0a0f26)}
.page-hero.has-photo,.err-hero.has-photo{background:
  radial-gradient(80% 70% at 80% 0%, color-mix(in srgb,var(--sodium) 16%,transparent), transparent 60%),
  linear-gradient(160deg,#0d1430,#070b1e)}
.pf-visual{background:
  radial-gradient(70% 80% at 75% 20%, color-mix(in srgb,var(--sodium) 22%,transparent), transparent 60%),
  linear-gradient(150deg,#101838,#0a0f26)}
/* l'image, quand elle charge, recouvre le dégradé ; sinon le dégradé reste visible */
.hero-photo,.what-photo img,.levier-ph img,.strip-img,.page-hero-photo{background:transparent}

/* ---------- Hero secteur : réduire la zone vide quand pas de photo ---------- */
.sector-hero{min-height:clamp(440px,62vh,580px)}

/* ============================================================
   V6 — visual-first : hero split 3D, vidéos métier, cards photo
   ============================================================ */

/* ---------- Hero split (texte gauche / visuel 3D droite, façon modèle V6) ---------- */
.hero-split{position:relative;min-height:96svh;display:flex;align-items:center;overflow:hidden;
  isolation:isolate;padding:6rem 0 3rem}
.hero-split-in{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,4vw,3.4rem);
  align-items:center;position:relative;z-index:2}
.hero-copy{max-width:600px}
.hero-split .hero-title{font-size:clamp(2.4rem,5.2vw,4.4rem);text-align:left}
.hero-split .hero-sub{margin-inline:0;max-width:42ch}
.hero-split .cta-row{justify-content:flex-start}
.hero-split .hero-proof{justify-content:flex-start;margin-top:2.4rem}
.hero-split .hero-stat-l{text-align:left}

.hero-visual{position:relative;border-radius:34px;min-height:clamp(380px,52vw,560px);overflow:hidden;
  border:1px solid var(--line);box-shadow:0 50px 110px -50px rgba(0,0,0,.85);
  transform:perspective(1100px) rotateY(-7deg) rotateX(2.5deg);transform-style:preserve-3d;
  transition:transform .6s cubic-bezier(.16,.8,.3,1)}
.hero-visual:hover{transform:perspective(1100px) rotateY(-3deg) rotateX(1deg) scale(1.015)}
.hero-visual-img,.hero-visual-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-visual-video{z-index:1;opacity:0;transition:opacity 1s ease}
.hero-visual-video.on{opacity:1}
.hero-visual-veil{position:absolute;inset:0;z-index:2;
  background:linear-gradient(to top,rgba(5,8,24,.85),rgba(5,8,24,.04))}
.hero-visual-card{position:absolute;left:20px;right:20px;bottom:20px;z-index:3;padding:18px 20px;
  border-radius:20px;background:rgba(10,15,38,.72);backdrop-filter:blur(16px)}
.hero-visual-card b{font-family:var(--font-display);font-size:1.05rem;color:var(--sodium)}
.hero-visual-card p{margin:.3rem 0 0;font-size:.9rem;color:var(--brume)}

/* ---------- Vidéo métier dans le hero secteur ---------- */
.hero-cine-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;
  opacity:0;transition:opacity 1.1s ease}
.hero-cine-video.on{opacity:.66}
.sector-hero .hero-photo{z-index:0}

/* ---------- Cartes secteurs façon V6 (grande photo + corps) ---------- */
.sector-card .sector-media{height:230px;overflow:hidden}
.sector-card .sector-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.sector-card:hover .sector-media img{transform:scale(1.08)}

@media (max-width:920px){
  .hero-split-in{grid-template-columns:1fr;gap:2rem}
  .hero-visual{transform:none;min-height:300px;order:-1}
  .hero-split .hero-title{font-size:clamp(2.2rem,8vw,3rem)}
}
@media (prefers-reduced-motion:reduce){
  .hero-visual{transform:none}
  .hero-cine-video,.hero-visual-video{display:none}
}

/* ============================================================
   V6 fusion — pages IA & sur-mesure enrichies
   ============================================================ */

/* ---------- Hero IA : split copy + carte agent flottante + stats ---------- */
.ia-hero{padding-bottom:0}
.ia-hero-in{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(1.6rem,4vw,3rem);align-items:center;position:relative;z-index:2}
.ia-agent-card{padding:1.5rem 1.6rem;border-radius:22px;align-self:center}
.ia-agent-head{display:flex;align-items:center;gap:.8rem;margin-bottom:1.2rem}
.ia-agent-badge{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--sodium),#ffd9a0);color:#1a1206;font-weight:800;font-size:.9rem}
.ia-agent-head b{display:block;font-family:var(--font-display);font-size:1rem}
.ia-agent-head span{font-size:.82rem;color:var(--brume)}
.ia-agent-pulse{margin-left:auto;width:10px;height:10px;border-radius:50%;background:#7FD8A8;box-shadow:0 0 0 0 rgba(127,216,168,.6);animation:pulse 2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 12px rgba(127,216,168,0)}100%{box-shadow:0 0 0 0 rgba(127,216,168,0)}}
.ia-agent-rows{margin:0;display:flex;flex-direction:column;gap:.7rem}
.ia-agent-rows div{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding-bottom:.7rem;border-bottom:1px solid var(--line)}
.ia-agent-rows div:last-child{border-bottom:none;padding-bottom:0}
.ia-agent-rows dt{color:var(--brume);font-size:.86rem}
.ia-agent-rows dd{margin:0;font-weight:600;font-size:.9rem;text-align:right}
.ia-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:2.4rem;
  padding:1.6rem 0;border-top:1px solid var(--line)}
.ia-stat{text-align:center}
.ia-stat-n{display:block;font-family:var(--font-display);font-weight:700;font-size:clamp(1.5rem,3vw,2.2rem);
  background:linear-gradient(120deg,#fff,var(--sodium));-webkit-background-clip:text;background-clip:text;color:transparent}
.ia-stat-l{font-size:.78rem;color:var(--brume)}

/* ---------- Cartes agents : vignette photo + accent ---------- */
.agent-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;margin-top:1.6rem}
.agent-card{overflow:hidden;border-radius:18px;display:flex;flex-direction:column;transition:transform .4s cubic-bezier(.16,.8,.3,1),border-color .4s}
.agent-card:hover{transform:translateY(-6px);border-color:rgba(255,180,84,.4)}
.agent-thumb{position:relative;height:140px;overflow:hidden}
.agent-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.agent-card:hover .agent-thumb img{transform:scale(1.08)}
.agent-thumb-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,11,30,.2),rgba(7,11,30,.92))}
.agent-n{position:absolute;left:1rem;bottom:.7rem;font-size:1.5rem;font-weight:700;color:var(--sodium);z-index:2}
.agent-body{padding:1.3rem 1.4rem}
.agent-body h3{margin:0 0 .2rem;font-size:1.2rem}
.agent-sub{color:var(--sodium);font-size:.9rem;margin:0 0 .7rem}
.agent-desc{color:var(--brume);font-size:.92rem;margin:0 0 1rem}
.agent-meta{margin:0;display:grid;grid-template-columns:auto 1fr;gap:.3rem .8rem;font-size:.84rem}
.agent-meta dt{color:var(--sodium);font-weight:600}
.agent-meta dd{margin:0;color:var(--brume)}

/* ---------- Sur-mesure : build-grid (6 types) + budgets ---------- */
.build-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1.6rem}
.build-card{overflow:hidden;border-radius:18px;transition:transform .4s cubic-bezier(.16,.8,.3,1),border-color .4s}
.build-card:hover{transform:translateY(-6px);border-color:rgba(255,180,84,.4)}
.build-thumb{position:relative;height:150px;overflow:hidden}
.build-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.build-card:hover .build-thumb img{transform:scale(1.08)}
.build-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,11,30,.15),rgba(7,11,30,.82))}
.build-body{padding:1.3rem 1.4rem}
.build-body h3{margin:0 0 .4rem;font-size:1.15rem}
.build-body p{margin:0;color:var(--brume);font-size:.9rem;line-height:1.5}
.budget-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1.6rem}
.budget-card{padding:1.6rem;border-radius:16px}
.budget-card.budget-mid{border-color:rgba(255,180,84,.4);background:rgba(255,180,84,.05)}
.budget-range{display:block;font-size:1.15rem;color:var(--sodium);font-weight:700;margin-bottom:.6rem}
.budget-card p{margin:0;color:var(--brume);font-size:.9rem;line-height:1.5}

@media (max-width:920px){
  .ia-hero-in{grid-template-columns:1fr}
  .ia-agent-card{order:-1}
  .ia-stats{grid-template-columns:repeat(2,1fr)}
  .agent-grid,.build-grid,.budget-grid{grid-template-columns:1fr}
}

/* ---------- Cartes agents : glyphes graphiques (remplacent les vignettes photo) ---------- */
.agent-glyph{position:relative;height:120px;display:flex;align-items:center;justify-content:center;
  overflow:hidden;border-bottom:1px solid var(--line)}
.agent-glyph svg{position:relative;z-index:2;color:#fff;opacity:.92}
.agent-glyph .agent-n{position:absolute;right:1rem;bottom:.6rem;font-size:1.5rem;font-weight:700;
  color:rgba(255,255,255,.85);z-index:2}
.agent-glyph::before{content:"";position:absolute;inset:0;z-index:0;opacity:.9}
.agent-glyph::after{content:"";position:absolute;inset:0;z-index:1;
  background:radial-gradient(120% 100% at 20% 0%,rgba(255,255,255,.18),transparent 55%)}
.agent-glyph-a::before{background:linear-gradient(135deg,#ff8a4c,#b23c6e)}
.agent-glyph-b::before{background:linear-gradient(135deg,#6e8bff,#4c3cb2)}
.agent-glyph-c::before{background:linear-gradient(135deg,#34b2a0,#1c6e7e)}
.agent-glyph-d::before{background:linear-gradient(135deg,#ffb04c,#b2683c)}
.agent-glyph-e::before{background:linear-gradient(135deg,#a06eff,#5e3cb2)}
.agent-glyph-f::before{background:linear-gradient(135deg,#ff6e8a,#b23c5e)}

/* ============================================================
   V6.3 — glyphes graphiques (remplacent les photos non vérifiées)
   ============================================================ */
/* palette de dégradés réutilisable */
.wg-a{--wg1:#ff8a4c;--wg2:#b23c6e}
.wg-b{--wg1:#6e8bff;--wg2:#4c3cb2}
.wg-c{--wg1:#34b2a0;--wg2:#1c6e7e}
.wg-d{--wg1:#ffb04c;--wg2:#b2683c}
.wg-e{--wg1:#a06eff;--wg2:#5e3cb2}

/* Tuiles home en glyphes */
.what-grid-glyph{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}
.what-glyph{position:relative;display:flex;flex-direction:column;gap:.9rem;padding:1.4rem 1.3rem;
  border-radius:16px;border:1px solid var(--line);overflow:hidden;aspect-ratio:auto;
  transition:transform .35s cubic-bezier(.16,.8,.3,1),border-color .35s}
.what-glyph::before{content:"";position:absolute;inset:0;opacity:.14;z-index:0;
  background:linear-gradient(150deg,var(--wg1,#6e8bff),var(--wg2,#4c3cb2))}
.what-glyph:hover{transform:translateY(-5px);border-color:rgba(255,180,84,.4)}
.what-glyph .what-ic{position:relative;z-index:1;width:48px;height:48px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;color:#fff;
  background:linear-gradient(135deg,var(--wg1,#6e8bff),var(--wg2,#4c3cb2))}
.what-glyph .what-txt{position:relative;z-index:1}
.what-glyph .what-txt h3{margin:0 0 .25rem;font-size:1rem}
.what-glyph .what-txt p{margin:0;color:var(--brume);font-size:.82rem;line-height:1.4}

/* Leviers secteurs en glyphes */
.levier-glyph{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.6rem}
.levier-glyph .levier-ph{position:relative;display:flex;flex-direction:column;gap:1rem;padding:1.6rem 1.4rem;
  border-radius:16px;border:1px solid var(--line);overflow:hidden;aspect-ratio:auto;
  transition:transform .35s cubic-bezier(.16,.8,.3,1),border-color .35s}
.levier-glyph .levier-ph::before{content:"";position:absolute;inset:0;opacity:.13;z-index:0;
  background:linear-gradient(150deg,var(--wg1),var(--wg2))}
.levier-glyph .levier-ph:hover{transform:translateY(-5px);border-color:rgba(255,180,84,.4)}
.levier-ic{position:relative;z-index:1;width:46px;height:46px;border-radius:12px;display:flex;
  align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,var(--wg1),var(--wg2))}
.levier-glyph .levier-txt{position:relative;z-index:1}
.levier-glyph .levier-txt .mono{color:var(--sodium);display:block;margin-bottom:.2rem}
.levier-glyph .levier-txt h3{margin:0 0 .3rem;font-size:1.1rem}
.levier-glyph .levier-txt p{margin:0;color:var(--brume);font-size:.88rem;line-height:1.45}

/* Cartes sur-mesure en glyphes */
.build-glyph{position:relative;height:130px;display:flex;align-items:center;justify-content:center;
  overflow:hidden;border-bottom:1px solid var(--line);color:#fff}
.build-glyph svg{position:relative;z-index:2}
.build-glyph::before{content:"";position:absolute;inset:0;opacity:.92;z-index:0}
.build-glyph::after{content:"";position:absolute;inset:0;z-index:1;
  background:radial-gradient(120% 100% at 25% 0%,rgba(255,255,255,.16),transparent 55%)}
.build-glyph-a::before{background:linear-gradient(135deg,#ff8a4c,#b23c6e)}
.build-glyph-b::before{background:linear-gradient(135deg,#6e8bff,#4c3cb2)}
.build-glyph-c::before{background:linear-gradient(135deg,#34b2a0,#1c6e7e)}
.build-glyph-d::before{background:linear-gradient(135deg,#ffb04c,#b2683c)}
.build-glyph-e::before{background:linear-gradient(135deg,#a06eff,#5e3cb2)}
.build-glyph-f::before{background:linear-gradient(135deg,#ff6e8a,#b23c5e)}

@media (max-width:980px){
  .what-grid-glyph{grid-template-columns:repeat(2,1fr)}
  .levier-glyph{grid-template-columns:1fr}
}
@media (max-width:560px){
  .what-grid-glyph{grid-template-columns:1fr}
}

/* ============================================================
   V6.4 — enrichissement pages IA & sur-mesure
   ============================================================ */
.section-tint{background:linear-gradient(180deg,transparent,rgba(110,139,255,.04) 30%,rgba(110,139,255,.04) 70%,transparent)}

/* Cas d'usage (sur-mesure) */
.usecase-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;margin-top:1.8rem}
.usecase-card{padding:1.6rem 1.5rem;border-radius:16px;transition:transform .35s cubic-bezier(.16,.8,.3,1),border-color .35s}
.usecase-card:hover{transform:translateY(-5px);border-color:rgba(255,180,84,.4)}
.usecase-tag{display:inline-block;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--sodium);background:rgba(255,180,84,.1);border:1px solid rgba(255,180,84,.25);
  padding:.3rem .7rem;border-radius:999px;margin-bottom:1rem}
.usecase-card h3{margin:0 0 .5rem;font-size:1.2rem}
.usecase-card>p{margin:0 0 1rem;color:var(--brume);font-size:.92rem;line-height:1.5}
.usecase-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.5rem}
.usecase-list li{font-size:.78rem;color:var(--ivoire);background:rgba(238,240,251,.05);
  border:1px solid var(--line);border-radius:999px;padding:.3rem .7rem}
.usecase-list li::before{content:"✓ ";color:var(--sodium)}

/* Technologies (sur-mesure) */
.tech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.8rem}
.tech-chip{padding:1.3rem 1.4rem;border-radius:14px}
.tech-chip b{display:block;font-family:var(--font-display);color:var(--sodium);font-size:1rem;margin-bottom:.3rem}
.tech-chip span{color:var(--brume);font-size:.86rem;line-height:1.4}

/* FAQ (sur-mesure + réutilisable) */
.faq-list{display:flex;flex-direction:column;gap:.8rem;margin-top:1.8rem;max-width:780px}
.faq-item{border-radius:14px;padding:0;overflow:hidden}
.faq-item summary{padding:1.15rem 1.4rem;cursor:pointer;font-family:var(--font-display);font-weight:600;
  font-size:1.02rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--sodium);font-size:1.5rem;font-weight:300;transition:transform .3s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{margin:0;padding:0 1.4rem 1.3rem;color:var(--brume);font-size:.92rem;line-height:1.55}

/* Démo de conversation (IA) */
.chat-demo{max-width:560px;margin:1.8rem auto 0;border-radius:20px;overflow:hidden;padding:0}
.chat-head{display:flex;align-items:center;gap:.6rem;padding:1rem 1.3rem;border-bottom:1px solid var(--line);
  font-size:.86rem;color:var(--brume);font-family:var(--font-display)}
.chat-dot{width:9px;height:9px;border-radius:50%;background:#7FD8A8;box-shadow:0 0 0 0 rgba(127,216,168,.6);animation:pulse 2s infinite}
.chat-body{padding:1.3rem;display:flex;flex-direction:column;gap:.7rem}
.chat-msg{max-width:80%;padding:.7rem .9rem;border-radius:14px;position:relative}
.chat-msg p{margin:0;font-size:.9rem;line-height:1.4}
.chat-time{display:block;font-size:.66rem;opacity:.6;margin-top:.3rem}
.chat-in{align-self:flex-start;background:rgba(238,240,251,.07);border-bottom-left-radius:4px}
.chat-out{align-self:flex-end;background:linear-gradient(135deg,rgba(255,180,84,.22),rgba(255,180,84,.12));
  border:1px solid rgba(255,180,84,.25);border-bottom-right-radius:4px}
.chat-foot{margin:0;padding:.9rem 1.3rem;border-top:1px solid var(--line);font-size:.78rem;
  color:var(--sodium);text-align:center}

/* Garde-fous (IA) */
.guard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;margin-top:1.8rem}
.guard-card{padding:1.5rem 1.5rem;border-radius:16px}
.guard-ic{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  color:#fff;margin-bottom:1rem;background:linear-gradient(135deg,var(--wg1,#6e8bff),var(--wg2,#4c3cb2))}
.guard-card h3{margin:0 0 .4rem;font-size:1.12rem}
.guard-card p{margin:0;color:var(--brume);font-size:.9rem;line-height:1.5}

@media (max-width:760px){
  .usecase-grid,.tech-grid,.guard-grid{grid-template-columns:1fr}
  .chat-msg{max-width:88%}
}

/* ============================================================
   V7 — Hero composé : mini-interfaces flottantes (montre les 4 services)
   ============================================================ */
.hero-stage{position:relative;min-height:clamp(420px,46vw,560px);perspective:1400px}
.hero-stage-glow{position:absolute;inset:-10% -5%;z-index:0;
  background:radial-gradient(50% 50% at 60% 35%,color-mix(in srgb,var(--sodium) 28%,transparent),transparent 70%),
  radial-gradient(45% 45% at 30% 80%,color-mix(in srgb,var(--lumen) 26%,transparent),transparent 70%);
  filter:blur(20px)}
.hs-card{position:absolute;border-radius:18px;background:linear-gradient(150deg,rgba(20,27,58,.96),rgba(11,16,38,.96));
  border:1px solid rgba(255,255,255,.1);box-shadow:0 30px 70px -30px rgba(0,0,0,.85);
  backdrop-filter:blur(14px);transform-style:preserve-3d}

/* Carte Google Business (centre, la plus grande) */
.hs-gbp{left:6%;top:14%;width:62%;padding:1.1rem 1.2rem;z-index:3;
  transform:rotateY(8deg) rotateX(3deg);animation:hsFloat1 7s ease-in-out infinite}
.hs-gbp-head{display:flex;align-items:center;gap:.7rem;margin-bottom:.9rem}
.hs-gbp-logo{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-weight:800;color:#1a1206;background:linear-gradient(135deg,var(--sodium),#ffd9a0);font-family:var(--font-display)}
.hs-gbp-id b{display:block;font-size:.92rem;color:var(--ivoire)}
.hs-gbp-id span{font-size:.74rem;color:var(--brume)}
.hs-gbp-rating{display:flex;align-items:center;gap:.5rem;margin-bottom:.8rem}
.hs-gbp-rating b{font-size:1.5rem;font-family:var(--font-display);color:var(--ivoire)}
.hs-stars{color:var(--sodium);font-size:.85rem;letter-spacing:.05em}
.hs-gbp-count{font-size:.72rem;color:var(--brume)}
.hs-gbp-actions{display:flex;gap:.4rem;margin-bottom:.9rem}
.hs-chip{font-size:.68rem;padding:.3rem .6rem;border-radius:999px;border:1px solid var(--line);color:var(--brume)}
.hs-chip-on{background:var(--sodium);color:#1a1206;border-color:transparent;font-weight:600}
.hs-gbp-bars{display:flex;gap:.4rem;align-items:flex-end;height:30px}
.hs-gbp-bars i{flex:1;height:var(--w);background:linear-gradient(180deg,var(--sodium),transparent);
  border-radius:3px 3px 0 0;opacity:.5}

/* Aperçu site web (haut droite) */
.hs-site{right:2%;top:2%;width:42%;z-index:4;overflow:hidden;
  transform:rotateY(-10deg) rotateX(3deg);animation:hsFloat2 8s ease-in-out infinite}
.hs-site-bar{display:flex;align-items:center;gap:.3rem;padding:.5rem .7rem;background:rgba(0,0,0,.3);border-bottom:1px solid var(--line)}
.hs-site-bar span{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.25)}
.hs-site-bar em{margin-left:.4rem;font-style:normal;font-size:.6rem;color:var(--brume)}
.hs-site-body{padding:.8rem}
.hs-site-hero{height:42px;border-radius:7px;margin-bottom:.6rem;
  background:linear-gradient(120deg,color-mix(in srgb,var(--sodium) 40%,transparent),color-mix(in srgb,var(--lumen) 40%,transparent))}
.hs-site-ln{height:6px;border-radius:3px;background:rgba(255,255,255,.16);margin-bottom:.4rem}
.hs-w70{width:70%}.hs-w50{width:50%}
.hs-site-cta{margin-top:.6rem;width:42%;height:16px;border-radius:5px;background:var(--sodium);opacity:.85}

/* Notification avis (bas gauche) */
.hs-notif{left:0;bottom:6%;width:50%;padding:.7rem .9rem;z-index:5;display:flex;align-items:center;gap:.6rem;
  animation:hsFloat2 6.5s ease-in-out infinite}
.hs-notif-ic{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,180,84,.18);color:var(--sodium);font-size:.9rem;flex-shrink:0}
.hs-notif-tx b{display:block;font-size:.76rem;color:var(--ivoire)}
.hs-notif-tx span{font-size:.68rem;color:var(--brume)}

/* Bulle IA (bas droite) */
.hs-ai{right:5%;bottom:0;width:54%;padding:.8rem .9rem;z-index:6;animation:hsFloat1 7.5s ease-in-out infinite}
.hs-ai-head{display:flex;align-items:center;gap:.4rem;font-size:.68rem;color:var(--brume);margin-bottom:.6rem}
.hs-ai-dot{width:7px;height:7px;border-radius:50%;background:#7FD8A8;box-shadow:0 0 0 0 rgba(127,216,168,.6);animation:pulse 2s infinite}
.hs-ai-msg{font-size:.74rem;color:var(--ivoire);background:rgba(255,255,255,.06);padding:.4rem .6rem;
  border-radius:10px 10px 10px 2px;margin-bottom:.4rem;display:inline-block}
.hs-ai-reply{font-size:.74rem;color:#1a1206;background:var(--sodium);padding:.4rem .6rem;
  border-radius:10px 10px 2px 10px;margin-left:auto;display:inline-block;float:right;font-weight:500}

@keyframes hsFloat1{0%,100%{transform:rotateY(8deg) rotateX(3deg) translateY(0)}50%{transform:rotateY(8deg) rotateX(3deg) translateY(-12px)}}
@keyframes hsFloat2{0%,100%{transform:rotateY(-10deg) rotateX(3deg) translateY(0)}50%{transform:rotateY(-10deg) rotateX(3deg) translateY(10px)}}

/* Mobile : composition simplifiée, empilée proprement, pas trop haute */
@media (max-width:920px){
  .hero-stage{min-height:340px;margin-top:1.5rem;perspective:none}
  .hs-card{animation:none !important;transform:none !important;backdrop-filter:blur(8px)}
  .hs-gbp{position:relative;left:0;top:0;width:100%;margin-bottom:-1.5rem}
  .hs-site{display:none}
  .hs-notif{left:0;bottom:auto;position:relative;width:64%;margin:0 0 .8rem auto}
  .hs-ai{position:relative;right:0;bottom:0;width:100%}
  .hs-ai-reply{float:none;margin-left:0}
}
@media (prefers-reduced-motion:reduce){.hs-card{animation:none !important}}

/* ============================================================
   V7 — Page IA : agents compacts, timeline workflow, scénarios mini
   ============================================================ */
/* Agents en grille compacte (3 cols, peu de texte) */
.agent-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.6rem}
.agent-mini{padding:1.3rem 1.3rem;border-radius:16px;transition:transform .35s cubic-bezier(.16,.8,.3,1),border-color .35s}
.agent-mini:hover{transform:translateY(-5px);border-color:rgba(255,180,84,.4)}
.agent-mini-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9rem}
.agent-mini-ic{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;
  color:#fff;background:linear-gradient(135deg,var(--wg1,#6e8bff),var(--wg2,#4c3cb2))}
.agent-mini-n{font-size:1.2rem;font-weight:700;color:rgba(255,255,255,.25)}
.agent-mini h3{margin:0 0 .4rem;font-size:1.1rem}
.agent-mini-desc{margin:0 0 .8rem;color:var(--brume);font-size:.88rem;line-height:1.45}
.agent-mini-for{margin:0;font-size:.78rem;color:var(--ivoire);padding-top:.7rem;border-top:1px solid var(--line)}
.agent-mini-for span{color:var(--sodium);font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:.68rem}
/* glyph color vars pour les mini-ic */
.agent-glyph-a{--wg1:#ff8a4c;--wg2:#b23c6e}.agent-glyph-b{--wg1:#6e8bff;--wg2:#4c3cb2}
.agent-glyph-c{--wg1:#34b2a0;--wg2:#1c6e7e}.agent-glyph-d{--wg1:#ffb04c;--wg2:#b2683c}
.agent-glyph-e{--wg1:#a06eff;--wg2:#5e3cb2}.agent-glyph-f{--wg1:#ff6e8a;--wg2:#b23c5e}

/* Timeline workflow horizontale */
.flow-line{list-style:none;margin:2rem 0 0;padding:0;display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;position:relative}
.flow-line::before{content:"";position:absolute;top:18px;left:8%;right:8%;height:2px;
  background:linear-gradient(90deg,var(--sodium),var(--lumen));opacity:.4;z-index:0}
.flow-step{display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;z-index:1;gap:.3rem}
.flow-dot{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:700;color:#1a1206;
  background:linear-gradient(135deg,var(--sodium),#ffd9a0);box-shadow:0 6px 18px -6px rgba(255,180,84,.6);margin-bottom:.4rem}
.flow-step b{font-size:.92rem;color:var(--ivoire)}
.flow-step span{font-size:.74rem;color:var(--brume);line-height:1.3}

/* Scénarios mini */
.scenario-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.6rem}
.scenario-card{padding:1.5rem 1.4rem;border-radius:16px;text-align:center;transition:transform .35s,border-color .35s}
.scenario-card:hover{transform:translateY(-5px);border-color:rgba(255,180,84,.4)}
.scenario-ic{font-size:2rem;display:block;margin-bottom:.6rem}
.scenario-card h3{margin:0 0 .4rem;font-size:1.15rem}
.scenario-card p{margin:0;color:var(--brume);font-size:.88rem;line-height:1.4}

@media (max-width:760px){
  .agent-mini-grid,.scenario-grid{grid-template-columns:1fr}
  .flow-line{grid-template-columns:1fr;gap:1.2rem}
  .flow-line::before{left:18px;top:8%;bottom:8%;right:auto;width:2px;height:auto}
  .flow-step{flex-direction:row;text-align:left;gap:.8rem;align-items:center}
  .flow-dot{margin-bottom:0;flex-shrink:0}
  .flow-step b{font-size:1rem}
}

/* ============================================================
   V7 — Sur-mesure : mini-mockups d'interface produit
   ============================================================ */
.build-card{overflow:hidden;border-radius:18px;transition:transform .4s cubic-bezier(.16,.8,.3,1),border-color .4s,box-shadow .4s}
.build-card:hover{transform:translateY(-6px);border-color:rgba(255,180,84,.4);box-shadow:0 30px 60px -34px rgba(255,180,84,.3)}
.mock{height:140px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;
  padding:1.2rem;background:radial-gradient(120% 100% at 50% 0%,rgba(110,139,255,.1),transparent 70%),linear-gradient(160deg,#0e1430,#0a0f26)}
.mock>*{position:relative;z-index:1}
.build-card:hover .mock>*{transform:translateY(-3px);transition:transform .5s}

/* App mobile */
.mock-app-screen{width:96px;height:130px;border-radius:14px;background:linear-gradient(160deg,#141b3a,#0c1124);
  border:1px solid rgba(255,255,255,.12);padding:8px;box-shadow:0 16px 36px -16px rgba(0,0,0,.7);display:flex;flex-direction:column;gap:5px}
.mock-app-bar{height:8px;width:50%;border-radius:3px;background:var(--sodium);opacity:.8}
.mock-app-card{height:30px;border-radius:6px;background:linear-gradient(120deg,rgba(255,180,84,.4),rgba(110,139,255,.3))}
.mock-app-row{display:flex;gap:4px}.mock-app-row span{flex:1;height:7px;border-radius:3px;background:rgba(255,255,255,.14)}
.mock-app-tab{margin-top:auto;display:flex;gap:5px;justify-content:center}
.mock-app-tab i{width:7px;height:7px;border-radius:2px;background:rgba(255,255,255,.18)}.mock-app-tab i.on{background:var(--sodium)}

/* Dashboard */
.mock-dash{flex-direction:column;gap:10px}
.mock-dash-top{display:flex;gap:8px;width:80%}
.mock-kpi{flex:1;height:26px;border-radius:7px;background:linear-gradient(135deg,rgba(255,180,84,.3),rgba(255,180,84,.1));border:1px solid rgba(255,180,84,.2)}
.mock-chart{display:flex;align-items:flex-end;gap:7px;height:60px;width:80%}
.mock-chart i{flex:1;height:var(--h);border-radius:4px 4px 0 0;background:linear-gradient(180deg,var(--sodium),rgba(255,180,84,.2))}

/* Web platform */
.mock-web{width:78%;height:120px;border-radius:10px;background:#0c1124;border:1px solid rgba(255,255,255,.12);overflow:hidden;padding:0;flex-direction:column;align-items:stretch}
.mock-web-bar{display:flex;gap:4px;padding:7px 9px;background:rgba(0,0,0,.3)}
.mock-web-bar span{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.25)}
.mock-web-body{padding:9px}
.mock-web-nav{display:flex;gap:6px;margin-bottom:8px}.mock-web-nav i{width:18px;height:5px;border-radius:2px;background:rgba(255,255,255,.18)}
.mock-web-hero{height:34px;border-radius:6px;margin-bottom:8px;background:linear-gradient(120deg,rgba(255,180,84,.4),rgba(110,139,255,.35))}
.mock-web-grid{display:flex;gap:6px}.mock-web-grid u{flex:1;height:22px;border-radius:5px;background:rgba(255,255,255,.1)}

/* CRM / client */
.mock-crm{flex-direction:column;gap:9px;width:84%}
.mock-crm-row{display:flex;align-items:center;gap:9px}
.mock-av{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--sodium),#ffd9a0);flex-shrink:0}
.mock-ln{height:8px;border-radius:4px;background:rgba(255,255,255,.16)}.mock-w60{width:60%}.mock-w80{width:80%}.mock-w50{width:50%}
.mock-badge{margin-left:auto;width:30px;height:14px;border-radius:7px;background:rgba(127,216,168,.3);border:1px solid rgba(127,216,168,.4);flex-shrink:0}
.mock-badge-2{background:rgba(255,180,84,.25);border-color:rgba(255,180,84,.4)}

/* Flow / automatisation */
.mock-flow{gap:6px}
.mock-flow-node{padding:.5rem .7rem;border-radius:8px;background:rgba(255,255,255,.07);border:1px solid var(--line);
  font-size:.72rem;color:var(--brume)}
.mock-flow-on{background:var(--sodium);color:#1a1206;border-color:transparent;font-weight:600}
.mock-flow-arr{width:14px;height:2px;background:var(--sodium);opacity:.5;position:relative}
.mock-flow-arr::after{content:"";position:absolute;right:-2px;top:-2px;width:5px;height:5px;border-top:2px solid var(--sodium);border-right:2px solid var(--sodium);transform:rotate(45deg)}

/* Calendrier */
.mock-cal{flex-direction:column;gap:7px;width:78%}
.mock-cal-head{display:flex;gap:6px}.mock-cal-head i{flex:1;height:8px;border-radius:2px;background:rgba(255,255,255,.2)}
.mock-cal-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}
.mock-cal-grid u{aspect-ratio:1;border-radius:4px;background:rgba(255,255,255,.1)}
.mock-cal-grid u.on{background:var(--sodium);opacity:.85}

.build-body{padding:1.2rem 1.3rem}
.build-body h3{margin:0 0 .3rem;font-size:1.1rem}
.build-body p{margin:0;color:var(--brume);font-size:.86rem;line-height:1.45}

/* ============================================================
   V7.1 — Mise en scène : profondeur, halos atmosphériques, lumière
   ============================================================ */
/* Halos d'ambiance globaux qui transparaissent derrière le contenu */
body{position:relative}
body::before{content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(40% 30% at 85% 8%, color-mix(in srgb,var(--sodium) 16%,transparent), transparent 70%),
    radial-gradient(45% 35% at 10% 28%, color-mix(in srgb,var(--lumen) 18%,transparent), transparent 70%),
    radial-gradient(50% 40% at 92% 65%, color-mix(in srgb,var(--lumen) 12%,transparent), transparent 70%),
    radial-gradient(40% 30% at 5% 88%, color-mix(in srgb,var(--sodium) 12%,transparent), transparent 70%)}
/* Grain subtil pour texture premium */
body::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* Section avec halo d'accent qui "respire" derrière */
.section-aura{position:relative}
.section-aura::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(60% 50% at 50% 0%, color-mix(in srgb,var(--lumen) 14%,transparent), transparent 70%)}
.section-aura-warm::before{background:radial-gradient(60% 50% at 50% 0%, color-mix(in srgb,var(--sodium) 14%,transparent), transparent 70%)}

/* Ligne lumineuse de séparation entre grandes sections */
.section-rule{position:relative}
.section-rule::before{content:"";position:absolute;top:0;left:15%;right:15%;height:1px;
  background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--sodium) 50%,transparent),transparent)}

/* Glow porté sur les cartes premium (au survol et au repos léger) */
.glass{position:relative}
.lift{transition:transform .4s cubic-bezier(.16,.8,.3,1),box-shadow .4s,border-color .4s}
.lift:hover{transform:translateY(-6px);border-color:color-mix(in srgb,var(--sodium) 45%,transparent);
  box-shadow:0 34px 70px -34px color-mix(in srgb,var(--sodium) 35%,transparent),0 0 0 1px color-mix(in srgb,var(--sodium) 12%,transparent)}

/* Halo derrière les mockups pour qu'ils "flottent" sur de la lumière */
.mock{position:relative}
.mock::after{content:"";position:absolute;inset:20% 15%;z-index:0;pointer-events:none;
  background:radial-gradient(60% 60% at 50% 40%, color-mix(in srgb,var(--sodium) 18%,transparent), transparent 70%);
  filter:blur(24px)}

/* ============================================================
   V7.2 — Pipeline IA : grosse mise en scène centrale
   ============================================================ */
.pipeline{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:1rem;align-items:center;margin-top:2.4rem}
.pl-stage{position:relative}
.pl-tag{display:block;font-size:.72rem;color:var(--sodium);margin-bottom:.8rem;letter-spacing:.04em}

/* Phone chat */
.pl-phone{background:linear-gradient(165deg,#141b3a,#0b1024);border:1px solid rgba(255,255,255,.12);
  border-radius:18px;padding:1rem;box-shadow:0 30px 60px -30px rgba(0,0,0,.8);display:flex;flex-direction:column;gap:.5rem}
.pl-bubble{max-width:85%;padding:.55rem .75rem;border-radius:13px;font-size:.82rem;line-height:1.35}
.pl-in{align-self:flex-start;background:rgba(238,240,251,.08);border-bottom-left-radius:3px;color:var(--ivoire)}
.pl-out{align-self:flex-end;background:linear-gradient(135deg,rgba(255,180,84,.28),rgba(255,180,84,.16));
  border:1px solid rgba(255,180,84,.3);border-bottom-right-radius:3px;color:var(--ivoire)}
.pl-typing{align-self:flex-start;display:flex;gap:4px;padding:.55rem .7rem;background:rgba(238,240,251,.08);border-radius:13px}
.pl-typing i{width:6px;height:6px;border-radius:50%;background:var(--brume);animation:plType 1.4s infinite}
.pl-typing i:nth-child(2){animation-delay:.2s}.pl-typing i:nth-child(3){animation-delay:.4s}
@keyframes plType{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}

/* Qualification card */
.pl-card{background:linear-gradient(165deg,#101a3e,#0a0f26);border:1px solid rgba(110,139,255,.25);
  border-radius:18px;padding:1.2rem;box-shadow:0 30px 60px -30px rgba(0,0,0,.8)}
.pl-row{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:.84rem}
.pl-row:last-child{border-bottom:none}
.pl-k{color:var(--brume)}.pl-v{color:var(--ivoire);font-weight:500}.pl-v-ok{color:#7FD8A8}
.pl-badge-ok{background:rgba(127,216,168,.18);color:#7FD8A8;border:1px solid rgba(127,216,168,.35);
  padding:.2rem .6rem;border-radius:999px;font-size:.74rem;font-weight:600}

/* Notifications */
.pl-notify{display:flex;flex-direction:column;gap:.7rem}
.pl-notif{display:flex;align-items:center;gap:.7rem;padding:.8rem .9rem;border-radius:14px;
  background:linear-gradient(150deg,rgba(20,27,58,.96),rgba(11,16,38,.96));border:1px solid rgba(255,255,255,.1);
  box-shadow:0 20px 44px -22px rgba(0,0,0,.7)}
.pl-notif-ic{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.95rem}
.pl-notif-a .pl-notif-ic{background:rgba(255,180,84,.2);color:var(--sodium)}
.pl-notif-b .pl-notif-ic{background:rgba(110,139,255,.2);color:var(--lumen)}
.pl-notif-c .pl-notif-ic{background:rgba(127,216,168,.2);color:#7FD8A8}
.pl-notif b{display:block;font-size:.82rem;color:var(--ivoire)}
.pl-notif span{font-size:.74rem;color:var(--brume)}

/* Flèches de flux */
.pl-flow{width:36px;height:2px;background:linear-gradient(90deg,var(--sodium),var(--lumen));position:relative;opacity:.6;align-self:center;margin-top:1.6rem}
.pl-flow::after{content:"";position:absolute;right:-3px;top:-3px;width:7px;height:7px;border-top:2px solid var(--lumen);border-right:2px solid var(--lumen);transform:rotate(45deg)}

@media (max-width:880px){
  .pipeline{grid-template-columns:1fr;gap:.5rem}
  .pl-flow{width:2px;height:32px;justify-self:center;margin:0;background:linear-gradient(180deg,var(--sodium),var(--lumen))}
  .pl-flow::after{right:auto;left:-3px;bottom:-3px;top:auto;transform:rotate(135deg)}
  .pl-stage{width:100%}
  .pl-tag{margin-top:.5rem}
}

/* ============================================================
   V7.2 — Dashboard mockup central (sur-mesure)
   ============================================================ */
.dashboard{display:grid;grid-template-columns:200px 1fr;gap:0;margin-top:2.4rem;border-radius:20px;overflow:hidden;
  background:linear-gradient(165deg,#0e1430,#0a0f24);border:1px solid rgba(255,255,255,.12);
  box-shadow:0 50px 100px -40px rgba(0,0,0,.85),0 0 0 1px rgba(255,180,84,.06)}
.db-side{background:rgba(0,0,0,.28);border-right:1px solid rgba(255,255,255,.07);padding:1.3rem 1rem}
.db-brand{display:flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-weight:600;font-size:.92rem;color:var(--ivoire);margin-bottom:1.6rem}
.db-brand-dot{width:22px;height:22px;border-radius:7px;background:linear-gradient(135deg,var(--sodium),#ffd9a0)}
.db-nav{display:flex;flex-direction:column;gap:.3rem}
.db-nav-i{display:flex;align-items:center;gap:.6rem;padding:.55rem .7rem;border-radius:9px;font-size:.82rem;color:var(--brume)}
.db-nav-i i{width:14px;height:14px;border-radius:4px;background:rgba(255,255,255,.16)}
.db-nav-i.db-on{background:rgba(255,180,84,.14);color:var(--ivoire)}
.db-nav-i.db-on i{background:var(--sodium)}
.db-main{padding:1.4rem}
.db-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem;margin-bottom:1.1rem}
.db-kpi{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:13px;padding:1rem}
.db-kpi-l{display:block;font-size:.74rem;color:var(--brume);margin-bottom:.3rem}
.db-kpi-n{display:block;font-size:1.7rem;font-family:var(--font-display);font-weight:700;color:var(--ivoire);line-height:1}
.db-kpi-spark{display:flex;align-items:flex-end;gap:3px;height:30px;margin:.2rem 0}
.db-kpi-spark i{flex:1;height:var(--h);border-radius:2px;background:linear-gradient(180deg,var(--sodium),rgba(255,180,84,.2))}
.db-kpi-ring{display:block;width:34px;height:34px;border-radius:50%;margin:.2rem 0;
  background:conic-gradient(var(--sodium) 78%,rgba(255,255,255,.1) 0);
  -webkit-mask:radial-gradient(circle 11px at center,transparent 98%,#000 100%);
  mask:radial-gradient(circle 11px at center,transparent 98%,#000 100%)}
.db-kpi-up{display:block;font-size:.68rem;color:#7FD8A8;margin-top:.3rem}
.db-chart{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:13px;padding:1.1rem;margin-bottom:1.1rem}
.db-chart-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.db-chart-head b{font-size:.9rem;color:var(--ivoire)}
.db-chart-tabs{display:flex;gap:.3rem}.db-chart-tabs i{width:22px;height:6px;border-radius:3px;background:rgba(255,255,255,.14)}
.db-chart-tabs i.db-on{background:var(--sodium)}
.db-bars{display:flex;align-items:flex-end;gap:.6rem;height:90px}
.db-bars i{flex:1;height:var(--h);border-radius:5px 5px 0 0;background:linear-gradient(180deg,var(--sodium),rgba(255,180,84,.15))}
.db-list{display:flex;flex-direction:column;gap:.6rem}
.db-li{display:flex;align-items:center;gap:.8rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:11px;padding:.7rem .9rem}
.db-av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--sodium),#ffd9a0);flex-shrink:0}
.db-av-2{background:linear-gradient(135deg,var(--lumen),#9db0ff)}
.db-li-tx{flex:1}.db-li-tx b{display:block;font-size:.82rem;color:var(--ivoire)}.db-li-tx span{font-size:.72rem;color:var(--brume)}
.db-li-badge{font-size:.7rem;padding:.25rem .6rem;border-radius:999px;font-weight:600}
.db-li-ok{background:rgba(127,216,168,.18);color:#7FD8A8;border:1px solid rgba(127,216,168,.3)}
.db-li-pending{background:rgba(255,180,84,.16);color:var(--sodium);border:1px solid rgba(255,180,84,.3)}

@media (max-width:760px){
  .dashboard{grid-template-columns:1fr}
  .db-side{display:flex;align-items:center;gap:1rem;border-right:none;border-bottom:1px solid rgba(255,255,255,.07);padding:1rem;overflow-x:auto}
  .db-brand{margin-bottom:0;flex-shrink:0}
  .db-nav{flex-direction:row;gap:.4rem}
  .db-nav-i{white-space:nowrap;font-size:.76rem;padding:.4rem .6rem}
  .db-nav-i i{display:none}
  .db-kpis{grid-template-columns:1fr;gap:.6rem}
  .db-kpi{display:flex;align-items:baseline;gap:.6rem}
  .db-kpi-n{font-size:1.3rem}
  .db-kpi-l,.db-kpi-up{margin:0}
}

/* ============================================================
   V7.3 — Fallbacks hero premium (si CDN image échoue, jamais de vide)
   ============================================================ */
.page-hero-fallback,.hero-photo-fallback{position:absolute;inset:0;z-index:0;overflow:hidden}
/* dégradés teintés par univers métier — restent visibles derrière l'image */
.hero-fb-restaurant{background:radial-gradient(80% 90% at 70% 20%,#3a1f1a,transparent 70%),linear-gradient(150deg,#1a1410,#0a0f24)}
.hero-fb-garage{background:radial-gradient(80% 90% at 70% 20%,#1a2740,transparent 70%),linear-gradient(150deg,#0e1626,#0a0f24)}
.hero-fb-barbier-coiffeur{background:radial-gradient(80% 90% at 70% 20%,#3a2a14,transparent 70%),linear-gradient(150deg,#1a160e,#0a0f24)}
.hero-fb-salon-de-beaute{background:radial-gradient(80% 90% at 70% 20%,#3a1f30,transparent 70%),linear-gradient(150deg,#180f1a,#0a0f24)}
.hero-fb-fitness-coaching{background:radial-gradient(80% 90% at 70% 20%,#142a2a,transparent 70%),linear-gradient(150deg,#0e1a1a,#0a0f24)}
.hero-fb-evenementiel-traiteur{background:radial-gradient(80% 90% at 70% 20%,#2a1f3a,transparent 70%),linear-gradient(150deg,#140f1a,#0a0f24)}
.hero-fb-immobilier{background:radial-gradient(80% 90% at 70% 20%,#1a2a3a,transparent 70%),linear-gradient(150deg,#0e1620,#0a0f24)}
.hero-fb-artisan-btp{background:radial-gradient(80% 90% at 70% 20%,#3a2f14,transparent 70%),linear-gradient(150deg,#1a160e,#0a0f24)}
/* heros pages principales */
.hero-fb-tech_ia{background:radial-gradient(80% 90% at 70% 20%,#1f2a4a,transparent 70%),linear-gradient(150deg,#0e1430,#0a0f24)}
.hero-fb-restaurant.page-hero-fallback{background:radial-gradient(80% 90% at 70% 20%,#3a1f1a,transparent 70%),linear-gradient(150deg,#1a1410,#0a0f24)}
.hero-fb-nuit{background:radial-gradient(80% 90% at 70% 20%,#1a2440,transparent 70%),linear-gradient(150deg,#0c1230,#0a0f24)}
/* la photo passe au-dessus du fallback */
.page-hero-photo,.hero-photo{position:relative;z-index:1}

/* ============================================================
   V7.4 — Logos outils reconnaissables (réutilisable, dark premium)
   ============================================================ */
.tool-strip{margin-top:2.2rem;display:flex;flex-direction:column;align-items:center;gap:1rem}
.tool-strip-label{font-size:.78rem;color:var(--brume);letter-spacing:.04em;text-align:center}
.tool-pills{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem;max-width:760px}
.tool-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .9rem .45rem .5rem;
  background:var(--glass);border:1px solid var(--line);border-radius:999px;
  font-size:.85rem;color:var(--ivoire);font-weight:500;line-height:1}
.tool-pill img{width:26px;height:26px;display:block}
/* en-tête d'app dans les maquettes de chat */
.pl-app{display:flex;align-items:center;gap:.5rem;margin:0 0 .7rem;padding-bottom:.6rem;
  border-bottom:1px solid rgba(255,255,255,.08)}
.pl-app img{width:24px;height:24px;display:block}
.pl-app b{font-size:.8rem;color:var(--ivoire);font-weight:600}
.pl-app .pl-app-on{margin-left:auto;font-size:.66rem;color:#7FD8A8;display:inline-flex;align-items:center;gap:.32rem}
.pl-app .pl-app-on::before{content:"";width:6px;height:6px;border-radius:50%;background:#7FD8A8;box-shadow:0 0 8px #7FD8A8}
/* logos dans les pastilles de notification */
.pl-notif-ic.has-logo{background:none !important}
.pl-notif-ic img{width:24px;height:24px;display:block}
/* mini-logos inline dans les cartes (home, sur-mesure) */
.io-logos{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.7rem}
.io-logos img{width:24px;height:24px;display:block}
.io-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.32rem .6rem .32rem .35rem;
  background:rgba(238,240,251,.05);border:1px solid var(--line);border-radius:999px;font-size:.74rem;color:var(--brume)}
.io-chip img{width:18px;height:18px}
/* logos dans les chips technologies (sur-mesure) */
.tech-chip .tech-logo{display:flex;gap:.45rem;margin-bottom:.7rem}
.tech-chip .tech-logo img{width:30px;height:30px;display:block}
