/* ============================================================
   STARVIA — Feuille de style globale
   starvia.css — À inclure sur TOUTES les pages
   ============================================================
   Usage dans le <head> de chaque page :
     <link rel="stylesheet" href="/assets/starvia.css">
   + Google Fonts (une seule fois par page) :
     <link href="https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Instrument+Serif:ital@1&display=swap" rel="stylesheet">
   ============================================================ */


/* ════════════════════════════════════════════════════════════
   1. TOKENS — Variables couleurs & design
════════════════════════════════════════════════════════════ */
:root {
  /* Fonds */
  --bg:       #04040a;
  --bg2:      #080812;
  --bg3:      #0c0c1a;
  --bg4:      #111120;

  /* Surfaces & bordures */
  --surface:  rgba(255,255,255,0.04);
  --surface2: rgba(255,255,255,0.07);
  --border:   rgba(255,255,255,0.06);
  --border2:  rgba(255,255,255,0.12);

  /* Violet — couleur principale */
  --v1:  #7c3aed;
  --v2:  #6d28d9;
  --v3:  #4c1d95;
  --vg:  rgba(124,58,237,0.4);
  --vl:  #a78bfa;   /* violet clair */
  --vll: #c4b5fd;   /* violet très clair */

  /* Sémantiques */
  --accent: #f97316;
  --gold:   #f59e0b;
  --green:  #22c55e;
  --red:    #ef4444;

  /* Texte */
  --text:  #eeeeff;
  --text2: #aaaacc;
  --text3: #666688;

  /* Radii */
  --r-sm:  8px;
  --r-md:  12px;
  --r-lg:  16px;
  --r-xl:  20px;
  --r-2xl: 24px;

  /* Transitions */
  --t:      .2s ease;
  --t-slow: .3s ease;
}


/* ════════════════════════════════════════════════════════════
   2. RESET & BASE
════════════════════════════════════════════════════════════ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html  { scroll-behavior:smooth; }
body  {
  font-family:'Inter',sans-serif;
  background:var(--bg); color:var(--text);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a   { color:inherit; text-decoration:none; }
img { max-width:100%; }
button,input,select,textarea { font-family:inherit; }


/* ════════════════════════════════════════════════════════════
   3. TYPOGRAPHIE
════════════════════════════════════════════════════════════ */
h2.sec-h {
  font-size:clamp(36px,4.5vw,58px);
  font-weight:800; letter-spacing:-2px; line-height:1.08;
  margin-bottom:16px; color:var(--text);
}
h2.sec-h .s {
  font-family:'Instrument Serif',serif; font-style:italic; font-weight:400;
  background:linear-gradient(135deg,var(--vll),var(--v1));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.sub-p {
  font-size:17px; color:var(--text2); line-height:1.65;
  max-width:520px; margin-bottom:52px;
}
.center { text-align:center; }
.center .sub-p { margin-left:auto; margin-right:auto; }

/* Tag pill */
.tag {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(124,58,237,.10); border:1px solid rgba(124,58,237,.22);
  color:var(--vl); font-size:11px; font-weight:700;
  letter-spacing:1.5px; text-transform:uppercase;
  padding:5px 14px; border-radius:100px; margin-bottom:20px;
}


/* ════════════════════════════════════════════════════════════
   4. BOUTONS
════════════════════════════════════════════════════════════ */
/* Primaire */
.btn-primary, .btn-hero-main, .btn-cta-nav, .pb-main {
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(135deg,var(--v1),var(--v2));
  color:#fff; border:none;
  font-size:14px; font-weight:600;
  padding:10px 20px; border-radius:var(--r-md);
  cursor:pointer; transition:all var(--t-slow);
  box-shadow:0 0 24px var(--vg); text-decoration:none;
}
.btn-primary:hover, .btn-hero-main:hover, .btn-cta-nav:hover, .pb-main:hover {
  transform:translateY(-2px); box-shadow:0 0 40px var(--vg);
}
.btn-hero-main { font-size:15px; padding:14px 28px; border-radius:var(--r-lg); box-shadow:0 0 40px var(--vg); }
.btn-cta-nav   { font-size:13px; padding:8px 18px; }

/* Fantôme */
.btn-ghost, .btn-hero-out, .pb-ghost {
  display:inline-flex; align-items:center; gap:8px;
  background:transparent; border:1px solid var(--border2);
  color:var(--text2);
  font-size:14px; font-weight:500;
  padding:10px 20px; border-radius:var(--r-md);
  cursor:pointer; transition:all var(--t); text-decoration:none;
}
.btn-ghost:hover, .btn-hero-out:hover, .pb-ghost:hover {
  background:var(--surface); color:var(--text); border-color:rgba(124,58,237,.3);
}
.btn-ghost  { font-size:13px; padding:7px 16px; }
.btn-hero-out { font-size:14px; padding:13px 24px; border-radius:var(--r-lg); }

/* Small (app) */
.bsm {
  display:inline-flex; align-items:center; gap:6px;
  font-size:11px; font-weight:700;
  padding:6px 12px; border-radius:var(--r-sm);
  cursor:pointer; transition:all var(--t);
  text-decoration:none; border:none; font-family:inherit;
}
.bp { background:linear-gradient(135deg,var(--v1),var(--v2)); color:#fff; box-shadow:0 0 12px var(--vg); }
.bp:hover { transform:translateY(-1px); box-shadow:0 0 20px var(--vg); }
.bg { background:var(--surface); border:1px solid var(--border2); color:var(--text2); }
.bg:hover { background:var(--surface2); color:var(--text); }

/* Plan btn */
.plan-btn { width:100%; padding:14px; border-radius:var(--r-md); font-size:14px; font-weight:600; cursor:pointer; border:none; font-family:inherit; transition:all .25s; text-decoration:none; display:block; text-align:center; }


/* ════════════════════════════════════════════════════════════
   5. LOGO
════════════════════════════════════════════════════════════ */
.logo, .s-logo, .foot-logo {
  display:flex; align-items:center; gap:10px;
  font-size:18px; font-weight:800; color:var(--text);
  text-decoration:none; letter-spacing:-.5px;
}
.logo em, .s-logo em { color:var(--vl); font-style:normal; }

.logo-mark, .lm, .foot-mark {
  width:32px; height:32px;
  background:linear-gradient(135deg,var(--v1),var(--v2));
  border-radius:9px;
  display:flex; align-items:center; justify-content:center;
  font-size:14px; box-shadow:0 0 20px var(--vg);
  animation:logoGlow 3s ease-in-out infinite; flex-shrink:0;
}
.foot-mark { width:28px; height:28px; font-size:13px; border-radius:8px; animation:none; }
@keyframes logoGlow {
  0%,100%{ box-shadow:0 0 20px var(--vg); }
  50%    { box-shadow:0 0 40px var(--vg),0 0 80px rgba(124,58,237,.2); }
}


/* ════════════════════════════════════════════════════════════
   6. SOCIAL BAR
════════════════════════════════════════════════════════════ */
.social-bar, .sbar {
  position:fixed; top:0; left:0; right:0; z-index:200;
  height:30px; background:rgba(4,4,10,.97);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:center; gap:22px;
}
.social-bar a, .sbar a {
  display:flex; align-items:center; gap:5px;
  font-size:11px; font-weight:600; color:var(--text3);
  text-decoration:none; transition:color var(--t);
}
.social-bar a:hover, .sbar a:hover { color:var(--vl); }
.sb-sep, .sbsep { color:rgba(255,255,255,.08); font-size:10px; }


/* ════════════════════════════════════════════════════════════
   7. NAV (landing)
════════════════════════════════════════════════════════════ */
nav {
  position:fixed; top:30px; left:0; right:0; z-index:100;
  height:60px; display:flex; align-items:center; justify-content:space-between;
  padding:0 48px;
  background:rgba(4,4,10,.8); backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border); transition:all var(--t-slow);
}
.nav-links { display:flex; gap:2px; list-style:none; }
.nav-links a {
  font-size:14px; font-weight:500; color:var(--text2);
  text-decoration:none; padding:7px 14px; border-radius:10px; transition:all var(--t);
}
.nav-links a:hover { background:var(--surface); color:var(--text); }
.nav-right { display:flex; align-items:center; gap:10px; }


/* ════════════════════════════════════════════════════════════
   8. SIDEBAR APP
════════════════════════════════════════════════════════════ */
.sidebar {
  width:220px; min-height:100vh;
  background:var(--bg2); border-right:1px solid var(--border);
  display:flex; flex-direction:column;
  position:fixed; top:30px; left:0; bottom:0; z-index:50;
  overflow-y:auto; padding:16px 10px; gap:2px;
}
.sidebar::-webkit-scrollbar       { width:3px; }
.sidebar::-webkit-scrollbar-track { background:transparent; }
.sidebar::-webkit-scrollbar-thumb { background:var(--border2); border-radius:3px; }

/* Logo sidebar */
.s-logo { padding:8px 8px 16px; font-size:17px; }
.s-logo .lm { width:28px; height:28px; font-size:13px; animation:logoGlow 3s ease-in-out infinite; }

/* Bloc établissement */
.ec {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:12px; margin-bottom:10px;
  cursor:pointer; transition:all var(--t);
}
.ec:hover { border-color:rgba(124,58,237,.3); }
.et  { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.en  { font-size:12px; font-weight:700; color:var(--text); line-height:1.3; }
.es  { font-size:10px; color:var(--text3); margin-top:2px; }
.er  { display:flex; align-items:center; gap:4px; font-size:10px; }
.rstar { color:var(--gold); font-size:9px; }
.rv  { font-weight:800; color:var(--text); font-size:11px; }
.rc  { color:var(--text3); }
.ee  { font-size:10px; color:var(--vl); font-weight:600; }

/* Labels de section sidebar */
.ns {
  font-size:9px; font-weight:700; color:var(--text3);
  text-transform:uppercase; letter-spacing:1.2px; padding:10px 8px 4px;
}

/* Liens de navigation */
.ni {
  display:flex; align-items:center; gap:10px;
  font-size:12px; font-weight:500; color:var(--text2);
  padding:8px 10px; border-radius:var(--r-sm);
  transition:all var(--t); text-decoration:none; position:relative;
}
.ni:hover { background:var(--surface); color:var(--text); }
.ni.on    { background:rgba(124,58,237,.12); color:var(--vl); font-weight:700; }
.ni.on::before {
  content:''; position:absolute; left:0; top:4px; bottom:4px;
  width:3px; background:var(--v1); border-radius:0 3px 3px 0;
}
.nic { font-size:14px; flex-shrink:0; }

/* Badges dans sidebar */
.nb {
  margin-left:auto; font-size:9px; font-weight:800;
  padding:2px 6px; border-radius:10px;
  background:rgba(239,68,68,.15); color:var(--red); border:1px solid rgba(239,68,68,.2);
}
.nb.g { background:rgba(245,158,11,.12); color:var(--gold); border-color:rgba(245,158,11,.2); }

/* Footer sidebar */
.sf { margin-top:auto; padding-top:12px; border-top:1px solid var(--border); }
.uc {
  display:flex; align-items:center; gap:10px;
  padding:10px 8px; border-radius:var(--r-sm);
  cursor:pointer; transition:background var(--t);
}
.uc:hover { background:var(--surface); }
.av {
  width:32px; height:32px; border-radius:50%;
  background:linear-gradient(135deg,var(--v1),var(--v2));
  display:flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:800; color:#fff; flex-shrink:0;
}
.un { font-size:12px; font-weight:700; color:var(--text); }
.up { font-size:9px; color:var(--text3); margin-top:1px; }


/* ════════════════════════════════════════════════════════════
   9. LAYOUT APP
════════════════════════════════════════════════════════════ */
body.app { display:flex; min-height:100vh; padding-top:30px; }
.main { margin-left:220px; flex:1; display:flex; flex-direction:column; min-height:100vh; }

/* Topbar */
.topbar {
  position:sticky; top:30px; z-index:40; height:52px;
  background:rgba(4,4,10,.92); backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 24px; gap:16px;
}
.tbl { display:flex; align-items:center; gap:12px; }
.tbt { font-size:15px; font-weight:700; letter-spacing:-.3px; }
.tbr { display:flex; align-items:center; gap:8px; }

/* Tabs période */
.ptabs { display:flex; background:var(--bg3); border:1px solid var(--border2); border-radius:9px; padding:3px; gap:2px; }
.pt {
  padding:4px 11px; border-radius:6px; font-size:11px; font-weight:600;
  border:none; font-family:inherit; transition:all var(--t);
  color:var(--text3); background:transparent; text-decoration:none; cursor:pointer;
}
.pt.on              { background:var(--v1); color:#fff; box-shadow:0 0 10px var(--vg); }
.pt:hover:not(.on)  { background:var(--surface); color:var(--text2); }

/* Bouton notif */
.nbt {
  width:32px; height:32px; background:var(--bg3); border:1px solid var(--border);
  border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center;
  cursor:pointer; font-size:13px; transition:all var(--t); position:relative;
}
.nbt:hover { border-color:rgba(124,58,237,.3); }
.ndot {
  width:6px; height:6px; background:var(--red); border-radius:50%;
  position:absolute; top:5px; right:5px;
  border:1.5px solid var(--bg); animation:blink 2s infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }

.content { padding:22px 24px; flex:1; }


/* ════════════════════════════════════════════════════════════
   10. CARDS GÉNÉRIQUES
════════════════════════════════════════════════════════════ */
.dcard, .kcard, .chcard, .rvcard, .suc, .smini {
  background:var(--bg3); border:1px solid var(--border); border-radius:var(--r-lg);
}
/* Ligne lumineuse décorative */
.card-glow-top::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(124,58,237,.28),transparent);
}

/* KPI grid */
.kgrid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:22px; }
.kcard { padding:16px 18px; position:relative; overflow:hidden; transition:all .25s; border-radius:14px; }
.kcard:hover { border-color:var(--border2); transform:translateY(-1px); }
.kcard::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; }
.kv .kcard::before { background:linear-gradient(90deg,var(--v1),transparent); }
.kg .kcard::before { background:linear-gradient(90deg,var(--green),transparent); }
.ko .kcard::before { background:linear-gradient(90deg,var(--gold),transparent); }
.kr .kcard::before { background:linear-gradient(90deg,var(--red),transparent); }
.klbl  { font-size:10px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:.8px; margin-bottom:8px; }
.kval  { font-size:28px; font-weight:900; letter-spacing:-1.5px; line-height:1; margin-bottom:5px; }
.kdelta{ font-size:10px; font-weight:600; }
.dg2 { color:var(--green); }
.dr2 { color:var(--red); }
.dn2 { color:var(--text3); }

/* Header card */
.chh {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px; border-bottom:1px solid var(--border);
}
.cht { font-size:14px; font-weight:700; color:var(--text); letter-spacing:-.3px; }
.chs { font-size:11px; color:var(--text3); margin-top:2px; }

/* Toast */
.toast {
  position:fixed; bottom:22px; right:22px;
  background:var(--bg3); border:1px solid var(--border2);
  border-radius:var(--r-md); padding:12px 16px;
  display:flex; align-items:center; gap:10px;
  z-index:300; transform:translateY(70px); opacity:0;
  transition:all var(--t-slow); max-width:300px;
  box-shadow:0 20px 50px rgba(0,0,0,.5);
}
.toast.show { transform:translateY(0); opacity:1; }

/* Badge statut */
.badge     { font-size:10px; font-weight:700; padding:3px 9px; border-radius:20px; display:inline-flex; align-items:center; gap:4px; }
.badge-ok  { background:rgba(34,197,94,.10);  color:#4ade80; border:1px solid rgba(34,197,94,.15); }
.badge-warn{ background:rgba(245,158,11,.08); color:#fbbf24; border:1px solid rgba(245,158,11,.12); }
.badge-bad { background:rgba(239,68,68,.08);  color:#f87171; border:1px solid rgba(239,68,68,.12); }
.badge-info{ background:rgba(124,58,237,.10); color:var(--vl); border:1px solid rgba(124,58,237,.16); }


/* ════════════════════════════════════════════════════════════
   11. HERO (landing)
════════════════════════════════════════════════════════════ */
.hero {
  min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center; padding:160px 24px 80px;
  position:relative; overflow:hidden; z-index:1;
}
.orb { position:absolute; border-radius:50%; filter:blur(120px); pointer-events:none; }
.orb1{ width:700px;height:700px;background:rgba(124,58,237,.12);top:-200px;left:50%;transform:translateX(-50%);animation:orbFloat 8s ease-in-out infinite; }
.orb2{ width:400px;height:400px;background:rgba(249,115,22,.06);bottom:0;right:-100px;animation:orbFloat2 10s ease-in-out infinite; }
.orb3{ width:350px;height:350px;background:rgba(124,58,237,.08);bottom:100px;left:-80px;animation:orbFloat3 12s ease-in-out infinite; }
@keyframes orbFloat  { 0%,100%{transform:translateX(-50%) translateY(0)}   50%{transform:translateX(-50%) translateY(-30px)} }
@keyframes orbFloat2 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-20px)} }
@keyframes orbFloat3 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(20px)} }

.hero-grid {
  position:absolute; inset:0;
  background-image:linear-gradient(rgba(124,58,237,.05)1px,transparent 1px),linear-gradient(90deg,rgba(124,58,237,.05)1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 70% 50% at 50% 30%,black,transparent);
}
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(124,58,237,.1); border:1px solid rgba(124,58,237,.25);
  color:var(--vl); font-size:12px; font-weight:600;
  padding:6px 16px; border-radius:100px; margin-bottom:32px;
  opacity:0; animation:fadeUp .8s .2s ease forwards;
  letter-spacing:.8px; text-transform:uppercase;
}
.badge-dot { width:6px;height:6px;background:var(--vl);border-radius:50%;animation:badgePulse 2s infinite; }
@keyframes badgePulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.3;transform:scale(1.6)} }

.glitch-wrap { margin-bottom:24px;opacity:0;animation:fadeUp .8s .4s ease forwards; }
.glitch { font-size:clamp(44px,7vw,88px);font-weight:900;line-height:1.05;letter-spacing:-3px;color:#fff;display:block; }
.serif-line {
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  font-size:clamp(44px,7vw,88px);
  background:linear-gradient(135deg,var(--vll),var(--vl),var(--v1));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  letter-spacing:-2px;display:block;line-height:1.05;
}
.dim-line { color:#9090bb;font-size:clamp(15px,1.8vw,20px);font-weight:500;display:block;margin-top:14px; }
.hero-sub  { font-size:18px;color:var(--text2);max-width:560px;margin:0 auto 40px;line-height:1.65;opacity:0;animation:fadeUp .8s .8s ease forwards; }
.hero-actions { display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:16px;opacity:0;animation:fadeUp .8s 1s ease forwards;flex-wrap:wrap; }
.hero-note    { font-size:13px;color:var(--text3);opacity:0;animation:fadeUp .8s 1.1s ease forwards; }
.social-row   { display:flex;align-items:center;justify-content:center;gap:14px;margin-top:18px;opacity:0;animation:fadeUp .8s 1.2s ease forwards; }
.avs { display:flex; }
.av-item { width:28px;height:28px;border-radius:50%;border:2px solid var(--bg);background:var(--bg3);margin-left:-6px;font-size:12px;display:flex;align-items:center;justify-content:center; }
.av-item:first-child { margin-left:0; }
.sp-txt { font-size:13px;color:var(--text2); }
.sp-txt strong { color:var(--text); }


/* ════════════════════════════════════════════════════════════
   12. SECTIONS LANDING
════════════════════════════════════════════════════════════ */
.section { padding:100px 24px;position:relative;z-index:1; }
.inner   { max-width:1100px;margin:0 auto; }
.sec-dark{ background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border); }

/* Counters */
.counters { display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;margin-bottom:60px; }
.counter-card { background:var(--bg3);padding:32px;text-align:center;transition:background var(--t-slow); }
.counter-card:hover { background:rgba(124,58,237,.06); }
.counter-val { font-size:52px;font-weight:900;letter-spacing:-3px;line-height:1;color:var(--text);margin-bottom:8px; }
.counter-val.v { color:var(--vl); }
.counter-val.g { color:var(--green); }
.counter-val.o { color:var(--gold); }
.counter-lbl { font-size:14px;color:var(--text2);font-weight:500; }

/* Secteurs */
.sec-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:12px; }
.sc { background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:26px 20px;text-align:center;transition:all var(--t-slow);position:relative;overflow:hidden;cursor:pointer; }
.sc:hover { border-color:rgba(124,58,237,.35);transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.5); }
.sc-em { font-size:32px;margin-bottom:10px;display:block;transition:transform var(--t-slow); }
.sc:hover .sc-em { transform:scale(1.15); }
.sc-n { font-size:13px;font-weight:700;color:var(--text);margin-bottom:4px; }
.sc-c { font-size:11px;color:var(--text3); }

/* Comparatif */
.cmp { display:grid;grid-template-columns:1fr 1fr;gap:16px; }
.cmp-card { border-radius:var(--r-xl);padding:32px;border:1px solid var(--border);background:var(--bg3);position:relative;overflow:hidden; }
.cmp-card.no::before  { content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#ef4444,transparent); }
.cmp-card.yes::before { content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--v1),transparent); }
.cmp-head { font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:20px; }
.cmp-head.bad  { color:#f87171; }
.cmp-head.good { color:var(--vl); }
.cmp-row { display:flex;align-items:flex-start;gap:12px;margin-bottom:12px;font-size:14px;color:var(--text2);line-height:1.5; }

/* Features */
.feat-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden; }
.fc { background:var(--bg3);padding:32px 28px;transition:background var(--t-slow);position:relative;overflow:hidden; }
.fc:hover { background:rgba(124,58,237,.05); }
.fc::after { content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--v1),var(--accent));opacity:0;transition:opacity var(--t-slow); }
.fc:hover::after { opacity:1; }
.fi-icon { width:48px;height:48px;border-radius:14px;background:rgba(124,58,237,.12);border:1px solid rgba(124,58,237,.18);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:18px;transition:all var(--t-slow); }
.fc:hover .fi-icon { background:rgba(124,58,237,.2);transform:scale(1.1); }
.fc-title { font-size:16px;font-weight:700;color:var(--text);margin-bottom:8px; }
.fc-desc  { font-size:13px;color:var(--text2);line-height:1.65; }

/* Steps */
.steps { display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative; }
.steps::after { content:'';position:absolute;top:32px;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--border2),var(--border2),transparent); }
.step  { text-align:center;position:relative; }
.step-n{ width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--v1),var(--v2));color:#fff;font-size:22px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;position:relative;z-index:1;box-shadow:0 0 40px var(--vg);transition:transform var(--t-slow); }
.step:hover .step-n { transform:scale(1.1); }
.step-t{ font-size:14px;font-weight:700;color:var(--text);margin-bottom:8px; }
.step-d{ font-size:13px;color:var(--text2);line-height:1.6; }

/* Pricing */
.plans { display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:780px;margin:0 auto; }
.plan  { background:var(--bg3);border:1px solid var(--border);border-radius:var(--r-2xl);padding:36px 32px;position:relative;transition:all var(--t-slow);overflow:hidden; }
.plan:hover { border-color:rgba(124,58,237,.3);transform:translateY(-4px);box-shadow:0 40px 100px rgba(0,0,0,.7); }
.plan.star  { border-color:rgba(124,58,237,.4);background:linear-gradient(160deg,rgba(124,58,237,.07),var(--bg3)); }
.plan-badge { position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--v1),var(--v2));color:#fff;font-size:11px;font-weight:700;padding:5px 18px;border-radius:0 0 14px 14px;white-space:nowrap;box-shadow:0 8px 24px var(--vg); }
.plan-name  { font-size:12px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:14px;margin-top:14px; }
.plan-price { font-size:64px;font-weight:900;letter-spacing:-3px;line-height:1;margin-bottom:4px; }
.plan.star .plan-price { background:linear-gradient(135deg,var(--vll),var(--v1));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text; }
.plan-price sup  { font-size:24px;vertical-align:top;margin-top:14px;font-weight:600;letter-spacing:0; }
.plan-price span { font-size:17px;color:var(--text2);font-weight:500;letter-spacing:0; }
.plan-sub   { font-size:12px;color:var(--text3);margin-bottom:8px; }
.nfc-pill   { display:inline-flex;align-items:center;gap:6px;background:rgba(124,58,237,.1);border:1px solid rgba(124,58,237,.2);color:var(--vl);font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px;margin-bottom:24px; }
.plan-div   { height:1px;background:var(--border);margin:18px 0; }
.pfeats     { list-style:none;margin-bottom:28px;display:flex;flex-direction:column;gap:9px; }
.pf         { display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--text2);line-height:1.4; }
.pck        { color:var(--vl);font-weight:800;flex-shrink:0; }

/* Témoignages */
.testis { display:grid;grid-template-columns:repeat(3,1fr);gap:14px; }
.testi  { background:var(--bg3);border:1px solid var(--border);border-radius:var(--r-xl);padding:26px;transition:all var(--t-slow);position:relative;overflow:hidden; }
.testi:hover { border-color:rgba(124,58,237,.3);transform:translateY(-4px); }
.t-stars  { color:var(--gold);font-size:13px;margin-bottom:12px;letter-spacing:3px; }
.t-text   { font-size:15px;color:var(--text);line-height:1.65;margin-bottom:18px;font-family:'Instrument Serif',serif;font-style:italic; }
.t-author { display:flex;align-items:center;gap:10px; }
.t-av     { width:38px;height:38px;border-radius:50%;background:rgba(124,58,237,.12);border:1px solid rgba(124,58,237,.2);display:flex;align-items:center;justify-content:center;font-size:18px; }
.t-name   { font-size:13px;font-weight:700;color:var(--text); }
.t-job    { font-size:11px;color:var(--text3); }
.t-result { margin-top:14px;display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--vl);background:rgba(124,58,237,.08);padding:7px 12px;border-radius:10px;border:1px solid rgba(124,58,237,.12); }

/* FAQ */
.faq-inner { max-width:700px;margin:0 auto; }
.faq-item  { background:var(--bg3);border:1px solid var(--border);border-radius:14px;margin-bottom:8px;overflow:hidden;transition:all .25s; }
.faq-item.on { border-color:rgba(124,58,237,.3); }
.faq-q     { padding:18px 20px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;color:var(--text);transition:background var(--t); }
.faq-item.on .faq-q { background:rgba(124,58,237,.07);color:var(--vl); }
.faq-ic    { width:26px;height:26px;border-radius:8px;background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:16px;transition:all var(--t-slow);flex-shrink:0;color:var(--text2); }
.faq-item.on .faq-ic { background:rgba(124,58,237,.18);color:var(--vl);transform:rotate(45deg); }
.faq-a { font-size:13px;color:var(--text2);line-height:1.75;padding:0 20px;max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s; }
.faq-item.on .faq-a { max-height:200px;padding:16px 20px; }

/* CTA */
.cta-wrap   { padding:120px 24px;text-align:center;position:relative;overflow:hidden;z-index:1; }
.cta-orb    { position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:700px;height:500px;background:radial-gradient(ellipse,rgba(124,58,237,.12),transparent 65%);pointer-events:none; }
.cta-inner  { max-width:660px;margin:0 auto;position:relative;z-index:1; }
.cta-h      { font-size:clamp(44px,6.5vw,80px);font-weight:900;letter-spacing:-3px;line-height:1.02;margin-bottom:20px;color:var(--text); }
.cta-h .s   { font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:linear-gradient(135deg,var(--vll),var(--v1));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text; }
.cta-p      { font-size:17px;color:var(--text2);margin-bottom:40px;line-height:1.65; }
.cta-badges { display:flex;justify-content:center;gap:16px;margin-top:20px;flex-wrap:wrap; }
.cbadge     { font-size:12px;color:var(--text3);display:flex;align-items:center;gap:6px; }
.cbadge::before { content:'✓';color:var(--vl);font-weight:800; }


/* ════════════════════════════════════════════════════════════
   13. FOOTER
════════════════════════════════════════════════════════════ */
footer { border-top:1px solid var(--border);padding:40px 48px;background:var(--bg);position:relative;z-index:1; }
.foot-top    { display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:24px;margin-bottom:28px; }
.foot-logo   { font-size:15px;font-weight:700;color:var(--text2); }
.foot-tagline{ font-size:12px;color:var(--text3);margin-top:6px;max-width:200px;line-height:1.5; }
.foot-social { display:flex;gap:8px;margin-top:12px; }
.foot-social a { width:32px;height:32px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:14px;text-decoration:none;transition:all var(--t); }
.foot-social a:hover { background:rgba(124,58,237,.12);border-color:rgba(124,58,237,.25); }
.foot-col h4 { font-size:11px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px; }
.foot-col a  { display:block;font-size:13px;color:var(--text3);text-decoration:none;margin-bottom:8px;transition:color var(--t); }
.foot-col a:hover { color:var(--text2); }
.foot-bottom { display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:20px;border-top:1px solid var(--border); }
.foot-copy   { font-size:12px;color:var(--text3); }
.foot-legal  { display:flex;gap:16px;flex-wrap:wrap; }
.foot-legal a{ font-size:12px;color:var(--text3);text-decoration:none;transition:color var(--t); }
.foot-legal a:hover { color:var(--text2); }


/* ════════════════════════════════════════════════════════════
   14. ANIMATIONS
════════════════════════════════════════════════════════════ */
.reveal       { opacity:0;transform:translateY(40px);  transition:opacity .8s ease,transform .8s ease; }
.reveal-left  { opacity:0;transform:translateX(-40px); transition:opacity .8s ease,transform .8s ease; }
.reveal-right { opacity:0;transform:translateX(40px);  transition:opacity .8s ease,transform .8s ease; }
.reveal.visible,.reveal-left.visible,.reveal-right.visible { opacity:1;transform:none; }
.d1 { transition-delay:.12s; }
.d2 { transition-delay:.24s; }
.d3 { transition-delay:.36s; }
@keyframes fadeUp { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }


/* ════════════════════════════════════════════════════════════
   15. CURSEUR PERSONNALISÉ + PARTICLES (landing)
════════════════════════════════════════════════════════════ */
#cursor { width:8px;height:8px;background:var(--vl);border-radius:50%;position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .2s,height .2s,background .2s; }
#particles { position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.6; }


/* ════════════════════════════════════════════════════════════
   16. MARQUEE
════════════════════════════════════════════════════════════ */
.marquee-wrap { overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg2);padding:14px 0;position:relative;z-index:1; }
.marquee-wrap::before,.marquee-wrap::after { content:'';position:absolute;top:0;bottom:0;width:200px;z-index:2;pointer-events:none; }
.marquee-wrap::before { left:0; background:linear-gradient(90deg,var(--bg2),transparent); }
.marquee-wrap::after  { right:0;background:linear-gradient(-90deg,var(--bg2),transparent); }
.mtrack { display:flex;width:max-content;animation:mq 28s linear infinite; }
.mitem  { display:flex;align-items:center;gap:10px;padding:0 40px;font-size:13px;font-weight:600;color:var(--text2);border-right:1px solid var(--border);white-space:nowrap; }
.mitem .mv { color:var(--text);font-size:15px;font-weight:800; }
@keyframes mq { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }


/* ════════════════════════════════════════════════════════════
   17. AUDIT GBP
════════════════════════════════════════════════════════════ */
.audit-grid { display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center; }
.audit-card { background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r-xl);padding:28px;box-shadow:0 40px 100px rgba(0,0,0,.7);position:relative;overflow:hidden; }
.audit-card::before { content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(124,58,237,.5),transparent); }
.score-ring  { width:96px;height:96px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 10px;position:relative;background:conic-gradient(var(--v1) 0% 68%,rgba(255,255,255,.05) 68% 100%); }
.score-ring::before { content:'';position:absolute;inset:10px;background:var(--bg3);border-radius:50%; }
.score-num   { position:relative;z-index:1;font-size:24px;font-weight:900;color:var(--vl); }
.score-lbl   { font-size:12px;color:var(--text2);text-align:center;margin-bottom:20px; }
.arows       { display:flex;flex-direction:column;gap:8px; }
.arow        { display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:10px 12px; }
.arow-icon   { font-size:15px;flex-shrink:0; }
.arow-label  { font-size:12px;font-weight:600;color:var(--text);flex:1; }
.arow-bar    { width:80px;height:5px;background:rgba(255,255,255,.05);border-radius:3px;overflow:hidden; }
.arow-fill   { height:100%;border-radius:3px;background:linear-gradient(90deg,var(--v1),var(--vl));width:0%;transition:width 1.5s ease; }
.arow-badge  { font-size:9px;font-weight:700;padding:2px 8px;border-radius:20px;white-space:nowrap; }
.ab-ok   { background:rgba(34,197,94,.1); color:#4ade80;border:1px solid rgba(34,197,94,.15); }
.ab-warn { background:rgba(245,158,11,.08);color:#fbbf24;border:1px solid rgba(245,158,11,.12); }
.ab-bad  { background:rgba(239,68,68,.08); color:#f87171;border:1px solid rgba(239,68,68,.12); }


/* ════════════════════════════════════════════════════════════
   18. RESPONSIVE
════════════════════════════════════════════════════════════ */
@media (max-width:960px) {
  nav { padding:0 16px; }
  .nav-links { display:none; }
  .hero,.section { padding:80px 16px; }
  .hero { padding-top:130px; }
  .sec-grid,.feat-grid,.testis,.steps { grid-template-columns:1fr; }
  .steps::after { display:none; }
  .cmp,.audit-grid,.plans { grid-template-columns:1fr; }
  .counters { grid-template-columns:1fr 1fr; }
  footer { padding:28px 16px; }
  .foot-top { flex-direction:column; }
  body { cursor:auto; }
  #cursor { display:none; }
  .social-bar,.sbar { gap:12px;flex-wrap:wrap;height:auto;padding:6px 12px; }
}
@media (max-width:1100px) {
  .kgrid  { grid-template-columns:1fr 1fr; }
  .mrow   { grid-template-columns:1fr; }
  .toprow { grid-template-columns:1fr 1fr; }
}
@media (max-width:900px) {
  .sidebar { transform:translateX(-100%); }
  .main    { margin-left:0; }
  .kgrid   { grid-template-columns:1fr 1fr; }
  .toprow  { grid-template-columns:1fr; }
  .content { padding:16px; }
}

/* FORMULAIRE PRO */

.form-pro {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.input-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.input-group label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.input-group input,
.input-group select,
.input-group textarea {
  background: rgba(255,255,255,0.03);
  border: 1.5px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 14px;
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  color: var(--text);
  transition: all .25s ease;
  outline: none;
}

/* HOVER */
.input-group input:hover,
.input-group textarea:hover,
.input-group select:hover {
  border-color: rgba(124,58,237,0.3);
}

/* FOCUS */
.input-group input:focus,
.input-group textarea:focus,
.input-group select:focus {
  border-color: #a78bfa;
  background: rgba(124,58,237,0.05);
  box-shadow: 0 0 0 3px rgba(124,58,237,0.15);
}

/* TEXTAREA */
textarea {
  min-height: 140px;
  resize: vertical;
}

/* BOUTON */
.btn-send-pro {
  margin-top: 10px;
  padding: 16px;
  border: none;
  border-radius: 14px;
  background: linear-gradient(135deg, #7c3aed, #a78bfa);
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: all .25s ease;
  box-shadow: 0 0 25px rgba(124,58,237,0.4);
}

.btn-send-pro:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 40px rgba(124,58,237,0.6);
}

/* MOBILE */
@media(max-width:768px) {
  .form-row {
    grid-template-columns: 1fr;
  }
}