  .eyebrow{
    font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
    color:var(--brand);font-weight:600;
  }



  /* ---------- BANDEAU D'ACCROCHE ---------- */
  .intro{
    position:relative;overflow:hidden;
    background:linear-gradient(160deg,#1c4a82,#2563a8 55%,#0f8a9c);
    color:#fff;padding:74px 0 84px;
  }
  .intro::before{
    content:"";position:absolute;top:-160px;left:-120px;width:480px;height:480px;
    background:radial-gradient(circle,rgba(255,255,255,.12),transparent 68%);border-radius:50%;
  }
  .intro::after{
    content:"";position:absolute;bottom:-200px;right:-140px;width:520px;height:520px;
    background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%);border-radius:50%;
  }
  .intro-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;
    position:relative;z-index:2;
  }
  .intro .eyebrow{color:#bcd6f0}
  .intro h2{
    color:#fff;font-size:clamp(1.7rem,3.4vw,2.5rem);
    margin:14px 0 18px;line-height:1.2;
  }
  .intro p{color:rgba(255,255,255,.82);font-size:1.05rem;max-width:46ch}
  .intro p strong{color:#fff;font-weight:600}
  .intro .scan-pill{
    display:inline-flex;align-items:center;gap:10px;margin-top:22px;
    background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.22);
    padding:.7rem 1.2rem;border-radius:999px;font-size:.95rem;
  }
  .intro .scan-pill svg{width:20px;height:20px;flex-shrink:0;color:#bcd6f0}

  /* mockups appareils */
  .devices{position:relative;height:380px}
  .device-laptop{
    position:absolute;top:18px;left:0;width:84%;z-index:2;
  }
  .laptop-screen{
    overflow:hidden;
  }
  .laptop-screen img{display:block;width:100%}
  .device-phone{
    position:absolute;bottom:0;right:10%;width:30%;z-index:3;
  }
  .phone-frame img{display:block;width:100%;border-radius:18px}

  /* ---------- HERO ---------- */
  .hero{position:relative;overflow:hidden;padding:84px 0 90px}
  .hero::before{
    content:"";position:absolute;top:-180px;right:-160px;width:560px;height:560px;
    background:radial-gradient(circle,rgba(37,99,168,.14),transparent 68%);border-radius:50%;
  }
  .hero::after{
    content:"";position:absolute;bottom:-200px;left:-180px;width:520px;height:520px;
    background:radial-gradient(circle,rgba(15,138,156,.13),transparent 68%);border-radius:50%;
  }
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;position:relative;z-index:2}
  .hero h1{font-size:clamp(1.7rem,3.3vw,2.4rem);margin:14px 0 22px}
  .hero h1 em{font-style:normal;color:var(--brand);position:relative}
  .hero h1 em::after{
    content:"";position:absolute;left:0;bottom:.06em;width:100%;height:.16em;
    background:rgba(37,99,168,.22);border-radius:4px;z-index:-1;
  }
  .hero .eyebrow{
    font-size:clamp(1.05rem,2.4vw,1.55rem);
    letter-spacing:.04em;line-height:1.25;
    display:block;
  }
  .hero p.lead{font-size:1.16rem;color:var(--ink-soft);max-width:38ch;margin-bottom:30px}
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
  .hero-cta .phone{font-size:.95rem;color:var(--ink-soft)}
  .hero-cta .phone b{color:var(--ink);font-weight:600}

  /* hero visual : carte produit "scan" */
  .hero-card{
    background:var(--surface);border-radius:var(--radius);border:1px solid var(--line);
    box-shadow:var(--shadow);padding:30px;position:relative;
  }
  .hero-card .tag{
    position:absolute;top:-16px;left:30px;background:var(--accent);color:#fff;
    font-size:.74rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
    padding:.45rem .95rem;border-radius:999px;
  }
  .scan-flow{display:flex;align-items:flex-start;gap:14px;margin-top:14px}
  .scan-step{flex:1;text-align:center;display:flex;flex-direction:column;align-items:center}
  .scan-icon{
    width:62px;height:62px;margin:0 auto 10px;border-radius:14px;
    display:flex;align-items:center;justify-content:center;
    background:var(--warm);border:1px solid var(--line);flex-shrink:0;
  }
  .scan-icon svg{width:30px;height:30px}
  .scan-step p{font-size:.82rem;color:var(--ink-soft);line-height:1.4}
  .scan-arrow{color:var(--brand);flex-shrink:0;height:62px;display:flex;align-items:center}
  .hero-card .result{
    margin-top:24px;padding:16px 18px;background:var(--accent-soft);
    border-radius:12px;display:flex;align-items:center;gap:12px;
  }
  .hero-card .result svg{width:22px;height:22px;color:var(--accent);flex-shrink:0}
  .hero-card .result span{font-size:.92rem;color:var(--ink)}

  /* ---------- SECTION ---------- */
  section{padding:90px 0}
  .sec-head{max-width:60ch;margin-bottom:54px}
  .sec-head h2{font-size:clamp(1.9rem,3.6vw,2.6rem);margin:14px 0 14px}
  .sec-head p{color:var(--ink-soft);font-size:1.06rem}

  /* trois piliers */
  .pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
  .pillar{
    background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
    padding:32px 28px;transition:transform .2s ease,box-shadow .2s ease;
  }
  .pillar:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
  .pillar .pic{
    width:54px;height:54px;border-radius:13px;display:flex;align-items:center;justify-content:center;
    margin-bottom:18px;
  }
  .pillar .pic svg{width:28px;height:28px;color:#fff}
  .p1 .pic{background:var(--brand)}
  .p2 .pic{background:var(--accent)}
  .p3 .pic{background:#3a78c4}
  .pillar h3{font-size:1.32rem;margin-bottom:10px}
  .pillar ul{list-style:none;margin-top:14px}
  .pillar li{
    font-size:.93rem;color:var(--ink-soft);padding:7px 0 7px 24px;position:relative;
    border-top:1px solid var(--line);
  }
  .pillar li:first-child{border-top:none}
  .pillar li::before{
    content:"";position:absolute;left:0;top:14px;width:8px;height:8px;border-radius:50%;
    background:var(--brand);opacity:.55;
  }

  /* ---------- WORKFLOW (organigramme client) ---------- */
  .flow{background:linear-gradient(180deg,var(--accent-soft),var(--warm))}
  .flow-steps{
    display:grid;grid-template-columns:repeat(4,1fr);gap:30px 22px;
    counter-reset:step;position:relative;
  }
  .flow-step{
    position:relative;background:var(--surface);
    border:1px solid var(--line);border-radius:var(--radius);
    padding:30px 24px 26px;box-shadow:0 10px 26px -20px rgba(20,40,70,.4);
    transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;
  }
  .flow-step:hover{
    transform:translateY(-8px);
    box-shadow:0 22px 44px -22px rgba(20,40,70,.5);
    border-color:var(--accent);
  }
  .flow-step .n{
    position:absolute;top:-20px;left:24px;
    width:46px;height:46px;border-radius:13px;
    background:var(--brand);color:#fff;
    font-family:'Fraunces',serif;font-size:1.35rem;font-weight:600;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 10px 20px -10px rgba(37,99,168,.8);
  }
  .flow-step .ic{
    width:54px;height:54px;border-radius:13px;
    background:var(--accent-soft);
    display:flex;align-items:center;justify-content:center;
    margin:14px 0 16px;
  }
  .flow-step .ic svg{width:28px;height:28px;color:var(--accent)}
  .flow-step h3{font-size:1.16rem;margin-bottom:8px}
  .flow-step p{font-size:.92rem;color:var(--ink-soft)}
  .flow-step::after{
    content:"";position:absolute;top:50%;right:-17px;z-index:3;
    width:12px;height:12px;
    border-top:2.5px solid var(--brand);border-right:2.5px solid var(--brand);
    transform:translateY(-50%) rotate(45deg);
  }
  .flow-step:last-child::after{display:none}

  /* ---------- FEATURE SPLIT ---------- */
  .split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
  .split-visual{
    background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
    padding:34px;box-shadow:var(--shadow);
  }
  .mini-list{list-style:none}
  .mini-list li{
    display:flex;gap:13px;padding:14px 0;border-bottom:1px dashed var(--line);
    font-size:.96rem;
  }
  .mini-list li:last-child{border-bottom:none}
  .mini-list .ck{
    flex-shrink:0;width:24px;height:24px;border-radius:7px;background:var(--accent-soft);
    display:flex;align-items:center;justify-content:center;
  }
  .mini-list .ck svg{width:14px;height:14px;color:var(--accent)}
  .split h2{font-size:clamp(1.8rem,3.4vw,2.4rem);margin:14px 0 16px}
  .split p{color:var(--ink-soft);margin-bottom:20px}

  /* ---------- CTA ---------- */
  .cta-band{
    background:var(--ink);color:#fff;border-radius:var(--radius);
    padding:56px 50px;display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:center;
    position:relative;overflow:hidden;
  }
  .cta-band::before{
    content:"";position:absolute;top:-120px;right:-80px;width:340px;height:340px;
    background:radial-gradient(circle,rgba(37,99,168,.45),transparent 70%);border-radius:50%;
  }
  .cta-band h2{color:#fff;font-size:2rem;margin-bottom:12px;position:relative}
  .cta-band p{color:rgba(255,255,255,.72);position:relative}
  .cta-actions{display:flex;flex-direction:column;gap:12px;position:relative}
  .cta-actions .btn-primary{text-align:center}
  .cta-actions .btn-light{background:#fff;color:var(--ink);text-align:center}
  .cta-actions .btn-light:hover{background:var(--warm)}


  /* reveal */
  .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
  .reveal.in{opacity:1;transform:none}

  /* ---------- RESPONSIVE ---------- */
  @media(max-width:900px){
    .hero-grid,.split,.cta-band{grid-template-columns:1fr}
    .intro-grid{grid-template-columns:1fr;gap:40px}
    .intro p{max-width:none}
    .devices{height:auto;padding-bottom:30px}
    .device-laptop{position:relative;width:100%;top:0}
    .device-phone{width:34%;right:2%;bottom:-10px}
    .pillars{grid-template-columns:1fr}
    .flow-steps{grid-template-columns:1fr 1fr;gap:38px 30px}
    .flow-step::after{
      top:auto;bottom:-26px;right:50%;
      transform:translateX(50%) rotate(135deg);
    }
    .flow-step:nth-child(2)::after{display:none}
    .cta-band{padding:40px 28px}
  }
  @media(max-width:560px){
    .flow-steps{grid-template-columns:1fr}
    .flow-step:nth-child(2)::after{display:block}
    .flow-step:last-child::after{display:none}
    .foot-grid{grid-template-columns:1fr}
    .scan-flow{flex-direction:column}
    .scan-arrow{transform:rotate(90deg); margin:0 auto;}
    .scan-step{width: 100%;}
  }