:root{
  /* ── Palette Senpremium-inspired — Bleu ciel + Orange ── */
  --bg0:#f5f7fa;--bg1:#eef0f8;--bg2:#ffffff;--bg3:#e8edf5;--bg4:#dde3f0;
  --txt1:#0d1117;--txt2:#374151;--txt3:#8b95a3;
  --blue:#00a8ff;--purple:#0072d6;--violet:#0055b3;--pink:#ff8c42;--cyan:#00d4ff;--green:#10b981;
  --grad1:linear-gradient(135deg,#00a8ff,#0072d6);
  --grad2:linear-gradient(135deg,#ff8c42,#e06000);
  --grad3:linear-gradient(135deg,#00d4ff,#00a8ff);
  --hero-bg:#050d1a;
  --brd:rgba(0,0,0,0.08);--brd2:rgba(0,0,0,0.14);
  --sh1:0 2px 16px rgba(0,0,0,0.07);--sh2:0 8px 32px rgba(0,168,255,0.2);
  --r1:8px;--r2:12px;--r3:16px;--r4:24px;
  --tr:.2s cubic-bezier(.4,0,.2,1);
  --hh:62px;--nh:0px;--ch:44px;
  --bh:0px;
  --nav-dark:rgba(5,12,25,0.97);
  --nav-border:rgba(255,255,255,0.08);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg0);color:var(--txt1);font-family:'Montserrat',system-ui,sans-serif;min-height:100vh;overflow-x:hidden;line-height:1.6}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit}
img{max-width:100%;display:block}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--bg3)}
::-webkit-scrollbar-thumb{background:var(--blue);border-radius:3px;opacity:.5}

/* ── UTILS ── */
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:8px}.gap-2{gap:12px}.gap-3{gap:16px}.gap-4{gap:24px}
.text-sm{font-size:13px}.text-xs{font-size:11px}.text-lg{font-size:18px}.text-xl{font-size:22px}.text-2xl{font-size:28px}.text-3xl{font-size:36px}
.fw-5{font-weight:500}.fw-6{font-weight:600}.fw-7{font-weight:700}.fw-8{font-weight:800}
.text-muted{color:var(--txt3)}.text-sec{color:var(--txt2)}.text-pink{color:var(--pink)}.text-cyan{color:var(--cyan)}.text-green{color:var(--green)}
.w-full{width:100%}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:var(--r2);font-size:14px;font-weight:600;transition:all var(--tr);cursor:pointer}
.btn-primary{background:var(--grad1);color:#fff;border:none}
.btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:var(--sh2)}
.btn-cta{background:var(--grad2);color:#fff;border:none}
.btn-cta:hover{opacity:.9;transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--txt1);border:1px solid var(--brd2)}
.btn-outline:hover{border-color:var(--purple);background:rgba(0,114,214,.1)}
.btn-ghost{background:rgba(255,255,255,.06);color:var(--txt1);border:none}
.btn-ghost:hover{background:rgba(255,255,255,.1)}
.btn-sm{padding:7px 14px;font-size:13px}
.btn-lg{padding:14px 28px;font-size:16px}
.btn-icon{width:38px;height:38px;padding:0;border-radius:var(--r1)}

/* ── BADGE ── */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.4px}
.badge-pink{background:rgba(0,168,255,.2);color:var(--pink)}
.badge-cyan{background:rgba(76,201,240,.2);color:var(--cyan)}
.badge-green{background:rgba(6,214,160,.2);color:var(--green)}
.badge-blue{background:rgba(0,168,255,.12);color:var(--blue)}
.badge-hot{background:linear-gradient(90deg,#ff8c42,#e06000);color:#fff}

/* ══════════════════════════════════════════════════════════
   NAVIGATION — Layout Pro (Stripe/Vercel pattern)
   Nav centré en position:absolute — zéro conflit flex
══════════════════════════════════════════════════════════ */

/* ═══ HEADER ═══ */
.header{
  position:fixed;top:0;left:0;right:0;height:var(--hh);
  background:rgba(6,12,26,.97);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow:0 2px 20px rgba(0,0,0,.5);
  z-index:900;
  display:flex;align-items:center;
  padding:0 20px;gap:10px;
  transition:background .3s,border-color .3s,box-shadow .3s;
}
body.on-hero .header:not(.scrolled){
  background:linear-gradient(180deg,rgba(5,13,26,.85) 0%,transparent 100%);
  border-bottom-color:transparent;box-shadow:none;
}
.header.scrolled{
  background:rgba(4,9,20,1);
  box-shadow:0 4px 40px rgba(0,0,0,.65);
  border-bottom-color:rgba(255,255,255,.07);
}

/* ═══ LOGO ═══ */
.logo{display:flex;align-items:center;gap:9px;cursor:pointer;flex-shrink:0;user-select:none;text-decoration:none}
.logo-img{height:33px;max-width:130px;object-fit:contain;filter:brightness(1.15) contrast(1.1)}
.logo-mark{width:33px;height:33px;background:linear-gradient(135deg,#00a8ff,#0055b3);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:900;color:#fff;flex-shrink:0;box-shadow:0 3px 12px rgba(0,168,255,.35)}
.logo-text{font-size:15px;font-weight:900;letter-spacing:-.4px;line-height:1}
.logo-sen{color:#fff}
.logo-virtuel{background:linear-gradient(135deg,#00d4ff,#00a8ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.logo-mkt{font-size:9px;font-weight:700;color:rgba(255,255,255,.28);display:block;letter-spacing:.9px;text-transform:uppercase;margin-top:2px}

/* ═══ DESKTOP NAV — centré en absolu (pattern Stripe/Vercel) ═══ */
/* Position:absolute permet au logo et aux icônes de garder leur flex  */
/* sans compétition pour l'espace                                       */
.sv-desktop-nav{
  display:none;
  position:absolute;
  left:50%;top:50%;
  transform:translate(-50%,-50%);
  align-items:center;
  gap:2px;
  z-index:2;
}
/* Les items nav */
.nav-item{
  display:flex;align-items:center;gap:5px;
  padding:7px 14px;
  font-size:13px;font-weight:600;letter-spacing:.05px;
  color:rgba(255,255,255,.5);
  cursor:pointer;border-radius:8px;
  transition:color .18s,background .18s;
  position:relative;white-space:nowrap;
  text-decoration:none;
}
.nav-item:hover{color:rgba(255,255,255,.9);background:rgba(255,255,255,.07)}
.nav-item.active{color:#fff}
/* Barre active sous le lien */
.nav-item.active::after{
  content:'';
  position:absolute;bottom:4px;left:14px;right:14px;height:2px;
  background:linear-gradient(90deg,#00a8ff,#00d4ff);
  border-radius:2px;
}
.nav-ico{font-size:13px;line-height:1}
.nav-sep{width:1px;height:14px;background:rgba(255,255,255,.1);margin:0 4px;flex-shrink:0}

/* ═══ BARRE DE RECHERCHE ═══ */
.header-search{
  margin-left:auto;
  flex:0 0 260px;
  position:relative;
}
.header-search input{
  width:100%;height:36px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  border-radius:100px;
  padding:0 16px 0 38px;
  color:#fff;font-size:12.5px;font-weight:500;outline:none;
  transition:background .2s,border-color .2s,box-shadow .2s;
}
.header-search input:focus{
  background:rgba(255,255,255,.1);
  border-color:rgba(0,168,255,.55);
  box-shadow:0 0 0 3px rgba(0,168,255,.1);
}
.header-search input::placeholder{color:rgba(255,255,255,.3)}
.search-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:rgba(255,255,255,.35);font-size:14px;pointer-events:none}
.search-drop{
  position:absolute;top:calc(100%+8px);left:0;right:0;
  background:rgba(6,14,30,.99);border:1px solid rgba(255,255,255,.1);
  border-radius:16px;z-index:210;display:none;
  box-shadow:0 20px 60px rgba(0,0,0,.6);overflow:hidden;
  backdrop-filter:blur(20px);
}
.search-drop.open{display:block}
.sdrop-item{padding:10px 16px;cursor:pointer;display:flex;align-items:center;gap:12px;font-size:13px;transition:background .15s;color:rgba(255,255,255,.8)}
.sdrop-item:hover{background:rgba(255,255,255,.07)}
.sdrop-ico{font-size:20px;width:32px;text-align:center;flex-shrink:0}
.sdrop-price{margin-left:auto;color:var(--pink);font-weight:700;font-size:12px;white-space:nowrap}

/* ═══ BOUTONS HEADER ═══ */
.header-end{display:flex;align-items:center;gap:3px;flex-shrink:0}
.hbtn{
  display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;padding:0;
  border-radius:9px;font-size:18px;
  color:rgba(255,255,255,.6);
  transition:background .2s,color .2s;cursor:pointer;position:relative;
  background:transparent;
}
.hbtn:hover{background:rgba(255,255,255,.1);color:#fff}
.theme-toggle{
  width:36px;height:36px;padding:0;border-radius:9px;font-size:15px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.55);
  transition:all .2s;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.theme-toggle:hover{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.18)}
.cart-dot{
  position:absolute;top:-4px;right:-4px;
  background:linear-gradient(135deg,#ff8c42,#e06000);
  color:#fff;font-size:9px;font-weight:800;
  min-width:16px;height:16px;border-radius:8px;
  display:none;align-items:center;justify-content:center;padding:0 3px;
  border:1.5px solid rgba(5,10,22,.95);
}
.cart-dot.show{display:flex}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.3)}}

/* ═══ HAMBURGER ═══ */
.mobile-menu-btn{
  width:36px;height:36px;border-radius:9px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:4.5px;padding:10px;cursor:pointer;transition:all .2s;flex-shrink:0;
}
.ham-line{width:16px;height:1.8px;background:rgba(255,255,255,.8);border-radius:2px;transition:all .3s}
.mobile-menu-btn.open .ham-line:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px)}
.mobile-menu-btn.open .ham-line:nth-child(2){opacity:0;transform:scaleX(0)}
.mobile-menu-btn.open .ham-line:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px)}

/* ═══ RESPONSIVE ═══ */
/* Mobile < 768px */
@media(max-width:767px){
  .header-search{display:none}
  .mobile-menu-btn{display:flex}
}
/* Tablet 768–1023px : search réduit, hamburger, pas de nav */
@media(min-width:768px) and (max-width:1023px){
  .header{padding:0 20px;gap:10px}
  .mobile-menu-btn{display:flex}
  .header-search{flex:0 0 200px}
}
/* Desktop ≥1024px : nav centré, pas de hamburger */
@media(min-width:1024px){
  .header{padding:0 28px;gap:12px}
  .mobile-menu-btn{display:none!important}
  .sv-desktop-nav{display:flex!important}
  .sv-desktop-nav .nav-ico{display:none}
  .header-search{flex:0 0 300px}
}
@media(min-width:1280px){
  .header-search{flex:0 0 360px}
}

/* ═══ ANCIENNE NAV BAR — désactivée ═══ */
.nav-bar{display:none!important}
.nav-inner{display:flex;align-items:center;gap:0;padding:0}

/* ═══ CATEGORY BAR ═══ */
.cat-bar{
  position:fixed;top:var(--hh);left:0;right:0;height:var(--ch);
  background:rgba(8,16,32,.94);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,.06);
  z-index:898;overflow-x:auto;scrollbar-width:none;
  display:flex;align-items:center;
  transition:opacity .3s,transform .3s;
}
body.on-hero .cat-bar:not(.cat-visible){opacity:0;pointer-events:none;transform:translateY(-4px)}
body.on-hero .cat-bar.cat-visible{opacity:1;pointer-events:auto;transform:none}
.cat-bar::-webkit-scrollbar{display:none}
.cat-inner{display:flex;padding:0 14px;gap:6px;white-space:nowrap;height:100%;align-items:center}

.cat-pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 14px;border-radius:100px;
  font-size:12px;font-weight:700;cursor:pointer;
  border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.55);background:rgba(255,255,255,.05);
  transition:all .2s;white-space:nowrap;
  letter-spacing:.2px;
}
.cat-pill:hover{
  color:#fff;background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.2);transform:translateY(-1px);
}
.cat-pill.active{
  background:linear-gradient(135deg,var(--blue),#0055b3);
  border-color:transparent;color:#fff;
  box-shadow:0 4px 16px rgba(0,114,214,.45);
  transform:translateY(-1px);
}
.cat-bar-hidden{display:none}

/* ═══ HAMBURGER (mobile) ═══ */
.mobile-menu-btn{
  display:none;width:38px;height:38px;border-radius:10px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);
  align-items:center;justify-content:center;cursor:pointer;
  flex-direction:column;gap:4.5px;padding:10px;transition:all .2s;flex-shrink:0;
}
@media(max-width:767px){.mobile-menu-btn{display:flex}}
.ham-line{width:16px;height:1.8px;background:rgba(255,255,255,.8);border-radius:2px;transition:all .3s}
.mobile-menu-btn.open .ham-line:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px)}
.mobile-menu-btn.open .ham-line:nth-child(2){opacity:0;transform:scaleX(0)}
.mobile-menu-btn.open .ham-line:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px)}

/* ═══ MOBILE DRAWER — redesign full dark ═══ */
#mobileDrawerOverlay{
  position:fixed;inset:0;z-index:1099;
  background:rgba(0,0,0,.7);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  opacity:0;pointer-events:none;transition:opacity .3s;
}
#mobileDrawerOverlay.open{opacity:1;pointer-events:all}
#mobileDrawer{
  position:fixed;top:0;right:0;bottom:0;
  width:min(340px,90vw);z-index:1100;
  background:rgba(6,12,26,.98);
  border-left:1px solid rgba(255,255,255,.08);
  transform:translateX(100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;display:flex;flex-direction:column;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
}
#mobileDrawer.open{transform:translateX(0);box-shadow:-16px 0 60px rgba(0,0,0,.6)}
.drawer-header{
  padding:0;
  background:linear-gradient(135deg,rgba(0,84,179,.9),rgba(0,40,100,.9));
  border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;
}
.drawer-header-inner{padding:22px 20px 24px;display:flex;align-items:center;gap:12px}
.drawer-logo-mark{
  width:44px;height:44px;background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.2);border-radius:14px;
  display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;
}
.drawer-logo-text{color:#fff;flex:1}
.drawer-logo-name{font-size:17px;font-weight:900;letter-spacing:-.4px}
.drawer-logo-sub{font-size:11px;opacity:.6;margin-top:2px}
.drawer-close{
  width:34px;height:34px;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.15);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:#fff;font-size:15px;flex-shrink:0;transition:all .2s;
}
.drawer-close:hover{background:rgba(255,255,255,.25);transform:rotate(90deg)}
.drawer-nav-section{padding:8px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.drawer-section-label{
  padding:10px 20px 6px;font-size:10px;font-weight:800;
  text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.3);
}
.drawer-nav-item{
  display:flex;align-items:center;gap:14px;
  padding:12px 20px;font-size:14px;font-weight:600;
  cursor:pointer;transition:all .2s;
  color:rgba(255,255,255,.65);border-left:3px solid transparent;
}
.drawer-nav-item:hover{background:rgba(255,255,255,.06);color:#fff;border-left-color:rgba(0,168,255,.5)}
.drawer-nav-item.active{color:var(--cyan);background:rgba(0,168,255,.08);border-left-color:var(--cyan)}
.drawer-nav-ico{
  width:34px;height:34px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:17px;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.08);flex-shrink:0;
}
.drawer-nav-item.active .drawer-nav-ico{background:rgba(0,168,255,.15);border-color:rgba(0,168,255,.2)}
.drawer-cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:12px 16px 16px}
.drawer-cat-chip{
  display:flex;flex-direction:column;align-items:center;gap:5px;
  padding:12px 6px 10px;border-radius:14px;cursor:pointer;
  background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.08);
  transition:all .2s;text-align:center;
}
.drawer-cat-chip:hover{transform:translateY(-2px);border-color:rgba(0,168,255,.4);background:rgba(0,168,255,.1)}
.drawer-cat-chip-ico{font-size:24px;line-height:1}
.drawer-cat-chip-lbl{font-size:10px;font-weight:700;color:rgba(255,255,255,.6);line-height:1.2}
.drawer-wa-btn{
  margin:12px 16px 16px;
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px;border-radius:14px;
  background:linear-gradient(135deg,#25d366,#128c7e);
  color:#fff;font-size:14px;font-weight:700;cursor:pointer;
  box-shadow:0 4px 20px rgba(37,211,102,.35);
  transition:all .25s;text-decoration:none;
}
.drawer-wa-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(37,211,102,.5)}

/* ═══ BOTTOM TAB BAR — iOS Pro Design ═══ */
#bottomNav{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:988;
  background:rgba(6,12,26,.97);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border-top:1px solid rgba(255,255,255,.08);
  box-shadow:0 -8px 32px rgba(0,0,0,.4);
  padding:6px 4px max(10px,env(safe-area-inset-bottom));
  gap:0;align-items:flex-start;
}
@media(max-width:767px){#bottomNav{display:flex;--bh:70px}}
.bnav-item{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:7px 4px 4px;cursor:pointer;
  transition:all .2s;color:rgba(255,255,255,.38);
  position:relative;
}
.bnav-item:hover{color:rgba(255,255,255,.7)}
.bnav-item.active{color:#fff}
.bnav-item.active .bnav-ico-wrap{
  background:rgba(0,168,255,.18);border-radius:12px;
}
.bnav-item.active .bnav-ico{
  filter:drop-shadow(0 0 6px rgba(0,168,255,.8));
}
.bnav-ico-wrap{padding:5px 12px 4px;border-radius:12px;transition:background .2s}
.bnav-ico{font-size:20px;line-height:1;display:block;transition:filter .2s}
.bnav-lbl{font-size:9px;font-weight:700;letter-spacing:.3px;text-transform:uppercase}
.bnav-badge{
  position:absolute;top:4px;left:50%;margin-left:6px;
  background:linear-gradient(135deg,var(--pink),#e06000);
  color:#fff;font-size:8px;font-weight:800;
  min-width:15px;height:15px;border-radius:8px;
  display:none;align-items:center;justify-content:center;padding:0 3px;
  border:1.5px solid rgba(6,12,26,.9);
}
.bnav-badge.show{display:flex}

/* ── MAIN ── */
#app{margin-top:calc(var(--hh) + var(--ch) + var(--bh));min-height:calc(100vh - var(--hh) - var(--ch) - var(--bh))}
body.on-hero #app{margin-top:0}
@media(max-width:767px){#app{margin-bottom:70px}}

/* ── HERO ── */
.hero{position:relative;overflow:hidden;padding:80px 20px 80px;text-align:center;background:var(--hero-bg)}
body.on-hero .hero{padding-top:calc(var(--hh) + 60px)}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-orb1{position:absolute;top:-60px;left:-80px;width:500px;height:500px;background:radial-gradient(circle,rgba(0,168,255,.18),transparent 65%);border-radius:50%}
.hero-orb2{position:absolute;bottom:-80px;right:-60px;width:450px;height:450px;background:radial-gradient(circle,rgba(0,212,255,.12),transparent 65%);border-radius:50%}
.hero-orb3{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:250px;background:radial-gradient(ellipse,rgba(255,140,66,.07),transparent 70%)}
.hero-content{position:relative;z-index:1;max-width:700px;margin:0 auto}
.hero-tag{display:inline-flex;align-items:center;gap:6px;background:rgba(0,168,255,.12);border:1px solid rgba(0,168,255,.3);border-radius:20px;padding:5px 14px;font-size:12px;font-weight:600;color:var(--cyan);margin-bottom:20px;letter-spacing:.4px}
.hero h1{font-size:clamp(26px,5vw,52px);font-weight:800;line-height:1.15;letter-spacing:-1px;margin-bottom:16px;color:#fff}
.hero h1 .grad{background:var(--grad2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:clamp(14px,2vw,17px);color:rgba(255,255,255,.7);max-width:520px;margin:0 auto 32px}
.hero-actions{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}
.hero-stats{display:flex;align-items:center;justify-content:center;gap:24px;margin-top:40px;flex-wrap:wrap}
.hero-stat{text-align:center}
.hero-stat-num{font-size:24px;font-weight:800;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-stat-lbl{font-size:12px;color:rgba(255,255,255,.5);margin-top:2px}
.hero-pay{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:20px;flex-wrap:wrap}
.pay-badge{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:var(--r1);padding:6px 12px;font-size:12px;font-weight:600;color:#fff;display:flex;align-items:center;gap:5px}

/* ── SECTION — structure (padding défini dans le bloc MISC/DESIGN ci-dessous) ── */
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}

/* ── CATEGORY GRID ── */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
@media(max-width:768px){.cat-grid{grid-template-columns:repeat(4,1fr);gap:8px}}
@media(max-width:480px){.cat-grid{grid-template-columns:repeat(4,1fr)}}
.cat-card{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r2);padding:14px 10px;text-align:center;cursor:pointer;transition:all var(--tr)}
.cat-card:hover{border-color:var(--purple);background:var(--bg3);transform:translateY(-2px)}
.cat-card.active{border-color:var(--cyan);background:rgba(76,201,240,.08)}
.cat-ico{font-size:26px;margin-bottom:6px}
.cat-name{font-size:12px;font-weight:600;color:var(--txt2)}
.cat-count{font-size:11px;color:var(--txt3);margin-top:2px}

/* ── PRODUCT GRID ── */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:1100px){.prod-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.prod-grid{grid-template-columns:repeat(2,1fr);gap:10px}}
@media(max-width:380px){.prod-grid{grid-template-columns:1fr}}

/* ── PRODUCT CARD — structure (visuals in Design Refresh block below) ── */
.prod-badges{position:absolute;top:8px;left:8px;display:flex;flex-direction:column;gap:4px}
.prod-fav{position:absolute;top:8px;right:8px;width:28px;height:28px;background:rgba(0,0,0,.4);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;opacity:0;transition:opacity var(--tr)}
.prod-card:hover .prod-fav{opacity:1}
.prod-rating{display:flex;align-items:center;gap:4px;margin-bottom:8px}
.stars{color:#f5a623;font-size:11px;letter-spacing:1px}
.rating-count{font-size:11px;color:var(--txt3)}
.prod-price-row{display:flex;align-items:baseline;gap:6px;margin-top:auto}
.prod-old{font-size:12px;color:var(--txt3);text-decoration:line-through}
.prod-unit{font-size:11px;color:var(--txt3)}

/* ── FLASH / TIMER / HOW / TRUST / CAT-IMG / WHY — defined in Premium block below ── */
.flash-icon{font-size:32px;flex-shrink:0}
.flash-title{font-size:17px;font-weight:700;color:var(--pink)}
.flash-sub{font-size:13px;color:var(--txt2);margin-top:2px}
.flash-timer{display:flex;gap:8px;margin-left:auto}
.timer-num{font-size:20px;font-weight:800;font-variant-numeric:tabular-nums;line-height:1}
.timer-lbl{font-size:9px;color:var(--txt3);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:600px){.how-grid{grid-template-columns:1fr;gap:12px}}
.how-num{font-size:42px;font-weight:900;color:rgba(0,0,0,.04);position:absolute;top:12px;right:16px;line-height:1}
.how-ico{font-size:30px;margin-bottom:12px}
.how-title{font-size:15px;font-weight:700;margin-bottom:6px}
.how-desc{font-size:13px;color:var(--txt2);line-height:1.6}
.trust-ico{font-size:20px}
.hero-img-overlay{position:absolute;inset:0;background-image:url('/img/hero.jpg');background-size:cover;background-position:center top;opacity:.04;z-index:0}
.hero-img-gradient{position:absolute;inset:0;background:linear-gradient(160deg,rgba(238,240,249,.95) 0%,rgba(240,238,255,.8) 50%,rgba(237,245,255,.95) 100%);z-index:1}
.cat-img-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:900px){.cat-img-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:580px){.cat-img-grid{grid-template-columns:repeat(2,1fr);gap:10px}}
.cat-img-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px}
.cat-img-body{position:absolute;bottom:0;left:0;right:0;padding:12px 14px;display:flex;align-items:flex-end;justify-content:space-between}
.cat-img-info{}
.cat-img-count{font-size:11px;color:rgba(255,255,255,.65);margin-top:2px}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:900px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.why-grid{grid-template-columns:1fr 1fr}}
.why-card-ico{font-size:34px;margin-bottom:10px;line-height:1}

/* ── SCROLL FADE-IN ── */
.fade-in{opacity:1;transform:translateY(0);transition:opacity .6s ease,transform .6s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}
.fade-in-delay-1{transition-delay:.1s}
.fade-in-delay-2{transition-delay:.2s}
.fade-in-delay-3{transition-delay:.3s}

/* ══════════════════════════════════════════════
   PREMIUM VISUAL SYSTEM — Phase 1-9
══════════════════════════════════════════════ */

/* ── KEYFRAME ANIMATIONS ── */
@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes heroGlow{0%,100%{opacity:.5;transform:translate(-50%,-50%) scale(1)}50%{opacity:.9;transform:translate(-50%,-50%) scale(1.1)}}
@keyframes pulseGlow{0%,100%{box-shadow:0 0 20px rgba(37,211,102,.5),0 4px 24px rgba(37,211,102,.4)}50%{box-shadow:0 0 35px rgba(37,211,102,.8),0 4px 32px rgba(37,211,102,.6)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes floatX{0%,100%{transform:translateY(0) rotate(0deg)}33%{transform:translateY(-8px) rotate(3deg)}66%{transform:translateY(-4px) rotate(-2deg)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes borderGlow{0%,100%{border-color:rgba(0,114,214,.3)}50%{border-color:rgba(0,168,255,.6)}}
@keyframes slideUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-50px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideInRight{from{opacity:0;transform:translateX(50px)}to{opacity:1;transform:translateX(0)}}
@keyframes popIn{0%{opacity:0;transform:scale(.5)}70%{transform:scale(1.08)}100%{opacity:1;transform:scale(1)}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
@keyframes progressFill{from{width:0}to{width:var(--pw,70%)}}
@keyframes neonPulse{0%,100%{text-shadow:0 0 10px rgba(76,201,240,.6),0 0 20px rgba(76,201,240,.4)}50%{text-shadow:0 0 20px rgba(76,201,240,1),0 0 40px rgba(76,201,240,.7),0 0 60px rgba(76,201,240,.4)}}
@keyframes starPop{0%{transform:scale(0) rotate(-20deg);opacity:0}60%{transform:scale(1.2) rotate(5deg);opacity:1}100%{transform:scale(1) rotate(0deg);opacity:1}}
@keyframes lineGrow{from{width:0;opacity:0}to{width:100%;opacity:1}}
@keyframes glowBorder{0%,100%{box-shadow:0 0 0 0 rgba(0,114,214,0)}50%{box-shadow:0 0 0 4px rgba(0,114,214,.25),0 0 30px rgba(0,114,214,.15)}}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes sparkle{0%,100%{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1)}}

/* ── SCROLL PROGRESS BAR ── */
.scroll-progress{position:fixed;top:0;left:0;height:3px;z-index:9999;background:linear-gradient(90deg,var(--blue),var(--cyan));width:0%;transition:width .1s linear;box-shadow:0 0 8px rgba(0,168,255,.5)}

/* ── SCROLL TO TOP ── */
.scroll-top-btn{position:fixed;bottom:90px;right:20px;z-index:985;width:44px;height:44px;background:var(--bg3);border:1px solid var(--brd2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;opacity:0;pointer-events:none;transition:all .3s;box-shadow:0 4px 16px rgba(0,0,0,.4)}
.scroll-top-btn.show{opacity:1;pointer-events:all}
.scroll-top-btn:hover{background:var(--purple);border-color:transparent;transform:translateY(-3px)}

/* ── HERO PARTICLES ── */
.hero-particles{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.hero-particle{position:absolute;border-radius:50%;animation:sparkle var(--dur,3s) var(--del,0s) ease-in-out infinite}

/* ── HERO FLOATING BADGES ── */
.hero-float-badges{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.hero-float-badge{position:absolute;display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.06);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(0,168,255,.25);border-radius:30px;padding:7px 14px;font-size:12px;font-weight:700;color:#fff;white-space:nowrap;animation:floatX var(--dur,5s) var(--del,0s) ease-in-out infinite;box-shadow:0 4px 20px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.1)}

/* ── TYPEWRITER ── */
.typewriter-wrap{display:inline-block;position:relative}
.typewriter-cursor{display:inline-block;width:3px;height:1.1em;background:var(--cyan);margin-left:3px;vertical-align:middle;animation:blink .8s ease infinite;border-radius:2px}

/* ── WAVE DIVIDER ── */
.wave-divider{display:block;width:100%;overflow:hidden;line-height:0;pointer-events:none}
.wave-divider svg{display:block;width:100%}

/* ── HOW STEPS CONNECTED (light) ── */
.how-grid-connected{display:grid;grid-template-columns:repeat(3,1fr);gap:0;position:relative}
@media(max-width:600px){.how-grid-connected{grid-template-columns:1fr;gap:12px}}
.how-connector-line{position:absolute;top:56px;left:calc(33.33% + 16px);right:calc(33.33% + 16px);height:2px;background:linear-gradient(90deg,var(--blue),var(--cyan));animation:lineGrow 1.5s ease forwards;opacity:0}
.how-connector-line.visible{opacity:1}
@media(max-width:600px){.how-connector-line{display:none}}
.how-card-v2{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r3);padding:32px 24px 28px;position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s,border-color .3s;margin:0 8px;text-align:center;box-shadow:0 2px 12px rgba(0,0,0,.04)}
.how-card-v2::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad1)}
.how-card-v2:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(0,168,255,.12);border-color:rgba(0,168,255,.25)}
.how-step-num{width:52px;height:52px;border-radius:50%;background:var(--grad1);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900;color:#fff;margin:0 auto 20px;box-shadow:0 4px 16px rgba(0,168,255,.35)}
.how-ico-v2{font-size:36px;margin-bottom:16px;display:block;animation:float 4s ease infinite}
.how-title-v2{font-size:17px;font-weight:800;margin-bottom:10px;letter-spacing:-.2px;color:var(--txt1)}
.how-desc-v2{font-size:13px;color:var(--txt3);line-height:1.65}

/* ── WHY CARDS V2 (light) ── */
.why-card-v2{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r3);padding:32px 22px;text-align:center;position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s,border-color .3s;cursor:default;box-shadow:0 2px 12px rgba(0,0,0,.04)}
.why-card-v2::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--r3) var(--r3) 0 0}
.why-card-v2:nth-child(1)::before{background:linear-gradient(90deg,#06d6a0,#00d4ff)}
.why-card-v2:nth-child(2)::before{background:var(--grad2)}
.why-card-v2:nth-child(3)::before{background:var(--grad1)}
.why-card-v2:nth-child(4)::before{background:linear-gradient(90deg,#f5a623,#ff8c42)}
.why-card-v2:hover{transform:translateY(-6px);border-color:rgba(0,168,255,.3);box-shadow:0 16px 40px rgba(0,168,255,.12)}
.why-ico-wrap{width:70px;height:70px;border-radius:50%;margin:0 auto 18px;display:flex;align-items:center;justify-content:center;font-size:32px;position:relative;transition:transform .3s}
.why-card-v2:hover .why-ico-wrap{transform:scale(1.12) rotate(5deg)}
.why-card-v2:nth-child(1) .why-ico-wrap{background:linear-gradient(135deg,rgba(6,214,160,.15),rgba(0,212,255,.1));box-shadow:0 4px 16px rgba(6,214,160,.2)}
.why-card-v2:nth-child(2) .why-ico-wrap{background:linear-gradient(135deg,rgba(255,140,66,.15),rgba(224,96,0,.1));box-shadow:0 4px 16px rgba(255,140,66,.2)}
.why-card-v2:nth-child(3) .why-ico-wrap{background:linear-gradient(135deg,rgba(0,168,255,.15),rgba(0,212,255,.1));box-shadow:0 4px 16px rgba(0,168,255,.2)}
.why-card-v2:nth-child(4) .why-ico-wrap{background:linear-gradient(135deg,rgba(245,166,35,.15),rgba(255,140,66,.1));box-shadow:0 4px 16px rgba(245,166,35,.2)}
.why-card-title-v2{font-size:16px;font-weight:800;margin-bottom:10px;letter-spacing:-.2px;color:var(--txt1)}
.why-card-desc-v2{font-size:13px;color:var(--txt3);line-height:1.65}

/* ── TRUST BAR V2 (light) ── */
.trust-bar-v2{background:var(--bg1);border-top:1px solid var(--brd);border-bottom:1px solid var(--brd);padding:14px 0;overflow:hidden;position:relative}
.trust-track{display:flex;gap:40px;white-space:nowrap;animation:marqueeScroll 20s linear infinite;width:max-content}
.trust-track:hover{animation-play-state:paused}
.trust-item-v2{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--txt2)}
.trust-item-v2:hover{color:var(--blue)}

/* ── FLASH DEALS V2 ── */
.flash-banner-v2{background:linear-gradient(135deg,rgba(0,114,214,.06) 0%,rgba(0,168,255,.07) 50%,rgba(255,140,66,.05) 100%);border:1px solid rgba(0,114,214,.18);border-radius:var(--r4);padding:22px 28px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:32px;box-shadow:0 4px 24px rgba(0,114,214,.1);position:relative;overflow:hidden}
.flash-banner-v2::before{content:'';position:absolute;top:-50%;left:-30%;width:60%;height:200%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.04),transparent);animation:shimmer 3s linear infinite;background-size:200% 100%}
.flash-banner-v2::after{content:'🔥';position:absolute;top:-8px;right:20px;font-size:48px;opacity:.08}
/* .timer-block-v2 / .timer-num-v2 / .timer-lbl-v2 — définis dans le bloc Flash Banner ci-dessous */

/* ── PRODUCT CARD V2 ── */
.prod-card-v2{background:#fff;border:1px solid rgba(0,0,0,.07);border-radius:var(--r3);overflow:hidden;cursor:pointer;transition:all .35s cubic-bezier(.4,0,.2,1);position:relative;display:flex;flex-direction:column;box-shadow:0 2px 12px rgba(0,0,0,.05)}
.prod-card-v2::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,114,214,.04),transparent);opacity:0;transition:opacity .3s;z-index:0;pointer-events:none}
.prod-card-v2:hover{transform:translateY(-8px) scale(1.01);border-color:rgba(0,114,214,.35);box-shadow:0 20px 48px rgba(0,114,214,.12),0 0 0 1px rgba(0,114,214,.18)}
.prod-card-v2:hover::before{opacity:1}
.prod-img-v2{aspect-ratio:1/1;width:100%;height:auto;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:64px;position:relative;flex-shrink:0}
.prod-img-v2 img{width:100%;height:100%;object-fit:cover;transition:transform .55s cubic-bezier(.4,0,.2,1)}
.prod-card-v2:hover .prod-img-v2 img{transform:scale(1.12)}
.prod-img-shine{position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.08) 0%,transparent 50%,rgba(255,255,255,.03) 100%);opacity:0;transition:opacity .3s;pointer-events:none}
.prod-card-v2:hover .prod-img-shine{opacity:1}
.prod-info-v2{padding:14px;flex:1;display:flex;flex-direction:column;position:relative;z-index:1}
.prod-price-v2{font-size:20px;font-weight:900;color:var(--blue);line-height:1}
.prod-old-v2{font-size:12px;color:var(--txt3);text-decoration:line-through}
.add-btn-v2{width:100%;background:linear-gradient(135deg,rgba(0,114,214,.08),rgba(0,168,255,.06));border:1px solid rgba(0,114,214,.25);border-radius:var(--r2);padding:10px;font-size:13px;font-weight:700;color:var(--blue);transition:all .25s;display:flex;align-items:center;justify-content:center;gap:7px;margin-top:auto;letter-spacing:.2px}
.add-btn-v2:hover{background:var(--grad1);border-color:transparent;color:#fff;box-shadow:0 6px 20px rgba(0,114,214,.35);transform:translateY(-2px)}

/* ── TESTI SLIDER ── */
.testi-slider-wrap{overflow:hidden;position:relative;padding:4px 0 20px}
.testi-track{display:flex;gap:20px;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.testi-card-v2{background:#fff;border:1px solid rgba(0,0,0,.07);border-radius:var(--r3);padding:24px;position:relative;overflow:hidden;min-width:340px;flex-shrink:0;transition:transform .25s,border-color .25s,box-shadow .25s;box-shadow:0 2px 16px rgba(0,0,0,.06)}
@media(max-width:768px){.testi-card-v2{min-width:280px}}
.testi-card-v2::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad1)}
.testi-card-v2:hover{transform:translateY(-5px);border-color:rgba(0,114,214,.25);box-shadow:0 16px 40px rgba(0,114,214,.12)}
.testi-quote-v2{position:absolute;top:14px;right:16px;font-size:52px;color:rgba(0,114,214,.1);font-family:Georgia,serif;line-height:1;pointer-events:none}
.testi-dots{display:flex;justify-content:center;gap:8px;margin-top:20px}
.testi-dot{width:8px;height:8px;border-radius:50%;background:rgba(0,0,0,.12);cursor:pointer;transition:all .3s}
.testi-dot.active{background:var(--blue);width:24px;border-radius:4px}

/* ── CTA FINAL V2 ── */
.cta-final-v2{position:relative;overflow:hidden;background:linear-gradient(145deg,#050d1a 0%,#071428 50%,#050d1a 100%);padding:80px 16px}
.cta-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.cta-particle{position:absolute;border-radius:50%;animation:sparkle var(--dur,4s) var(--del,0s) ease-in-out infinite}
.cta-orb-1{position:absolute;top:-20%;left:-5%;width:600px;height:600px;background:radial-gradient(circle,rgba(0,168,255,.1),transparent 60%);animation:float 8s ease infinite;pointer-events:none}
.cta-orb-2{position:absolute;bottom:-20%;right:-5%;width:500px;height:500px;background:radial-gradient(circle,rgba(0,114,214,.12),transparent 60%);animation:float 10s ease infinite reverse;pointer-events:none}

/* ── SECTION TITLE V2 ── */
.section-title-v2{display:flex;flex-direction:column;gap:6px}
.section-label{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--cyan);margin-bottom:4px}
.section-label::before,.section-label::after{content:'';flex:1;height:1px;background:currentColor;opacity:.3;max-width:30px}
.section-h2{font-size:clamp(20px,3.5vw,28px);font-weight:900;letter-spacing:-.4px;line-height:1.2}
.section-h2 .grad{background:var(--grad2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── CATEGORY CARDS V2 ── */
.cat-img-card-v2{position:relative;border-radius:18px;overflow:hidden;cursor:pointer;aspect-ratio:16/9;border:1px solid rgba(255,255,255,.06);transition:all .35s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 20px rgba(0,0,0,.3)}
.cat-img-card-v2::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 100%,rgba(255,255,255,.04),transparent 60%);opacity:0;transition:opacity .3s;z-index:2;pointer-events:none}
.cat-img-card-v2:hover{transform:translateY(-8px) scale(1.01);box-shadow:0 28px 64px rgba(0,0,0,.6),0 0 0 1px rgba(0,114,214,.4),0 0 40px rgba(0,114,214,.12)}
.cat-img-card-v2:hover::after{opacity:1}
.cat-img-card-v2 img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.4,0,.2,1);display:block}
.cat-img-card-v2:hover img{transform:scale(1.1)}
.cat-color-bar{position:absolute;bottom:0;left:0;right:0;height:3px;opacity:0;transition:opacity .3s;z-index:3}
.cat-img-card-v2:hover .cat-color-bar{opacity:1}

/* ── STATS COUNT UP ── */
.stat-num{display:inline-block;font-variant-numeric:tabular-nums}

/* ── PROGRESS BAR DEAL ── */
.deal-progress{height:4px;background:rgba(0,0,0,.07);border-radius:2px;overflow:hidden;margin-top:8px}
.deal-progress-fill{height:100%;border-radius:2px;animation:progressFill 1.5s ease forwards;animation-delay:.3s;width:0}

/* ── SECTION BADGE ── */
.s-badge{display:inline-flex;align-items:center;gap:6px;border-radius:20px;padding:5px 14px;font-size:11px;font-weight:800;letter-spacing:.5px;margin-bottom:14px}

/* ── HERO PREMIUM ── */
.hero-animated-bg{
  position:absolute;inset:0;z-index:0;
  background:linear-gradient(125deg,#050d1a 0%,#071428 25%,#050d1a 50%,#071428 75%,#050d1a 100%);
  background-size:400% 400%;
  animation:gradientShift 12s ease infinite;
}
/* ── HERO MOSAIC — vraies photos en arrière-plan ── */
.hero-mosaic{
  position:absolute;inset:0;z-index:0;
  display:grid;
  grid-template-columns:repeat(5,1fr);
  grid-template-rows:repeat(3,1fr);
  overflow:hidden;
}
.hero-mosaic-img{
  width:100%;height:100%;object-fit:cover;
  opacity:.22;
  filter:saturate(.9) brightness(.8);
  transition:opacity .3s;
}
.hero-mosaic::after{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 40%,rgba(5,13,26,.55) 0%,rgba(5,13,26,.9) 100%),
    linear-gradient(to bottom,rgba(5,13,26,.7) 0%,transparent 30%,transparent 70%,rgba(5,13,26,.8) 100%);
  pointer-events:none;
}
.hero-glow-orb{
  position:absolute;z-index:1;border-radius:50%;filter:blur(80px);pointer-events:none;
}
.hero-glow-orb-1{
  top:-80px;left:-60px;width:550px;height:550px;
  background:radial-gradient(circle,rgba(0,168,255,.22),transparent 65%);
  animation:float 6s ease infinite;
}
.hero-glow-orb-2{
  bottom:-80px;right:-60px;width:500px;height:500px;
  background:radial-gradient(circle,rgba(0,212,255,.15),transparent 65%);
  animation:float 8s ease infinite reverse;
}
.hero-glow-orb-3{
  top:50%;left:50%;transform:translate(-50%,-50%);width:800px;height:300px;
  background:radial-gradient(ellipse,rgba(255,140,66,.08),transparent 65%);
  animation:heroGlow 5s ease infinite;
}
.hero-title-glow{
  position:relative;display:inline-block;
}
.hero-title-glow::after{
  content:'';position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);
  width:80%;height:2px;
  background:var(--grad1);
  border-radius:2px;
  box-shadow:0 0 12px rgba(0,168,255,.6);
}
.hero-cta-btn{
  display:inline-flex;align-items:center;gap:9px;
  background:linear-gradient(135deg,#00a8ff,#0072d6,#00d4ff);
  background-size:200% 200%;
  animation:gradientShift 3s ease infinite;
  color:#fff;border:none;border-radius:50px;
  padding:15px 32px;font-size:16px;font-weight:800;
  cursor:pointer;letter-spacing:.2px;
  box-shadow:0 4px 24px rgba(0,168,255,.5),0 0 0 0 rgba(0,168,255,.4);
  transition:transform .25s,box-shadow .25s;
}
.hero-cta-btn:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 10px 40px rgba(0,168,255,.7),0 0 0 6px rgba(0,168,255,.15)}
.hero-wa-btn{
  display:inline-flex;align-items:center;gap:9px;
  background:#25d366;color:#fff;border:none;border-radius:50px;
  padding:15px 28px;font-size:16px;font-weight:800;
  cursor:pointer;letter-spacing:.2px;
  box-shadow:0 4px 20px rgba(37,211,102,.4);
  transition:all .25s;text-decoration:none;
}
.hero-wa-btn:hover{background:#1ebe5d;transform:translateY(-3px) scale(1.02);box-shadow:0 10px 32px rgba(37,211,102,.6)}
.hero-stat-num{
  font-size:26px;font-weight:900;
  background:linear-gradient(135deg,#fff 0%,var(--cyan) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1;
}
.hero-service-cards{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.hero-service-card{
  position:absolute;background:rgba(255,255,255,.06);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(0,168,255,.2);border-radius:16px;padding:14px 16px;
  display:flex;align-items:center;gap:10px;white-space:nowrap;
  box-shadow:0 8px 32px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.1);
  animation:floatX var(--dur,6s) var(--del,0s) ease-in-out infinite;
}
.hero-service-card .svc-ico{font-size:22px;flex-shrink:0}
.hero-service-card .svc-name{font-size:12px;font-weight:700;color:#fff;line-height:1.2}
.hero-service-card .svc-price{font-size:11px;color:var(--cyan);font-weight:600}

/* ── prod-card / prod-img / add-to-cart-btn : voir "Product Card — définition canonique" ci-dessous ── */
.badge-hot{
  background:linear-gradient(90deg,#ff8c42,#e06000);color:#fff;
  box-shadow:0 2px 10px rgba(255,140,66,.5);
  font-size:10px;letter-spacing:.5px;border-radius:20px;
  padding:3px 8px;font-weight:800;
}
.badge-green{background:linear-gradient(90deg,rgba(6,214,160,.25),rgba(6,214,160,.15));color:#06d6a0;border:1px solid rgba(6,214,160,.3)}

/* ── WHY SENVIRTUEL SECTION (light) ── */
.why-section{
  background:var(--bg1);
  border-top:1px solid var(--brd);border-bottom:1px solid var(--brd);
  position:relative;overflow:hidden;
}
.why-card{
  background:var(--bg2);
  border:1px solid var(--brd);
  border-radius:var(--r3);padding:28px 20px;text-align:center;
  transition:transform .25s,border-color .25s,box-shadow .25s;
}
.why-card:hover{
  transform:translateY(-4px);
  border-color:rgba(0,168,255,.35);
  box-shadow:0 12px 32px rgba(0,168,255,.12);
}
.why-card-ico{font-size:38px;margin-bottom:14px;line-height:1;display:block}
.why-card-title{font-size:15px;font-weight:800;margin-bottom:8px;color:var(--txt1)}
.why-card-desc{font-size:12px;color:var(--txt3);line-height:1.6}

/* ── FLASH BANNER PREMIUM ── */
.flash-banner{
  background:linear-gradient(135deg,rgba(0,114,214,.06) 0%,rgba(0,168,255,.07) 50%,rgba(255,140,66,.05) 100%);
  border:1px solid rgba(0,114,214,.18);border-radius:var(--r4);
  padding:20px 24px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  margin-bottom:32px;
  box-shadow:0 4px 24px rgba(0,114,214,.1);
  position:relative;overflow:hidden;
}
.flash-banner::before{
  content:'';position:absolute;top:-50%;left:-20%;width:40%;height:200%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.03),transparent);
  animation:shimmer 4s linear infinite;background-size:200% 100%;
}
.timer-block{
  background:#fff;border:1px solid rgba(0,0,0,.09);
  border-radius:var(--r2);padding:10px 14px;text-align:center;min-width:52px;
  box-shadow:0 2px 8px rgba(0,0,0,.06);
}
.timer-num{font-size:22px;font-weight:900;color:var(--blue);line-height:1;letter-spacing:-1px}

/* ── TESTIMONIALS (light) ── */
.testi-card{
  background:var(--bg2);
  border:1px solid var(--brd);
  border-radius:var(--r3);padding:22px;
  position:relative;overflow:hidden;
  transition:transform .25s,border-color .25s,box-shadow .25s;
  box-shadow:0 2px 12px rgba(0,0,0,.05);
}
.testi-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--grad1);
}
.testi-card:hover{
  transform:translateY(-4px);
  border-color:rgba(0,168,255,.25);
  box-shadow:0 12px 32px rgba(0,168,255,.1);
}
.testi-quote{
  position:absolute;top:18px;right:18px;font-size:36px;
  color:rgba(0,168,255,.12);font-family:Georgia,serif;line-height:1;
}

/* ── HOW IT WORKS (light) ── */
.how-card{
  background:var(--bg2);
  border:1px solid var(--brd);
  border-radius:var(--r3);padding:28px 22px;
  position:relative;overflow:hidden;
  transition:transform .25s,box-shadow .25s,border-color .25s;
  box-shadow:0 2px 12px rgba(0,0,0,.04);
}
.how-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad1)}
.how-card:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,168,255,.1);border-color:rgba(0,168,255,.25)}

/* ── SECTION TITLES PREMIUM ── */
.section-title{font-size:21px;font-weight:800;letter-spacing:-.3px;display:flex;align-items:center;gap:10px}
.section-title::before{content:'';display:block;width:4px;height:22px;background:var(--grad2);border-radius:2px;box-shadow:0 0 8px rgba(0,168,255,.5)}

/* ── CAT IMG HELPERS (partagés entre cat-img-card-v2 et variantes) ── */
.cat-img-overlay{
  background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.3) 50%,transparent 100%);
}
.cat-img-name{font-size:16px;font-weight:800;letter-spacing:-.2px;color:#fff;line-height:1.2}
.cat-img-badge{
  position:absolute;top:10px;left:10px;
  background:linear-gradient(135deg,rgba(0,168,255,.8),rgba(0,114,214,.8));
  backdrop-filter:blur(8px);border:none;border-radius:20px;
  padding:3px 9px;font-size:10px;font-weight:700;color:#fff;letter-spacing:.4px;
  box-shadow:0 2px 10px rgba(0,168,255,.4);
}
.cat-img-arrow{
  width:34px;height:34px;
  background:rgba(255,255,255,.15);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:14px;color:#fff;
  flex-shrink:0;transition:all .25s;
}
.cat-img-card-v2:hover .cat-img-arrow{
  background:var(--grad2);border-color:transparent;
  box-shadow:0 0 16px rgba(0,168,255,.5);
  transform:scale(1.1);
}

/* ── TRUST BAR PREMIUM ── */
.trust-bar{
  background:linear-gradient(90deg,rgba(0,114,214,.04) 0%,rgba(0,168,255,.06) 50%,rgba(0,114,214,.04) 100%);
  border-top:1px solid rgba(0,0,0,.06);border-bottom:1px solid rgba(0,0,0,.06);
  padding:18px 16px;
}
.trust-item{
  display:flex;align-items:center;gap:8px;
  font-size:13px;font-weight:700;color:var(--txt2);
  transition:color .2s;
}
.trust-item:hover{color:var(--blue)}
.trust-ico{font-size:22px}

/* ── STICKY WHATSAPP ── */
.sticky-wa-btn{
  position:fixed;bottom:24px;right:20px;z-index:990;
  display:flex;align-items:center;gap:10px;
  background:#25d366;color:#fff;border:none;border-radius:50px;
  padding:13px 20px 13px 16px;
  font-size:14px;font-weight:800;cursor:pointer;
  box-shadow:0 4px 24px rgba(37,211,102,.55);
  animation:pulseGlow 3s ease infinite;
  transition:all .25s;text-decoration:none;
  white-space:nowrap;
}
.sticky-wa-btn:hover{
  transform:translateY(-3px) scale(1.04);
  box-shadow:0 8px 36px rgba(37,211,102,.75);
  animation-play-state:paused;
}
.sticky-wa-btn svg{flex-shrink:0}
@media(max-width:480px){.sticky-wa-btn span.wa-label{display:none}.sticky-wa-btn{padding:14px;border-radius:50%}}

/* ── MOBILE STICKY CTA BAR ── */
.mobile-cta-bar{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:989;
  background:rgba(255,255,255,.97);backdrop-filter:blur(16px);
  border-top:1px solid rgba(0,0,0,.08);
  padding:12px 16px;gap:10px;
}
@media(max-width:600px){.mobile-cta-bar{display:flex}}
.mobile-cta-bar .hero-cta-btn,.mobile-cta-bar .hero-wa-btn{
  flex:1;padding:13px 12px;font-size:14px;justify-content:center;
}

/* ── SECTION RHYTHM — alternating backgrounds ── */
.section-alt{background:linear-gradient(180deg,rgba(0,114,214,.04) 0%,var(--bg0) 100%)}
.section-dark{background:linear-gradient(145deg,#f0f1fa,#eef0f8)}

/* ── PROMO BAR PREMIUM ── */
.promo-bar{
  background:linear-gradient(90deg,#0072d6,#ff8c42,#0072d6,#ff8c42,#0072d6);
  background-size:300% 100%;
  animation:gradientShift 5s linear infinite;
}

/* ── MISC REFINEMENTS ── */
.container{max-width:1160px;margin:0 auto;padding:0 16px}
.section{padding:48px 0}
@media(max-width:600px){.section{padding:36px 0}}

/* ── SHOP LAYOUT ── */
.shop-layout{display:grid;grid-template-columns:220px 1fr;gap:20px;padding:20px 16px}
@media(max-width:900px){.shop-layout{grid-template-columns:1fr}}
.shop-sidebar{display:flex;flex-direction:column;gap:16px}
@media(max-width:900px){.shop-sidebar{display:none}}
.sidebar-box{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r2);padding:16px}
.sidebar-box-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--txt3);margin-bottom:12px}
.filter-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:13px;cursor:pointer;transition:color var(--tr)}
.filter-item:hover{color:var(--cyan)}
.filter-check{width:16px;height:16px;border:1px solid var(--brd2);border-radius:4px;background:var(--bg3);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:10px;transition:all var(--tr)}
.filter-item.checked .filter-check{background:var(--purple);border-color:var(--purple)}
.price-range{display:flex;flex-direction:column;gap:8px}
.price-slider{width:100%;accent-color:var(--purple)}
.price-inputs{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.price-input{background:var(--bg3);border:1px solid var(--brd);border-radius:var(--r1);padding:6px 8px;font-size:12px;color:var(--txt1);outline:none;width:100%}
.shop-main{}
.shop-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:8px}
.shop-count{font-size:13px;color:var(--txt3)}
.shop-sort{display:flex;align-items:center;gap:6px;font-size:13px}
.sort-select{background:var(--bg3);border:1px solid var(--brd);border-radius:var(--r1);padding:6px 10px;color:var(--txt1);font-size:13px;outline:none;cursor:pointer}

/* ── PRODUCT DETAIL ── */
.prod-detail{max-width:1000px;margin:0 auto;padding:24px 16px}
.prod-detail-grid{display:grid;grid-template-columns:380px 1fr;gap:32px;align-items:start}
@media(max-width:768px){.prod-detail-grid{grid-template-columns:1fr}}
.prod-visual{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r3);padding:40px;text-align:center}
.prod-visual-ico{font-size:90px;margin-bottom:12px}
.prod-visual-name{font-size:15px;font-weight:600;color:var(--txt2)}
.prod-meta{display:flex;flex-direction:column;gap:16px}
.prod-detail-cat{display:flex;align-items:center;gap:6px}
.prod-detail-name{font-size:26px;font-weight:800;line-height:1.3;letter-spacing:-.5px}
.prod-detail-rating{display:flex;align-items:center;gap:8px}
.big-stars{color:#f5a623;font-size:16px}
.prod-detail-price-box{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r2);padding:16px}
.detail-price{font-size:32px;font-weight:900}
.detail-old{font-size:16px;color:var(--txt3);text-decoration:line-through}
.detail-save{background:rgba(6,214,160,.15);color:var(--green);font-size:12px;font-weight:700;padding:3px 8px;border-radius:12px;margin-left:8px}
.duration-tabs{display:flex;gap:8px;flex-wrap:wrap}
.dur-tab{padding:8px 16px;border-radius:var(--r1);border:1px solid var(--brd2);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--tr)}
.dur-tab.active{background:var(--grad1);border-color:transparent;color:#fff}
.dur-tab:hover:not(.active){border-color:var(--purple)}
.features-list{display:flex;flex-direction:column;gap:8px}
.feature-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--txt2)}
.feature-ico{color:var(--green);font-size:14px;flex-shrink:0}
.detail-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.qty-row{display:flex;align-items:center;gap:12px;background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r1);padding:4px;width:fit-content}
.qty-btn{width:32px;height:32px;border-radius:6px;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:18px;transition:background var(--tr);font-weight:700}
.qty-btn:hover{background:var(--bg4)}
.qty-num{font-size:16px;font-weight:700;min-width:28px;text-align:center}

/* ── CART DRAWER ── */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1000;opacity:0;pointer-events:none;transition:opacity var(--tr)}
.cart-overlay.open{opacity:1;pointer-events:all}
.cart-drawer{position:fixed;top:0;right:0;bottom:0;width:min(420px,100vw);background:var(--bg1);z-index:1001;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;border-left:1px solid var(--brd)}
.cart-drawer.open{transform:translateX(0)}
.cart-head{padding:16px 20px;border-bottom:1px solid var(--brd);display:flex;align-items:center;justify-content:space-between}
.cart-head-title{font-size:17px;font-weight:700}
.cart-close{width:34px;height:34px;border-radius:var(--r1);background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;transition:background var(--tr)}
.cart-close:hover{background:var(--bg4)}
.cart-items{flex:1;overflow-y:auto;padding:16px}
.cart-empty{text-align:center;padding:60px 20px;color:var(--txt3)}
.cart-empty-ico{font-size:48px;margin-bottom:12px}
.cart-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--brd)}
.cart-item-img{width:54px;height:54px;background:var(--bg3);border-radius:var(--r1);display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{font-size:13px;font-weight:600;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cart-item-price{font-size:14px;font-weight:800;color:var(--pink)}
.cart-item-qty{display:flex;align-items:center;gap:6px;margin-top:4px}
.cqty-btn{width:22px;height:22px;background:var(--bg3);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;transition:background var(--tr)}
.cqty-btn:hover{background:var(--purple)}
.cart-item-del{color:var(--txt3);font-size:18px;cursor:pointer;padding:4px;transition:color var(--tr)}
.cart-item-del:hover{color:var(--pink)}
.cart-foot{padding:16px 20px;border-top:1px solid var(--brd)}
.cart-sub-row{display:flex;justify-content:space-between;font-size:13px;color:var(--txt2);margin-bottom:8px}
.cart-total-row{display:flex;justify-content:space-between;font-size:17px;font-weight:800;margin-bottom:16px}

/* ── CHECKOUT ── */
.checkout-page{max-width:860px;margin:0 auto;padding:24px 16px}
.checkout-title{font-size:24px;font-weight:800;margin-bottom:24px}
.checkout-grid{display:grid;grid-template-columns:1fr 340px;gap:24px}
@media(max-width:768px){.checkout-grid{grid-template-columns:1fr}}
.checkout-steps{display:flex;gap:0;margin-bottom:28px}
.step{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--txt3)}
.step-num{width:28px;height:28px;border-radius:50%;background:var(--bg3);border:1px solid var(--brd2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;transition:all var(--tr)}
.step.active{color:var(--txt1)}
.step.active .step-num{background:var(--grad1);border-color:transparent}
.step.done .step-num{background:var(--green);border-color:transparent;color:var(--bg0)}
.step-sep{flex:1;height:1px;background:var(--brd2);margin:0 6px;margin-bottom:14px}
.form-section{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r2);padding:20px;margin-bottom:16px}
.form-section-title{font-size:14px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:6px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){.form-grid{grid-template-columns:1fr}}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-label{font-size:12px;font-weight:600;color:var(--txt3);text-transform:uppercase;letter-spacing:.4px}
.form-input{background:var(--bg3);border:1px solid var(--brd2);border-radius:var(--r1);padding:10px 12px;color:var(--txt1);font-size:14px;outline:none;transition:border-color var(--tr);width:100%}
.form-input:focus{border-color:var(--purple)}
.form-input::placeholder{color:var(--txt3)}
.form-full{grid-column:1/-1}
.pay-methods{display:flex;flex-direction:column;gap:8px}
.pay-method{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg3);border:1px solid var(--brd2);border-radius:var(--r2);cursor:pointer;transition:all var(--tr)}
.pay-method:hover{border-color:var(--purple)}
.pay-method.selected{border-color:var(--purple);background:rgba(0,114,214,.1)}
.pay-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--brd2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--tr)}
.pay-method.selected .pay-radio{border-color:var(--purple);background:var(--purple)}
.pay-radio-dot{width:7px;height:7px;border-radius:50%;background:#fff;display:none}
.pay-method.selected .pay-radio-dot{display:block}
.pay-ico{font-size:22px}
.pay-name{font-size:14px;font-weight:600}
.pay-sub{font-size:12px;color:var(--txt3)}
.order-summary-box{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r2);padding:20px;position:sticky;top:calc(var(--hh) + var(--nh) + var(--ch) + 20px)}
.order-sum-title{font-size:14px;font-weight:700;margin-bottom:16px}
.order-items{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.order-item{display:flex;align-items:center;gap:10px}
.order-item-img{width:40px;height:40px;background:var(--bg3);border-radius:var(--r1);display:flex;align-items:center;justify-content:center;font-size:20px}
.order-item-name{font-size:12px;font-weight:600;flex:1}
.order-item-price{font-size:13px;font-weight:700;color:var(--pink)}
.order-divider{height:1px;background:var(--brd);margin:12px 0}
.order-row{display:flex;justify-content:space-between;font-size:13px;color:var(--txt2);margin-bottom:6px}
.order-total-row{display:flex;justify-content:space-between;font-size:17px;font-weight:800;margin-top:8px}
.promo-row{display:flex;gap:8px;margin:12px 0}
.promo-input{flex:1;background:var(--bg3);border:1px solid var(--brd2);border-radius:var(--r1);padding:9px 12px;font-size:13px;color:var(--txt1);outline:none}

/* ── ACCOUNT ── */
.account-page{max-width:760px;margin:0 auto;padding:24px 16px}
.auth-box{max-width:440px;margin:0 auto;background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r3);padding:32px}
.auth-logo{text-align:center;margin-bottom:24px;font-size:32px}
.auth-title{font-size:22px;font-weight:800;text-align:center;margin-bottom:6px}
.auth-sub{font-size:13px;color:var(--txt3);text-align:center;margin-bottom:24px}
.auth-tabs{display:grid;grid-template-columns:1fr 1fr;background:var(--bg3);border-radius:var(--r1);padding:3px;margin-bottom:24px;gap:3px}
.auth-tab{padding:9px;border-radius:7px;font-size:13px;font-weight:600;text-align:center;cursor:pointer;transition:all var(--tr);color:var(--txt3)}
.auth-tab.active{background:var(--grad1);color:#fff}
.divider-or{display:flex;align-items:center;gap:10px;margin:16px 0;font-size:12px;color:var(--txt3)}
.divider-or::before,.divider-or::after{content:'';flex:1;height:1px;background:var(--brd)}
.social-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px;background:var(--bg3);border:1px solid var(--brd2);border-radius:var(--r1);font-size:13px;font-weight:600;margin-bottom:8px;transition:all var(--tr);cursor:pointer}
.social-btn:hover{border-color:var(--purple)}

/* ── ADMIN ── */
.admin-layout{display:grid;grid-template-columns:220px 1fr;min-height:calc(100vh - var(--hh) - var(--nh) - var(--ch))}
@media(max-width:900px){.admin-layout{grid-template-columns:1fr}}
.admin-sidebar{background:var(--bg1);border-right:1px solid var(--brd);padding:16px;display:flex;flex-direction:column;gap:4px}
@media(max-width:900px){.admin-sidebar{display:none}}
.admin-menu-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r1);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--tr);color:var(--txt3)}
.admin-menu-item:hover{background:var(--bg3);color:var(--txt1)}
.admin-menu-item.active{background:rgba(0,114,214,.15);color:var(--cyan)}
.admin-menu-ico{font-size:16px;width:20px;text-align:center}
.admin-main{padding:24px;overflow-y:auto}
.admin-title{font-size:22px;font-weight:800;margin-bottom:24px}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}
@media(max-width:900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.stats-grid{grid-template-columns:1fr 1fr}}
.stat-card{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r2);padding:18px;position:relative;overflow:hidden}
.stat-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad1)}
.stat-ico{font-size:24px;margin-bottom:10px}
.stat-num{font-size:24px;font-weight:800;margin-bottom:2px}
.stat-lbl{font-size:12px;color:var(--txt3)}
.stat-change{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;margin-top:6px}
.stat-up{color:var(--green)}.stat-down{color:var(--pink)}
.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:700px){.admin-grid{grid-template-columns:1fr}}
.admin-box{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r2);padding:20px}
.admin-box-title{font-size:14px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between}
.orders-table{width:100%;font-size:12px;border-collapse:collapse}
.orders-table th{text-align:left;padding:8px;color:var(--txt3);font-weight:600;border-bottom:1px solid var(--brd);font-size:11px;text-transform:uppercase;letter-spacing:.4px}
.orders-table td{padding:9px 8px;border-bottom:1px solid var(--brd)}
.order-status{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700}
.status-success{background:rgba(6,214,160,.15);color:var(--green)}
.status-pending{background:rgba(0,168,255,.15);color:var(--pink)}
.status-process{background:rgba(76,201,240,.15);color:var(--cyan)}
.bar-chart{display:flex;flex-direction:column;gap:10px}
.bar-row{display:flex;align-items:center;gap:10px;font-size:12px}
.bar-label{width:100px;color:var(--txt2);flex-shrink:0}
.bar-track{flex:1;background:var(--bg3);border-radius:4px;height:8px;overflow:hidden}
.bar-fill{height:100%;border-radius:4px;background:var(--grad1);transition:width .6s ease}
.bar-value{width:60px;text-align:right;font-weight:700;color:var(--txt2)}

/* ── FOOTER ── */
.footer{background:var(--bg1);border-top:1px solid var(--brd);padding:40px 16px 24px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:28px;max-width:1100px;margin:0 auto}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-brand .logo-text{font-size:20px;font-weight:800;margin-bottom:8px}
.footer-desc{font-size:13px;color:var(--txt3);line-height:1.7;margin-bottom:16px}
.footer-social{display:flex;gap:8px}
.social-ico{width:34px;height:34px;background:var(--bg3);border:1px solid var(--brd);border-radius:var(--r1);display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;transition:all var(--tr)}
.social-ico:hover{background:var(--purple);border-color:var(--purple)}
.footer-col-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--txt3);margin-bottom:14px}
.footer-link{font-size:13px;color:var(--txt3);padding:4px 0;display:block;cursor:pointer;transition:color var(--tr)}
.footer-link:hover{color:var(--cyan)}
.footer-bottom{border-top:1px solid var(--brd);padding-top:20px;margin-top:28px;max-width:1100px;margin-left:auto;margin-right:auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--txt3)}
.pay-icons{display:flex;gap:6px;flex-wrap:wrap}
.pay-ico-sm{background:var(--bg3);border:1px solid var(--brd);border-radius:5px;padding:3px 7px;font-size:11px;font-weight:700}

/* ── TOAST ── */
.toast-container{position:fixed;bottom:20px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--bg3);border:1px solid var(--brd2);border-radius:var(--r2);padding:12px 16px;min-width:260px;max-width:340px;display:flex;align-items:center;gap:10px;font-size:13px;font-weight:500;box-shadow:var(--sh1);animation:slideIn .25s ease;pointer-events:none}
.toast-success{border-left:3px solid var(--green)}
.toast-info{border-left:3px solid var(--cyan)}
.toast-error{border-left:3px solid var(--pink)}
@keyframes slideIn{from{transform:translateX(60px);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes fadeOut{from{opacity:1}to{opacity:0;transform:translateX(60px)}}

/* ── TESTIMONIALS ── */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:700px){.testi-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.testi-grid{grid-template-columns:1fr}}
/* .testi-card — défini dans le bloc TESTIMONIALS (light) ci-dessus */
.testi-stars{color:#f5a623;font-size:13px;margin-bottom:10px}
.testi-text{font-size:13px;color:var(--txt2);line-height:1.7;margin-bottom:14px;font-style:italic}
.testi-author{display:flex;align-items:center;gap:10px}
.testi-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.testi-name{font-size:13px;font-weight:700}
.testi-city{font-size:11px;color:var(--txt3)}

/* ── MISC ── */
.page-loading{display:flex;align-items:center;justify-content:center;min-height:300px}
.spinner{width:36px;height:36px;border:3px solid var(--brd);border-top-color:var(--purple);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--txt3);margin-bottom:16px}
.breadcrumb-sep{font-size:10px}
.breadcrumb-cur{color:var(--txt2)}

/* ── LOGO IMAGE ── */
.logo-img{height:34px;max-width:160px;object-fit:contain;filter:brightness(1.1)}
.logo{gap:6px}

/* ── PAYMENT LOGOS ── */
.pay-logo-img{height:22px;width:auto;object-fit:contain;border-radius:4px}

/* ── PROMO BANNER ── */
.promo-bar{background:var(--grad2);padding:8px 16px;text-align:center;font-size:12px;font-weight:600;letter-spacing:.3px;position:fixed;top:0;left:0;right:0;z-index:901;display:flex;align-items:center;justify-content:center;gap:6px}
/* new promo bandeau overrides old bar height if present */
.promo-bandeau{display:none!important}

/* ── CONTENT PAGES ── */
.page-wrap{max-width:900px;margin:0 auto;padding:40px 16px 60px}
.page-hero{text-align:center;padding:44px 16px 28px;border-bottom:1px solid var(--brd)}
.page-hero h1{font-size:clamp(22px,4vw,38px);font-weight:800;margin-bottom:10px}
.page-hero p{font-size:14px;color:var(--txt2);max-width:580px;margin:0 auto}
.page-breadcrumb{font-size:12px;color:var(--txt3);margin-bottom:24px}
.page-breadcrumb span{cursor:pointer;transition:color var(--tr)}.page-breadcrumb span:hover{color:var(--cyan)}

/* ── BLOG ── */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin:24px 0}
.blog-card{background:var(--bg1);border:1px solid var(--brd);border-radius:var(--r3);overflow:hidden;cursor:pointer;transition:all var(--tr)}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--sh2);border-color:var(--purple)}
.blog-card-img{height:160px;display:flex;align-items:center;justify-content:center;font-size:56px}
.blog-card-body{padding:16px}
.blog-card-cat{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--cyan);margin-bottom:6px}
.blog-card-title{font-size:15px;font-weight:700;margin-bottom:8px;line-height:1.4}
.blog-card-excerpt{font-size:13px;color:var(--txt2);line-height:1.6;margin-bottom:10px}
.blog-card-meta{font-size:11px;color:var(--txt3);display:flex;gap:12px;align-items:center}
/* ── ARTICLE ── */
.article-wrap{max-width:760px;margin:0 auto;padding:32px 16px 60px}
.article-cat{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--cyan);margin-bottom:10px}
.article-title{font-size:clamp(20px,4vw,34px);font-weight:800;line-height:1.3;margin-bottom:12px}
.article-meta{font-size:12px;color:var(--txt3);margin-bottom:24px;display:flex;gap:16px}
.article-body h2{font-size:19px;font-weight:700;margin:30px 0 12px;color:var(--txt1);padding-left:12px;border-left:3px solid var(--purple)}
.article-body h3{font-size:15px;font-weight:700;margin:20px 0 8px;color:var(--cyan)}
.article-body p{font-size:14px;color:var(--txt2);line-height:1.85;margin-bottom:14px}
.article-body ul{padding-left:18px;margin-bottom:14px}
.article-body ul li{font-size:14px;color:var(--txt2);line-height:1.8;margin-bottom:6px;list-style:none;padding-left:6px}
.article-body ul li::before{content:"✓ ";color:var(--green);font-weight:700}
.article-body strong{color:var(--txt1)}
.article-cta{background:linear-gradient(135deg,rgba(0,114,214,.15),rgba(0,114,214,.15));border:1px solid var(--purple);border-radius:var(--r3);padding:22px;margin:28px 0;text-align:center}

/* ── FAQ ── */
.faq-list{display:flex;flex-direction:column;gap:8px;margin:20px 0}
.faq-item{background:var(--bg1);border:1px solid var(--brd);border-radius:var(--r2);overflow:hidden;transition:border var(--tr)}
.faq-item:hover{border-color:var(--brd2)}
.faq-q{padding:15px 18px;font-weight:600;font-size:14px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:10px}
.faq-a{padding:0 18px;max-height:0;overflow:hidden;transition:all .3s;font-size:13px;color:var(--txt2);line-height:1.8}
.faq-a.open{padding:0 18px 14px;max-height:500px}
.faq-chevron{transition:transform .3s;font-size:12px;flex-shrink:0}
.faq-chevron.open{transform:rotate(180deg)}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:24px 0}
@media(max-width:640px){.contact-grid{grid-template-columns:1fr}}
.contact-card{background:var(--bg1);border:1px solid var(--brd);border-radius:var(--r3);padding:22px}
.contact-form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.contact-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--txt3)}
.contact-input{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r1);padding:10px 13px;font-size:13px;color:var(--txt1);outline:none;transition:border var(--tr);width:100%}
.contact-input:focus{border-color:var(--purple)}
textarea.contact-input{min-height:90px;resize:vertical}

/* ── POLICY PAGES ── */
.policy-body{max-width:780px;margin:0 auto}
.policy-body h2{font-size:17px;font-weight:700;margin:26px 0 10px;color:var(--cyan);padding-bottom:6px;border-bottom:1px solid var(--brd)}
.policy-body p{font-size:13px;color:var(--txt2);line-height:1.85;margin-bottom:12px}
.policy-body ul{padding-left:16px;margin-bottom:12px}
.policy-body ul li{font-size:13px;color:var(--txt2);line-height:1.75;margin-bottom:5px}
.policy-date{font-size:12px;color:var(--txt3);margin-bottom:24px}

/* ── SEO PAGES ── */
.seo-hero{padding:48px 16px 32px;text-align:center;background:linear-gradient(135deg,rgba(0,114,214,.18),rgba(0,114,214,.18));border-bottom:1px solid var(--brd)}
.seo-hero h1{font-size:clamp(22px,4vw,38px);font-weight:800;margin-bottom:12px}
.seo-hero .seo-sub{font-size:14px;color:var(--txt2);max-width:600px;margin:0 auto 20px}
.seo-content{max-width:860px;margin:0 auto;padding:32px 16px 60px}
.seo-content h2{font-size:19px;font-weight:700;margin:28px 0 12px;padding-left:12px;border-left:3px solid var(--cyan)}
.seo-content h3{font-size:15px;font-weight:700;margin:18px 0 8px;color:var(--cyan)}
.seo-content p{font-size:14px;color:var(--txt2);line-height:1.85;margin-bottom:14px}
.seo-content ul{padding-left:18px;margin-bottom:14px}
.seo-content ul li{font-size:14px;color:var(--txt2);line-height:1.8;margin-bottom:6px}
.seo-faq{margin:32px 0}
.seo-faq-item{background:var(--bg1);border:1px solid var(--brd);border-radius:var(--r2);padding:16px 18px;margin-bottom:8px}
.seo-faq-q{font-size:14px;font-weight:700;color:var(--txt1);margin-bottom:8px}
.seo-faq-a{font-size:13px;color:var(--txt2);line-height:1.7}
.seo-prod-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px;margin:20px 0}

/* ── ORDER TRACKING ── */
.tracking-timeline{display:flex;flex-direction:column;gap:0;margin:24px 0;position:relative}
.tracking-step{display:flex;align-items:flex-start;gap:16px;padding:16px 0;position:relative}
.tracking-step::before{content:'';position:absolute;left:19px;top:44px;width:2px;height:calc(100% - 12px);background:var(--brd);z-index:0}
.tracking-step:last-child::before{display:none}
.tracking-step-ico{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;position:relative;z-index:1;transition:all .4s}
.tracking-step.done .tracking-step-ico{background:linear-gradient(135deg,var(--green),#05b386);box-shadow:0 0 16px rgba(6,214,160,.4)}
.tracking-step.active .tracking-step-ico{background:linear-gradient(135deg,var(--pink),var(--purple));box-shadow:0 0 20px rgba(0,168,255,.5);animation:pulseGlow 1.5s ease infinite}
.tracking-step.pending .tracking-step-ico{background:var(--bg2);border:2px solid var(--brd)}
.tracking-step.done::before{background:var(--green)}
.tracking-step-content{flex:1;padding-top:8px}
.tracking-step-title{font-size:14px;font-weight:700;margin-bottom:2px}
.tracking-step-time{font-size:12px;color:var(--txt3)}
.tracking-step.active .tracking-step-title{color:var(--pink)}
.tracking-step.done  .tracking-step-title{color:var(--green)}
.suivi-search{display:flex;gap:8px;margin-bottom:24px}
.suivi-search input{flex:1;background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r2);padding:12px 16px;color:var(--txt1);font-size:14px;outline:none;transition:border-color .2s}
.suivi-search input:focus{border-color:var(--cyan)}
.order-track-card{background:var(--bg1);border:1px solid var(--brd);border-radius:var(--r3);padding:24px;margin-bottom:20px}
/* ── LUCKY WHEEL ── */
#wheelModal{position:fixed;inset:0;z-index:9996;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .35s}
#wheelModal.show{opacity:1;pointer-events:all}
#wheelModal::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(10px)}
.wheel-box{position:relative;background:linear-gradient(145deg,#0f0f2e,#1a1a40);border:1px solid rgba(0,168,255,.3);border-radius:28px;padding:32px 24px 28px;max-width:460px;width:100%;text-align:center;box-shadow:0 0 80px rgba(0,114,214,.25),0 32px 80px rgba(0,0,0,.7);animation:popIn .4s ease}
.wheel-close{position:absolute;top:14px;right:16px;background:rgba(255,255,255,.06);border:none;color:rgba(255,255,255,.5);width:32px;height:32px;border-radius:50%;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.wheel-close:hover{background:rgba(255,255,255,.12)}
.wheel-wrap{position:relative;width:280px;height:280px;margin:0 auto 20px}
.wheel-canvas{border-radius:50%;display:block;filter:drop-shadow(0 0 24px rgba(0,114,214,.5))}
.wheel-pointer{position:absolute;top:-18px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:13px solid transparent;border-right:13px solid transparent;border-top:28px solid var(--pink);filter:drop-shadow(0 2px 6px rgba(0,168,255,.6));z-index:2}
.wheel-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#0f0f2e,#1a1a40);border:3px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:20px;z-index:3;box-shadow:0 0 16px rgba(0,0,0,.6)}
.wheel-spin-btn{background:linear-gradient(135deg,#ff8c42,#0072d6);color:#fff;border:none;border-radius:var(--r2);padding:14px 40px;font-size:16px;font-weight:800;cursor:pointer;transition:all .25s;box-shadow:0 4px 20px rgba(0,168,255,.4);letter-spacing:.3px}
.wheel-spin-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,168,255,.5)}
.wheel-spin-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.wheel-result{display:none;animation:popIn .5s ease}
.wheel-result.show{display:block}
#wheelFloatBtn{position:fixed;bottom:140px;right:16px;z-index:850;background:linear-gradient(135deg,#ff8c42,#0072d6);color:#fff;border:none;border-radius:20px;padding:10px 16px;font-size:13px;font-weight:800;cursor:pointer;box-shadow:0 4px 20px rgba(0,168,255,.5);display:flex;align-items:center;gap:8px;transition:transform .2s,box-shadow .2s;animation:float 3s ease infinite}
#wheelFloatBtn:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 8px 30px rgba(0,168,255,.6)}
/* Confetti */
.confetti-piece{position:fixed;width:8px;height:8px;z-index:99999;pointer-events:none;animation:confettiFall var(--dur,1.5s) var(--del,0s) ease-out forwards}
@keyframes confettiFall{0%{opacity:1;transform:translate(var(--x,0),0) rotate(0deg)}100%{opacity:0;transform:translate(calc(var(--x,0) + var(--dx,20px)),90vh) rotate(720deg)}}
/* ── SUBSCRIPTION TRACKER ── */
.sub-card{background:var(--bg1);border:1px solid var(--brd);border-radius:var(--r3);padding:20px;position:relative;overflow:hidden;transition:border-color .2s}
.sub-card.expiring-soon{border-color:rgba(0,168,255,.4);background:linear-gradient(135deg,rgba(0,168,255,.04),rgba(0,114,214,.04))}
.sub-card.expired{border-color:rgba(255,255,255,.05);opacity:.6}
.sub-card.active{border-color:rgba(6,214,160,.25)}
.sub-bar-track{background:rgba(255,255,255,.06);border-radius:3px;height:6px;margin:10px 0;overflow:hidden}
.sub-bar-fill{height:100%;border-radius:3px;transition:width .8s ease}
.sub-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700}
.sub-badge.active{background:rgba(6,214,160,.15);color:var(--green)}
.sub-badge.expiring{background:rgba(0,168,255,.15);color:var(--pink);animation:neonPulse 2s ease infinite}
.sub-badge.expired{background:rgba(255,255,255,.06);color:var(--txt3)}
/* ── REFERRAL SYSTEM ── */
#referralBanner{position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(135deg,#06d6a0,#4cc9f0);color:#fff;padding:10px 16px;display:flex;align-items:center;justify-content:center;gap:10px;font-size:13px;font-weight:700;transform:translateY(-100%);transition:transform .4s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 4px 24px rgba(6,214,160,.5)}
#referralBanner.show{transform:translateY(0)}
.ref-banner-close{margin-left:auto;cursor:pointer;opacity:.7;font-size:16px;flex-shrink:0;padding:2px 6px}
.ref-card{background:linear-gradient(135deg,rgba(6,214,160,.1),rgba(76,201,240,.08));border:1px solid rgba(6,214,160,.25);border-radius:var(--r3);padding:28px;text-align:center;margin-bottom:24px}
.ref-code-box{background:rgba(0,0,0,.3);border:2px dashed rgba(6,214,160,.4);border-radius:var(--r2);padding:14px 20px;font-family:monospace;font-size:22px;font-weight:900;letter-spacing:3px;color:#06d6a0;cursor:pointer;transition:background .2s;display:inline-block;margin:12px 0}
.ref-code-box:hover{background:rgba(6,214,160,.1)}
.ref-link-box{background:rgba(255,255,255,.05);border:1px solid var(--brd);border-radius:var(--r1);padding:10px 14px;font-size:12px;color:var(--txt3);word-break:break-all;margin:8px 0;text-align:left}
.ref-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:24px 0}
.ref-stat{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r2);padding:16px;text-align:center}
.ref-stat-num{font-size:26px;font-weight:900;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.ref-stat-lbl{font-size:12px;color:var(--txt3);margin-top:4px}
.ref-steps{display:flex;flex-direction:column;gap:12px;margin:20px 0}
.ref-step{display:flex;align-items:flex-start;gap:14px;background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r2);padding:14px 16px}
.ref-step-num{width:32px;height:32px;border-radius:50%;background:var(--grad1);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:900;flex-shrink:0}
.ref-share-btns{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:16px}
/* ── FAV / COMPARE BUTTONS ON CARDS ── */
.fav-btn{position:absolute;top:8px;right:8px;z-index:3;background:rgba(255,255,255,.9);backdrop-filter:blur(4px);border:1px solid rgba(0,0,0,.08);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:15px;transition:all .2s;line-height:1;box-shadow:0 1px 4px rgba(0,0,0,.1)}
.fav-btn.active{background:rgba(0,168,255,.12);border-color:rgba(0,168,255,.3);box-shadow:0 0 10px rgba(0,168,255,.25)}
.compare-btn{position:absolute;bottom:8px;right:8px;z-index:3;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);border:none;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;transition:all .2s;opacity:0}
.prod-card:hover .compare-btn{opacity:1}
.compare-btn.active{opacity:1;background:rgba(76,201,240,.25)}
.btn-buynow{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border:none;border-radius:var(--r1);width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;flex-shrink:0;transition:all .2s}
.btn-buynow:hover{transform:scale(1.1);box-shadow:0 4px 15px rgba(0,168,255,.4)}
/* ── FIELD VALIDATION ── */
.field-err{font-size:11px;color:var(--pink);margin-top:3px;min-height:14px}
.form-input.valid{border-color:var(--green)!important}
.form-input.invalid{border-color:var(--pink)!important}
/* ── PRICE SLIDER ── */
.price-slider{-webkit-appearance:none;appearance:none;width:100%;height:4px;border-radius:2px;background:linear-gradient(90deg,var(--pink) var(--pct,80%),rgba(255,255,255,.1) var(--pct,80%));outline:none;cursor:pointer}
.price-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--pink);box-shadow:0 2px 8px rgba(0,168,255,.5);cursor:pointer}
/* ── COMPARE MODAL ── */
#compareModal{position:fixed;inset:0;z-index:9990;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .3s}
#compareModal.show{opacity:1;pointer-events:all}
#compareModal::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.8);backdrop-filter:blur(8px)}
.compare-box{position:relative;background:var(--bg1);border:1px solid var(--brd);border-radius:var(--r3);padding:24px;max-width:900px;width:100%;max-height:85vh;overflow-y:auto;animation:popIn .3s ease}
.compare-grid{display:grid;gap:16px;margin-top:16px}
/* ── 404 ── */
.page-404{min-height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 16px}
.page-404-num{font-size:clamp(80px,18vw,150px);font-weight:900;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1;animation:heroGlow 3s ease infinite}
/* ── PRODUCT TABS ── */
.prod-tabs{overflow-x:auto;scrollbar-width:none}
.prod-tabs::-webkit-scrollbar{display:none}
/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin:24px 0}
.about-card{background:var(--bg1);border:1px solid var(--brd);border-radius:var(--r3);padding:22px;text-align:center}
.about-card-icon{font-size:36px;margin-bottom:12px}
.about-card-title{font-size:14px;font-weight:700;margin-bottom:6px}
.about-card-desc{font-size:13px;color:var(--txt2);line-height:1.6}
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:24px 0}
@media(max-width:560px){.trust-grid{grid-template-columns:1fr 1fr}}
.trust-grid .trust-item{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r2);padding:16px;text-align:center;display:block}
.trust-num{font-size:26px;font-weight:800;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:4px}
.trust-label{font-size:12px;color:var(--txt2)}

/* ══════════════════════════════════════════════
   NOUVELLES AMÉLIORATIONS — Batch 2
══════════════════════════════════════════════ */

/* ── SPLASH SCREEN ── */
#splashScreen{position:fixed;inset:0;z-index:99999;background:var(--bg0);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;transition:opacity .5s ease,transform .5s ease}
#splashScreen.out{opacity:0;transform:scale(1.04);pointer-events:none}
.splash-logo{font-size:52px;font-weight:900;letter-spacing:-2px;animation:popIn .6s ease}
.splash-logo span:first-child{color:var(--cyan)}
.splash-logo span:last-child{color:var(--pink)}
.splash-bar{width:180px;height:3px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden;margin-top:8px}
.splash-fill{height:100%;background:linear-gradient(90deg,#ff8c42,#0072d6,#0072d6);animation:progressFill 1.2s ease forwards;--pw:100%}
.splash-tag{font-size:13px;color:rgba(255,255,255,.4);letter-spacing:.5px;animation:slideUp .6s .3s ease both}

/* ── CURSEUR PERSONNALISÉ ── */
.custom-cursor{position:fixed;pointer-events:none;z-index:99998;transition:transform .15s ease,opacity .3s}
.cursor-dot{width:8px;height:8px;border-radius:50%;background:var(--pink);position:fixed;pointer-events:none;z-index:99998;transform:translate(-50%,-50%);transition:transform .08s,background .2s}
.cursor-ring{width:32px;height:32px;border-radius:50%;border:1.5px solid rgba(0,168,255,.5);position:fixed;pointer-events:none;z-index:99997;transform:translate(-50%,-50%);transition:transform .18s ease,width .2s,height .2s,border-color .2s,background .2s}
.cursor-ring.hover{width:48px;height:48px;background:rgba(0,114,214,.08);border-color:var(--purple)}
@media(pointer:coarse){.cursor-dot,.cursor-ring{display:none}}

/* ── EXIT INTENT POPUP ── */
#exitPopup{position:fixed;inset:0;z-index:9998;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .3s}
#exitPopup.show{opacity:1;pointer-events:all}
#exitPopup::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(6px)}
.exit-box{position:relative;background:linear-gradient(145deg,#131330,#1e1e45);border:1px solid rgba(0,168,255,.35);border-radius:24px;padding:40px 32px;max-width:460px;width:100%;text-align:center;box-shadow:0 32px 80px rgba(0,0,0,.7),0 0 60px rgba(0,168,255,.1);animation:popIn .4s ease}
.exit-close{position:absolute;top:14px;right:16px;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;transition:background .2s}
.exit-close:hover{background:rgba(255,255,255,.12)}
.exit-timer{font-size:28px;font-weight:900;color:var(--pink);font-variant-numeric:tabular-nums;margin:10px 0}
.exit-code{background:rgba(0,168,255,.1);border:2px dashed rgba(0,168,255,.4);border-radius:12px;padding:12px 20px;font-size:22px;font-weight:900;letter-spacing:3px;color:var(--pink);margin:16px 0;cursor:pointer;transition:background .2s;position:relative}
.exit-code:hover{background:rgba(0,168,255,.18)}
.exit-code::after{content:'Cliquer pour copier';position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);font-size:10px;color:rgba(255,255,255,.4);font-weight:400;letter-spacing:0;white-space:nowrap}

/* ── SOCIAL PROOF TOAST ── */
#socialToastWrap{position:fixed;bottom:100px;left:16px;z-index:980;display:flex;flex-direction:column;gap:10px;pointer-events:none}
@media(max-width:600px){#socialToastWrap{bottom:80px}}
.social-toast{display:flex;align-items:center;gap:12px;background:rgba(5,13,26,.95);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-left:3px solid var(--green);border-radius:var(--r2);padding:12px 16px;font-size:13px;min-width:240px;max-width:300px;box-shadow:0 8px 32px rgba(0,0,0,.5);animation:slideInLeft .4s ease;pointer-events:none}
.social-toast.out{animation:slideInLeft .3s ease reverse forwards}
.social-toast-avatar{width:36px;height:36px;border-radius:50%;background:var(--grad1);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.social-toast-time{font-size:10px;color:rgba(255,255,255,.35);margin-top:2px}

/* ── LIVE COUNTER ── */
.live-counter{display:inline-flex;align-items:center;gap:6px;background:rgba(6,214,160,.08);border:1px solid rgba(6,214,160,.2);border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700;color:var(--green)}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulseGlow 1.5s ease infinite;box-shadow:0 0 6px rgba(6,214,160,.8)}

/* ── STOCK BADGE ── */
.stock-badge{display:flex;align-items:center;gap:4px;font-size:10px;font-weight:700;color:#ff9500;padding:3px 7px;background:rgba(255,149,0,.1);border:1px solid rgba(255,149,0,.25);border-radius:20px;margin-bottom:6px}

/* ── 3D TILT CARDS ── */
.tilt-card{transform-style:preserve-3d;will-change:transform}

/* ── PARTENAIRES ── */
.partners-section{background:var(--bg1);border-top:1px solid var(--brd);border-bottom:1px solid var(--brd);padding:24px 0;overflow:hidden}
.partners-track{display:flex;gap:28px;align-items:center;white-space:nowrap;animation:marqueeScroll 18s linear infinite;width:max-content}
.partners-track:hover{animation-play-state:paused}
.partner-logo{height:34px;filter:grayscale(.4) opacity(.7);transition:filter .3s;flex-shrink:0;object-fit:contain}
.partner-logo:hover{filter:grayscale(0) opacity(1)}

/* ── FAQ ACCORDION ── */
.faq-item{border:1px solid rgba(255,255,255,.07);border-radius:var(--r2);overflow:hidden;transition:border-color .2s;margin-bottom:8px}
.faq-item:hover,.faq-item.open{border-color:rgba(0,114,214,.35)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;cursor:pointer;font-size:14px;font-weight:700;gap:12px;background:var(--bg3);transition:background .2s}
.faq-q:hover{background:rgba(0,114,214,.08)}
.faq-item.open .faq-q{background:rgba(0,114,214,.06)}
.faq-arrow{font-size:16px;flex-shrink:0;transition:transform .3s;color:var(--purple)}
.faq-item.open .faq-arrow{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1),padding .3s}
.faq-item.open .faq-a{max-height:400px;padding:14px 18px}
.faq-a-inner{font-size:13px;color:var(--txt2);line-height:1.75}
/* FAQ section dans page produit */
.prod-faq-section{margin-top:40px;padding-top:32px;border-top:1px solid var(--brd)}
.prod-faq-title{font-size:18px;font-weight:800;margin-bottom:6px;display:flex;align-items:center;gap:8px}
.prod-faq-sub{font-size:13px;color:var(--txt2);margin-bottom:16px}
/* FAQ page améliorée */
.faq-search-wrap{position:relative;margin-bottom:20px}
.faq-search-wrap input{width:100%;background:var(--bg2);border:1px solid var(--brd2);border-radius:var(--r4);padding:12px 18px 12px 44px;font-size:14px;color:var(--txt1);outline:none;transition:border-color .2s}
.faq-search-wrap input:focus{border-color:var(--purple)}
.faq-search-ico{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:16px;pointer-events:none}
.faq-cat-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.faq-cat-tab{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:700;cursor:pointer;border:1px solid var(--brd2);background:var(--bg2);color:var(--txt2);transition:all .2s}
.faq-cat-tab:hover{border-color:var(--purple);color:var(--txt1)}
.faq-cat-tab.active{background:var(--grad1);border-color:transparent;color:#fff}
.faq-group-label{font-size:11px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--purple);margin:20px 0 8px;display:flex;align-items:center;gap:6px}
.faq-empty{text-align:center;padding:32px;color:var(--txt3);font-size:14px}
/* Light mode */
html[data-theme="light"] .faq-item{border-color:var(--brd)}
html[data-theme="light"] .faq-q{background:var(--bg3)}
html[data-theme="light"] .faq-q:hover{background:var(--bg4)}
html[data-theme="light"] .faq-item.open .faq-q{background:rgba(0,114,214,.05)}
html[data-theme="light"] .faq-a-inner{color:var(--txt2)}

/* ── SKELETON LOADING ── */
.skeleton{background:linear-gradient(90deg,rgba(0,0,0,.04) 0%,rgba(0,0,0,.07) 50%,rgba(0,0,0,.04) 100%);background-size:200% 100%;animation:shimmer 1.5s linear infinite;border-radius:var(--r1)}

/* ── BOTTOM NAV MOBILE ── */
#bottomNav{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:988;
  background:rgba(255,255,255,.98);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-top:1px solid rgba(0,0,0,.08);
  box-shadow:0 -4px 20px rgba(0,0,0,.08);
  padding:6px 0 max(10px,env(safe-area-inset-bottom));gap:0;
}
@media(max-width:640px){#bottomNav{display:flex}}
.bnav-item{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:6px 4px;cursor:pointer;
  transition:color .2s,transform .15s;
  color:var(--txt3);position:relative;
}
.bnav-item.active{color:var(--blue);transform:translateY(-2px)}
.bnav-item:hover{color:var(--blue)}
.bnav-item.active .bnav-ico-wrap{background:rgba(0,114,214,.1);border-radius:12px}
.bnav-ico-wrap{padding:4px 10px 3px;border-radius:12px;transition:background .2s}
.bnav-ico{font-size:21px;line-height:1;display:block}
.bnav-lbl{font-size:9.5px;font-weight:700;letter-spacing:.2px}
.bnav-badge{position:absolute;top:2px;left:50%;margin-left:4px;background:var(--pink);color:#fff;font-size:9px;font-weight:800;min-width:16px;height:16px;border-radius:8px;display:none;align-items:center;justify-content:center;padding:0 3px}
.bnav-badge.show{display:flex}

/* ── (old duplicate mobile/drawer styles removed — see nav section above) ── */

/* ── BLUR TO SHARP ── */
.img-blur{filter:blur(12px);transition:filter .5s ease}
.img-blur.loaded{filter:blur(0)}

/* ── HOTSPOT badge sur cartes ── */
.viewers-badge{position:absolute;bottom:8px;right:8px;background:rgba(0,0,0,.65);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:3px 8px;font-size:10px;font-weight:700;color:rgba(255,255,255,.8);z-index:3}

/* ── PROMO BANDEAU ── */
.promo-bandeau{background:linear-gradient(90deg,#0072d6,#ff8c42,#0072d6,#ff8c42,#0072d6);background-size:300% 100%;animation:gradientShift 4s linear infinite;padding:10px 40px;display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;font-size:13px;font-weight:800;color:#fff;position:relative;overflow:hidden;cursor:pointer}
.promo-bandeau::before{content:'';position:absolute;top:0;left:-30%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);animation:shimmer 3s linear infinite;background-size:200% 100%}
.promo-timer-inline{font-variant-numeric:tabular-nums;background:rgba(0,0,0,.3);padding:2px 8px;border-radius:8px;font-size:12px}
.close-bandeau{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.3);border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;color:#fff;transition:background .2s}
.close-bandeau:hover{background:rgba(0,0,0,.5)}

/* ── Header WA btn ── */
.header-wa-btn{display:flex;align-items:center;gap:5px;background:#25d366;color:#fff;border:none;border-radius:20px;padding:7px 14px;font-size:12px;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap}
.header-wa-btn:hover{background:#1fba59;transform:translateY(-1px);box-shadow:0 4px 12px rgba(37,211,102,.4)}
@media(max-width:480px){.header-wa-btn span.wa-text{display:none}}

/* ── Product Card — définition canonique LIGHT ── */
.prod-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.07);
  border-radius:var(--r3);overflow:hidden;cursor:pointer;
  position:relative;display:flex;flex-direction:column;
  transition:transform .28s cubic-bezier(.4,0,.2,1),box-shadow .28s,border-color .28s;
  box-shadow:0 2px 12px rgba(0,0,0,.06);
}
.prod-card:hover{
  transform:translateY(-6px);
  border-color:rgba(0,114,214,.25);
  box-shadow:0 16px 48px rgba(0,114,214,.14),0 4px 16px rgba(0,0,0,.08);
}
.prod-img{
  aspect-ratio:1/1;width:100%;height:auto;
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  font-size:64px;flex-shrink:0;
}
.prod-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s cubic-bezier(.4,0,.2,1);
  display:block;
}
.prod-card:hover .prod-img img{transform:scale(1.1)}
.prod-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 50%,rgba(0,0,0,.25) 100%);
  pointer-events:none;
}
.prod-info{padding:14px 14px 12px;flex:1;display:flex;flex-direction:column}
.prod-cat{
  font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;
  color:var(--blue);margin-bottom:5px;opacity:.7;
}
.prod-name{
  font-size:13px;font-weight:700;line-height:1.4;margin-bottom:7px;
  color:var(--txt1);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.prod-rating{display:flex;align-items:center;gap:4px;margin-bottom:9px}
.stars{color:#f59e0b;font-size:11px;letter-spacing:.5px}
.rating-count{font-size:11px;color:var(--txt3)}
.prod-price-row{display:flex;align-items:baseline;gap:7px;margin-bottom:10px}
.prod-price{font-size:17px;font-weight:900;color:var(--blue)}
.prod-old{font-size:11px;color:var(--txt3);text-decoration:line-through}
.prod-add{display:flex;gap:7px}
.add-to-cart-btn{
  flex:1;
  background:rgba(0,114,214,.07);
  border:1px solid rgba(0,114,214,.2);
  border-radius:var(--r1);padding:8px 10px;
  font-size:13px;font-weight:700;color:var(--blue);
  display:flex;align-items:center;justify-content:center;gap:5px;
  transition:all .2s;
}
.add-to-cart-btn:hover{
  background:var(--grad1);border-color:transparent;
  color:#fff;box-shadow:0 4px 16px rgba(0,114,214,.35);transform:translateY(-1px);
}
.btn-buynow{
  background:var(--grad1);border:none;border-radius:var(--r1);
  color:#fff;width:38px;height:38px;padding:0;
  display:flex;align-items:center;justify-content:center;font-size:15px;
  flex-shrink:0;transition:all .2s;
}
.btn-buynow:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,114,214,.4)}

/* ── Section Labels LIGHT ── */
.section-label{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:800;letter-spacing:.9px;text-transform:uppercase;
  color:var(--blue);
  background:rgba(0,114,214,.08);border:1px solid rgba(0,114,214,.18);
  border-radius:20px;padding:4px 12px;margin-bottom:8px;
}
.section-h2{font-size:clamp(22px,4vw,32px);font-weight:900;letter-spacing:-.5px;line-height:1.2;color:var(--txt1)}
.s-badge{
  display:inline-block;padding:5px 16px;border-radius:20px;
  font-size:11px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;
  margin-bottom:12px;
}
.grad{
  background:var(--grad1);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.see-all{
  display:inline-flex;align-items:center;gap:4px;
  font-size:13px;font-weight:700;color:var(--blue);
  border:1px solid rgba(0,114,214,.22);padding:7px 16px;
  border-radius:20px;cursor:pointer;transition:all .2s;
}
.see-all:hover{background:rgba(0,114,214,.07);transform:translateX(2px)}

/* ── Why Cards Premium LIGHT ── */
.why-card-v2{
  background:#fff;
  border:1px solid rgba(0,0,0,.07);
  border-radius:var(--r3);padding:28px 24px;
  position:relative;overflow:hidden;transition:all .28s;
  box-shadow:0 2px 12px rgba(0,0,0,.05);
}
.why-card-v2::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--grad1);transform:scaleX(0);transform-origin:left;transition:transform .3s ease;
}
.why-card-v2:hover::before{transform:scaleX(1)}
.why-card-v2:hover{
  transform:translateY(-5px);
  border-color:rgba(0,114,214,.15);
  box-shadow:0 16px 48px rgba(0,114,214,.12);
}
.why-ico-wrap{
  width:56px;height:56px;
  background:linear-gradient(135deg,rgba(0,114,214,.1),rgba(0,168,255,.1));
  border:1px solid rgba(0,114,214,.16);
  border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;
}
.why-card-title-v2{font-size:16px;font-weight:800;margin-bottom:8px;color:var(--txt1)}
.why-card-desc-v2{font-size:13px;color:var(--txt2);line-height:1.7}

/* ── How Cards Premium LIGHT ── */
.how-card-v2{
  background:#fff;
  border:1px solid rgba(0,0,0,.07);
  border-radius:var(--r3);padding:30px 24px;
  text-align:center;position:relative;transition:all .28s;
  box-shadow:0 2px 12px rgba(0,0,0,.05);
}
.how-card-v2:hover{
  transform:translateY(-5px);
  box-shadow:0 14px 44px rgba(0,114,214,.14);
  border-color:rgba(0,114,214,.2);
}
.how-ico-v2{font-size:42px;margin-bottom:14px;display:block}
.how-title-v2{font-size:15px;font-weight:800;margin-bottom:8px;color:var(--txt1)}
.how-desc-v2{font-size:13px;color:var(--txt2);line-height:1.65}
.how-step-num{
  width:32px;height:32px;border-radius:50%;color:#fff;
  font-size:13px;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 14px;
}

/* ── Footer Premium ── */
.footer{
  background:linear-gradient(180deg,#071428 0%,#050d1a 100%);
  border-top:none;padding:52px 16px 28px;
  position:relative;
}
.footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,rgba(0,168,255,.6) 25%,rgba(0,114,214,.6) 50%,rgba(76,201,240,.6) 75%,transparent);
}
.footer-col-title{
  font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;
  color:var(--txt3);margin-bottom:16px;
}
.footer-link{
  font-size:13px;color:rgba(255,255,255,.45);padding:4px 0;
  display:block;cursor:pointer;transition:color .2s,transform .2s;
}
.footer-link:hover{color:var(--cyan);transform:translateX(3px)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.05);
  padding-top:22px;margin-top:32px;
}

/* ── Cart Drawer Premium ── */
.cart-drawer{border-left:1px solid rgba(255,255,255,.05)}
.cart-head{
  background:var(--bg2);border-bottom:1px solid var(--brd);
  padding:16px 20px;display:flex;align-items:center;justify-content:space-between;
}
.cart-head-title{font-size:16px;font-weight:800}
.cart-close{
  width:32px;height:32px;background:var(--bg3);border-radius:50%;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  font-size:13px;transition:background .2s,transform .2s;
}
.cart-close:hover{background:var(--bg4);transform:rotate(90deg)}

/* ── Search Drop Premium ── */
.search-drop{
  border-radius:var(--r2);background:var(--bg2);
  backdrop-filter:blur(16px);
}
.sdrop-item{border-bottom:1px solid rgba(255,255,255,.04);font-size:13px}
.sdrop-item:last-child{border-bottom:none}
.sdrop-price{margin-left:auto;font-weight:800;color:var(--pink);font-size:12px}

/* ── Toasts Premium ── */
.toast{border-radius:var(--r2);backdrop-filter:blur(12px)}
.toast-success{border-left:3px solid var(--green)}
.toast-error{border-left:3px solid var(--pink)}
.toast-info{border-left:3px solid var(--cyan)}

/* ── Page Hero Premium ── */
.page-hero{
  padding:52px 20px 34px;
  background:linear-gradient(135deg,rgba(0,114,214,.07),rgba(0,114,214,.05));
  border-bottom:1px solid var(--brd);position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;top:-60%;left:-10%;
  width:55%;height:250%;
  background:radial-gradient(ellipse,rgba(0,114,214,.07),transparent 70%);
  pointer-events:none;
}
.page-hero h1{font-size:clamp(24px,4vw,38px);font-weight:900;letter-spacing:-.6px;margin-bottom:8px}
.page-hero p{font-size:14px;color:var(--txt2);max-width:480px;margin:0 auto}

/* ── Scroll-top button ── */
.scroll-top-btn{
  position:fixed;bottom:90px;right:20px;
  width:42px;height:42px;background:var(--grad1);
  color:#fff;border-radius:50%;font-size:16px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  z-index:800;opacity:0;pointer-events:none;
  transition:opacity .3s,transform .3s;
  box-shadow:0 4px 16px rgba(0,114,214,.45);
}
.scroll-top-btn.visible{opacity:1;pointer-events:all}
.scroll-top-btn:hover{transform:translateY(-3px) scale(1.06)}

/* ── Mobile Bottom Nav ── */
.bottom-nav{
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-top:1px solid rgba(0,0,0,.08);
}
.bottom-nav-item.active .bnav-ico{
  filter:drop-shadow(0 0 6px var(--pink));
}

/* ── Flash Banner ── */
.flash-banner-v2{
  background:linear-gradient(135deg,rgba(0,168,255,.07),rgba(0,114,214,.1));
  border:1px solid rgba(0,168,255,.2);
  border-radius:var(--r3);padding:20px 24px;
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  margin-bottom:28px;
}
.timer-block-v2{
  background:#fff;
  border:1px solid rgba(0,0,0,.1);
  border-radius:var(--r1);padding:8px 12px;text-align:center;min-width:52px;
  box-shadow:0 2px 8px rgba(0,0,0,.06);
}
.timer-num-v2{
  font-size:22px;font-weight:900;font-variant-numeric:tabular-nums;line-height:1;
  color:var(--blue);
}
.timer-lbl-v2{font-size:9px;color:var(--txt3);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.timer-sep{font-size:20px;font-weight:900;color:var(--pink);opacity:.6}

/* ── Page breadcrumb ── */
.page-breadcrumb{
  font-size:12px;color:var(--txt3);margin-bottom:20px;
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
}
.page-breadcrumb span:not(:last-child){cursor:pointer;transition:color .2s}
.page-breadcrumb span:not(:last-child):hover{color:var(--cyan)}

/* ── (light mode adjustments supprimés — light est maintenant le défaut) ── */

/* ══ THEME TOGGLE ══ */
.theme-toggle{
  width:36px;height:36px;border-radius:var(--r1);
  background:var(--bg3);border:1px solid var(--brd2);
  display:flex;align-items:center;justify-content:center;
  font-size:17px;cursor:pointer;transition:all var(--tr);
  flex-shrink:0;user-select:none
}
.theme-toggle:hover{background:var(--bg4);transform:scale(1.08)}

/* Classe temporaire pour les transitions fluides */
html.theme-transitioning,
html.theme-transitioning *{
  transition:background-color .28s ease,color .22s ease,border-color .25s ease,
             box-shadow .25s ease !important;
}
/* Sauf les animations qui doivent rester rapides */
html.theme-transitioning *[style*="animation"],
html.theme-transitioning canvas{transition:none !important}

/* ══ MODE SOMBRE (dark toggle) ══ */
html[data-theme="dark"]{
  --bg0:#110830;--bg1:#191040;--bg2:#221854;--bg3:#2c2068;--bg4:#36287c;
  --txt1:#ffffff;--txt2:#d4cbf8;--txt3:#9480cc;
  --brd:rgba(255,255,255,0.12);--brd2:rgba(255,255,255,0.20);
  --sh1:0 4px 24px rgba(0,0,0,0.4);--sh2:0 8px 40px rgba(0,168,255,0.4);
}
html[data-theme="dark"] body{
  background-image:radial-gradient(ellipse at 20% 0%,rgba(0,114,214,.18) 0%,transparent 50%),
    radial-gradient(ellipse at 80% 100%,rgba(0,114,214,.15) 0%,transparent 50%);
  background-attachment:fixed;
}
/* Header dark */
html[data-theme="dark"] .header{background:rgba(17,8,48,.94);border-bottom:1px solid rgba(255,255,255,.10);box-shadow:0 6px 40px rgba(0,0,0,.5)}
html[data-theme="dark"] .header::after{background:linear-gradient(90deg,transparent,rgba(0,168,255,.6) 25%,rgba(0,114,214,.6) 50%,rgba(76,201,240,.6) 75%,transparent)}
html[data-theme="dark"] .header-search input{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.08);color:#fff}
html[data-theme="dark"] .header-search input::placeholder{color:rgba(255,255,255,.35)}
html[data-theme="dark"] .header-search input:focus{background:rgba(255,255,255,.09);border-color:rgba(0,168,255,.55)}
html[data-theme="dark"] .hbtn{color:rgba(255,255,255,.7)}
html[data-theme="dark"] .hbtn:hover{background:var(--bg3);color:#fff}
/* Nav dark */
html[data-theme="dark"] .header{background:rgba(17,8,48,.97);border-bottom:1px solid rgba(255,255,255,.08)}
html[data-theme="dark"] .header-search input{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1);color:#fff}
html[data-theme="dark"] .header-search input:focus{background:rgba(255,255,255,.1);border-color:var(--purple)}
html[data-theme="dark"] .hbtn{color:rgba(255,255,255,.7)}
html[data-theme="dark"] .hbtn:hover{background:rgba(255,255,255,.08);color:#fff}
html[data-theme="dark"] .theme-toggle{background:rgba(255,255,255,.06)}
html[data-theme="dark"] .nav-bar{background:rgba(17,8,48,.98);border-bottom:1px solid rgba(255,255,255,.08)}
html[data-theme="dark"] .nav-item{color:rgba(255,255,255,.6)}
html[data-theme="dark"] .nav-item:hover{color:#fff;background:rgba(255,255,255,.08)}
html[data-theme="dark"] .nav-item.active{color:var(--cyan);background:rgba(76,201,240,.08);border-bottom-color:var(--cyan)}
html[data-theme="dark"] .cat-pill{color:rgba(255,255,255,.55)}
html[data-theme="dark"] .cat-pill:hover{background:rgba(255,255,255,.08);color:#fff;border-color:transparent}
html[data-theme="dark"] .cat-pill.active{background:var(--grad1);color:#fff}
html[data-theme="dark"] .bottom-nav{background:rgba(17,8,48,.97);border-top:1px solid rgba(255,255,255,.08)}
html[data-theme="dark"] #bottomNav{background:rgba(7,7,26,.97);border-top-color:rgba(255,255,255,.07)}
html[data-theme="dark"] .bnav-item{color:rgba(255,255,255,.4)}
html[data-theme="dark"] .bnav-item.active,.bnav-item:hover{color:var(--cyan)}
html[data-theme="dark"] #mobileDrawer{background:linear-gradient(180deg,#071428,#050d1a);border-right:1px solid rgba(255,255,255,.08)}
html[data-theme="dark"] .drawer-nav-item{color:rgba(255,255,255,.75)}
html[data-theme="dark"] .drawer-nav-item:hover{background:rgba(255,255,255,.05);color:#fff}
html[data-theme="dark"] .drawer-nav-item.active{color:var(--cyan);background:rgba(76,201,240,.05)}
html[data-theme="dark"] .cat-pill{color:rgba(255,255,255,.55);background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.1)}
html[data-theme="dark"] .cat-pill:hover{color:#fff;background:rgba(255,255,255,.09)}
html[data-theme="dark"] .cat-pill.active{background:var(--grad2);box-shadow:0 3px 12px rgba(0,168,255,.3)}
/* Hero dark */
/* Hero is always dark — dark mode keeps the same look */
html[data-theme="dark"] .hero{background:var(--hero-bg)}
html[data-theme="dark"] .hero-wa-btn{background:#25d366}
@media(max-width:900px){.hero-service-cards{display:none}}
/* Trust bar dark */
html[data-theme="dark"] .trust-bar{background:linear-gradient(90deg,rgba(5,13,26,.95) 0%,rgba(5,13,26,.6) 50%,rgba(5,13,26,.95) 100%);border-color:rgba(255,255,255,.06)}
html[data-theme="dark"] .trust-item{color:rgba(255,255,255,.75)}
html[data-theme="dark"] .trust-item:hover{color:#fff}
/* Skeleton dark */
html[data-theme="dark"] .skeleton{background:linear-gradient(90deg,rgba(255,255,255,.04) 0%,rgba(255,255,255,.08) 50%,rgba(255,255,255,.04) 100%);background-size:200% 100%}
/* Bottom nav / mobile CTA dark */
html[data-theme="dark"] .mobile-cta-bar{background:rgba(7,7,26,.96);border-top-color:rgba(255,255,255,.08)}
html[data-theme="dark"] .fav-btn{background:rgba(0,0,0,.55);border-color:transparent}
/* Product cards dark */
html[data-theme="dark"] .prod-card{background:linear-gradient(170deg,#2a1a60 0%,#1e1248 100%);border-color:rgba(255,255,255,.14);box-shadow:0 4px 20px rgba(0,0,0,.3)}
html[data-theme="dark"] .prod-card:hover{border-color:rgba(0,168,255,.5);box-shadow:0 24px 64px rgba(0,114,214,.4),0 4px 20px rgba(0,0,0,.4)}
html[data-theme="dark"] .prod-img::after{background:linear-gradient(to bottom,transparent 45%,rgba(0,0,0,.65) 100%)}
html[data-theme="dark"] .prod-cat{color:var(--txt3);opacity:1}
html[data-theme="dark"] .prod-price{color:var(--cyan)}
html[data-theme="dark"] .add-to-cart-btn{background:linear-gradient(135deg,rgba(0,114,214,.15),rgba(0,114,214,.15));border-color:rgba(0,114,214,.28);color:#fff}
html[data-theme="dark"] .add-to-cart-btn:hover{background:var(--grad1);box-shadow:0 4px 16px rgba(0,114,214,.4)}
html[data-theme="dark"] .btn-buynow{background:var(--grad2)}
html[data-theme="dark"] .btn-buynow:hover{box-shadow:0 4px 16px rgba(0,168,255,.5)}
/* Why/How cards dark */
html[data-theme="dark"] .why-card-v2{background:linear-gradient(145deg,#271960,#1c1248);border-color:rgba(255,255,255,.13);box-shadow:none}
html[data-theme="dark"] .why-card-v2:hover{border-color:rgba(0,168,255,.2);box-shadow:0 16px 48px rgba(0,114,214,.2)}
html[data-theme="dark"] .why-card-v2::before{background:var(--grad2)}
html[data-theme="dark"] .why-ico-wrap{background:linear-gradient(135deg,rgba(0,168,255,.1),rgba(0,114,214,.1));border-color:rgba(0,168,255,.18)}
html[data-theme="dark"] .how-card-v2{background:linear-gradient(145deg,#221760,#181048);border-color:rgba(255,255,255,.13);box-shadow:none}
html[data-theme="dark"] .how-card-v2:hover{box-shadow:0 14px 44px rgba(0,114,214,.22);border-color:rgba(0,114,214,.3)}
/* Section labels dark */
html[data-theme="dark"] .section-label{color:var(--pink);background:rgba(0,168,255,.08);border-color:rgba(0,168,255,.18)}
html[data-theme="dark"] .section-h2{color:#fff}
html[data-theme="dark"] .grad{background:var(--grad2);-webkit-background-clip:text;background-clip:text}
html[data-theme="dark"] .see-all{color:var(--cyan);border-color:rgba(76,201,240,.22)}
html[data-theme="dark"] .see-all:hover{background:rgba(76,201,240,.1)}
html[data-theme="dark"] .section-title{color:#fff}
html[data-theme="dark"] .section-title::before{background:var(--grad2)}
/* Flash banner dark */
html[data-theme="dark"] .flash-banner{background:linear-gradient(135deg,rgba(0,114,214,.12),rgba(0,168,255,.08));border-color:rgba(0,168,255,.25)}
/* Inputs/forms dark */
html[data-theme="dark"] input:not([type="range"]),html[data-theme="dark"] select,html[data-theme="dark"] textarea{background:var(--bg3);color:#fff;border-color:var(--brd2)}
html[data-theme="dark"] input::placeholder{color:var(--txt3)}
html[data-theme="dark"] .search-drop{background:var(--bg3);border-color:var(--brd2)}
/* Buttons dark */
html[data-theme="dark"] .btn-ghost{background:rgba(255,255,255,.06);color:#fff}
html[data-theme="dark"] .btn-ghost:hover{background:rgba(255,255,255,.10)}
html[data-theme="dark"] .btn-outline{border-color:var(--brd2);color:#fff}
html[data-theme="dark"] .btn-outline:hover{border-color:var(--purple);background:rgba(0,114,214,.1)}
/* Drawer dark */
html[data-theme="dark"] #mobileDrawer{background:linear-gradient(180deg,var(--bg1),var(--bg0));border-right:1px solid var(--brd)}
html[data-theme="dark"] .drawer-nav-item{color:rgba(255,255,255,.75)}
html[data-theme="dark"] .drawer-nav-item:hover{background:rgba(255,255,255,.05);color:#fff}
html[data-theme="dark"] .drawer-nav-item.active{color:var(--cyan);background:rgba(76,201,240,.05)}
/* Cart dark */
html[data-theme="dark"] .cart-drawer{background:var(--bg1);border-left-color:var(--brd)}
html[data-theme="dark"] .cart-head{background:var(--bg2);border-bottom:1px solid var(--brd)}
html[data-theme="dark"] .cart-foot{background:var(--bg2);border-top:1px solid var(--brd)}
/* Misc dark */
html[data-theme="dark"] ::-webkit-scrollbar-track{background:var(--bg1)}
html[data-theme="dark"] .order-track-card{background:var(--bg2);border-color:var(--brd2)}
html[data-theme="dark"] .tracking-step.pending .tracking-step-ico{background:var(--bg3)}
html[data-theme="dark"] #notifPrompt{background:var(--bg2);border-color:rgba(0,114,214,.2)}
html[data-theme="dark"] #splashScreen{background:var(--bg0)}
html[data-theme="dark"] .page-hero{background:linear-gradient(135deg,rgba(0,114,214,.1),rgba(0,114,214,.1)) !important}
html[data-theme="dark"] .sub-card,html[data-theme="dark"] .ref-card{background:var(--bg2)}
html[data-theme="dark"] .faq-item{border-color:var(--brd)}
html[data-theme="dark"] .faq-q{background:var(--bg3)}
html[data-theme="dark"] .faq-q:hover{background:var(--bg4)}
html[data-theme="dark"] .faq-item.open .faq-q{background:rgba(0,114,214,.08)}
html[data-theme="dark"] #wheelModal > div:first-child{background:rgba(17,8,48,.97) !important}
html[data-theme="dark"] .section-alt{background:linear-gradient(180deg,rgba(5,13,26,.08) 0%,var(--bg0) 100%)}
html[data-theme="dark"] .section-dark{background:linear-gradient(145deg,#050d1a,#071428)}
html[data-theme="dark"] .trust-item-v2{color:rgba(255,255,255,.65)}
html[data-theme="dark"] .trust-item-v2:hover{color:#fff}
html[data-theme="dark"] .timer-num-v2{color:#fff}
html[data-theme="dark"] .timer-lbl-v2{color:rgba(255,255,255,.4)}
html[data-theme="dark"] .why-card-title{color:#fff}
html[data-theme="dark"] .why-card-desc{color:rgba(255,255,255,.5)}
html[data-theme="dark"] .prod-old{color:rgba(255,255,255,.3)}
html[data-theme="dark"] .prod-name{color:rgba(255,255,255,.9)}
html[data-theme="dark"] .testi-card-v2{background:linear-gradient(145deg,#131330,#1b1b3e);border-color:rgba(255,255,255,.07);box-shadow:none}
html[data-theme="dark"] .testi-card-v2:hover{border-color:rgba(0,114,214,.35);box-shadow:0 16px 40px rgba(0,114,214,.18)}
html[data-theme="dark"] .testi-quote-v2{color:rgba(0,114,214,.15)}
html[data-theme="dark"] .testi-dot{background:rgba(255,255,255,.15)}
html[data-theme="dark"] .testi-dot.active{background:var(--purple)}
html[data-theme="dark"] .flash-banner-v2{background:linear-gradient(135deg,rgba(0,168,255,.08),rgba(0,114,214,.1))}
html[data-theme="dark"] .timer-block-v2{background:var(--bg3);border-color:var(--brd2)}
/* Flash deal cards v2 dark */
html[data-theme="dark"] .prod-card-v2{background:linear-gradient(145deg,#131330,#1a1a3d);border-color:rgba(255,255,255,.06);box-shadow:0 4px 20px rgba(0,0,0,.3)}
html[data-theme="dark"] .prod-card-v2:hover{border-color:rgba(0,114,214,.55);box-shadow:0 28px 60px rgba(0,0,0,.55),0 0 0 1px rgba(0,114,214,.25)}
html[data-theme="dark"] .prod-price-v2{background:linear-gradient(135deg,#fff 0%,#d8c5ff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
html[data-theme="dark"] .prod-old-v2{color:rgba(255,255,255,.28)}
html[data-theme="dark"] .add-btn-v2{background:linear-gradient(135deg,rgba(0,114,214,.15),rgba(0,114,214,.1));border-color:rgba(0,114,214,.3);color:#fff}
html[data-theme="dark"] .add-btn-v2:hover{background:var(--grad1);box-shadow:0 6px 20px rgba(0,114,214,.55)}
html[data-theme="dark"] .deal-progress{background:rgba(255,255,255,.08)}
html[data-theme="dark"] .prod-img-v2{background:linear-gradient(145deg,#0e0e28,#161638) !important}
html[data-theme="dark"] .prod-card-v2 .prod-name{color:rgba(255,255,255,.9) !important}
html[data-theme="dark"] .prod-card-v2 [style*="color:#9ca3af"]{color:rgba(255,255,255,.35) !important}
html[data-theme="dark"] .page-breadcrumb span:not(:last-child):hover{color:var(--cyan)}
html[data-theme="dark"] .cat-card{background:var(--bg2);border-color:var(--brd)}
html[data-theme="dark"] .cat-card:hover{border-color:var(--purple);background:var(--bg3)}
html[data-theme="dark"] .cat-name{color:rgba(255,255,255,.8)}

/* ══ ONBOARDING FIRST VISIT ══ */
#onboardingModal{
  position:fixed;inset:0;z-index:9996;
  background:rgba(7,7,26,.85);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  display:flex;align-items:center;justify-content:center;padding:16px;
  opacity:0;pointer-events:none;transition:opacity .4s ease;
}
#onboardingModal.show{opacity:1;pointer-events:all}
.onboard-card{
  background:var(--bg1);border:1px solid var(--brd2);
  border-radius:var(--r4);overflow:hidden;
  width:100%;max-width:400px;position:relative;
  box-shadow:0 24px 80px rgba(0,114,214,.35),0 4px 24px rgba(0,0,0,.5);
}
.onboard-slides{display:flex;transition:transform .42s cubic-bezier(.4,0,.2,1);will-change:transform}
.onboard-slide{
  min-width:100%;padding:36px 28px 20px;
  display:flex;flex-direction:column;align-items:center;text-align:center;
}
.onboard-emoji{font-size:54px;margin-bottom:14px;display:block;
  animation:float 3s ease-in-out infinite}
.onboard-title{font-size:22px;font-weight:900;margin-bottom:8px;
  background:var(--grad2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.onboard-sub{font-size:13px;color:var(--txt2);line-height:1.65;margin-bottom:18px}
.onboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%;margin-bottom:18px}
.onboard-feat-card{
  background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r2);
  padding:12px 8px;display:flex;flex-direction:column;align-items:center;gap:5px
}
.onboard-feat-ico{font-size:26px}
.onboard-feat-name{font-size:11px;font-weight:700;color:var(--txt1)}
.onboard-feat-desc{font-size:10px;color:var(--txt3)}
.onboard-how{display:flex;flex-direction:column;gap:8px;width:100%;margin-bottom:18px}
.onboard-how-step{
  display:flex;align-items:center;gap:12px;
  background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r2);
  padding:12px 14px;text-align:left;
}
.onboard-how-num{
  width:30px;height:30px;border-radius:50%;
  background:var(--grad1);color:#fff;font-size:13px;font-weight:800;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.onboard-how-text{flex:1}
.onboard-how-title{font-size:13px;font-weight:700;margin-bottom:1px}
.onboard-how-sub{font-size:11px;color:var(--txt2)}
.onboard-promo-wrap{
  background:linear-gradient(135deg,rgba(0,168,255,.08),rgba(0,114,214,.1));
  border:2px dashed rgba(0,168,255,.5);border-radius:var(--r3);
  padding:18px 20px;width:100%;margin-bottom:14px;
  cursor:pointer;transition:all .2s;
}
.onboard-promo-wrap:hover{border-color:var(--pink);background:linear-gradient(135deg,rgba(0,168,255,.14),rgba(0,114,214,.16))}
.onboard-promo-code{font-size:30px;font-weight:900;font-family:monospace;
  color:var(--pink);letter-spacing:3px;margin-bottom:4px}
.onboard-promo-pct{font-size:14px;font-weight:700;color:var(--txt1);margin-bottom:2px}
.onboard-promo-hint{font-size:11px;color:var(--txt3)}
.onboard-footer{
  padding:14px 28px 22px;display:flex;flex-direction:column;align-items:center;gap:10px;
  border-top:1px solid var(--brd);
}
.onboard-dots{display:flex;gap:7px;margin-bottom:2px}
.onboard-dot{width:7px;height:7px;border-radius:4px;background:var(--bg4);transition:all .35s}
.onboard-dot.active{width:22px;background:var(--pink)}
.onboard-actions{display:flex;gap:10px;width:100%}
.onboard-next-btn{
  flex:1;background:var(--grad2);color:#fff;border:none;border-radius:var(--r2);
  padding:12px 20px;font-size:14px;font-weight:700;cursor:pointer;
  transition:opacity .2s,transform .2s;
}
.onboard-next-btn:hover{opacity:.9;transform:translateY(-1px)}
.onboard-skip-btn{
  background:rgba(255,255,255,.06);color:var(--txt2);border:none;border-radius:var(--r2);
  padding:12px 14px;font-size:13px;cursor:pointer;transition:background .2s;white-space:nowrap;
}
.onboard-skip-btn:hover{background:rgba(255,255,255,.1);color:var(--txt1)}
/* Copié flash */
.onboard-promo-wrap.copied{border-color:var(--green);background:rgba(6,214,160,.08)}
/* Light mode */
html[data-theme="light"] #onboardingModal{background:rgba(220,220,238,.85)}
html[data-theme="light"] .onboard-card{background:var(--bg2)}
html[data-theme="light"] .onboard-feat-card{background:var(--bg3)}
html[data-theme="light"] .onboard-how-step{background:var(--bg3)}
html[data-theme="light"] .onboard-skip-btn{background:rgba(0,0,0,.05);color:var(--txt2)}

/* ── PUSH NOTIFICATION PROMPT ── */
#notifPrompt{
  position:fixed;bottom:24px;right:20px;z-index:9990;
  background:var(--bg1);border:1px solid rgba(76,201,240,.25);
  border-radius:var(--r3);padding:18px 20px;max-width:300px;width:calc(100% - 40px);
  box-shadow:0 8px 40px rgba(76,201,240,.15),0 2px 12px rgba(0,0,0,.5);
  transform:translateX(calc(100% + 40px));
  transition:transform .45s cubic-bezier(.175,.885,.32,1.275);
  pointer-events:none;
}
#notifPrompt.show{transform:translateX(0);pointer-events:all}
.notif-prompt-ico{font-size:32px;margin-bottom:8px;display:block;
  animation:float 2.5s ease-in-out infinite}
.notif-prompt-title{font-size:14px;font-weight:800;margin-bottom:4px;color:var(--txt1)}
.notif-prompt-sub{font-size:12px;color:var(--txt2);line-height:1.5;margin-bottom:14px}
.notif-prompt-actions{display:flex;gap:8px}
.notif-prompt-accept{flex:1;background:linear-gradient(135deg,#4cc9f0,#0072d6);
  color:#fff;border:none;border-radius:var(--r1);padding:8px 12px;
  font-size:13px;font-weight:700;cursor:pointer;transition:opacity .2s}
.notif-prompt-accept:hover{opacity:.85}
.notif-prompt-later{background:rgba(255,255,255,.06);color:var(--txt2);
  border:none;border-radius:var(--r1);padding:8px 10px;
  font-size:12px;cursor:pointer;transition:background .2s}
.notif-prompt-later:hover{background:rgba(255,255,255,.1)}
.notif-status-badge{display:inline-flex;align-items:center;gap:6px;
  background:rgba(6,214,160,.12);border:1px solid rgba(6,214,160,.25);
  border-radius:20px;padding:4px 10px;font-size:11px;font-weight:700;color:var(--green)}

/* ═══════════════════════════════════════════════════════════
   PREMIUM POLISH — Micro-interactions & Visual Consistency
═══════════════════════════════════════════════════════════ */

/* ── Text selection ── */
::selection{background:rgba(0,168,255,.18);color:var(--txt1)}

/* ── Thin brand scrollbar ── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(0,168,255,.25);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--blue)}

/* ── Accessible focus ring ── */
:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:4px}
button:focus:not(:focus-visible),a:focus:not(:focus-visible){outline:none}

/* ── Universal button press feedback ── */
.btn:active,.hero-cta-btn:active,.hero-wa-btn:active,
.add-to-cart-btn:active,.btn-buynow:active,.cat-pill:active,
.hbtn:active,.theme-toggle:active{
  transform:translateY(0) scale(.97);
  transition-duration:.06s!important;
}

/* ── btn-primary: shadow over opacity ── */
.btn-primary{box-shadow:0 2px 10px rgba(0,114,214,.18)}
.btn-primary:hover{opacity:1;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,114,214,.32)}

/* ── btn-ghost: visible on white background ── */
.btn-ghost{background:var(--bg1);color:var(--txt2);border:1px solid var(--brd)}
.btn-ghost:hover{background:var(--bg3);color:var(--txt1);border-color:var(--brd2)}

/* ── btn-outline refined ── */
.btn-outline:hover{color:var(--blue);background:rgba(0,114,214,.06);border-color:var(--blue)}

/* ── GPU acceleration for animated cards ── */
.prod-card,.why-card-v2,.how-card-v2,.testi-card-v2,.cat-img-card-v2{will-change:transform}

/* ── Product card image smooth zoom ── */
.prod-img img{transition:transform .4s cubic-bezier(.4,0,.2,1)}
.prod-card:hover .prod-img img{transform:scale(1.07)}
.prod-fav:hover{transform:scale(1.2);background:rgba(255,60,60,.18)!important}

/* ── Cat pills press + smooth lift ── */
.cat-pill{transition:background .18s,border-color .18s,color .18s,transform .2s,box-shadow .2s}
.cat-pill:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.09)}
.cat-pill.active{box-shadow:0 4px 16px rgba(0,114,214,.28)}

/* ── Search input focus glow ── */
.header-search input{transition:border-color .2s,box-shadow .2s,background .2s}

/* ── Nav item pill hover ── */
.nav-item{border-radius:6px;transition:background .18s,color .18s}

/* ── Prices: gradient text for visual weight ── */
.prod-price,.prod-price-v2{
  background:var(--grad1);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  font-weight:900;letter-spacing:-.3px
}

/* ── Section headings consistent scale ── */
.section-h2{font-weight:900;letter-spacing:-.5px;line-height:1.2;color:var(--txt1)}

/* ── Footer link hover ── */
.footer-link{transition:color .18s,transform .18s;display:inline-block}
.footer-link:hover{transform:translateX(3px)}

/* ── Scroll-to-top button ── */
.scroll-top-btn{background:var(--bg2);border:1px solid var(--brd);color:var(--txt2);
  transition:background .2s,transform .22s,box-shadow .2s,border-color .2s}
.scroll-top-btn:hover,.scroll-top-btn.show:hover{
  background:var(--blue);border-color:transparent;color:#fff;
  transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,168,255,.38)
}

/* ── Page transition on navigate ── */
#app{animation:appFadeIn .2s ease}
@keyframes appFadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}

/* ── Notification prompt fix on light bg ── */
.notif-prompt-later{background:var(--bg2);color:var(--txt2);border:1px solid var(--brd)!important}
.notif-prompt-later:hover{background:var(--bg3)!important}

/* ── Deal progress bar brand colors ── */
.deal-progress{background:var(--bg3)}
.deal-progress-fill{background:linear-gradient(90deg,var(--pink),#e06000)}

/* ── Why/How icon animation on hover ── */
.why-ico-wrap,.how-ico-wrap{transition:transform .28s cubic-bezier(.34,1.56,.64,1)}
.why-card-v2:hover .why-ico-wrap,.how-card-v2:hover .how-ico-wrap{transform:scale(1.15) rotate(4deg)}

/* ── Testimonial card quote style ── */
.testi-quote{line-height:1.75;font-style:italic}

/* ── Flash timer tabular nums ── */
[id*="Timer"],[id*="timer"],.promo-timer-inline{font-variant-numeric:tabular-nums}

/* ── Mobile elements base font ── */
input,textarea,select,button{font-family:inherit}

/* ── Image rendering ── */
img{display:block;max-width:100%}