/* ===========================================================================
   NovaIA — Design system partagé (landing · inscription · onboarding)
   Tokens alignés sur le dashboard. Charte : bleu / blanc / argent.
   =========================================================================== */
:root{
  --brume:#F5F8FA; --carte:#FFFFFF; --encre:#0F2030; --encre-2:#4F6170; --encre-3:#8696A3;
  --ligne:#E4EBF0; --ligne-2:#D6E0E8;
  --bleu:#1789C9; --bleu-fonce:#0F6CA3; --bleu-pale:#EAF5FC; --bleu-clair:#6BC6F0;
  --orange:#EE8A2A; --orange-pale:#FDF3E7;
  --vert:#17A06B; --vert-pale:#E8F7F0;
  --violet:#7A5CF0; --rouge:#D9534F; --rouge-pale:#FBEDEC;
  --nuit:#0F2030; --nuit-2:#1A3147;
  --argent:#C9D6E0; --argent-clair:#EEF3F7;
  --r:14px; --r-sm:10px; --r-lg:22px;
  --ombre:0 1px 2px rgba(15,32,48,.04), 0 10px 28px -14px rgba(15,32,48,.12);
  --ombre-h:0 2px 4px rgba(15,32,48,.05), 0 18px 36px -14px rgba(15,32,48,.18);
  --ombre-xl:0 30px 70px -30px rgba(15,32,48,.40);
  --display:"Bricolage Grotesque",sans-serif; --body:"Inter",sans-serif; --mono:"JetBrains Mono",monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--brume);color:var(--encre);font-size:15.5px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:var(--body);cursor:pointer;border:none;background:none;color:inherit}
img,svg{display:block}
:focus-visible{outline:2px solid var(--bleu);outline-offset:2px;border-radius:6px}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
h1,h2,h3{font-family:var(--display);letter-spacing:-.025em;line-height:1.08}

/* ---- avatars (sprite) ---- */
.av{border-radius:50%;flex:none;box-shadow:0 1px 0 rgba(255,255,255,.9) inset, 0 0 0 2.5px #fff, 0 6px 16px -6px rgba(15,32,48,.40)}
.av-28{width:28px;height:28px}.av-34{width:34px;height:34px}.av-40{width:40px;height:40px}
.av-44{width:44px;height:44px}.av-56{width:56px;height:56px}.av-64{width:64px;height:64px}.av-84{width:84px;height:84px}

/* ---- boutons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:600;font-size:15px;padding:12px 22px;border-radius:12px;transition:transform .12s,box-shadow .18s,background .18s,border-color .18s;white-space:nowrap}
.btn:active{transform:scale(.97)}
.btn-primaire{background:var(--bleu);color:#fff;box-shadow:0 8px 20px -8px rgba(23,137,201,.65)}
.btn-primaire:hover{background:var(--bleu-fonce);box-shadow:0 12px 26px -8px rgba(23,137,201,.7)}
.btn-fantome{border:1px solid var(--ligne-2);background:var(--carte);color:var(--encre)}
.btn-fantome:hover{border-color:var(--encre-3)}
.btn-nuit{background:var(--nuit);color:#fff}
.btn-nuit:hover{background:var(--nuit-2)}
.btn-lg{padding:15px 28px;font-size:16.5px;border-radius:13px}
.btn-bloc{width:100%}

/* ---- en-tête ---- */
.entete{position:sticky;top:0;z-index:50;background:rgba(245,248,250,.82);backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid transparent;transition:border-color .2s,background .2s}
.entete.scrolled{border-color:var(--ligne);background:rgba(255,255,255,.85)}
.entete .wrap{display:flex;align-items:center;gap:26px;height:68px}
.logo{font-family:var(--display);font-weight:800;font-size:22px;letter-spacing:-.03em;display:flex;align-items:center;gap:9px}
.logo .spark{width:26px;height:26px;border-radius:8px;background:linear-gradient(135deg,var(--bleu),var(--bleu-clair));display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:14px;box-shadow:0 5px 13px -4px rgba(23,137,201,.7)}
.entete nav{display:flex;gap:4px;margin-left:8px}
.entete nav a{padding:8px 13px;border-radius:9px;color:var(--encre-2);font-weight:500;font-size:14.5px;transition:background .15s,color .15s}
.entete nav a:hover{background:var(--bleu-pale);color:var(--bleu-fonce)}
.entete .droite{margin-left:auto;display:flex;align-items:center;gap:10px}
.lien-conn{font-weight:600;font-size:14.5px;color:var(--encre);padding:8px 12px}
.burger{display:none;font-size:24px;margin-left:auto;background:none}

/* ---- héro ---- */
.hero{position:relative;overflow:hidden;padding:72px 0 40px}
.hero::before{content:"";position:absolute;inset:0;background:
   radial-gradient(60% 50% at 78% 8%, rgba(107,198,240,.20), transparent 70%),
   radial-gradient(50% 45% at 12% 30%, rgba(122,92,240,.10), transparent 70%);
   pointer-events:none}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.puce{display:inline-flex;align-items:center;gap:8px;background:var(--carte);border:1px solid var(--ligne);border-radius:99px;padding:6px 14px 6px 7px;font-size:13px;font-weight:600;color:var(--encre-2);box-shadow:var(--ombre);margin-bottom:22px}
.puce .pt{width:8px;height:8px;border-radius:50%;background:var(--vert);box-shadow:0 0 0 4px var(--vert-pale)}
.hero h1{font-size:54px;font-weight:800}
.hero h1 .surligne{background:linear-gradient(120deg,var(--bleu),var(--violet));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .accroche{font-size:19px;color:var(--encre-2);margin:22px 0 30px;max-width:540px}
.hero .cta-rang{display:flex;gap:13px;flex-wrap:wrap}
.hero .sous-cta{margin-top:16px;font-size:13.5px;color:var(--encre-3);display:flex;align-items:center;gap:8px}
.hero .preuve{margin-top:34px;display:flex;align-items:center;gap:14px}
.hero .preuve .pile{display:flex}
.hero .preuve .pile .av{margin-left:-10px}
.hero .preuve .pile .av:first-child{margin-left:0}
.hero .preuve small{font-size:13px;color:var(--encre-2)}
.hero .preuve b{color:var(--encre)}

/* maquette carte de proposition dans le héro */
.maquette{background:var(--carte);border:1px solid var(--ligne);border-radius:var(--r-lg);box-shadow:var(--ombre-xl);padding:18px;position:relative}
.maquette .barre{display:flex;align-items:center;gap:7px;padding:2px 4px 14px}
.maquette .barre i{width:11px;height:11px;border-radius:50%;background:var(--ligne-2)}
.maquette .barre b{margin-left:8px;font-family:var(--display);font-size:14px}
.maquette .barre .live{margin-left:auto;font-size:11px;font-weight:700;color:var(--vert);display:flex;align-items:center;gap:5px}
.maquette .barre .live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--vert);animation:blip 1.6s infinite}
@keyframes blip{0%,100%{opacity:1}50%{opacity:.3}}
.prop{border:1px solid var(--ligne);border-left:4px solid var(--orange);border-radius:12px;padding:15px 16px;margin-bottom:11px;background:#fff;animation:montee .5s both}
.prop:nth-child(2){animation-delay:.1s}.prop:nth-child(3){animation-delay:.2s}
@keyframes montee{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.prop .tete{display:flex;gap:11px;align-items:flex-start}
.prop .qui{font-size:11.5px;color:var(--encre-3);font-weight:600}
.prop .quoi{font-weight:600;font-size:14.5px;margin-top:1px;line-height:1.35}
.prop .pq{margin-top:8px;font-size:12.5px;color:var(--encre-2);background:var(--brume);border:1px solid var(--ligne);border-radius:8px;padding:8px 10px}
.prop .actes{display:flex;gap:8px;margin-top:12px}
.mini-valider{background:var(--vert);color:#fff;padding:7px 15px;border-radius:8px;font-weight:700;font-size:12.5px}
.mini-modif{border:1px solid var(--ligne-2);color:var(--encre-2);padding:7px 13px;border-radius:8px;font-weight:600;font-size:12.5px}
.mini-refus{color:var(--encre-3);font-weight:600;font-size:12.5px;padding:7px 6px}

/* ---- sections ---- */
section.bloc{padding:64px 0}
.surtitre{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--bleu-fonce);margin-bottom:14px}
.bloc h2{font-size:38px;font-weight:800;max-width:680px}
.bloc .lede{font-size:18px;color:var(--encre-2);margin-top:14px;max-width:620px}
.centre{text-align:center;margin:0 auto}
.centre .lede{margin-left:auto;margin-right:auto}

/* bandeau différenciateur (sombre) */
.contraste{background:linear-gradient(160deg,var(--nuit),var(--nuit-2));color:#fff;border-radius:var(--r-lg);padding:48px;margin:8px 0;box-shadow:var(--ombre-xl)}
.contraste h2{color:#fff;font-size:34px}
.contraste .duo{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:30px}
.contraste .col{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);border-radius:16px;padding:24px}
.contraste .col.nous{background:rgba(23,137,201,.16);border-color:rgba(107,198,240,.4)}
.contraste .col .et{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--argent);margin-bottom:10px}
.contraste .col.nous .et{color:var(--bleu-clair)}
.contraste .col p{font-size:17px;color:#E7EEF4}
.contraste .col.nous p{color:#fff;font-weight:500}

/* étapes "comment ça marche" */
.etapes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:36px}
.etape{background:var(--carte);border:1px solid var(--ligne);border-radius:var(--r);padding:26px;box-shadow:var(--ombre)}
.etape .num{width:34px;height:34px;border-radius:10px;background:var(--bleu-pale);color:var(--bleu-fonce);font-family:var(--display);font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.etape h3{font-size:19px}
.etape p{color:var(--encre-2);margin-top:8px;font-size:14.5px}

/* grille employés */
.poles{display:flex;flex-direction:column;gap:30px;margin-top:38px}
.pole .titre-pole{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:700;font-size:15px;margin-bottom:14px;color:var(--encre)}
.pole .titre-pole .pastille{width:9px;height:9px;border-radius:50%}
.grille-emp{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px}
.emp{display:flex;align-items:center;gap:13px;background:var(--carte);border:1px solid var(--ligne);border-radius:var(--r);padding:14px 15px;box-shadow:var(--ombre);transition:transform .15s,box-shadow .2s}
.emp:hover{transform:translateY(-3px);box-shadow:var(--ombre-h)}
.emp b{font-size:15px;display:block}
.emp span{font-size:12.5px;color:var(--encre-3)}
.emp.vedette{grid-column:1/-1;background:linear-gradient(120deg,#fff,var(--bleu-pale));border-color:var(--ligne-2)}
.emp .ruban{margin-left:auto;font-size:11px;font-weight:700;color:var(--bleu-fonce);background:#fff;border:1px solid var(--ligne);border-radius:99px;padding:3px 10px}

/* atout téléphonie */
.split{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center;margin-top:30px}
.liste-coches{list-style:none;margin-top:22px;display:flex;flex-direction:column;gap:14px}
.liste-coches li{display:flex;gap:12px;align-items:flex-start;font-size:15.5px}
.liste-coches .ck{width:24px;height:24px;border-radius:8px;background:var(--vert-pale);color:var(--vert);display:flex;align-items:center;justify-content:center;font-weight:800;flex:none;font-size:13px}
.panneau-tel{background:var(--carte);border:1px solid var(--ligne);border-radius:var(--r-lg);box-shadow:var(--ombre-xl);overflow:hidden}
.panneau-tel .haut{background:linear-gradient(160deg,var(--nuit),var(--nuit-2));color:#fff;padding:20px 22px}
.panneau-tel .haut .num{font-family:var(--mono);font-size:22px;letter-spacing:.04em}
.panneau-tel .haut small{color:var(--argent);font-size:12px}
.panneau-tel .corps{padding:18px 22px;display:flex;flex-direction:column;gap:12px}
.ligne-appel{display:flex;align-items:center;gap:12px;font-size:14px}
.ligne-appel .badge-res{margin-left:auto;font-size:11px;font-weight:700;border-radius:99px;padding:3px 10px}
.b-vert{background:var(--vert-pale);color:var(--vert)}.b-bleu{background:var(--bleu-pale);color:var(--bleu-fonce)}.b-orange{background:var(--orange-pale);color:var(--orange)}

/* cartes génériques 3 colonnes */
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:36px}
.carte-fonc{background:var(--carte);border:1px solid var(--ligne);border-radius:var(--r);padding:26px;box-shadow:var(--ombre)}
.carte-fonc .ico{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:16px}
.carte-fonc h3{font-size:19px}
.carte-fonc p{color:var(--encre-2);margin-top:8px;font-size:14.5px}

/* pricing */
.prix-grille{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px;align-items:stretch}
.plan{background:var(--carte);border:1px solid var(--ligne);border-radius:var(--r-lg);padding:30px;box-shadow:var(--ombre);display:flex;flex-direction:column;position:relative}
.plan.populaire{border:2px solid var(--bleu);box-shadow:var(--ombre-xl);transform:translateY(-6px)}
.plan .tag-pop{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--bleu);color:#fff;font-size:12px;font-weight:700;padding:5px 14px;border-radius:99px}
.plan h3{font-size:21px}
.plan .px{font-family:var(--display);font-size:42px;font-weight:800;margin:12px 0 2px}
.plan .px small{font-size:15px;font-weight:500;color:var(--encre-3)}
.plan .desc{color:var(--encre-2);font-size:14px;min-height:42px}
.plan ul{list-style:none;margin:20px 0;display:flex;flex-direction:column;gap:11px;flex:1}
.plan ul li{display:flex;gap:10px;font-size:14.5px;align-items:flex-start}
.plan ul li::before{content:"✓";color:var(--vert);font-weight:800;flex:none}
.bandeau-inclus{margin-top:26px;background:linear-gradient(120deg,var(--bleu-pale),#fff);border:1px solid var(--ligne-2);border-radius:var(--r);padding:18px 22px;display:flex;align-items:center;gap:16px;font-size:15px}
.bandeau-inclus .pile{display:flex}.bandeau-inclus .pile .av{margin-left:-12px}.bandeau-inclus .pile .av:first-child{margin-left:0}

/* faq */
.faq{max-width:760px;margin:34px auto 0}
.qa{background:var(--carte);border:1px solid var(--ligne);border-radius:var(--r);margin-bottom:12px;box-shadow:var(--ombre);overflow:hidden}
.qa summary{padding:18px 22px;font-weight:600;font-size:16px;cursor:pointer;list-style:none;display:flex;align-items:center;gap:12px}
.qa summary::after{content:"+";margin-left:auto;font-size:22px;color:var(--encre-3);transition:transform .2s}
.qa[open] summary::after{transform:rotate(45deg)}
.qa .rep{padding:0 22px 18px;color:var(--encre-2);font-size:15px}

/* cta final */
.cta-final{background:linear-gradient(160deg,var(--bleu),var(--bleu-fonce));border-radius:var(--r-lg);padding:56px;text-align:center;color:#fff;box-shadow:var(--ombre-xl);position:relative;overflow:hidden}
.cta-final::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 50% -10%,rgba(255,255,255,.22),transparent 70%)}
.cta-final h2{color:#fff;font-size:38px;position:relative}
.cta-final p{color:#E7F3FB;font-size:18px;margin:14px auto 28px;max-width:520px;position:relative}
.cta-final .btn{position:relative}
.cta-final .btn-blanc{background:#fff;color:var(--bleu-fonce)}
.cta-final .btn-blanc:hover{background:#F0F8FD}

/* pied */
footer.pied{padding:54px 0 40px;border-top:1px solid var(--ligne);margin-top:20px}
footer.pied .wrap{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px}
footer.pied .logo{margin-bottom:12px}
footer.pied p{color:var(--encre-3);font-size:13.5px;max-width:260px}
footer.pied h4{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--encre-3);margin-bottom:12px;font-family:var(--body)}
footer.pied a{display:block;color:var(--encre-2);font-size:14px;padding:5px 0}
footer.pied a:hover{color:var(--bleu-fonce)}
.copy{text-align:center;color:var(--encre-3);font-size:13px;margin-top:36px}
.copy .ft{display:inline-flex;align-items:center;gap:6px;font-weight:600;color:var(--encre-2)}

/* responsive */
@media(max-width:920px){
  .hero .wrap,.split,.contraste .duo{grid-template-columns:1fr}
  .hero h1{font-size:40px}.bloc h2{font-size:30px}
  .etapes,.trio,.prix-grille{grid-template-columns:1fr}
  .entete nav{display:none}.burger{display:block}
  .plan.populaire{transform:none}
  footer.pied .wrap{grid-template-columns:1fr 1fr}
  .hero .maquette{order:-1}
}
