:root{
  --bg:#080c14;
  --bg2:#0e1422;
  --bg3:#131929;
  --txt:#fff;
  --txt2:#94a3b8;
  --muted:#4b5a6e;
  --border:#1e2a3a;
  --blight:#253347;
  --green:#10b981;
  --grad:linear-gradient(135deg,#2563eb,#06b6d4);
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--txt);font-family:var(--font);line-height:1.6;-webkit-font-smoothing:antialiased;padding-top:96px;overflow-x:hidden;width:100%;max-width:100vw}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.g{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.c{width:min(1140px,92%);margin:0 auto}

/* NAV FLOTTANTE */
.nav{position:fixed;top:20px;left:50%;transform:translateX(-50%);width:96%;max-width:1200px;height:64px;z-index:1000;border-radius:18px;background:rgba(8,12,20,.88);border:1px solid rgba(37,99,235,.22);backdrop-filter:blur(40px) saturate(180%);-webkit-backdrop-filter:blur(40px) saturate(180%);box-shadow:0 10px 40px rgba(0,0,0,.5);overflow:hidden}
.nav::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:1px;background:linear-gradient(90deg,transparent,#2563eb,#06b6d4,transparent);animation:beam 6s linear infinite}
@keyframes beam{0%{left:-100%}100%{left:200%}}
.nav-i{display:flex;align-items:center;justify-content:space-between;height:100%;padding:0 24px}
.logo{display:flex;align-items:center;gap:10px}
.logo img{height:32px;width:32px;object-fit:contain;flex-shrink:0;border-radius:6px}
.logo-t{font-size:1.05rem;font-weight:800;letter-spacing:-.02em}
.logo-t span{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav-l{display:flex;align-items:center;gap:4px}
.nav-l a{padding:7px 13px;border-radius:9px;font-size:.83rem;font-weight:500;color:var(--txt2);transition:color .18s,background .18s}
.nav-l a:hover,.nav-l a.active{color:var(--txt);background:rgba(255,255,255,.06)}
.nav-cta{padding:8px 18px!important;background:var(--grad)!important;color:#fff!important;border-radius:11px!important;font-weight:600!important}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;border:none;background:none}
.burger span{display:block;width:22px;height:2px;background:var(--txt);border-radius:2px}
.mob{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:999;background:rgba(8,12,20,.98);backdrop-filter:blur(20px);padding:100px 24px 40px;flex-direction:column;gap:8px}
.mob.open{display:flex}
.mob a{padding:14px 18px;border-radius:12px;font-size:1.05rem;font-weight:500;color:var(--txt2);border:1px solid var(--border)}
.mob a:hover{color:var(--txt);border-color:rgba(37,99,235,.5)}
.mob .x{position:absolute;top:24px;right:24px;background:var(--bg2);border:1px solid var(--border);color:var(--txt);width:40px;height:40px;border-radius:10px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center}

/* HERO */
.hero{padding:60px 0;background:radial-gradient(ellipse at 30% 40%,rgba(37,99,235,.13) 0,transparent 55%),radial-gradient(ellipse at 80% 20%,rgba(6,182,212,.08) 0,transparent 45%),var(--bg);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.badge{display:inline-flex;align-items:center;gap:7px;background:rgba(37,99,235,.1);border:1px solid rgba(37,99,235,.3);border-radius:50px;padding:5px 15px;font-size:.72rem;font-weight:700;color:#60a5fa;letter-spacing:.05em;text-transform:uppercase;margin-bottom:22px}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--grad);flex-shrink:0;animation:pd 2s ease-in-out infinite}
@keyframes pd{0%,100%{opacity:1}50%{opacity:.3}}
h1{font-size:clamp(2rem,4.5vw,3.1rem);font-weight:900;letter-spacing:-.04em;line-height:1.08;margin-bottom:18px}
.sub{font-size:.97rem;color:var(--txt2);max-width:460px;margin-bottom:34px;line-height:1.78}
.btns{display:flex;gap:13px;margin-bottom:44px;flex-wrap:wrap}
.btn{padding:12px 24px;border-radius:12px;font-size:.9rem;font-weight:600;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:all .2s}
.btn:hover{transform:translateY(-1px)}
.bp{background:var(--grad);color:#fff;box-shadow:0 4px 20px rgba(37,99,235,.3)}
.bo{background:transparent;border:1.5px solid var(--blight);color:var(--txt)}
.stats{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.stat strong{display:block;font-size:1.5rem;font-weight:900;letter-spacing:-.03em;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat span{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.sdiv{width:1px;height:30px;background:var(--border)}
.hero-img{position:relative}
.hero-img img{width:100%;border-radius:20px;border:1px solid var(--border);max-height:460px;object-fit:cover}

/* PAGE HERO (autres pages) */
.ph{padding:40px 0 30px;text-align:center;background:radial-gradient(ellipse at top,rgba(37,99,235,.1) 0,transparent 55%),var(--bg)}
.ph .lab{font-size:.69rem;font-weight:700;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px;display:inline-block}
.ph h1{font-size:clamp(1.7rem,3.5vw,2.5rem);margin-bottom:14px}
.ph p{font-size:.93rem;color:var(--txt2);max-width:580px;margin:0 auto;line-height:1.7}

/* SECTIONS */
.sec{padding:64px 0}
.sec-d{background:var(--bg2)}
.sh{margin-bottom:46px}
.sh.ctr{text-align:center}
.lab{font-size:.69rem;font-weight:700;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.1em;text-transform:uppercase;display:block;margin-bottom:10px}
h2{font-size:clamp(1.6rem,3vw,2.1rem);font-weight:800;letter-spacing:-.03em;line-height:1.15;margin-bottom:10px}
h3{font-size:1.05rem;font-weight:700;color:var(--txt)}
.sd{font-size:.93rem;color:var(--txt2);max-width:520px;line-height:1.75}
.sh.ctr .sd{margin:0 auto}

/* FEATURES */
.feat-g{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.feat{background:var(--bg2);border:1px solid var(--border);border-radius:17px;padding:24px;transition:.2s}
.feat:hover{border-color:rgba(37,99,235,.35);transform:translateY(-3px)}
.fic{width:44px;height:44px;background:rgba(37,99,235,.1);border:1px solid rgba(37,99,235,.2);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:14px}
.feat h3{font-size:.97rem;margin-bottom:7px}
.feat p{font-size:.82rem;color:var(--txt2);line-height:1.65}

/* DEVICES */
.dev-g{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.dev-img{border-radius:18px;overflow:hidden;border:1px solid var(--border)}
.dev-img img{width:100%;height:320px;object-fit:cover}
.compat{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:22px 0}
.cc{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:14px 8px;text-align:center;transition:.2s}
.cc:hover{border-color:rgba(37,99,235,.35)}
.cc-i{font-size:1.5rem;margin-bottom:6px}
.cc span{font-size:.7rem;color:var(--txt2);font-weight:500}

/* CHECK LIST */
.cl{display:flex;flex-direction:column;gap:11px;margin:22px 0;list-style:none}
.cl li{display:flex;align-items:flex-start;gap:10px;font-size:.88rem;color:var(--txt2)}
.cl li::before{content:'✓';color:var(--green);font-weight:700;flex-shrink:0}

/* PRICING */
.pr-g{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.pc{background:var(--bg2);border:1px solid var(--border);border-radius:19px;padding:28px;position:relative;transition:.2s}
.pc.star{border-color:rgba(37,99,235,.5);background:linear-gradient(160deg,rgba(37,99,235,.07),var(--bg2))}
.pbd{display:inline-block;background:var(--grad);color:#fff;font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 10px;border-radius:20px;margin-bottom:16px}
.pc h3{font-size:1.1rem;margin-bottom:4px}
.pt{font-size:.75rem;color:var(--muted);margin-bottom:20px}
.pp{font-size:2.6rem;font-weight:900;letter-spacing:-.04em;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.ps{font-size:.75rem;color:var(--muted);margin:5px 0 24px;display:block}
.pl{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.pl li{display:flex;align-items:flex-start;gap:8px;font-size:.82rem;color:var(--txt2)}
.pl li::before{content:'✓';color:var(--green);font-weight:700;flex-shrink:0}
.pbn{width:100%;padding:11px;border-radius:11px;font-size:.84rem;font-weight:600;border:none;cursor:pointer;margin-bottom:10px;display:inline-block;text-align:center;text-decoration:none}
.pbn-g{background:var(--grad);color:#fff}
.pbn-o{background:transparent;border:1.5px solid var(--blight);color:var(--txt)}
.ppr{text-align:center;font-size:.7rem;color:var(--muted)}
.ppr code{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.2);color:var(--green);padding:2px 7px;border-radius:5px}

/* PROMO */
.promo{background:linear-gradient(135deg,rgba(37,99,235,.11),rgba(6,182,212,.05));border:1px solid rgba(37,99,235,.22);border-radius:18px;padding:34px 38px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.promo h3{font-size:1.4rem;font-weight:800;letter-spacing:-.02em;margin-bottom:7px;color:var(--txt)}
.promo p{font-size:.86rem;color:var(--txt2)}
.pcd{background:rgba(16,185,129,.07);border:2px dashed rgba(16,185,129,.28);border-radius:12px;padding:14px 26px;text-align:center;flex-shrink:0}
.pcd .cd{font-size:1.5rem;font-weight:900;letter-spacing:.08em;color:var(--green);display:block}
.pcd small{font-size:.68rem;color:var(--muted);margin-top:3px;display:block}

/* AVIS */
.rev-g{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.rev{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:20px}
.stars{font-size:.8rem;color:#f59e0b;margin-bottom:9px}
.rev p{font-size:.8rem;color:var(--txt2);line-height:1.65;margin-bottom:13px}
.ra{display:flex;align-items:center;gap:8px}
.rav{width:32px;height:32px;border-radius:50%;background:rgba(37,99,235,.15);border:1px solid rgba(37,99,235,.25);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}
.ra strong{font-size:.79rem;font-weight:600;display:block}
.ra span{font-size:.69rem;color:var(--muted)}

/* FAQ */
.faq{display:flex;flex-direction:column;gap:9px;max-width:760px;margin:0 auto}
details{background:var(--bg2);border:1px solid var(--border);border-radius:13px;overflow:hidden;transition:.2s}
details[open]{border-color:rgba(37,99,235,.35)}
summary{padding:17px 21px;font-size:.91rem;font-weight:600;cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px;user-select:none}
summary::-webkit-details-marker{display:none}
summary::after{content:'+';font-size:1.3rem;font-weight:300;color:var(--muted)}
details[open] summary::after{content:'−'}
.fa{padding:0 21px 16px;font-size:.83rem;color:var(--txt2);line-height:1.75}

/* CTA */
.cta{background:linear-gradient(135deg,rgba(37,99,235,.13),rgba(6,182,212,.05));border:1px solid rgba(37,99,235,.2);border-radius:22px;padding:62px 40px;text-align:center}
.cta h2{font-size:clamp(1.5rem,2.5vw,2.1rem);font-weight:900;letter-spacing:-.03em;margin-bottom:12px}
.cta p{font-size:.95rem;color:var(--txt2);max-width:460px;margin:0 auto 30px}
.cta-b{display:flex;align-items:center;justify-content:center;gap:13px;flex-wrap:wrap}

/* BLOG GRID */
.bg-g{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.bc{background:var(--bg2);border:1px solid var(--border);border-radius:18px;overflow:hidden;transition:.2s;display:flex;flex-direction:column}
.bc:hover{border-color:rgba(37,99,235,.35);transform:translateY(-3px)}
.bc-img-wrap{display:block;height:200px;overflow:hidden;position:relative}
.bc-img-wrap picture,.bc-img-wrap img{display:block;width:100%;height:100%;object-fit:cover;transition:transform .4s}
.bc:hover .bc-img-wrap img{transform:scale(1.04)}
.bc-b{padding:20px;display:flex;flex-direction:column;gap:8px;flex:1}
.bc-tag{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:inline-block}
.bc h3{font-size:1.02rem;font-weight:700;line-height:1.35;margin:2px 0 4px}
.bc h3 a{color:var(--txt);transition:color .15s}
.bc h3 a:hover{color:#60a5fa}
.bc p{font-size:.84rem;color:var(--txt2);line-height:1.6;margin-bottom:auto}
.bc-m{display:flex;justify-content:space-between;align-items:center;font-size:.74rem;padding-top:10px;border-top:1px solid var(--border);margin-top:14px}
.bc-m span{color:var(--muted)}
.bc-m a{color:#60a5fa;font-weight:600}
.bc-m a:hover{color:#06b6d4}

/* ARTICLE */
.aw{max-width:780px;margin:0 auto;padding:30px 4% 60px}
.bk{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:.85rem;margin-bottom:28px}
.bk:hover{color:#60a5fa}
.acat{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block;margin-bottom:10px}
.aw h1{font-size:clamp(1.7rem,3.5vw,2.4rem);font-weight:900;letter-spacing:-.03em;line-height:1.15;margin-bottom:14px}
.am{display:flex;align-items:center;gap:16px;font-size:.78rem;color:var(--muted);margin-bottom:32px;flex-wrap:wrap}
.ah{width:100%;border-radius:18px;margin-bottom:40px;border:1px solid var(--border);height:300px;object-fit:cover}
.prose{font-size:.94rem;color:var(--txt2);line-height:1.85}
.prose h2{font-size:1.4rem;font-weight:800;color:var(--txt);margin:36px 0 14px;letter-spacing:-.02em}
.prose h3{font-size:1.1rem;font-weight:700;color:var(--txt);margin:26px 0 10px}
.prose p{margin-bottom:16px}
.prose ul,.prose ol{padding-left:1.4rem;margin-bottom:16px;display:flex;flex-direction:column;gap:8px}
.prose ul li{list-style:disc}
.prose ol li{list-style:decimal}
.prose strong{color:var(--txt)}
.prose a{color:#60a5fa;text-decoration:underline}

/* LEGAL */
.lw{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:24px}
.lb{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:26px}
.lb h2{font-size:1.05rem;font-weight:700;color:var(--txt);margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.lb p{font-size:.88rem;color:var(--txt2);line-height:1.78;margin-bottom:10px}
.lb p:last-child{margin-bottom:0}
.lb ul{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:10px;font-size:.88rem;color:var(--txt2)}
.lb ul li{display:flex;gap:10px}
.lb ul li::before{content:'→';color:#60a5fa;flex-shrink:0}
.lb a{color:#60a5fa}

/* FOOTER */
footer{background:var(--bg);border-top:1px solid var(--border);padding:50px 0 26px}
.fg{display:grid;grid-template-columns:1.8fr repeat(4,1fr);gap:36px;margin-bottom:40px}
.fb p{font-size:.8rem;color:var(--muted);margin-top:8px;line-height:1.65;max-width:210px}
.fl{display:flex;align-items:center;gap:9px;margin-bottom:8px}
.fl img{height:28px;width:28px;object-fit:contain;border-radius:5px}
.fl-t{font-size:.97rem;font-weight:800;letter-spacing:-.02em}
.fl-t span{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.fc h4{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.fc ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.fc ul li a{font-size:.81rem;color:var(--txt2);transition:.2s}
.fc ul li a:hover{color:var(--txt)}
.fbot{border-top:1px solid var(--border);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.fbot p{font-size:.71rem;color:var(--muted)}

/* WHATSAPP */
.wa{position:fixed;bottom:24px;right:24px;z-index:990;width:52px;height:52px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 5px 20px rgba(37,211,102,.4);animation:wap 3s ease-in-out infinite}
@keyframes wap{0%,100%{box-shadow:0 5px 20px rgba(37,211,102,.4)}50%{box-shadow:0 5px 28px rgba(37,211,102,.6)}}
.wa svg{width:24px;height:24px;fill:#fff}
.wa:hover{transform:scale(1.08)}

/* RESPONSIVE */
@media(max-width:900px){
  .nav-l{display:none}
  .burger{display:flex}
  .hero-grid,.dev-g{grid-template-columns:1fr;gap:32px}
  .feat-g,.bg-g,.pr-g{grid-template-columns:1fr 1fr}
  .rev-g{grid-template-columns:1fr 1fr}
  .fg{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .feat-g,.bg-g,.pr-g,.rev-g,.fg{grid-template-columns:1fr}
  .hero{padding:30px 0}
  body{padding-top:88px}
}


/* ═══════════ OPTIMISATIONS MOBILE STYLE APP ═══════════ */

/* Effets tactiles type app native */
@media(max-width:900px){
  body{-webkit-tap-highlight-color:transparent;overscroll-behavior-y:contain;padding-top:80px}
  
  /* Nav plus compacte sur mobile */
  .nav{top:12px;width:94%;height:56px;border-radius:14px}
  .nav-i{padding:0 16px}
  .logo img{height:28px;width:28px}
  .logo-t{font-size:.95rem}
  
  /* Menu mobile plus épuré */
  .mob{padding:80px 20px 30px}
  .mob a{font-size:1rem;padding:14px 16px;border-radius:11px}
  .mob .x{top:18px;right:18px;width:36px;height:36px}
  
  /* Hero mobile compact */
  .hero{padding:24px 0 36px}
  .hero-grid{gap:24px}
  h1{font-size:clamp(1.65rem,7vw,2.2rem);line-height:1.1}
  .badge{font-size:.65rem;padding:4px 12px;margin-bottom:14px}
  .sub{font-size:.88rem;margin-bottom:22px;line-height:1.65}
  .btns{gap:10px;margin-bottom:28px}
  .btn{padding:12px 20px;font-size:.85rem;flex:1;justify-content:center;min-height:46px}
  
  /* Stats hero mobile : grille 2x2 */
  .stats{display:grid;grid-template-columns:1fr 1fr;gap:14px;width:100%}
  .stat{text-align:center}
  .sdiv{display:none}
  .stat strong{font-size:1.3rem}
  .stat span{font-size:.65rem}
  
  /* Hero image mobile */
  .hero-img img{max-height:240px;border-radius:14px}
  
  /* Sections plus compactes */
  .sec{padding:40px 0}
  .sh{margin-bottom:28px}
  h2{font-size:clamp(1.4rem,5.5vw,1.7rem);line-height:1.18}
  .sd{font-size:.88rem}
  
  /* Page hero mobile */
  .ph{padding:24px 0 20px}
  .ph h1{font-size:clamp(1.5rem,6.5vw,2rem)}
  .ph p{font-size:.86rem}
  
  /* Features cards mobile */
  .feat{padding:18px;border-radius:14px}
  .feat:hover{transform:none}
  .fic{width:38px;height:38px;font-size:1.05rem;margin-bottom:10px}
  .feat h3{font-size:.92rem}
  .feat p{font-size:.78rem}
  
  /* Pricing mobile : un seul par ligne avec animation */
  .pr-g{gap:14px}
  .pc{padding:22px;border-radius:16px}
  .pc.star{transform:none;border-width:1.5px}
  .pp{font-size:2.2rem}
  .pl li{font-size:.8rem;line-height:1.5}
  .pbn{padding:13px;font-size:.86rem;min-height:46px}
  
  /* Promo bandeau mobile */
  .promo{padding:22px 18px;flex-direction:column;text-align:center}
  .promo h3{font-size:1.15rem}
  .promo p{font-size:.83rem}
  .pcd{padding:12px 22px}
  .pcd .cd{font-size:1.3rem}
  
  /* Compat icônes */
  .compat{grid-template-columns:repeat(4,1fr);gap:8px}
  .cc{padding:12px 6px}
  .cc-i{font-size:1.25rem;margin-bottom:4px}
  .cc span{font-size:.62rem}
  
  /* Devices mobile */
  .dev-img img{height:240px;border-radius:14px}
  
  /* Reviews compact */
  .rev-g{gap:10px}
  .rev{padding:16px;border-radius:12px}
  .rev p{font-size:.78rem;margin-bottom:10px}
  .rav{width:28px;height:28px;font-size:.7rem}
  .ra strong{font-size:.76rem}
  .ra span{font-size:.65rem}
  
  /* FAQ mobile */
  summary{padding:14px 16px;font-size:.86rem}
  .fa{padding:0 16px 14px;font-size:.79rem;line-height:1.65}
  
  /* CTA mobile */
  .cta{padding:40px 22px;border-radius:16px}
  .cta h2{font-size:1.35rem}
  .cta p{font-size:.86rem;margin-bottom:22px}
  .cta-b{flex-direction:column;gap:10px}
  .cta-b .btn{width:100%}
  
  /* Blog cards mobile */
  .bg-g{gap:14px}
  .bc{border-radius:14px}
  .bc-img-wrap{height:170px}
  .bc-b{padding:16px;gap:6px}
  .bc h3{font-size:.95rem}
  .bc p{font-size:.78rem}
  
  /* Article mobile */
  .aw{padding:24px 5% 50px}
  .aw h1{font-size:clamp(1.5rem,6vw,2rem)}
  .ah{height:200px;border-radius:14px;margin-bottom:30px}
  .am{font-size:.72rem;gap:10px}
  .prose{font-size:.88rem;line-height:1.78}
  .prose h2{font-size:1.2rem;margin:28px 0 12px}
  .prose h3{font-size:1rem;margin:20px 0 10px}
  
  /* Pages légales mobile */
  .lb{padding:20px;border-radius:14px}
  .lb h2{font-size:.98rem}
  .lb p{font-size:.83rem;line-height:1.7}
  
  /* Footer mobile */
  footer{padding:36px 0 20px}
  .fg{gap:24px;margin-bottom:28px}
  .fc h4{font-size:.66rem;margin-bottom:10px}
  .fc ul{gap:6px}
  .fc ul li a{font-size:.82rem}
  .fb p{font-size:.76rem}
  .fbot{padding-top:18px;flex-direction:column;text-align:center;gap:6px}
  .fbot p{font-size:.68rem}
  
  /* WhatsApp button mobile - plus petit, mieux placé */
  .wa{bottom:18px;right:18px;width:48px;height:48px}
  .wa svg{width:22px;height:22px}
  
  /* Animations actives */
  .btn:active,.pbn:active,.feat:active,.bc:active{transform:scale(.97);transition:transform .1s}
  details:active{transform:scale(.998)}
  
  /* Smooth scroll iOS */
  *{-webkit-overflow-scrolling:touch}
  html{scroll-behavior:smooth}
  
  /* Safe area iOS notch */
  body{padding-bottom:env(safe-area-inset-bottom)}
  .wa{bottom:max(18px,env(safe-area-inset-bottom))}
}

/* Tablette */
@media(min-width:560px) and (max-width:900px){
  .feat-g,.pr-g,.bg-g,.rev-g{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:repeat(4,1fr)}
}

/* Très petits écrans */
@media(max-width:380px){
  body{padding-top:74px}
  .nav{height:52px;top:10px}
  .logo-t{font-size:.85rem}
  h1{font-size:1.55rem}
  .pp{font-size:1.95rem}
  .stats{grid-template-columns:1fr 1fr}
  .stat strong{font-size:1.15rem}
  .compat{grid-template-columns:repeat(3,1fr)}
}

/* PWA-like : empêche zoom sur input */
@media(max-width:900px){
  input,select,textarea{font-size:16px!important}
}


/* ═══════════ PANIER — Style ASOS-like ═══════════ */

/* Bouton panier dans la nav (DESKTOP) */
.nav-cart{
  position:relative;display:flex;align-items:center;justify-content:center;
  width:40px;height:40px;color:var(--txt2);transition:color .15s;
  margin-right:6px;border-radius:10px
}
.nav-cart:hover{color:var(--txt);background:rgba(255,255,255,.05)}
.nav-cart svg{width:20px;height:20px}

/* Badge compteur */
.cart-badge{
  position:absolute;top:-3px;right:-3px;
  background:var(--grad);color:#fff;
  font-size:.62rem;font-weight:800;
  min-width:18px;height:18px;border-radius:50px;
  display:none;align-items:center;justify-content:center;
  padding:0 5px;border:2px solid var(--bg);
  font-family:var(--font);line-height:1
}
.cart-badge.show{display:flex}

/* MOBILE - le bouton panier reste visible */
@media(max-width:900px){
  .nav-cart{margin-right:4px;width:36px;height:36px}
  .nav-cart svg{width:18px;height:18px}
}

/* Bouton "Ajouter au panier" dans les forfaits */
.add-cart{
  width:100%;padding:12px;border-radius:11px;
  font-size:.86rem;font-weight:700;
  border:none;cursor:pointer;
  background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:.18s;font-family:inherit;margin-bottom:8px;
  min-height:46px
}
.add-cart:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(37,99,235,.35)}
.add-cart:active{transform:scale(.97)}
.add-cart.outline{background:transparent;border:1.5px solid var(--blight);color:var(--txt)}
.add-cart.outline:hover{background:rgba(37,99,235,.06);border-color:rgba(37,99,235,.4)}
.add-cart.added{background:#10b981;animation:pulse-green .4s ease}
@keyframes pulse-green{0%,100%{transform:scale(1)}50%{transform:scale(1.03)}}

/* Toast confirmation ajout */
.toast{
  position:fixed;bottom:90px;left:50%;
  transform:translateX(-50%) translateY(20px);
  background:linear-gradient(135deg,#10b981,#059669);
  color:#fff;padding:12px 22px;border-radius:50px;
  font-size:.86rem;font-weight:600;
  box-shadow:0 10px 28px rgba(16,185,129,.4);
  z-index:1100;display:flex;align-items:center;gap:8px;
  opacity:0;pointer-events:none;
  transition:transform .3s ease,opacity .3s ease;
  max-width:90vw
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ─────── PAGE PANIER ─────── */
.bag-wrap{
  width:min(1140px,94%);margin:0 auto;padding:30px 0 60px
}
.bag-grid{
  display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start
}
@media(max-width:880px){.bag-grid{grid-template-columns:1fr}}

/* Titre du panier */
.bag-header{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:14px;padding:18px 24px;margin-bottom:14px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px
}
.bag-header h2{font-size:1.05rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.bag-header span{font-size:.76rem;color:var(--muted)}

/* Items dans le panier */
.bag-items{display:flex;flex-direction:column;gap:12px}
.bag-item{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:14px;padding:18px;
  display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center
}
@media(max-width:560px){
  .bag-item{grid-template-columns:auto 1fr;gap:14px}
  .bag-item-actions{grid-column:1/-1;display:flex;justify-content:space-between;align-items:center;margin-top:6px;padding-top:14px;border-top:1px solid var(--border)}
}
.bag-item-img{
  width:80px;height:80px;border-radius:12px;
  background:linear-gradient(135deg,rgba(37,99,235,.15),rgba(6,182,212,.08));
  border:1px solid rgba(37,99,235,.2);
  display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0
}
.bag-item-info h3{font-size:1.02rem;font-weight:700;margin-bottom:4px;color:var(--txt)}
.bag-item-info .meta{font-size:.78rem;color:var(--txt2);line-height:1.55;display:flex;flex-wrap:wrap;gap:6px}
.bag-item-info .meta span{background:rgba(255,255,255,.04);padding:2px 8px;border-radius:6px;border:1px solid var(--border);font-size:.72rem}
.bag-item-actions{display:flex;align-items:center;gap:14px}

/* Quantité */
.bag-qty{
  display:flex;align-items:center;gap:0;
  background:var(--bg);border:1px solid var(--border);border-radius:9px;overflow:hidden
}
.bag-qty button{
  background:transparent;border:none;color:var(--txt);
  width:30px;height:32px;cursor:pointer;
  font-size:1.05rem;font-weight:600;transition:.15s
}
.bag-qty button:hover{background:rgba(255,255,255,.06);color:#60a5fa}
.bag-qty button:disabled{opacity:.3;cursor:not-allowed}
.bag-qty span{
  min-width:28px;text-align:center;
  font-size:.88rem;font-weight:700;color:var(--txt);
  border-left:1px solid var(--border);border-right:1px solid var(--border);
  padding:0 4px;line-height:32px
}

/* Prix article */
.bag-item-price{font-size:1.05rem;font-weight:800;color:var(--txt);min-width:80px;text-align:right}

/* Bouton supprimer */
.bag-remove{
  background:transparent;border:none;color:var(--muted);
  cursor:pointer;width:34px;height:34px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;transition:.15s
}
.bag-remove:hover{color:#ef4444;background:rgba(239,68,68,.08)}

/* RÉCAP À DROITE */
.bag-summary{
  background:var(--bg2);border:1px solid var(--border);border-radius:14px;
  padding:24px;position:sticky;top:100px
}
.bag-summary h3{
  font-size:.95rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;
  color:var(--txt);margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border)
}
.bag-line{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.88rem;color:var(--txt2);margin-bottom:10px
}
.bag-line strong{color:var(--txt);font-weight:600}
.bag-line.discount{color:var(--green)}

.bag-promo{display:flex;gap:8px;margin:18px 0 14px}
.bag-promo input{
  flex:1;background:var(--bg);border:1px solid var(--border);
  border-radius:9px;padding:10px 12px;color:var(--txt);
  font-size:.85rem;font-family:inherit;text-transform:uppercase;letter-spacing:.05em
}
.bag-promo input:focus{outline:none;border-color:rgba(37,99,235,.5);background:rgba(37,99,235,.04)}
.bag-promo button{
  background:rgba(255,255,255,.06);border:1px solid var(--border);
  color:var(--txt);padding:10px 16px;border-radius:9px;
  font-size:.78rem;font-weight:700;cursor:pointer;transition:.15s;text-transform:uppercase;letter-spacing:.05em
}
.bag-promo button:hover{background:rgba(37,99,235,.1);border-color:rgba(37,99,235,.5);color:#60a5fa}
.bag-promo-msg{font-size:.75rem;margin:-6px 0 14px;min-height:18px}
.bag-promo-msg.ok{color:var(--green)}
.bag-promo-msg.error{color:#ef4444}

.bag-total{
  display:flex;justify-content:space-between;align-items:baseline;
  font-size:1rem;font-weight:700;color:var(--txt);
  margin-top:18px;padding-top:18px;border-top:1px solid var(--border)
}
.bag-total strong{
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;font-size:1.6rem;font-weight:900;letter-spacing:-.03em
}

.bag-checkout{
  width:100%;padding:15px;background:var(--grad);color:#fff;
  border:none;border-radius:11px;
  font-size:.92rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
  cursor:pointer;margin-top:18px;transition:.2s;
  display:flex;align-items:center;justify-content:center;gap:10px;
  box-shadow:0 8px 22px rgba(37,99,235,.3);font-family:inherit
}
.bag-checkout:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(37,99,235,.45)}
.bag-checkout:active{transform:scale(.98)}
.bag-checkout svg{width:18px;height:18px}

.bag-trust{
  display:flex;justify-content:center;gap:14px;
  font-size:.7rem;color:var(--muted);margin-top:14px;flex-wrap:wrap
}
.bag-trust span{display:flex;align-items:center;gap:4px}

/* PANIER VIDE */
.bag-empty{
  background:var(--bg2);border:1px solid var(--border);border-radius:18px;
  padding:60px 24px;text-align:center;max-width:600px;margin:0 auto
}
.bag-empty-icon{
  width:80px;height:80px;border-radius:24px;
  background:linear-gradient(135deg,rgba(37,99,235,.12),rgba(6,182,212,.06));
  border:1px solid rgba(37,99,235,.2);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 24px;color:#60a5fa
}
.bag-empty h2{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin-bottom:10px}
.bag-empty p{font-size:.92rem;color:var(--txt2);margin-bottom:28px;max-width:400px;margin-left:auto;margin-right:auto}

/* ─────── PAGE COMMANDE ─────── */
.order-wrap{width:min(1140px,94%);margin:0 auto;padding:30px 0 60px}
.order-grid{display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start}
@media(max-width:880px){.order-grid{grid-template-columns:1fr}}

.order-form{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:14px;padding:28px
}
.order-form h2{
  font-size:1.05rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
  color:var(--txt);margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border)
}

.field{margin-bottom:16px}
.field label{
  display:block;font-size:.74rem;color:var(--txt2);
  margin-bottom:6px;font-weight:600;letter-spacing:.03em;text-transform:uppercase
}
.field input,.field select,.field textarea{
  width:100%;background:var(--bg);
  border:1px solid var(--border);border-radius:10px;
  padding:12px 14px;color:var(--txt);
  font-family:inherit;font-size:.92rem;transition:.15s;
  -webkit-appearance:none;appearance:none
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:rgba(37,99,235,.6);
  background:rgba(37,99,235,.04);box-shadow:0 0 0 3px rgba(37,99,235,.08)
}
.field input.error{border-color:#ef4444;background:rgba(239,68,68,.05)}
.field textarea{resize:vertical;min-height:90px}
.field.required label::after{content:' *';color:#ef4444}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.field-row{grid-template-columns:1fr}}

/* Select avec flèche */
.field select{
  background:var(--bg) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%2394a3b8' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") right 14px center/12px no-repeat;padding-right:36px
}

/* Bouton final commande */
.order-submit{
  width:100%;padding:16px;background:#25d366;color:#fff;
  border:none;border-radius:11px;
  font-size:.95rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
  cursor:pointer;transition:.2s;margin-top:8px;
  display:flex;align-items:center;justify-content:center;gap:10px;
  box-shadow:0 8px 22px rgba(37,211,102,.35);font-family:inherit
}
.order-submit:hover{background:#22c55e;transform:translateY(-2px);box-shadow:0 12px 30px rgba(37,211,102,.5)}
.order-submit:active{transform:scale(.98)}
.order-submit svg{width:20px;height:20px;fill:currentColor}

.order-info{
  font-size:.78rem;color:var(--txt2);line-height:1.6;
  background:rgba(37,99,235,.06);border:1px solid rgba(37,99,235,.18);
  border-radius:10px;padding:14px;margin-top:14px;
  display:flex;align-items:flex-start;gap:10px
}
.order-info svg{flex-shrink:0;color:#60a5fa;margin-top:1px}

