/* =====================================================================
   CT Web Empire — Feuille de style principale
   Studio numerique (Quebec) : sites web, applications, jeux, bots.
   Tout le CSS du site (variables, composants, responsive) vit ici.
   ===================================================================== */

:root{
  --bg:#0f1117;
  --bg-2:#141824;
  --surface:#161b28;
  --surface-2:#1c2233;
  --border:rgba(255,255,255,.08);
  --border-2:rgba(255,255,255,.14);
  --text:#eef2f9;
  --text-2:#a7b0c4;
  --text-3:#6b7488;
  --cyan:#22d3ee;
  --violet:#a855f7;
  --cyan-soft:rgba(34,211,238,.14);
  --violet-soft:rgba(168,85,247,.14);
  --grad:linear-gradient(120deg,#22d3ee 0%,#7c8cff 50%,#a855f7 100%);
  --grad-soft:linear-gradient(120deg,rgba(34,211,238,.18),rgba(168,85,247,.18));
  --glow-cyan:0 0 40px rgba(34,211,238,.35);
  --glow-violet:0 0 40px rgba(168,85,247,.35);
  --shadow:0 18px 50px -20px rgba(0,0,0,.7);
  --shadow-sm:0 8px 24px -12px rgba(0,0,0,.6);
  --font:'Sora',system-ui,-apple-system,sans-serif;
  --font-alt:'Space Grotesk',system-ui,sans-serif;
  --r-sm:10px; --r:16px; --r-lg:24px; --r-pill:999px;
  --maxw:1200px;
  --space:clamp(4rem,9vw,8rem);
  --ease:cubic-bezier(.16,1,.3,1);
  /* Hauteur reelle du header (clamp 64->78px). +18px de marge = 96px.
     Sert d'offset d'ancrage pour que les titres ne passent pas sous la barre. */
  --header-h:78px;
  --anchor-offset:96px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:var(--anchor-offset)}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  font-size:clamp(15px,1.05vw,16.5px);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(900px 500px at 78% -8%,rgba(168,85,247,.16),transparent 60%),
    radial-gradient(800px 480px at 8% 8%,rgba(34,211,238,.13),transparent 58%),
    radial-gradient(700px 700px at 50% 120%,rgba(124,140,255,.10),transparent 60%);
}
body::after{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);
  background-size:60px 60px;
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000,transparent 75%);
  mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000,transparent 75%);
}
/* Verrou de scroll quand le menu mobile plein ecran est ouvert */
body.menu-open{overflow:hidden}
main,header,footer{position:relative;z-index:1}
a{color:inherit;text-decoration:none}
ul{list-style:none}
img,svg{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--violet);color:#fff}
:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:6px}
.skip-link{position:absolute;left:-999px;top:0;z-index:200;background:var(--cyan);color:#0a0d14;padding:.7rem 1.2rem;border-radius:0 0 10px 0;font-weight:600}
.skip-link:focus{left:0}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.1rem,4vw,2.5rem)}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--font-alt);font-size:.72rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--cyan);padding:.4rem .85rem;border:1px solid var(--border-2);border-radius:var(--r-pill);
  background:rgba(34,211,238,.06);
}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan)}
/* Numero d'index de section (touche editoriale "agence", repris de B) */
.eyebrow .idx{font-family:var(--font-alt);font-weight:700;color:var(--violet);letter-spacing:.12em;opacity:.9}
.section-head{max-width:680px;margin:0 auto clamp(2.5rem,5vw,3.75rem);text-align:center}
.section-head h2{
  font-size:clamp(1.9rem,4.6vw,3rem);font-weight:700;line-height:1.1;letter-spacing:-.02em;margin:1.1rem 0 .9rem;
}
.section-head p{color:var(--text-2);font-size:clamp(1rem,1.4vw,1.12rem)}
section{padding:var(--space) 0}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--font);font-weight:600;font-size:.96rem;line-height:1;
  padding:.95rem 1.6rem;border-radius:var(--r-pill);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s,border-color .25s,color .25s;
  will-change:transform;white-space:nowrap;border:1px solid transparent;
}
.btn svg{width:18px;height:18px;flex-shrink:0}
.btn-primary{background:var(--grad);color:#0a0d14;box-shadow:0 10px 30px -8px rgba(34,211,238,.5)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 44px -10px rgba(168,85,247,.6)}
.btn-ghost{background:rgba(255,255,255,.03);color:var(--text);border-color:var(--border-2)}
.btn-ghost:hover{transform:translateY(-3px);border-color:var(--cyan);background:rgba(34,211,238,.07)}
.btn-block{width:100%}
.btn-sm{padding:.6rem 1.1rem;font-size:.85rem}

/* ===== HEADER ===== */
header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .35s,backdrop-filter .35s,border-color .35s,box-shadow .35s}
header.scrolled{background:rgba(15,17,23,.82);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);border-bottom:1px solid var(--border);box-shadow:0 10px 30px -20px rgba(0,0,0,.9)}
.nav{display:flex;align-items:center;justify-content:space-between;height:clamp(64px,8vw,78px);gap:1rem}
.logo{display:flex;align-items:center;gap:.7rem;font-weight:700;font-size:1.06rem;letter-spacing:-.01em;flex-shrink:0}
.logo .mark{width:40px;height:40px;flex-shrink:0;filter:drop-shadow(0 0 10px rgba(34,211,238,.4))}
.logo .name b{font-weight:700}
.logo .name .emp{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.nav-links{display:flex;align-items:center;gap:.35rem;margin-left:auto}
.nav-links a{
  font-size:.92rem;font-weight:500;color:var(--text-2);padding:.55rem .8rem;border-radius:var(--r-pill);
  transition:color .2s,background .2s;
}
.nav-links a:hover{color:var(--text);background:rgba(255,255,255,.04)}
.nav-right{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
/* Bascule de langue a DEUX boutons FR | EN (pattern repris de A, plus accessible) */
.lang-toggle{
  display:inline-flex;align-items:center;font-family:var(--font-alt);font-weight:600;font-size:.82rem;
  border:1px solid var(--border-2);border-radius:var(--r-pill);overflow:hidden;background:rgba(255,255,255,.02);
}
.lang-toggle button{padding:.42rem .7rem;color:var(--text-3);transition:color .2s,background .2s;line-height:1}
.lang-toggle button[aria-pressed="true"]{color:#0a0d14;background:var(--grad)}
.lang-toggle button:focus-visible{outline-offset:-2px}
.nav-cta{display:inline-flex}
.nav-links .nav-cta{display:none}/* CTA du menu reserve au tiroir mobile (evite le doublon + debordement desktop) */
.burger{display:none;width:44px;height:44px;border:1px solid var(--border-2);border-radius:12px;background:rgba(255,255,255,.02);position:relative}
.burger span{position:absolute;left:11px;right:11px;height:2px;background:var(--text);border-radius:2px;transition:transform .35s var(--ease),opacity .25s,top .35s var(--ease)}
.burger span:nth-child(1){top:15px}
.burger span:nth-child(2){top:21px}
.burger span:nth-child(3){top:27px}
body.menu-open .burger span:nth-child(1){top:21px;transform:rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){top:21px;transform:rotate(-45deg)}

/* ===== HERO ===== */
.hero{min-height:100svh;display:flex;align-items:center;padding-top:clamp(96px,14vh,120px);padding-bottom:4rem;position:relative}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center;width:100%}
.hero h1{font-size:clamp(2.4rem,6.2vw,4.4rem);font-weight:800;line-height:1.04;letter-spacing:-.03em;margin:1.5rem 0 1.4rem}
.hero h1 .line2{display:block}
.hero p.lead{font-size:clamp(1.04rem,1.7vw,1.25rem);color:var(--text-2);max-width:34em;margin-bottom:1.6rem}
/* Micro-badges de preuve sociale chiffree, juste sous le H1 (repris de A/B) */
.hero-badges{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2rem}
.hero-badge{
  display:inline-flex;align-items:center;gap:.45rem;font-family:var(--font-alt);font-weight:600;font-size:.82rem;
  color:var(--text);padding:.45rem .85rem;border:1px solid var(--border-2);border-radius:var(--r-pill);
  background:rgba(255,255,255,.025);
}
.hero-badge svg{width:15px;height:15px;color:var(--cyan)}
.hero-badge strong{color:var(--cyan);font-weight:700}
.hero-cta{display:flex;flex-wrap:wrap;gap:.9rem}
.hero-mini{display:flex;flex-wrap:wrap;gap:1.4rem;margin-top:2.4rem;color:var(--text-3);font-size:.84rem;font-family:var(--font-alt);font-weight:500}
.hero-mini span.it{display:inline-flex;align-items:center;gap:.45rem}
.hero-mini svg{width:15px;height:15px;color:var(--cyan)}

/* hero visual */
.hero-visual{position:relative;perspective:1400px}
.browser{
  background:linear-gradient(165deg,var(--surface),var(--bg-2));border:1px solid var(--border-2);
  border-radius:var(--r-lg);box-shadow:var(--shadow),var(--glow-violet);overflow:hidden;
  transform:rotateY(-9deg) rotateX(4deg);transition:transform .6s var(--ease);
}
.hero-visual:hover .browser{transform:rotateY(-4deg) rotateX(2deg)}
.browser-bar{display:flex;align-items:center;gap:.45rem;padding:.85rem 1rem;border-bottom:1px solid var(--border);background:rgba(0,0,0,.2)}
.browser-bar .d{width:11px;height:11px;border-radius:50%}
.browser-bar .d.r{background:#ff5f57}.browser-bar .d.y{background:#febc2e}.browser-bar .d.g{background:#28c840}
.browser-bar .url{margin-left:.7rem;flex:1;height:24px;border-radius:7px;background:rgba(255,255,255,.05);display:flex;align-items:center;padding:0 .7rem;font-family:var(--font-alt);font-size:.7rem;color:var(--text-3);gap:.4rem}
.browser-bar .url svg{width:11px;height:11px;color:var(--cyan)}
.browser-body{padding:1.4rem;display:flex;flex-direction:column;gap:1rem}
.bb-hero{height:108px;border-radius:14px;background:var(--grad-soft);border:1px solid var(--border);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center;padding:0 1.2rem;gap:.6rem}
.bb-hero::after{content:"";position:absolute;right:-30px;top:-30px;width:130px;height:130px;border-radius:50%;background:radial-gradient(circle,rgba(34,211,238,.4),transparent 70%)}
.bar{height:9px;border-radius:6px;background:rgba(255,255,255,.16)}
.bar.w1{width:55%}.bar.w2{width:78%;background:rgba(255,255,255,.1)}
.bb-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem}
.bb-card{height:74px;border-radius:12px;background:rgba(255,255,255,.035);border:1px solid var(--border);padding:.7rem;display:flex;flex-direction:column;gap:.45rem}
.bb-card .ic{width:24px;height:24px;border-radius:8px;background:var(--grad);display:flex;align-items:center;justify-content:center}
.bb-card .ic svg{width:13px;height:13px;color:#0a0d14}
.bb-card .l{height:6px;border-radius:4px;background:rgba(255,255,255,.14);width:80%}
.bb-card .l.s{width:55%;background:rgba(255,255,255,.08)}
.float-chip{
  position:absolute;background:rgba(20,24,36,.9);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-2);
  border-radius:14px;padding:.7rem .9rem;display:flex;align-items:center;gap:.6rem;box-shadow:var(--shadow-sm);
  font-size:.78rem;font-weight:600;font-family:var(--font-alt);
}
.float-chip .fi{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.float-chip .fi svg{width:18px;height:18px}
.chip-1{top:8%;left:-7%;animation:float 6s ease-in-out infinite}
.chip-1 .fi{background:var(--cyan-soft)}.chip-1 .fi svg{color:var(--cyan)}
.chip-2{bottom:9%;right:-6%;animation:float 6s ease-in-out infinite 1.5s}
.chip-2 .fi{background:var(--violet-soft)}.chip-2 .fi svg{color:var(--violet)}
.chip-3{bottom:30%;left:-9%;animation:float 7s ease-in-out infinite .8s}
.chip-3 .fi{background:rgba(124,140,255,.16)}.chip-3 .fi svg{color:#9aa6ff}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ===== TRUST STRIP ===== */
.trust{padding:0;margin-top:-1rem}
.trust-inner{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;
}
.trust-cell{background:linear-gradient(180deg,var(--surface),var(--bg-2));padding:clamp(1.4rem,3vw,2.1rem) 1.2rem;text-align:center;transition:background .3s}
.trust-cell:hover{background:var(--surface-2)}
.trust-cell .num{font-size:clamp(1.5rem,3vw,2.3rem);font-weight:800;letter-spacing:-.02em;line-height:1}
.trust-cell .lbl{color:var(--text-2);font-size:.86rem;margin-top:.55rem;font-weight:500}

/* ===== SERVICES ===== */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2vw,1.5rem)}
.svc-card{
  position:relative;background:linear-gradient(180deg,var(--surface),var(--bg-2));border:1px solid var(--border);
  border-radius:var(--r);padding:clamp(1.5rem,2.6vw,2rem);overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s;
}
.svc-card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .35s;pointer-events:none}
.svc-card:hover{transform:translateY(-7px);box-shadow:var(--shadow)}
.svc-card:hover::before{opacity:1}
.svc-icon{width:54px;height:54px;border-radius:14px;background:var(--grad-soft);border:1px solid var(--border-2);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;transition:transform .35s var(--ease)}
.svc-card:hover .svc-icon{transform:scale(1.08) rotate(-4deg)}
.svc-icon svg{width:26px;height:26px;color:var(--cyan)}
.svc-card:nth-child(even) .svc-icon svg{color:var(--violet)}
.svc-card h3{font-size:1.22rem;font-weight:600;margin-bottom:.55rem;letter-spacing:-.01em}
.svc-card p{color:var(--text-2);font-size:.95rem}
.svc-card .tag{margin-top:1.1rem;display:inline-block;font-family:var(--font-alt);font-size:.72rem;font-weight:600;letter-spacing:.06em;color:var(--cyan);text-transform:uppercase}

/* ===== PORTFOLIO ===== */
.port-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,2vw,1.6rem)}
.port-card{
  position:relative;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;
  background:var(--surface);transition:transform .4s var(--ease),box-shadow .4s,border-color .4s;
}
.port-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--border-2)}
.port-card:focus-within{border-color:var(--cyan)}
.port-visual{height:230px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.port-visual.v1{background:linear-gradient(135deg,#0b2330,#10283a)}
.port-visual.v2{background:linear-gradient(135deg,#1a1430,#241a3e)}
.port-visual.v3{background:linear-gradient(135deg,#0d2630,#13202e)}
.port-visual.v4{background:linear-gradient(135deg,#221833,#2b1a3a)}
.port-visual::after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.06) 1px,transparent 0);background-size:22px 22px;opacity:.6}
.port-mock{position:relative;z-index:2;width:78%;transition:transform .5s var(--ease)}
.port-card:hover .port-mock{transform:translateY(-6px) scale(1.02)}
.pm-shop{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem}
.pm-shop .it{background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:10px;height:64px;display:flex;flex-direction:column;padding:.5rem;gap:.35rem}
.pm-shop .it .sq{flex:1;border-radius:6px;background:linear-gradient(135deg,rgba(34,211,238,.3),rgba(168,85,247,.25))}
.pm-shop .it .ln{height:4px;border-radius:3px;background:rgba(255,255,255,.2);width:70%}
.pm-app{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:14px;padding:.8rem;display:flex;gap:.7rem}
.pm-app .side{width:34%;display:flex;flex-direction:column;gap:.4rem}
.pm-app .side .r{height:8px;border-radius:4px;background:rgba(255,255,255,.12)}
.pm-app .side .r.a{background:var(--grad)}
.pm-app .mn{flex:1;display:flex;flex-direction:column;gap:.5rem}
.pm-app .mn .big{height:40px;border-radius:8px;background:var(--grad-soft);border:1px solid var(--border)}
.pm-app .mn .stat{display:flex;gap:.5rem}
.pm-app .mn .stat .s{flex:1;height:26px;border-radius:7px;background:rgba(255,255,255,.06)}
.pm-game{display:grid;grid-template-columns:repeat(8,1fr);gap:3px;width:72%;aspect-ratio:8/6}
.pm-game .px{border-radius:3px;background:rgba(255,255,255,.05)}
.pm-game .px.c{background:var(--cyan);box-shadow:0 0 8px var(--cyan)}
.pm-game .px.v{background:var(--violet);box-shadow:0 0 8px var(--violet)}
.pm-game .px.w{background:rgba(255,255,255,.5)}
.pm-bot{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:14px;padding:.8rem;display:flex;flex-direction:column;gap:.55rem}
.pm-bot .msg{display:flex;gap:.5rem;align-items:flex-start}
.pm-bot .av{width:24px;height:24px;border-radius:7px;flex-shrink:0}
.pm-bot .av.b{background:var(--grad)}
.pm-bot .av.u{background:rgba(255,255,255,.12)}
.pm-bot .bub{flex:1;border-radius:8px;padding:.4rem .55rem;background:rgba(255,255,255,.06)}
.pm-bot .bub .ln{height:5px;border-radius:3px;background:rgba(255,255,255,.18);margin-bottom:.3rem}
.pm-bot .bub .ln.s{width:60%;margin-bottom:0}
.pm-bot .bub.b{background:var(--grad-soft);border:1px solid var(--border)}
.port-body{padding:1.4rem 1.5rem 1.6rem}
.port-cat{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-alt);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--cyan);margin-bottom:.6rem}
.port-cat .pdot{width:6px;height:6px;border-radius:50%;background:var(--cyan)}
.port-card:nth-child(even) .port-cat,.port-card:nth-child(even) .port-cat .pdot{color:var(--violet)}
.port-card:nth-child(even) .port-cat .pdot{background:var(--violet)}
.port-body h3{font-size:1.25rem;font-weight:600;margin-bottom:.35rem}
.port-body p{color:var(--text-2);font-size:.92rem;margin-bottom:1.1rem}
/* Lien d'action explicite => transforme la galerie en levier de conversion */
.port-link{
  display:inline-flex;align-items:center;gap:.45rem;font-family:var(--font-alt);font-weight:600;font-size:.86rem;
  color:var(--cyan);transition:gap .25s var(--ease),color .25s;
}
.port-card:nth-child(even) .port-link{color:var(--violet)}
.port-link svg{width:16px;height:16px;transition:transform .25s var(--ease)}
.port-card:hover .port-link{gap:.7rem}
.port-card:hover .port-link svg{transform:translateX(3px)}

/* ===== PROCESS ===== */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,2vw,1.5rem);position:relative}
.proc-grid::before{content:"";position:absolute;top:38px;left:11%;right:11%;height:1px;background:linear-gradient(90deg,transparent,var(--border-2) 12%,var(--border-2) 88%,transparent);z-index:0}
.proc-step{position:relative;z-index:1;text-align:center}
.proc-num{
  width:76px;height:76px;margin:0 auto 1.3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,var(--surface),var(--bg-2));border:1px solid var(--border-2);position:relative;
  transition:transform .35s var(--ease),box-shadow .35s,border-color .35s;
}
.proc-step:hover .proc-num{transform:translateY(-5px);border-color:var(--cyan);box-shadow:var(--glow-cyan)}
.proc-num>svg{width:30px;height:30px;color:var(--cyan)}
.proc-step:nth-child(even) .proc-num>svg{color:var(--violet)}
.proc-step:nth-child(even):hover .proc-num{border-color:var(--violet);box-shadow:var(--glow-violet)}
.proc-badge{position:absolute;top:-6px;right:-6px;width:28px;height:28px;border-radius:50%;background:var(--grad);color:#0a0d14;font-weight:700;font-size:.82rem;display:flex;align-items:center;justify-content:center;font-family:var(--font-alt)}
.proc-step h3{font-size:1.12rem;font-weight:600;margin-bottom:.45rem}
.proc-step p{color:var(--text-2);font-size:.9rem;max-width:18em;margin:0 auto}

/* ===== PRICING ===== */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2vw,1.5rem);align-items:stretch}
.price-card{
  display:flex;flex-direction:column;background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--border);border-radius:var(--r-lg);padding:clamp(1.6rem,2.6vw,2.2rem);
  transition:transform .35s var(--ease),box-shadow .35s,border-color .35s;position:relative;
}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--border-2)}
.price-card.featured{border-color:transparent;background:linear-gradient(180deg,var(--surface-2),var(--bg-2));box-shadow:var(--shadow),0 0 60px -22px rgba(168,85,247,.5)}
.price-card.featured::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.price-pop{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--grad);color:#0a0d14;font-weight:700;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;padding:.4rem 1rem;border-radius:var(--r-pill);font-family:var(--font-alt);box-shadow:0 8px 22px -8px rgba(168,85,247,.6)}
.price-name{font-size:1.16rem;font-weight:600;margin-bottom:.3rem}
.price-desc{color:var(--text-2);font-size:.88rem;margin-bottom:1.4rem;min-height:2.6em}
.price-amt{display:flex;align-items:baseline;gap:.35rem;margin-bottom:1.5rem;flex-wrap:wrap}
.price-amt .pre{font-size:.85rem;color:var(--text-3);font-weight:500}
.price-amt .val{font-size:clamp(2rem,4vw,2.7rem);font-weight:800;letter-spacing:-.02em;line-height:1}
.price-amt .cur{font-size:.9rem;color:var(--text-2);font-weight:600}
.price-feat{display:flex;flex-direction:column;gap:.8rem;margin-bottom:1.2rem;flex:1}
.price-feat li{display:flex;align-items:flex-start;gap:.7rem;font-size:.92rem;color:var(--text-2)}
.price-feat li svg{width:18px;height:18px;color:var(--cyan);flex-shrink:0;margin-top:1px}
.price-card.featured .price-feat li svg{color:var(--violet)}
/* Ligne "fonction non incluse" barree (repris de A) pour clarifier la montee en gamme */
.price-feat li.off{color:var(--text-3);text-decoration:line-through;text-decoration-color:rgba(255,255,255,.25)}
.price-feat li.off svg{color:var(--text-3)}
/* Micro-mention d'honnetete des prix sous chaque carte */
.price-note{font-size:.74rem;color:var(--text-3);font-family:var(--font-alt);text-align:center;margin-bottom:1.2rem;line-height:1.5}

/* ===== ABOUT ===== */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.about-card{
  position:relative;background:linear-gradient(160deg,var(--surface),var(--bg-2));border:1px solid var(--border-2);
  border-radius:var(--r-lg);padding:clamp(2rem,4vw,3rem);text-align:center;box-shadow:var(--shadow)
}
.about-card::after{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.5;pointer-events:none}
.avatar{width:130px;height:130px;margin:0 auto 1.4rem}
.avatar svg{width:100%;height:100%;filter:drop-shadow(0 8px 24px rgba(34,211,238,.3))}
.about-card .pname{font-size:1.5rem;font-weight:700;letter-spacing:-.01em}
.about-card .prole{color:var(--cyan);font-family:var(--font-alt);font-weight:500;font-size:.88rem;margin-top:.3rem;letter-spacing:.04em}
.about-stats{display:flex;justify-content:center;gap:1.6rem;margin-top:1.7rem;padding-top:1.6rem;border-top:1px solid var(--border)}
.about-stats .st .n{font-size:1.45rem;font-weight:800}
.about-stats .st .t{font-size:.72rem;color:var(--text-3);font-family:var(--font-alt);text-transform:uppercase;letter-spacing:.06em;margin-top:.15rem}
.about-text h2{font-size:clamp(1.8rem,4vw,2.7rem);font-weight:700;line-height:1.1;letter-spacing:-.02em;margin:1.1rem 0 1.3rem}
.about-text p{color:var(--text-2);margin-bottom:1.1rem;font-size:1.02rem}
.about-skills{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.7rem}
.skill-pill{font-family:var(--font-alt);font-size:.82rem;font-weight:500;padding:.5rem 1rem;border-radius:var(--r-pill);border:1px solid var(--border-2);background:rgba(255,255,255,.025);color:var(--text-2);transition:border-color .25s,color .25s,background .25s}
.skill-pill:hover{border-color:var(--cyan);color:var(--text);background:rgba(34,211,238,.06)}

/* ===== TESTIMONIALS ===== */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2vw,1.5rem)}
.testi-card{
  background:linear-gradient(180deg,var(--surface),var(--bg-2));border:1px solid var(--border);border-radius:var(--r);
  padding:clamp(1.6rem,2.6vw,2rem);display:flex;flex-direction:column;transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;
}
.testi-card:hover{transform:translateY(-6px);border-color:var(--border-2);box-shadow:var(--shadow)}
.stars{display:flex;gap:.2rem;margin-bottom:1.1rem}
.stars svg{width:18px;height:18px;color:#fbbf24}
.testi-card blockquote{font-size:1rem;color:var(--text);line-height:1.7;flex:1;margin-bottom:1.5rem}
.testi-author{display:flex;align-items:center;gap:.85rem}
.testi-author .ta-av{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;font-family:var(--font-alt);color:#0a0d14;background:var(--grad);flex-shrink:0}
.testi-author .ta-n{font-weight:600;font-size:.96rem}
.testi-author .ta-c{font-size:.82rem;color:var(--text-3)}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
.form-card{background:linear-gradient(180deg,var(--surface),var(--bg-2));border:1px solid var(--border-2);border-radius:var(--r-lg);padding:clamp(1.6rem,3vw,2.5rem);box-shadow:var(--shadow)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{margin-bottom:1.1rem;display:flex;flex-direction:column}
.field label{font-size:.82rem;font-weight:500;color:var(--text-2);margin-bottom:.5rem;font-family:var(--font-alt)}
.field label .req{color:var(--cyan)}
.field input,.field select,.field textarea{
  font-family:var(--font);font-size:.95rem;color:var(--text);background:rgba(255,255,255,.025);
  border:1px solid var(--border-2);border-radius:var(--r-sm);padding:.85rem 1rem;width:100%;transition:border-color .25s,box-shadow .25s,background .25s;
}
.field textarea{resize:vertical;min-height:120px}
.field select{appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23a7b0c4' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.4rem}
.field select option{background:var(--bg-2);color:var(--text)}
.field input::placeholder,.field textarea::placeholder{color:var(--text-3)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--cyan);background:rgba(34,211,238,.04);box-shadow:0 0 0 3px rgba(34,211,238,.12)}
.field.error input,.field.error select,.field.error textarea{border-color:#f87171;box-shadow:0 0 0 3px rgba(248,113,113,.12)}
.field .err-msg{color:#f87171;font-size:.76rem;margin-top:.4rem;display:none}
.field.error .err-msg{display:block}
.form-status{margin-top:1.2rem;padding:1rem 1.2rem;border-radius:var(--r-sm);font-size:.92rem;display:none;align-items:center;gap:.7rem}
.form-status svg{width:20px;height:20px;flex-shrink:0}
.form-status.show{display:flex;animation:popin .45s var(--ease)}
.form-status.ok{background:rgba(34,211,238,.1);border:1px solid rgba(34,211,238,.3);color:#67e8f9}
.form-status.err{background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.3);color:#fca5a5}
@keyframes popin{from{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:none}}
.contact-info{display:flex;flex-direction:column;gap:1rem}
.info-card{display:flex;align-items:flex-start;gap:1rem;background:linear-gradient(180deg,var(--surface),var(--bg-2));border:1px solid var(--border);border-radius:var(--r);padding:1.4rem;transition:transform .3s var(--ease),border-color .3s}
.info-card:hover{transform:translateX(5px);border-color:var(--border-2)}
.info-card .ici{width:46px;height:46px;border-radius:12px;background:var(--grad-soft);border:1px solid var(--border-2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.info-card .ici svg{width:22px;height:22px;color:var(--cyan)}
.info-card:nth-child(even) .ici svg{color:var(--violet)}
.info-card .itl{font-size:.78rem;color:var(--text-3);font-family:var(--font-alt);text-transform:uppercase;letter-spacing:.06em}
.info-card .iv{font-weight:600;font-size:1rem;margin-top:.15rem;word-break:break-word}
.info-card .iv a:hover{color:var(--cyan)}

/* ===== FOOTER ===== */
footer{border-top:1px solid var(--border);padding:clamp(3rem,6vw,4.5rem) 0 2rem;margin-top:var(--space);background:linear-gradient(180deg,transparent,rgba(0,0,0,.25))}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;margin-bottom:3rem}
.foot-brand .logo{margin-bottom:1.1rem}
.foot-brand p{color:var(--text-2);font-size:.94rem;max-width:30em;margin-bottom:1.4rem}
.foot-brand .tagline{font-family:var(--font-alt);font-size:.86rem;color:var(--cyan);font-weight:500}
.foot-col h4{font-size:.8rem;font-family:var(--font-alt);text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:1.1rem}
.foot-col ul{display:flex;flex-direction:column;gap:.7rem}
.foot-col a{color:var(--text-2);font-size:.92rem;transition:color .2s}
.foot-col a:hover{color:var(--cyan)}
.foot-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.2rem;padding-top:2rem;border-top:1px solid var(--border)}
.foot-bottom p{color:var(--text-3);font-size:.85rem}
.socials{display:flex;gap:.7rem}
.socials a{width:40px;height:40px;border-radius:11px;border:1px solid var(--border-2);background:rgba(255,255,255,.02);display:flex;align-items:center;justify-content:center;color:var(--text-2);transition:color .25s,background .25s,border-color .25s,transform .25s}
.socials a:hover{color:#0a0d14;background:var(--grad);border-color:transparent;transform:translateY(-3px)}
.socials svg{width:19px;height:19px}

/* ===== SCROLL REVEAL ===== */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}

/* ===== RESPONSIVE ===== */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:3rem}
  .hero-visual{max-width:480px;margin:0 auto;width:100%}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:2.5rem}
  .foot-top{grid-template-columns:1fr 1fr;gap:2rem}
  .foot-brand{grid-column:1/-1}
  .cards-grid,.testi-grid{grid-template-columns:repeat(2,1fr)}
  .proc-grid{grid-template-columns:repeat(2,1fr);row-gap:2.5rem}
  .proc-grid::before{display:none}
}
@media(max-width:860px){
  .nav-links{
    position:fixed;inset:0;flex-direction:column;justify-content:center;gap:.4rem;
    background:#0f1117;padding:2rem;/* fond 100% opaque, sans backdrop-filter: corrige le menu mobile qui s'affichait mal apres defilement (bug fixed+backdrop sur mobile) */
    transform:translateX(100%);transition:transform .45s var(--ease);z-index:90;
  }
  body.menu-open .nav-links{transform:none}
  /* IMPORTANT: quand le menu est ouvert, on retire le backdrop-filter du header.
     Sinon (apres defilement) le header.scrolled cree un bloc conteneur qui
     "emprisonne" le menu position:fixed dans sa hauteur (~65px) -> menu coupe. */
  body.menu-open header,body.menu-open header.scrolled{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}
  .nav-links a{font-size:1.4rem;font-weight:600;color:var(--text);padding:.7rem 2rem}
  .nav-links .nav-cta{display:inline-flex;margin-top:1.2rem}
  .nav-right .nav-cta{display:none}
  .burger{display:flex;align-items:center;justify-content:center}
}
@media(max-width:640px){
  .trust-inner{grid-template-columns:repeat(2,1fr)}
  .cards-grid,.port-grid,.price-grid,.testi-grid,.proc-grid{grid-template-columns:1fr}
  .price-grid{gap:1.6rem}
  .form-row{grid-template-columns:1fr;gap:0}
  .foot-top{grid-template-columns:1fr}
  .hero-mini{gap:1rem}
  .chip-1{left:-2%}.chip-2{right:-2%}.chip-3{left:-4%}
  .about-stats{gap:1.1rem}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .browser{transform:none}
}

/* =====================================================================
   AJOUTS — Carte service "specialite" (IA) + section Industries & Tarifs
   Reutilise les variables existantes (--grad, --surface, --border, etc.).
   ===================================================================== */

/* ---- Badge "Notre specialite" sur la carte IA (services) ---- */
.svc-card.svc-feat{border-color:transparent}
.svc-card.svc-feat::before{opacity:.55}
.svc-card.svc-feat:hover::before{opacity:1}
.svc-badge{
  position:absolute;top:1rem;right:1rem;z-index:2;
  background:var(--grad);color:#0a0d14;font-family:var(--font-alt);
  font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:.32rem .7rem;border-radius:var(--r-pill);
  box-shadow:0 8px 22px -8px rgba(168,85,247,.6)
}

/* ---- INDUSTRIES & TARIFS ---- */
.price-disclaimer{
  margin-top:1.1rem;font-family:var(--font-alt);font-size:.84rem;font-weight:500;
  color:var(--text-2);
  display:inline-block;padding:.5rem 1.1rem;border-radius:var(--r-pill);
  border:1px solid var(--border-2);background:rgba(255,255,255,.025)
}
.ind-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:clamp(1rem,2vw,1.5rem);align-items:stretch
}
.ind-card{
  position:relative;display:flex;flex-direction:column;overflow:hidden;
  background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--border);border-radius:var(--r);
  padding:clamp(1.5rem,2.6vw,1.9rem);
  transition:transform .35s var(--ease),box-shadow .35s,border-color .35s
}
.ind-card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .35s;pointer-events:none}
.ind-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--border-2)}
.ind-card:hover::before{opacity:1}
.ind-card.ind-feat{border-color:transparent;background:linear-gradient(180deg,var(--surface-2),var(--bg-2));box-shadow:var(--shadow),0 0 60px -26px rgba(168,85,247,.5)}
.ind-card.ind-feat::before{opacity:.6}
.ind-badge{
  align-self:flex-start;margin-bottom:.9rem;
  background:var(--grad);color:#0a0d14;font-family:var(--font-alt);
  font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:.32rem .7rem;border-radius:var(--r-pill);
  box-shadow:0 8px 22px -8px rgba(168,85,247,.6)
}
.ind-name{font-size:1.1rem;font-weight:600;letter-spacing:-.01em;margin-bottom:.7rem;min-height:2.6em;display:flex;align-items:center}
.ind-price{display:flex;align-items:baseline;gap:.35rem;margin-bottom:.9rem;flex-wrap:wrap}
.ind-price .pre{font-size:.82rem;color:var(--text-3);font-weight:500;font-family:var(--font-alt)}
.ind-price .val{font-size:clamp(1.5rem,3vw,1.9rem);font-weight:800;letter-spacing:-.02em;line-height:1}
.ind-desc{color:var(--text-2);font-size:.92rem;margin-bottom:1.3rem;flex:1}
.ind-cta{margin-top:auto}
@media(max-width:520px){
  .ind-grid{grid-template-columns:1fr}
  .ind-name{min-height:0}
}

/* ===== AVIS CLIENTS — etat vide honnete (carte unique centree) ===== */
.testi-grid--empty{grid-template-columns:1fr;justify-items:center}
.testi-card--empty{
  max-width:520px;width:100%;text-align:center;align-items:center;
  gap:1.5rem;
}
.testi-card--empty .testi-empty-msg{color:var(--text-2);font-size:1.05rem;line-height:1.6;margin:0}
.testi-card--empty .btn{align-self:center}

/* =====================================================================
   SYSTEME D'AVIS — resume, etoiles pleines/vides, cartes, formulaire
   Reutilise les variables existantes (--cyan, --violet, --surface, etc.).
   ===================================================================== */

/* ---- Utilitaire : champ visuellement cache mais present dans le DOM
   (honeypot anti-robot ; reste accessible/atteignable par les robots) ---- */
.visually-hidden{
  position:absolute!important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

/* ---- Resume (note moyenne + etoiles + nombre d'avis) ---- */
.reviews-summary{
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;
  gap:.6rem;margin:0 auto clamp(2rem,4vw,2.75rem);
}
.reviews-summary[hidden]{display:none}
.reviews-summary .rs-note{font-size:clamp(1.8rem,4vw,2.4rem);font-weight:800;letter-spacing:-.02em;line-height:1}
.reviews-summary .rs-outof{font-size:.95rem;color:var(--text-3);font-family:var(--font-alt);font-weight:500}
.reviews-summary .stars{margin-bottom:0}
.reviews-summary .rs-count{
  font-family:var(--font-alt);font-size:.9rem;font-weight:600;color:var(--text-2);
  padding-left:.4rem;border-left:1px solid var(--border-2);margin-left:.3rem;
}

/* ---- Etoiles pleines / vides (cartes + resume) ---- */
.stars .star{display:inline-flex}
.stars .star svg{width:18px;height:18px}
.stars .star.full svg{color:#fbbf24;fill:#fbbf24}
.stars .star.empty svg{color:var(--border-2);fill:rgba(255,255,255,.08)}

/* ---- Carte d'avis : meta auteur (nom + entreprise + date) ---- */
.testi-author .ta-meta{display:flex;flex-direction:column;gap:.1rem}
.testi-author .ta-d{font-size:.76rem;color:var(--text-3);font-family:var(--font-alt);margin-top:.15rem}

/* ---- Formulaire d'avis ---- */
.review-form-wrap{
  max-width:760px;margin:clamp(2rem,4vw,3rem) auto 0;
  background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--border-2);border-radius:var(--r-lg);
  padding:clamp(1.6rem,3vw,2.5rem);box-shadow:var(--shadow);
}
.review-form-title{
  font-size:clamp(1.2rem,2.4vw,1.5rem);font-weight:700;letter-spacing:-.01em;
  margin-bottom:1.5rem;text-align:center;
}
.review-form .field:last-of-type{margin-bottom:1.1rem}

/* ---- Notation par etoiles cliquables ---- */
.rating-input{display:inline-flex;gap:.25rem;margin-top:.15rem}
.rating-star{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.2rem;border-radius:8px;line-height:0;
  color:var(--border-2);
  transition:color .18s var(--ease),transform .18s var(--ease);
}
.rating-star svg{width:30px;height:30px;fill:currentColor;stroke:none}
.rating-star:hover{transform:scale(1.12)}
.rating-star.on{color:#fbbf24}
.rating-star:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}

@media(max-width:520px){
  .reviews-summary .rs-count{border-left:0;margin-left:0;padding-left:0}
}
