*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --black:#0D0D0D;--dark:#111;--gray-900:#1A1A1A;--gray-800:#222;--gray-700:#333;
  --gray-600:#555;--gray-500:#777;--gray-400:#999;--gray-300:#BBB;--gray-200:#DDD;
  --gray-100:#F0F0F0;--gray-50:#F7F7F9;--white:#FFF;--bg:#FAFAFA;
  --orange:#FF6B00;--orange-h:#FF8533;--orange-d:#E55E00;
  --green:#22C55E;--red:#EF4444;--amber:#F59E0B;
  --r:6px;--r-lg:10px;--max:1360px;
  --t:all .2s ease;
}
html{scroll-behavior:smooth;overflow-x:hidden;overflow-x:clip}
body{font-family:'DM Sans',system-ui,sans-serif;background:var(--bg);color:var(--gray-700);line-height:1.6;-webkit-font-smoothing:antialiased;padding-top:120px;overflow-x:hidden;overflow-x:clip;width:100%;max-width:100vw}
h1,h2,h3,h4,p,span,div,li,a{overflow-wrap:break-word;word-wrap:break-word}
h1,h2,h3,h4,.section-title,.tab-btn,.btn-add,.product-title,.price-amount,.brand-name,.brand-series,.p-price,.gallery-badge,.footer h4,.nav-link,.nav-list-title{font-family:'Rajdhani',sans-serif}
a{color:inherit;text-decoration:none;transition:var(--t)}
img{max-width:100%;display:block}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}
.container{max-width:var(--max);margin:0 auto;padding:0 24px}

/* ═══ HEADER ═══ */
.header-wrap{position:fixed;top:0;left:0;right:0;z-index:1000;transition:transform .3s ease,box-shadow .3s ease;will-change:transform;box-shadow:0 2px 14px rgba(0,0,0,.35)}
.header-wrap.hidden{transform:translateY(-100%)}
.header{background:linear-gradient(180deg,#141418 0%,var(--dark) 100%);padding:0;border-bottom:1px solid rgba(255,255,255,.04)}
.header-inner{display:flex;align-items:center;height:74px;gap:28px}
.logo{flex-shrink:0;display:flex;align-items:center;transition:transform .25s ease}
.logo:hover{transform:scale(1.03)}
.logo img{height:52px;width:auto;display:block}
.search-bar{flex:1;max-width:620px;position:relative;display:flex}
.search-bar input{width:100%;height:46px;background:#0f0f12;border:1px solid rgba(255,255,255,.08);border-radius:999px;padding:0 56px 0 22px;color:var(--white);font-size:14px;outline:none;transition:var(--t);font-family:inherit}
.search-bar input:focus{border-color:var(--orange);background:#0a0a0c;box-shadow:0 0 0 3px rgba(255,107,0,.18)}
.search-bar input::placeholder{color:var(--gray-600)}
.search-btn{position:absolute;right:4px;top:4px;width:38px;height:38px;background:var(--orange);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--t);cursor:pointer;box-shadow:0 4px 12px -2px rgba(255,107,0,.5)}
.search-btn:hover{background:var(--orange-h);transform:scale(1.05)}
.search-btn svg{width:18px;height:18px;color:var(--white)}
.header-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}
.h-action{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:9px 14px;min-width:64px;border-radius:10px;color:var(--gray-300);transition:var(--t);position:relative;text-decoration:none}
.h-action:hover{background:rgba(255,255,255,.06);color:var(--white);transform:translateY(-1px)}
.h-action svg{width:22px;height:22px;margin-bottom:4px;stroke-width:1.8}
.h-action span{font-size:11px;font-weight:600;letter-spacing:.3px}
.h-action.cart{background:linear-gradient(180deg,var(--orange) 0%,var(--orange-h) 100%);color:var(--white);padding:9px 18px;box-shadow:0 6px 18px -6px rgba(255,107,0,.65);margin-left:4px}
.h-action.cart:hover{background:linear-gradient(180deg,var(--orange-h) 0%,#c74e00 100%);color:var(--white);transform:translateY(-1px)}
.cart-count{position:absolute;top:3px;right:8px;background:var(--white);color:var(--orange);font-size:10px;font-weight:800;min-width:18px;height:18px;padding:0 4px;border-radius:999px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px rgba(0,0,0,.3)}
.header-phone{display:flex;align-items:center;gap:10px;color:var(--gray-200);font-size:13px;font-weight:600;flex-shrink:0;padding:8px 14px 8px 18px;margin-left:8px;border-left:1px solid rgba(255,255,255,.08);text-decoration:none;transition:var(--t);border-radius:8px}
.header-phone svg{color:var(--orange);flex-shrink:0;transition:transform .3s ease}
.header-phone:hover{color:var(--orange);background:rgba(255,107,0,.06)}
.header-phone:hover svg{transform:rotate(-12deg) scale(1.1)}
.header-phone-txt{display:flex;flex-direction:column;line-height:1.2}
.header-phone-txt small{font-size:10px;font-weight:500;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px}
.header-phone-txt strong{font-size:14px;font-weight:700;color:inherit;letter-spacing:.3px}

/* ═══ NAV ═══ */
.nav{background:var(--dark);border-top:1px solid rgba(255,255,255,.06);border-bottom:3px solid var(--orange)}
.nav-list{display:flex;align-items:center;height:46px}
.nav-item{position:relative}
.nav-link{display:flex;align-items:center;gap:5px;padding:0 18px;height:46px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--gray-200);transition:var(--t);white-space:nowrap}
.nav-link:hover,.nav-item:hover .nav-link{color:var(--orange);background:rgba(255,107,0,.06)}
.nav-link svg{width:12px;height:12px;opacity:.5}
.nav-link.hl{color:var(--orange)}
.mega-dd{position:absolute;top:100%;left:0;background:var(--white);border-top:3px solid var(--orange);border-radius:0 0 var(--r-lg) var(--r-lg);box-shadow:0 12px 40px rgba(0,0,0,.15);padding:22px 24px;display:none;z-index:998;white-space:nowrap}
.nav-item:hover>.mega-dd{display:flex;flex-direction:row}
.mega-col{min-width:0;padding:0 20px 0 0;white-space:normal}
.mega-col:last-child{padding-right:0}
.mega-col-title{display:block;font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--black);margin-bottom:8px;padding-bottom:6px;border-bottom:2px solid var(--orange);text-decoration:none;transition:color .2s;white-space:nowrap}
a.mega-col-title:hover{color:var(--orange)}
.mega-col a{display:flex;align-items:center;gap:8px;padding:5px 0 5px 8px;font-size:13px;color:var(--gray-600);transition:all .15s ease;border-left:2px solid transparent;white-space:nowrap}
.mega-col a:hover{color:var(--orange);border-left-color:var(--orange)}
.mi{width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:0;background:transparent}
.mi img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}
.mob-overlay{display:none}
.nav-list-header{display:none}
.hamburger{display:none;width:40px;height:40px;align-items:center;justify-content:center;color:var(--white);font-size:24px;background:none;border:none;cursor:pointer}

/* ═══ BREADCRUMB — UHNW minimal ═══ */
.breadcrumb{background:var(--white);padding:28px 0 24px;font-size:11px;color:var(--gray-400);text-transform:uppercase;letter-spacing:1.4px;font-weight:500}
.breadcrumb .container{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.breadcrumb a{color:var(--gray-500);transition:var(--t);white-space:nowrap}
.breadcrumb a:hover{color:var(--orange)}
.breadcrumb .sep{color:var(--gray-300);font-weight:300;font-size:10px}
.breadcrumb strong{color:var(--black);font-weight:600;letter-spacing:.8px;max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ═══ PRODUCT PAGE ═══ */
.product-page{padding:40px 0 80px;background:var(--bg)}
.product-layout{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:56px;align-items:start}

/* ─── GALLERY — vertical thumbs + large main ─── */
.gallery{position:sticky;top:140px;display:grid;grid-template-columns:96px 1fr;gap:16px;align-items:start;align-self:start}
.gallery-thumbs{display:flex;flex-direction:column;gap:10px;max-height:640px;overflow-y:auto;padding:2px 4px 2px 2px;scrollbar-width:thin;scrollbar-color:var(--gray-300) transparent}
.gallery-thumbs::-webkit-scrollbar{width:4px}
.gallery-thumbs::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:2px}
.gallery-thumbs::-webkit-scrollbar-track{background:transparent}
.gallery-thumb{width:92px;height:92px;background:linear-gradient(160deg,#f5f5f7 0%,#e7e7ed 100%);border:2px solid transparent;border-radius:var(--r);cursor:pointer;transition:var(--t);overflow:hidden;padding:5px;flex-shrink:0;position:relative}
.gallery-thumb::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 30%,rgba(255,255,255,.5) 0%,transparent 60%);pointer-events:none}
.gallery-thumb img{position:relative;width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}
.gallery-thumb:hover{border-color:var(--gray-300);transform:translateX(2px)}
.gallery-thumb.active{border-color:var(--orange);box-shadow:0 6px 16px -4px rgba(255,107,0,.35)}
.gallery-main{width:100%;aspect-ratio:1/1;background:linear-gradient(160deg,#f5f5f7 0%,#e7e7ed 100%);border-radius:var(--r-lg);overflow:hidden;position:relative;border:1px solid var(--gray-200);display:flex;align-items:center;justify-content:center;padding:40px;box-sizing:border-box;touch-action:pan-y;cursor:grab;user-select:none;-webkit-user-select:none}
.gallery-main:active{cursor:grabbing}
.gallery-main.swiping img{transition:transform .35s cubic-bezier(.2,.7,.2,1),opacity .35s ease}
.gallery-main::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 30%,rgba(255,255,255,.6) 0%,transparent 60%);pointer-events:none;z-index:1}
.gallery-main img{position:relative;z-index:2;display:block;width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain;mix-blend-mode:multiply;transition:opacity .2s ease}
.gallery-badge{position:absolute;top:26px;left:26px;z-index:3;display:inline-flex;align-items:center;gap:12px;font-family:'Rajdhani',sans-serif;font-size:9.5px;font-weight:600;letter-spacing:3.2px;text-transform:uppercase;color:var(--black);background:none;border:none;box-shadow:none;padding:0;line-height:1}
.gallery-badge::before{content:'';width:22px;height:1px;background:var(--gray-400);flex-shrink:0;display:block}
.gallery-badge.warning::before{background:#B45309}
.gallery-badge.in-stock::before{background:#166534}
.gallery-badge.out::before{background:var(--gray-400)}
.gallery-badge.out{color:var(--gray-500)}
.gallery-wishlist{position:absolute;top:16px;right:16px;width:44px;height:44px;background:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gray-500);cursor:pointer;transition:var(--t);z-index:4;box-shadow:0 4px 14px rgba(0,0,0,.08);border:1px solid var(--gray-200)}
.gallery-wishlist svg{width:20px;height:20px}
.gallery-wishlist:hover{color:var(--red);transform:scale(1.06);border-color:var(--red)}
/* Navigation arrows on main image */
.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--black);cursor:pointer;transition:all .25s ease;z-index:4;box-shadow:0 6px 18px -4px rgba(0,0,0,.18);border:1px solid var(--gray-200);opacity:0;pointer-events:none;padding:0}
.gallery-main:hover .gallery-nav,.gallery-nav:focus-visible{opacity:1;pointer-events:auto}
.gallery-nav:hover{background:var(--white);color:var(--orange);transform:translateY(-50%) scale(1.06)}
.gallery-nav:active{transform:translateY(-50%) scale(.96)}
.gallery-nav svg{width:22px;height:22px;stroke-width:2;fill:none;stroke:currentColor;display:block}
.gallery-nav-prev{left:14px}
.gallery-nav-next{right:14px}
.gallery-counter{position:absolute;bottom:18px;right:18px;background:rgba(13,13,13,.78);backdrop-filter:blur(6px);color:#fff;font-size:11px;padding:6px 12px;border-radius:99px;letter-spacing:.5px;font-weight:500;z-index:3}
.gallery-zoom{position:absolute;bottom:18px;left:18px;background:rgba(13,13,13,.78);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:3;cursor:pointer;transition:var(--t);border:none}
.gallery-zoom:hover{background:var(--orange)}
.gallery-zoom svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}
.gallery-main{cursor:zoom-in}
.gallery-main.swiping{cursor:grabbing}

/* ═══ LIGHTBOX — fullscreen zoom ═══ */
.lightbox{position:fixed;inset:0;background:rgba(10,10,12,.96);z-index:10000;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .28s ease}
.lightbox.open{display:flex;opacity:1}
.lightbox-stage{position:relative;width:100%;height:100%;overflow:hidden;display:flex;align-items:center;justify-content:center;cursor:zoom-in;touch-action:none}
.lightbox-stage.zoomed{cursor:grab}
.lightbox-stage.zoomed.dragging{cursor:grabbing}
.lightbox-img{max-width:92vw;max-height:88vh;width:auto;height:auto;object-fit:contain;transform-origin:center center;transform:scale(1) translate(0,0);transition:transform .28s cubic-bezier(.2,.7,.2,1);user-select:none;-webkit-user-select:none;pointer-events:none;filter:drop-shadow(0 20px 60px rgba(0,0,0,.6))}
.lightbox-stage.dragging .lightbox-img{transition:none}
.lightbox-close,.lightbox-nav{position:absolute;background:rgba(255,255,255,.06);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;border:1px solid rgba(255,255,255,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:2;padding:0}
.lightbox-close{top:24px;right:24px;width:52px;height:52px}
.lightbox-close svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round}
.lightbox-close:hover{background:rgba(255,255,255,.14);transform:rotate(90deg)}
.lightbox-nav{top:50%;transform:translateY(-50%);width:56px;height:56px}
.lightbox-nav svg{width:26px;height:26px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.lightbox-nav-prev{left:28px}
.lightbox-nav-next{right:28px}
.lightbox-nav:hover{background:rgba(255,255,255,.14);color:var(--orange)}
.lightbox-nav-prev:hover{transform:translateY(-50%) translateX(-3px)}
.lightbox-nav-next:hover{transform:translateY(-50%) translateX(3px)}
.lightbox-counter{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);font-family:'Rajdhani',sans-serif;font-size:12px;font-weight:600;letter-spacing:2.4px;text-transform:uppercase;color:rgba(255,255,255,.75);z-index:2;display:flex;align-items:center;gap:14px}
.lightbox-counter::before,.lightbox-counter::after{content:'';width:22px;height:1px;background:rgba(255,255,255,.3);display:block}
.lightbox-hint{position:absolute;top:24px;left:24px;font-family:'Rajdhani',sans-serif;font-size:10.5px;font-weight:600;letter-spacing:2.2px;text-transform:uppercase;color:rgba(255,255,255,.55);z-index:2;display:inline-flex;align-items:center;gap:10px}
.lightbox-hint::before{content:'';width:22px;height:1px;background:rgba(255,255,255,.35)}
body.lightbox-open{overflow:hidden}
@media(max-width:768px){
  .lightbox-close{top:14px;right:14px;width:44px;height:44px}
  .lightbox-nav{width:44px;height:44px}
  .lightbox-nav-prev{left:10px}
  .lightbox-nav-next{right:10px}
  .lightbox-img{max-width:96vw;max-height:82vh}
  .lightbox-counter{bottom:20px;font-size:10.5px}
  .lightbox-hint{display:none}
}

/* ─── BUY BLOCK — UHNW editorial, flat, typography-driven ─── */
.buy-block{min-width:0;padding-top:4px}

/* Brand kicker — single line, flat, no box */
.buy-brand-kicker{display:flex;align-items:center;gap:18px;padding-bottom:32px;margin-bottom:32px;border-bottom:1px solid var(--gray-200)}
.brand-logo-inline{height:44px;width:auto;max-width:92px;object-fit:contain;mix-blend-mode:multiply;flex-shrink:0}
.brand-kicker-txt{display:flex;align-items:center;gap:12px;flex-wrap:wrap;line-height:1}
.brand-name{font-family:'Rajdhani',sans-serif;font-size:15px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--black)}
.brand-sep{color:var(--gray-300);font-weight:300;font-size:14px;line-height:1}
.brand-series{font-family:'Rajdhani',sans-serif;font-size:12px;font-weight:600;letter-spacing:2.2px;text-transform:uppercase;color:var(--orange)}

/* Title — big refined Rajdhani */
.product-title{font-family:'Rajdhani',sans-serif;font-size:38px;font-weight:600;line-height:1.08;letter-spacing:-.6px;color:var(--black);margin-bottom:14px;word-break:break-word;overflow-wrap:break-word;hyphens:auto;max-width:100%}
.product-subtitle{display:block;font-size:22px;font-weight:400;color:var(--gray-500);margin-top:8px;letter-spacing:-.2px;line-height:1.2}
.product-meta{font-size:10.5px;color:var(--gray-400);letter-spacing:1.2px;text-transform:uppercase;margin-bottom:44px;font-weight:500}

/* Price — flat, no clutter */
.product-price{margin-bottom:20px}
.price-amount{font-family:'Rajdhani',sans-serif;font-size:46px;font-weight:700;color:var(--black);line-height:1;letter-spacing:-.8px;margin-bottom:10px}
.price-info{font-size:11px;color:var(--gray-500);letter-spacing:.3px;font-weight:500}

/* Availability — single line UHNW conditional 3 states (refactor 2026-04-26) :
 * .stock-ok (qty>5) green · .stock-low (qty 1-5) amber · .stock-oos (qty<=0) red.
 * Le dot est un span <.stock-dot> dans le DOM (pas ::before) pour autoriser
 * les pulse animations CSS sans collision avec les pseudo-elements. */
.product-availability{display:flex;align-items:center;gap:10px;font-size:12.5px;font-weight:600;letter-spacing:.2px;margin-bottom:36px;padding-top:22px;padding-bottom:28px;border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200)}
.product-availability .stock-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;display:inline-block}
.product-availability.stock-ok{color:#10a956}
.product-availability.stock-ok .stock-dot{background:#10a956;box-shadow:0 0 0 3px rgba(16,169,86,.18)}
.product-availability.stock-low{color:var(--amber)}
.product-availability.stock-low .stock-dot{background:var(--amber);box-shadow:0 0 0 3px rgba(245,158,11,.2)}
.product-availability.stock-oos{color:var(--red)}
.product-availability.stock-oos .stock-dot{background:var(--red);box-shadow:0 0 0 3px rgba(239,68,68,.2)}

/* Action row — qty + CTA */
.buy-action{display:flex;gap:12px;align-items:stretch;margin-bottom:14px}
.qty{display:flex;align-items:center;border:1px solid var(--gray-200);border-radius:var(--r);overflow:hidden;background:var(--white)}
.qty button{width:52px;height:60px;background:var(--white);color:var(--black);font-size:20px;font-weight:400;display:flex;align-items:center;justify-content:center;transition:background .2s}
.qty button:hover{background:var(--gray-50)}
.qty span,.qty .qty-input{width:52px;height:60px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:15px;color:var(--black);border-left:1px solid var(--gray-200);border-right:1px solid var(--gray-200)}
.qty .qty-input{border-top:none;border-bottom:none;background:var(--white);text-align:center;font-family:'DM Sans',system-ui,sans-serif;line-height:1;padding:0;outline:none;-moz-appearance:textfield;appearance:textfield}
.qty .qty-input::-webkit-outer-spin-button,.qty .qty-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.qty .qty-input:focus{border-left-color:var(--gray-300);border-right-color:var(--gray-300)}
#add-to-cart-or-refresh{margin:0;padding:0;border:0;display:block}
.btn-add{flex:1;height:60px;background:var(--black);color:#fff;border-radius:var(--r);font-family:'Rajdhani',sans-serif;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:14px;text-transform:uppercase;letter-spacing:3px;transition:var(--t)}
.btn-add svg{width:18px;height:18px}
.btn-add:hover{background:var(--orange)}

/* Payment — one-line subtle note */
.buy-payment-line{font-size:11px;color:var(--gray-500);letter-spacing:.4px;text-align:center;margin-bottom:34px;padding-top:4px}
.buy-payment-line strong{color:var(--black);font-weight:700}

/* Garanties row UHNW — grid 4 colonnes sous le CTA (signature Apple/Hermès) */
.buy-warranties{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:30px 0 14px;padding-top:26px;border-top:1px solid var(--gray-200)}
.buy-warranty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;padding:0 4px;transition:transform .25s cubic-bezier(.4,0,.2,1)}
.buy-warranty svg{width:26px;height:26px;color:var(--black);transition:color .3s cubic-bezier(.4,0,.2,1)}
.buy-warranty:hover{transform:translateY(-2px)}
.buy-warranty:hover svg{color:var(--orange)}
.buy-warranty strong{font-family:'Rajdhani',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--black);line-height:1.2}
.buy-warranty span{font-family:'DM Sans',sans-serif;font-size:10.5px;color:var(--gray-500);font-weight:400;line-height:1.3}
@media (max-width:480px){
  .buy-warranties{grid-template-columns:repeat(2,1fr);gap:14px;margin:24px 0 12px;padding-top:22px}
  .buy-warranty svg{width:22px;height:22px}
  .buy-warranty strong{font-size:10.5px;letter-spacing:.8px}
  .buy-warranty span{font-size:10px}
}

/* Stock alert — UHNW restock notification */
.buy-alert{margin-bottom:14px}
.btn-alert{display:flex;width:100%;height:60px;background:var(--black);color:#fff;border-radius:var(--r);font-family:'Rajdhani',sans-serif;font-size:14px;font-weight:700;align-items:center;justify-content:center;gap:14px;text-transform:uppercase;letter-spacing:2.6px;transition:var(--t);border:1px solid var(--black);cursor:pointer}
.btn-alert svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.btn-alert:hover{background:transparent;color:var(--black)}
.btn-alert:hover svg{animation:bellShake .6s ease}
@keyframes bellShake{0%,100%{transform:rotate(0)}20%{transform:rotate(-12deg)}40%{transform:rotate(10deg)}60%{transform:rotate(-6deg)}80%{transform:rotate(4deg)}}
.alert-form{margin-top:18px;padding-top:22px;border-top:1px solid var(--gray-200);display:none;animation:alertFadeIn .28s ease}
.alert-form.open{display:block}
@keyframes alertFadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.alert-form-kicker{display:inline-flex;align-items:center;gap:10px;font-family:'Rajdhani',sans-serif;font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:3px;color:var(--gray-400);margin-bottom:10px}
.alert-form-kicker::before{content:'';width:18px;height:1px;background:var(--gray-300);display:block}
.alert-form-hint{font-family:'DM Sans',sans-serif;font-size:12.5px;color:var(--gray-600);line-height:1.6;margin:0 0 16px}
.alert-form-user{display:flex;align-items:center;gap:10px;padding:10px 14px;margin-bottom:14px;border:1px solid var(--gray-200);border-radius:var(--r);background:var(--gray-50);font-family:'DM Sans',sans-serif;font-size:12px;color:var(--gray-600)}
.alert-form-user svg{width:16px;height:16px;color:var(--green);flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.alert-form-user strong{color:var(--black);font-weight:700;margin-left:auto}
.alert-form-row{display:flex;gap:10px;align-items:stretch}
.alert-form-row input{flex:1;min-width:0;height:52px;padding:0 18px;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r);font-family:'DM Sans',sans-serif;font-size:13.5px;color:var(--black);outline:none;transition:var(--t)}
.alert-form-row input:focus{border-color:var(--black)}
.alert-form-row input:read-only{background:var(--gray-50);color:var(--gray-600);cursor:default}
.alert-form-row input::placeholder{color:var(--gray-400)}
.alert-form-submit{flex-shrink:0;height:52px;padding:0 26px;background:var(--orange);color:#fff;border:none;border-radius:var(--r);font-family:'Rajdhani',sans-serif;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:2.2px;cursor:pointer;transition:var(--t);display:inline-flex;align-items:center;gap:8px}
.alert-form-submit:hover{background:var(--orange-h)}
.alert-form-submit svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.4}
.alert-form-terms{font-family:'DM Sans',sans-serif;font-size:10.5px;color:var(--gray-400);line-height:1.5;margin-top:10px;letter-spacing:.1px}
.alert-form-terms a{color:var(--gray-500);text-decoration:underline;text-underline-offset:2px}
.alert-form-terms a:hover{color:var(--orange)}
.alert-form-success{display:none;align-items:flex-start;gap:14px;padding:16px 18px;border:1px solid var(--green);border-radius:var(--r);background:rgba(34,197,94,.05)}
.alert-form-success.show{display:flex}
.alert-form-success svg{width:26px;height:26px;color:var(--green);flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;margin-top:2px}
.alert-form-success div{display:flex;flex-direction:column;gap:4px;min-width:0}
.alert-form-success strong{font-family:'Rajdhani',sans-serif;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1.8px;color:var(--black)}
.alert-form-success span{font-family:'DM Sans',sans-serif;font-size:12.5px;color:var(--gray-600);line-height:1.55}
@media(max-width:480px){
  .alert-form-row{flex-direction:column}
  .alert-form-submit{width:100%;height:48px}
  .alert-form-row input{height:48px}
}

/* ZN Points — UHNW loyalty block */
.buy-points{margin-bottom:38px;padding:26px 0 30px;border-top:1px solid var(--gray-200);display:flex;align-items:center;gap:26px}
.buy-points-mark{flex-shrink:0;width:58px;height:58px;border-radius:50%;border:1px solid var(--gray-200);display:flex;align-items:center;justify-content:center;font-family:'Rajdhani',sans-serif;font-size:9px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--orange);background:linear-gradient(160deg,#fff 0%,#f7f7f9 100%);flex-direction:column;line-height:1;gap:3px}
.buy-points-mark span{letter-spacing:1.8px}
.buy-points-mark strong{font-size:17px;font-weight:700;letter-spacing:-.3px;color:var(--black)}
.buy-points-body{flex:1;min-width:0}
.buy-points-kicker{display:inline-flex;align-items:center;gap:10px;font-family:'Rajdhani',sans-serif;font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:3px;color:var(--gray-400);margin-bottom:12px}
.buy-points-kicker::before{content:'';width:18px;height:1px;background:var(--gray-300);display:block}
.buy-points-stats{display:flex;align-items:stretch;gap:24px}
.buy-points-stat{display:flex;flex-direction:column;gap:5px;min-width:0}
.buy-points-stat-num{font-family:'Rajdhani',sans-serif;font-size:26px;font-weight:700;color:var(--black);line-height:1;letter-spacing:-.6px}
.buy-points-stat-num.accent{color:var(--orange)}
.buy-points-stat-label{font-family:'Rajdhani',sans-serif;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--gray-500)}
.buy-points-stat-sep{width:1px;background:var(--gray-200);flex-shrink:0}
.buy-points-link{display:inline-block;margin-top:12px;font-family:'Rajdhani',sans-serif;font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--gray-500);transition:var(--t)}
.buy-points-link:hover{color:var(--orange)}
@media(max-width:480px){
  .buy-points{gap:18px;padding:22px 0 24px}
  .buy-points-mark{width:50px;height:50px}
  .buy-points-mark strong{font-size:15px}
  .buy-points-stats{gap:18px}
  .buy-points-stat-num{font-size:22px}
  .buy-points-stat-label{font-size:8.5px}
  .buy-points-link{font-size:9px;letter-spacing:1.5px}
}

/* Editorial sections — no boxes, just typography */
.product-editorial{padding-top:36px;border-top:1px solid var(--gray-200)}
.product-editorial section+section{margin-top:34px}
.product-editorial h3{font-family:'Rajdhani',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:3px;color:var(--gray-400);margin-bottom:14px}
.product-editorial p{font-size:13.5px;line-height:1.85;color:var(--gray-700);margin:0;max-width:none}
.product-editorial p em{font-style:normal;font-weight:700;color:var(--black)}

/* Trust footer — minimal inline dividers */
.product-trust{display:flex;flex-wrap:wrap;margin-top:52px;padding-top:26px;border-top:1px solid var(--gray-200);font-size:10px;text-transform:uppercase;letter-spacing:1.6px;color:var(--gray-500);font-weight:600}
.product-trust span{position:relative;padding:0 18px;line-height:1.5}
.product-trust span:first-child{padding-left:0}
.product-trust span+span::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:1px;height:11px;background:var(--gray-300)}

/* ═══ DETAIL TABS ═══ */
.detail-tabs{padding:72px 0;background:var(--white);border-top:1px solid var(--gray-200)}
.detail-tabs .container{max-width:1100px}
.tab-nav{display:flex;gap:0;border-bottom:1px solid var(--gray-200);margin-bottom:40px;overflow-x:auto;scrollbar-width:none}
.tab-nav::-webkit-scrollbar{display:none}
.tab-btn{padding:18px 32px;font-size:14px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:1.8px;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:var(--t);white-space:nowrap;background:none}
.tab-btn.active{color:var(--black);border-bottom-color:var(--orange)}
.tab-btn:hover{color:var(--black)}
.tab-panel{display:none}
.tab-panel.active{display:block}
.tab-panel h3{font-size:24px;font-weight:700;color:var(--black);margin:32px 0 14px;letter-spacing:.3px}
.tab-panel h3:first-child{margin-top:0}
.tab-panel h4{font-size:16px;font-weight:700;color:var(--black);margin:24px 0 10px}
.tab-panel p{font-size:14px;color:var(--gray-600);line-height:1.85;margin-bottom:14px;max-width:100%}
.tab-panel p strong{color:var(--black);font-weight:700}
.tab-panel ul:not(.faq-list){list-style:none;padding:0;margin:14px 0 20px;max-width:100%}
.tab-panel ul:not(.faq-list) li{position:relative;padding:6px 0 6px 24px;font-size:13.5px;color:var(--gray-600);line-height:1.7}
.tab-panel ul:not(.faq-list) li::before{content:'';position:absolute;left:0;top:14px;width:8px;height:8px;background:var(--orange);border-radius:50%}

.specs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 56px;max-width:100%}
.spec-row{display:flex;justify-content:space-between;align-items:baseline;padding:15px 0;border-bottom:1px solid var(--gray-200);gap:16px}
.spec-row dt{font-size:11.5px;color:var(--gray-500);text-transform:uppercase;letter-spacing:.7px;font-weight:600;flex-shrink:0}
.spec-row dd{font-size:13.5px;color:var(--black);font-weight:600;text-align:right}

.reviews-empty{padding:48px 36px;background:var(--gray-50);border:1px dashed var(--gray-200);border-radius:var(--r-lg);text-align:center;max-width:720px}
.reviews-empty svg{width:40px;height:40px;color:var(--gray-300);margin-bottom:14px}
.reviews-empty h4{font-size:17px;color:var(--black);margin-bottom:8px}
.reviews-empty p{font-size:13px;color:var(--gray-500);margin-bottom:20px;max-width:none}
.reviews-empty a{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:var(--orange);color:#fff;border-radius:var(--r);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;font-family:'Rajdhani',sans-serif}
.reviews-empty a:hover{background:var(--orange-h)}

.faq-list{display:flex;flex-direction:column;gap:10px;max-width:100%}
.faq-item{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r);overflow:hidden;transition:var(--t)}
.faq-item.open{border-color:var(--orange);box-shadow:0 6px 24px rgba(0,0,0,.06)}
.faq-q{font-weight:700;font-size:14.5px;cursor:pointer;padding:18px 24px;display:flex;justify-content:space-between;align-items:center;color:var(--black);gap:16px;letter-spacing:.1px}
.faq-q svg{color:var(--orange);transition:transform .25s ease;flex-shrink:0;width:18px;height:18px}
.faq-item.open .faq-q svg{transform:rotate(180deg)}
.faq-a{font-size:13.5px;color:var(--gray-600);line-height:1.75;padding:0 24px 20px;display:none}
.faq-item.open .faq-a{display:block}

/* ═══ ACCESSOIRES SWIPER — identique à la home ═══ */
.products{padding:72px 0;background:var(--bg);border-top:1px solid var(--gray-200)}
.products .section-head{margin-bottom:28px}
.products .section-title{font-family:'DM Sans',sans-serif;font-size:26px;font-weight:800;color:var(--black);letter-spacing:-.2px}
.acc-tag{display:block;margin-top:6px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;color:var(--gray-500);letter-spacing:.1px}
.acc-tag em{font-style:normal;font-weight:600;color:var(--black)}
.swiper-button-prev.acc-prev,.swiper-button-next.acc-next{top:50%;margin-top:0}
.swiper-button-prev.acc-prev::after,.swiper-button-next.acc-next::after{font-size:14px;font-weight:700}

/* ═══ RELATED ═══ */
.related{padding:72px 0;background:var(--bg)}
.related.alt{background:var(--white);border-top:1px solid var(--gray-200)}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}
.section-title{font-size:28px;font-weight:700;color:var(--black);letter-spacing:.5px}
.section-link{font-size:13px;font-weight:600;color:var(--orange);font-family:'DM Sans',sans-serif}
.section-link:hover{text-decoration:underline}

.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
a.p-card{text-decoration:none;color:inherit;display:flex;flex-direction:column}
.p-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-lg);overflow:hidden;transition:border-color .25s ease,box-shadow .25s ease;position:relative}
.p-card:hover{border-color:var(--gray-300);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.p-img{width:100%;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;padding:22px;position:relative;background:#fff;border-bottom:1px solid var(--gray-100)}
.p-img img{max-width:100%;max-height:100%;object-fit:contain;mix-blend-mode:multiply;transition:transform .4s ease}
.p-card:hover .p-img img{transform:scale(1.04)}
.p-info{padding:18px 20px 20px;display:flex;flex-direction:column;gap:10px;flex:1}
.p-name{font-size:13.5px;font-weight:600;color:var(--gray-700);line-height:1.45;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:58px}
.p-name strong{color:var(--black);font-weight:600}
.p-card:hover .p-name{color:var(--black)}
.p-stock{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--green);font-weight:500;letter-spacing:.1px}
.p-stock::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0}
.p-stock.warning{color:var(--orange)}
.p-stock.warning::before{background:var(--orange)}
.p-stock.out{color:var(--gray-400)}
.p-stock.out::before{background:var(--gray-400)}
.p-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto;padding-top:6px}
.p-price{font-family:'Rajdhani',sans-serif;font-size:22px;font-weight:700;color:var(--black);line-height:1;letter-spacing:.2px}
.p-cart{width:38px;height:38px;background:transparent;border:none;display:flex;align-items:center;justify-content:center;color:var(--gray-500);cursor:pointer;transition:all .2s;border-radius:50%;padding:0;flex-shrink:0}
.p-cart svg{width:22px;height:22px;stroke:currentColor;stroke-width:1.7;fill:none}
.p-cart:hover:not(:disabled){background:var(--gray-100);color:var(--orange);transform:scale(1.06)}
.p-cart:disabled{opacity:.35;cursor:not-allowed}

/* ═══ FOOTER ═══ */
.footer{position:relative;background:linear-gradient(180deg,#0F0F12 0%,#0A0A0C 100%);padding:72px 0 40px;color:var(--gray-400);border-top:1px solid rgba(255,255,255,.05)}
.footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,107,0,.5) 50%,transparent 100%)}
.footer::after{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:220px;height:3px;background:var(--orange);box-shadow:0 0 24px rgba(255,107,0,.6)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1.4fr;gap:40px}
.footer h4{position:relative;font-size:12px;font-weight:800;color:var(--white);text-transform:uppercase;letter-spacing:2px;margin-bottom:22px;padding-bottom:12px}
.footer h4::after{content:'';position:absolute;left:0;bottom:0;width:28px;height:2px;background:var(--orange)}
.footer ul{list-style:none;padding:0;margin:0}
.footer-col a{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--gray-400);padding:6px 0;transition:var(--t);position:relative}
.footer-col a::before{content:'';width:0;height:1px;background:var(--orange);transition:width .25s ease}
.footer-col a:hover{color:var(--white);transform:translateX(4px)}
.footer-col a:hover::before{width:10px}
.footer-about .f-logo{display:block;margin-bottom:20px}
.footer-about .f-logo img{height:48px;width:auto;filter:brightness(1.1)}
.footer-about p{font-size:13px;line-height:1.75;color:var(--gray-500);margin:0 0 22px;max-width:340px}
.footer-about .f-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:rgba(255,107,0,.08);border:1px solid rgba(255,107,0,.25);border-radius:999px;font-size:11px;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:1px;margin-bottom:22px}
.footer-about .f-badge svg{width:14px;height:14px}
.f-socials{display:flex;gap:14px;margin-bottom:24px;align-items:center}
.f-social{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:0;color:var(--gray-400);transition:color .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1);text-decoration:none}
.f-social svg{width:22px;height:22px;fill:currentColor;color:currentColor;transition:inherit}
.f-social:hover,.f-social:focus-visible{background:transparent;border:none;color:var(--orange);transform:translateY(-2px);box-shadow:none}
.f-social:hover svg,.f-social:focus-visible svg{fill:var(--orange);color:var(--orange)}
.f-social::before,.f-social::after{display:none !important;content:none}
.f-contact li{display:flex;align-items:flex-start;gap:12px;padding:8px 0;font-size:13px;color:var(--gray-400)}
.f-contact li svg{width:16px;height:16px;color:var(--orange);flex-shrink:0;margin-top:3px}
.f-contact li>div{min-width:0;flex:1}
.f-contact li strong{display:block;color:var(--white);font-size:13px;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.f-contact li span{display:block;color:var(--gray-500);font-size:12px;line-height:1.5}
.f-contact a{display:block;color:var(--gray-400);transition:var(--t);text-decoration:none}
.f-contact a:hover strong{color:var(--orange)}
.footer-bottom{background:var(--black);padding:20px 0;border-top:1px solid var(--gray-900)}
.footer-bottom .container{display:flex;justify-content:space-between;align-items:center;gap:20px;font-size:12px;color:var(--gray-600)}
.footer-bottom-left{display:flex;align-items:center;gap:16px}
.footer-bottom-legal{display:flex;gap:20px}
.footer-bottom a{color:var(--gray-500);display:inline;transition:var(--t)}
.footer-bottom a:hover{color:var(--orange)}
.f-top{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:transparent;border:1px solid var(--gray-800);border-radius:99px;font-size:11px;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:var(--t)}
.f-top:hover{background:var(--orange);border-color:var(--orange);color:var(--white);transform:translateY(-2px)}
.f-top svg{width:12px;height:12px}

/* ═══ STICKY BAR — compact buy summary on scroll ═══ */
.sticky-bar{position:fixed;top:0;left:0;right:0;z-index:999;background:linear-gradient(180deg,#141418 0%,var(--dark) 100%);border-bottom:1px solid rgba(255,255,255,.06);box-shadow:0 6px 24px rgba(0,0,0,.35);transform:translateY(-120%);transition:transform .32s cubic-bezier(.22,1,.36,1),top .3s ease;will-change:transform,top}
.sticky-bar.visible{transform:translateY(0)}
.sticky-bar.below-header{top:120px}
@media(max-width:1024px){.sticky-bar.below-header{top:110px}}
@media(max-width:768px){.sticky-bar.below-header{top:56px}}
.sticky-bar .container{display:flex;align-items:center;gap:20px;height:68px}
.sticky-bar-thumb{width:48px;height:48px;border-radius:var(--r);background:linear-gradient(160deg,#f5f5f7 0%,#e7e7ed 100%);flex-shrink:0;padding:4px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.08)}
.sticky-bar-thumb img{max-width:100%;max-height:100%;object-fit:contain;mix-blend-mode:multiply}
.sticky-bar-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.sticky-bar-name{font-family:'Rajdhani',sans-serif;font-size:15px;font-weight:600;color:#fff;letter-spacing:.2px;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sticky-bar-brand{font-family:'Rajdhani',sans-serif;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gray-500)}
.sticky-bar-price{font-family:'Rajdhani',sans-serif;font-size:24px;font-weight:700;color:#fff;letter-spacing:-.3px;flex-shrink:0;line-height:1}
.sticky-bar-cta{flex-shrink:0;height:44px;padding:0 24px;background:var(--orange);color:#fff;border-radius:var(--r);font-family:'Rajdhani',sans-serif;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1.8px;display:inline-flex;align-items:center;gap:10px;transition:background .2s ease,transform .2s ease;box-shadow:0 6px 18px -6px rgba(255,107,0,.6);border:none;cursor:pointer}
.sticky-bar-cta:hover{background:var(--orange-h);transform:translateY(-1px)}
.sticky-bar-cta svg{width:16px;height:16px}
@media(max-width:768px){
  .sticky-bar .container{height:60px;gap:12px;padding:0 12px}
  .sticky-bar-thumb{width:40px;height:40px}
  .sticky-bar-brand{display:none}
  .sticky-bar-name{font-size:13px}
  .sticky-bar-price{font-size:19px}
  .sticky-bar-cta{padding:0 14px;height:40px;font-size:11px;letter-spacing:1.2px}
  .sticky-bar-cta span{display:none}
}
@media(max-width:480px){
  .sticky-bar-name{display:none}
}

.scroll-top-btn{position:fixed;bottom:24px;right:24px;width:46px;height:46px;background:var(--orange);color:#fff;border-radius:50%;font-size:20px;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:all .3s;z-index:999;box-shadow:0 6px 20px rgba(255,107,0,.45);border:none}
.scroll-top-btn.visible{opacity:1;pointer-events:auto}
.scroll-top-btn:hover{background:var(--orange-h);transform:translateY(-3px)}

/* ═══ RESPONSIVE ═══ */
@media(max-width:1100px){
  .product-layout{gap:36px}
}
@media(max-width:1024px){
  body{padding-top:110px}
  .container{padding:0 16px}
  .header-inner{gap:16px;height:64px}
  .logo img{height:44px}
  .search-bar{max-width:360px}
  .header-phone-txt{display:none}
  .header-phone{padding:8px 10px;margin-left:4px;border-radius:50%}
  .h-action{min-width:auto;padding:8px 10px}
  .product-layout{grid-template-columns:minmax(0,1fr);gap:40px}
  .gallery{position:static;display:flex;flex-direction:column-reverse;gap:14px;min-width:0;max-width:100%;width:100%}
  .buy-block{min-width:0;max-width:100%;width:100%}
  .gallery-thumbs{flex-direction:row;max-height:none;overflow-y:visible;overflow-x:auto;padding:4px 2px 8px;min-width:0;max-width:100%;width:100%;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;scroll-padding:4px}
  .gallery-thumb{width:88px;height:88px;scroll-snap-align:start}
  .gallery-main{min-width:0;max-width:100%;width:100%}
  .product-grid{grid-template-columns:repeat(3,1fr)}
  .products{padding:56px 0}
  .products .section-title{font-size:22px}
  .footer-grid{grid-template-columns:repeat(3,1fr);gap:32px}
  .specs-grid{gap:0 32px}
  .tab-btn{padding:16px 24px}
}
@media(max-width:768px){
  body{padding-top:56px}
  .top-bar{display:none}
  .header-inner{height:56px;gap:8px}
  .logo img{height:32px}
  .search-bar{max-width:none;flex:1;min-width:0}
  .search-bar input{height:38px;font-size:13px;padding:0 40px 0 12px}
  .search-btn{width:32px;height:32px}
  .header-actions{gap:2px}
  .h-action span{display:none}
  .h-action{padding:6px 6px;min-width:auto}
  .h-action svg{width:20px;height:20px;margin-bottom:0}
  .h-action.cart{padding:6px 10px;margin-left:2px}
  .cart-count{width:16px;height:16px;font-size:9px;top:0;right:0}
  .hamburger{display:flex;width:36px}
  .header-phone{display:none}
  .mob-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:9998;backdrop-filter:blur(2px)}
  .mob-overlay.active{display:block}
  .nav{position:static;border:none;background:none}
  .nav .container{padding:0}
  .nav-list{flex-direction:column;position:fixed;top:0;left:0;bottom:0;width:300px;max-width:85vw;background:#111;z-index:9999;padding:0;margin:0;overflow-y:auto;transform:translateX(-100%);transition:transform .35s cubic-bezier(.22,1,.36,1);height:100vh;height:100dvh;display:flex}
  .nav-list.open{transform:translateX(0)}
  .nav-list-header{display:flex !important;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:2px solid var(--orange);flex-shrink:0;background:#111}
  .nav-list-title{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:#fff}
  .nav-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.1);border-radius:50%;color:#ccc;font-size:18px;cursor:pointer;border:none}
  .nav-item{width:100%;display:block !important;position:static !important}
  .nav-link{padding:16px 20px;height:auto !important;font-size:14px;font-weight:600;border-bottom:1px solid rgba(255,255,255,.06);display:flex !important;justify-content:space-between;align-items:center;text-transform:uppercase;letter-spacing:.5px;color:#ddd;background:transparent}
  .nav-link svg{display:block !important;width:16px;height:16px;opacity:.5;transition:transform .3s ease;flex-shrink:0}
  .nav-item.mob-open>.nav-link{color:var(--orange);background:rgba(255,107,0,.08)}
  .nav-item.mob-open>.nav-link svg{transform:rotate(180deg);opacity:1}
  .mega-dd{display:none !important;position:static !important;opacity:1 !important;visibility:visible !important;transform:none !important;box-shadow:none !important;border:none !important;border-top:none !important;border-radius:0 !important;min-width:0 !important;padding:0 !important;background:#fff !important;flex-direction:column !important}
  .nav-item.mob-open>.mega-dd{display:flex !important}
  .mega-dd .mega-col{padding:8px 20px 10px 20px !important;border-bottom:1px solid #eee;min-width:0 !important}
  .mega-dd .mega-col:last-child{border-bottom:none}
  .mega-dd .mega-col-title{font-size:11px !important;color:var(--orange) !important;padding:10px 0 6px !important;margin-bottom:0 !important;border:none !important;border-bottom:2px solid var(--orange) !important;letter-spacing:1.5px;display:inline-block !important}
  .mega-dd .mega-col a{font-size:13px !important;padding:9px 0 9px 8px !important;color:#333 !important}
  .breadcrumb{padding:12px 0;font-size:11px}
  .breadcrumb strong{display:none}
  .product-page{padding:20px 0 48px}
  .product-layout{gap:28px}
  .gallery-main{padding:22px}
  .gallery-nav{opacity:1;pointer-events:auto;width:40px;height:40px;background:rgba(255,255,255,.88)}
  .gallery-nav svg{width:18px;height:18px}
  .gallery-nav-prev{left:10px}
  .gallery-nav-next{right:10px}
  .gallery-thumb{width:64px;height:64px;padding:4px}

  /* Brand kicker mobile */
  .buy-brand-kicker{padding-bottom:22px;margin-bottom:24px;gap:14px}
  .brand-logo-inline{height:36px;max-width:72px}
  .brand-name{font-size:13px;letter-spacing:2.5px}
  .brand-series{font-size:11px;letter-spacing:1.8px}

  /* Title mobile */
  .product-title{font-size:26px;letter-spacing:-.3px}
  .product-subtitle{font-size:16px;margin-top:4px}
  .product-meta{font-size:10px;margin-bottom:28px;letter-spacing:1px}

  /* Price + availability mobile */
  .price-amount{font-size:34px}
  .product-availability{padding-top:16px;padding-bottom:20px;margin-bottom:26px;font-size:11.5px}

  /* Action row mobile — stack qty + CTA */
  .buy-action{flex-direction:column;gap:10px}
  .qty{width:100%}
  .qty button,.qty span,.qty .qty-input{flex:1;height:52px}
  .btn-add{width:100%;flex:none;height:54px;font-size:13px;letter-spacing:2.2px}
  .buy-payment-line{margin-bottom:32px;font-size:10.5px}

  /* Editorial mobile */
  .product-editorial{padding-top:28px}
  .product-editorial section+section{margin-top:26px}
  .product-editorial h3{font-size:10.5px;letter-spacing:2.5px}
  .product-editorial p{font-size:13px;line-height:1.75}

  /* Trust footer mobile */
  .product-trust{margin-top:32px;padding-top:20px;font-size:9.5px;letter-spacing:1.2px;justify-content:center}
  .product-trust span{padding:2px 12px}

  .detail-tabs{padding:48px 0}
  .tab-btn{padding:14px 20px;font-size:12px;letter-spacing:1px}
  .tab-panel h3{font-size:20px}
  .specs-grid{grid-template-columns:1fr;gap:0}
  .related{padding:48px 0}
  .products{padding:48px 0}
  .products .section-head{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:20px}
  .products .section-title{font-size:20px}
  .section-title{font-size:22px}
  .product-grid{grid-template-columns:1fr 1fr;gap:12px}
  .p-img{padding:14px}
  .p-info{padding:14px 14px 16px;gap:8px}
  .p-name{font-size:12.5px;min-height:0;-webkit-line-clamp:2}
  .p-stock{font-size:10.5px}
  .p-price{font-size:18px}
  .p-cart{width:32px;height:32px}
  .p-cart svg{width:18px;height:18px}
  .footer{padding:48px 0 24px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .footer-about{grid-column:1/-1}
  .footer-about p{max-width:100%}
  .footer-bottom .container{flex-direction:column;gap:14px;text-align:center}
  .footer-bottom-left{flex-direction:column;gap:8px}
}
@media(max-width:480px){
  .product-grid{gap:8px}
  .p-img{padding:12px}
  .p-info{padding:12px}
  .product-title{font-size:23px}
  .product-subtitle{font-size:15px}
  .price-amount{font-size:30px}
  .brand-kicker-txt{flex-direction:column;align-items:flex-start;gap:4px}
  .brand-sep{display:none}
  .product-trust span{padding:2px 10px;font-size:9px;letter-spacing:1px}
  .footer-grid{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════════════════════════════
 * TABS REFACTOR UHNW (sprint 2026-04-26)
 *  - Émojis bruts ⚖️ 📦 🎯 💰 etc. remplacés par <span class="zn-icon">SVG</span>
 *    inline (parser PHP replaceEmojisWithIcons). Style monoline 18px,
 *    color noir, hover orange.
 *  - Specs grid : tableau 2 colonnes propres avec dividers, hover row.
 *  - FAQ accordion : 1ère ouverte par défaut, animation chevron, hover orange.
 * ═══════════════════════════════════════════════════════════════════════ */

/* Émoji → icône inline UHNW */
.tab-panel .zn-icon{display:inline-flex;align-items:center;justify-content:center;width:1.2em;height:1.2em;vertical-align:-0.2em;color:var(--black);transition:color .25s cubic-bezier(.4,0,.2,1)}
.tab-panel .zn-icon svg{width:100%;height:100%}
.tab-panel .zn-icon:hover{color:var(--orange)}

/* Specs grid — tableau 2 colonnes UHNW (label uppercase + valeur, hover row) */
.specs-grid{display:flex;flex-direction:column;gap:0;margin:0;padding:0;list-style:none}
.spec-row{display:grid;grid-template-columns:minmax(160px,1fr) 2fr;gap:24px;padding:14px 16px;border-bottom:1px solid var(--gray-200);transition:background .2s ease}
.spec-row:first-child{border-top:1px solid var(--gray-200)}
.spec-row:hover{background:#fafafa}
.spec-row dt{font-family:'Rajdhani',sans-serif;font-size:13px;font-weight:600;color:var(--black);text-transform:uppercase;letter-spacing:1px;margin:0;align-self:center}
.spec-row dd{font-family:'DM Sans',sans-serif;font-size:14.5px;color:var(--gray-700,#2a2a2a);margin:0;align-self:center;line-height:1.5}
@media (max-width:600px){
  .spec-row{grid-template-columns:1fr;gap:4px;padding:12px 8px}
  .spec-row dt{font-size:11.5px}
  .spec-row dd{font-size:13.5px}
}

/* ═══════════════════════════════════════════════════════════════════════
 * DESCRIPTION UHNW — override global du HTML BO PrestaShop (sprint 2026-04-26)
 *  Remonté Eric : descriptions BO rendaient avec un mix de styles cassés
 *  - encadrés bleus inline (style="background-color:#..."), barres orange
 *    parasites, listes <ul> sans branding, h2 IBM Plex Sans, classes
 *    Tailwind (text-xl, grid-cols-1, font-bold...) qui rendent en plain
 *    text sans Tailwind, classes custom .zn-hero/.zn-stat-strip/.zn-bonus-
 *    section/.zn-comparison-table/.zn-section-title sans CSS associé.
 *  Stratégie : neutraliser TOUS les styles inline + classes custom et
 *  forcer la grammaire UHNW (Rajdhani uppercase pour titres, DM Sans
 *  body, bullets carrés orange, dividers gris, table entête noire).
 *  Scope : .tab-panel#desc uniquement (pas la section accessoires, pas
 *  la fiche complète) pour éviter de casser d'autres composants.
 * ═══════════════════════════════════════════════════════════════════════ */

/* 1. RESET — neutralise les styles inline cassés sur tous les éléments du
 *    bloc description BO. !important est légitime ici : on combat des
 *    style="..." inline qui ne disparaîtront pas sans surcharge forte. */
.tab-panel#desc{font-family:'DM Sans',sans-serif;font-size:15px;line-height:1.75;color:#2a2a2a;max-width:100%}
.tab-panel#desc *{font-family:inherit !important;background-color:transparent !important;background:none}
.tab-panel#desc img{background:none !important}

/* 2. Reset Tailwind grid utilitaires (display:grid copié-collé sans
 *    Tailwind chargé reste neutre, mais on neutralise la grid héritée
 *    pour sécurité). Les classes Tailwind text-/font-/bg- n'ont aucun
 *    effet sans le runtime — pas la peine de les annuler, ce qui évite
 *    qu'elles écrasent nos règles UHNW par sur-spécificité d'attribut. */
.tab-panel#desc [class*="grid-cols-"],
.tab-panel#desc [class*="grid-rows-"]{display:block !important}

/* 3. TITRES UHNW — Rajdhani uppercase + trait orange ::after signature ZN. */
.tab-panel#desc h2,
.tab-panel#desc h3,
.tab-panel#desc h4,
.tab-panel#desc .zn-hero-title,
.tab-panel#desc .zn-section-title{font-family:'Rajdhani',sans-serif !important;font-weight:700 !important;text-transform:uppercase;letter-spacing:1px;color:var(--black) !important;margin:36px 0 18px !important;position:relative;padding-bottom:14px;line-height:1.2;max-width:100%}
.tab-panel#desc h2:first-child,
.tab-panel#desc h3:first-child,
.tab-panel#desc h4:first-child,
.tab-panel#desc .zn-hero-title{margin-top:0 !important}
.tab-panel#desc h2,
.tab-panel#desc .zn-hero-title{font-size:22px !important}
.tab-panel#desc h3,
.tab-panel#desc .zn-section-title{font-size:18px !important}
.tab-panel#desc h4{font-size:16px !important}
.tab-panel#desc h2::after,
.tab-panel#desc h3::after,
.tab-panel#desc .zn-hero-title::after,
.tab-panel#desc .zn-section-title::after{content:'';position:absolute;bottom:0;left:0;width:32px;height:2px;background:var(--orange);display:block}

/* 4. PARAGRAPHES — DM Sans body, gris confort, max-width pour confort lecture. */
.tab-panel#desc p,
.tab-panel#desc .zn-hero-subtitle{font-family:'DM Sans',sans-serif !important;font-size:15px !important;line-height:1.75 !important;color:#2a2a2a !important;margin:0 0 16px !important;max-width:100%}
.tab-panel#desc p strong,
.tab-panel#desc strong,
.tab-panel#desc b,
.tab-panel#desc span[style*="bolder"],
.tab-panel#desc span[style*="bold"]{font-weight:700 !important;color:var(--black) !important}

/* 5. LISTES — bullets carrés orange UHNW, pas de styles natifs. */
.tab-panel#desc ul{list-style:none !important;padding:0 !important;margin:18px 0 26px !important;max-width:100%}
.tab-panel#desc ul li{position:relative;padding-left:24px !important;margin-bottom:10px;line-height:1.65;font-size:14.5px;color:var(--gray-700,#2a2a2a);font-family:'DM Sans',sans-serif !important;list-style:none !important}
.tab-panel#desc ul li::before{content:'';position:absolute;left:0;top:9px;width:7px;height:7px;background:var(--orange);border-radius:0;flex-shrink:0}
.tab-panel#desc ul li::marker{display:none;content:''}
.tab-panel#desc ol{padding-left:22px !important;margin:18px 0 26px !important}
.tab-panel#desc ol li{margin-bottom:10px;line-height:1.65;font-size:14.5px;font-family:'DM Sans',sans-serif !important;padding-left:6px}

/* 6. LIENS — orange UHNW, soulignement fin offset. Distinction interne
 * vs externe : externe a un chevron diagonal subtil (↗), classes posées
 * par znairsofttheme::fixDescriptionLinks. */
.tab-panel#desc a,
.tab-panel#desc a.zn-desc-link,
.tab-panel#desc a.zn-desc-link-external{color:var(--orange) !important;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:4px;transition:color .2s ease,text-decoration-thickness .2s ease;font-weight:500}
.tab-panel#desc a:hover,
.tab-panel#desc a.zn-desc-link:hover,
.tab-panel#desc a.zn-desc-link-external:hover{color:var(--orange-d,#cc5500) !important;text-decoration-thickness:2px}
.tab-panel#desc a.zn-desc-link-external::after{content:' ↗';font-size:.85em;opacity:.6;margin-left:1px}

/* 7. ENCADRÉS / BLOCKQUOTE — neutralise les fonds bleus / barres orange
 *    parasites des descriptions BO et impose le bloc UHNW signature. */
.tab-panel#desc blockquote,
.tab-panel#desc .zn-bonus-section,
.tab-panel#desc div[style*="background-color"],
.tab-panel#desc div[style*="border"],
.tab-panel#desc div[class*="encadr"],
.tab-panel#desc div[class*="callout"]{background:#fafafa !important;border:none !important;border-left:3px solid var(--orange) !important;padding:24px 26px !important;margin:24px 0 !important;color:#2a2a2a !important;border-radius:0 !important;font-style:normal !important;box-shadow:none !important}

/* 8. TABLES — entête noire Rajdhani uppercase, lignes alternées subtiles. */
.tab-panel#desc table,
.tab-panel#desc .zn-comparison-table{width:100% !important;border-collapse:collapse !important;margin:24px 0 !important;font-size:14px !important;background:transparent !important;border:1px solid var(--gray-200) !important}
.tab-panel#desc table th,
.tab-panel#desc .zn-comparison-table th{background:var(--black) !important;color:#fff !important;padding:12px 16px !important;text-align:left !important;font-family:'Rajdhani',sans-serif !important;text-transform:uppercase !important;letter-spacing:.8px !important;font-size:12px !important;font-weight:700 !important;border:none !important}
.tab-panel#desc table td,
.tab-panel#desc .zn-comparison-table td{padding:12px 16px !important;border-bottom:1px solid var(--gray-200) !important;color:#2a2a2a !important;font-family:'DM Sans',sans-serif !important;font-size:14px !important;background:transparent !important}
.tab-panel#desc table tr:last-child td,
.tab-panel#desc .zn-comparison-table tr:last-child td{border-bottom:none !important}
.tab-panel#desc table tr:hover td{background:#fafafa !important}
.tab-panel#desc .zn-table-wrapper{overflow-x:auto;margin:24px 0;-webkit-overflow-scrolling:touch}

/* 9. ZN-HERO — encart d'intro UHNW (badge + titre + sous-titre). */
.tab-panel#desc .zn-hero{background:#fafafa;padding:32px 28px;margin:0 0 32px;border-left:3px solid var(--orange);border-radius:0}
.tab-panel#desc .zn-hero-badge{display:inline-block;font-family:'Rajdhani',sans-serif !important;font-size:11px !important;font-weight:700 !important;letter-spacing:2.5px;text-transform:uppercase;color:var(--orange) !important;margin-bottom:14px}

/* 10. ZN-STAT-STRIP — grille 6 stats UHNW (value + label compacts). */
.tab-panel#desc .zn-stat-strip{display:grid !important;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:0;background:transparent !important;border:1px solid var(--gray-200);border-radius:0;margin:28px 0;padding:0 !important}
.tab-panel#desc .zn-stat-item{display:flex !important;flex-direction:column;align-items:flex-start;justify-content:center;padding:18px 20px !important;border-right:1px solid var(--gray-200);background:transparent !important}
.tab-panel#desc .zn-stat-item:last-child{border-right:none}
.tab-panel#desc .zn-stat-icon{display:none}
.tab-panel#desc .zn-stat-value{font-family:'Rajdhani',sans-serif !important;font-size:18px !important;font-weight:700 !important;color:var(--black) !important;margin-bottom:4px;line-height:1.1}
.tab-panel#desc .zn-stat-label{font-family:'DM Sans',sans-serif !important;font-size:11px !important;font-weight:500 !important;color:var(--gray-500) !important;text-transform:uppercase;letter-spacing:.6px;line-height:1.3}

/* Petits écrans : la zn-stat-strip passe en pleine largeur 1 ou 2 colonnes,
 * les bordures verticales se transforment en horizontales. */
@media (max-width:600px){
  .tab-panel#desc .zn-stat-strip{grid-template-columns:repeat(2,1fr)}
  .tab-panel#desc .zn-stat-item{border-right:none;border-bottom:1px solid var(--gray-200)}
  .tab-panel#desc .zn-stat-item:nth-child(odd){border-right:1px solid var(--gray-200)}
  .tab-panel#desc .zn-stat-item:nth-last-child(-n+2){border-bottom:none}
}

/* 11. Mobile typo confort. */
@media (max-width:768px){
  .tab-panel#desc{font-size:14.5px}
  .tab-panel#desc h2,
  .tab-panel#desc .zn-hero-title{font-size:19px !important}
  .tab-panel#desc h3,
  .tab-panel#desc .zn-section-title{font-size:16px !important}
  .tab-panel#desc h4{font-size:15px !important}
  .tab-panel#desc .zn-hero{padding:22px 18px}
}

/* ═══════════════════════════════════════════════════════════════════════
 * KEY-POINTS BOX — sticky sidebar UHNW (sprint 2026-04-26)
 *  Position : 3e colonne du fold (gallery + buy-block + key-points) sur
 *  desktop ≥ 1280px. En dessous : passe sous le buy-block pleine largeur.
 *  Extraction : module znairsofttheme::extractKeyPoints() (cf. PHP).
 * ═══════════════════════════════════════════════════════════════════════ */

.zn-key-points-box{background:#fafafa;border-left:3px solid var(--orange);padding:26px 24px;align-self:start;max-width:100%;margin:0}
.key-points-header{display:flex;align-items:center;gap:10px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--gray-200)}
.key-points-icon{width:20px;height:20px;color:var(--orange);flex-shrink:0}
.key-points-icon svg{width:100%;height:100%;display:block}
.key-points-title{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:2px;color:var(--black);margin:0}
.key-points-list{list-style:none;padding:0;margin:0}
.key-points-item{position:relative;padding-left:18px;margin-bottom:13px;font-family:'DM Sans',sans-serif;font-size:13.5px;line-height:1.55;color:#2a2a2a}
.key-points-item:last-child{margin-bottom:0}
.key-points-item::before{content:'';position:absolute;left:0;top:8px;width:6px;height:6px;background:var(--orange);border-radius:0;flex-shrink:0}
.key-points-item strong{color:var(--black);font-weight:700}

/* Desktop ≥ 1280px : 3e colonne sticky à droite du buy-block. */
@media (min-width:1280px){
  .product-layout.has-key-points{grid-template-columns:minmax(0,1.05fr) minmax(0,1fr) 280px;gap:48px}
  .product-layout.has-key-points .zn-key-points-box{position:sticky;top:140px}
}

/* 1024-1279px : 3 colonnes deviennent 2, .zn-key-points-box bascule sous
 * le buy-block en pleine largeur (rangée 2, span 2 colonnes). */
@media (max-width:1279px) and (min-width:1024px){
  .product-layout.has-key-points{grid-template-columns:minmax(0,1.15fr) minmax(0,1fr)}
  .product-layout.has-key-points .zn-key-points-box{grid-column:1 / -1;margin-top:8px}
}

/* < 1024px : tout stack en 1 colonne (déjà existant), la box hérite simplement. */
@media (max-width:1023px){
  .product-layout.has-key-points{grid-template-columns:minmax(0,1fr)}
  .zn-key-points-box{padding:22px 20px}
}

@media (max-width:480px){
  .zn-key-points-box{padding:20px 16px}
  .key-points-title{font-size:12px;letter-spacing:1.6px}
  .key-points-item{font-size:13px}
}

/* ═══════════════════════════════════════════════════════════════════════
 * RECOMMANDATION ATELIER — encart UHNW autour des blocs
 * "Équipement recommandé / Notre conseil / À associer avec / etc."
 * Wrapper posé par znairsofttheme::wrapRecommendationBlocks().
 * Signature ZN : kicker uppercase Rajdhani gris + titre noir + bullet
 * carré orange + étoile décorative en haut à droite.
 * ═══════════════════════════════════════════════════════════════════════ */
.tab-panel#desc .zn-recommandation{position:relative;background:linear-gradient(135deg,#fafafa 0%,#f0f0f0 100%);border-left:3px solid var(--orange);padding:32px 36px 28px;margin:36px 0;border-radius:0}
.tab-panel#desc .zn-recommandation::before{content:'★';position:absolute;top:24px;right:28px;font-size:22px;color:var(--orange);opacity:.4;line-height:1;font-family:Arial,sans-serif}
.tab-panel#desc .zn-recommandation .zn-recommandation-kicker{display:block;font-family:'Rajdhani',sans-serif !important;font-size:10.5px !important;font-weight:700 !important;text-transform:uppercase;letter-spacing:2px;color:var(--gray-500) !important;margin-bottom:8px}
.tab-panel#desc .zn-recommandation h2,
.tab-panel#desc .zn-recommandation h3,
.tab-panel#desc .zn-recommandation h4{font-family:'Rajdhani',sans-serif !important;font-weight:700 !important;text-transform:uppercase;letter-spacing:1.5px;color:var(--black) !important;font-size:17px !important;margin-top:0 !important;margin-bottom:18px !important;padding-bottom:14px !important;border-bottom:1px solid var(--gray-200);position:relative;display:block}
.tab-panel#desc .zn-recommandation h2::after,
.tab-panel#desc .zn-recommandation h3::after,
.tab-panel#desc .zn-recommandation h4::after{display:none !important;content:none}
.tab-panel#desc .zn-recommandation p{font-family:'DM Sans',sans-serif !important;font-size:14.5px !important;line-height:1.7 !important;color:var(--gray-700,#2a2a2a) !important;margin-bottom:12px !important}
.tab-panel#desc .zn-recommandation p:last-child{margin-bottom:0 !important}
.tab-panel#desc .zn-recommandation ul{margin:14px 0 6px !important;padding:0 !important}
.tab-panel#desc .zn-recommandation ul li{padding-left:22px !important;margin-bottom:9px;font-size:14px}
.tab-panel#desc .zn-recommandation ul li::before{top:9px;width:6px;height:6px}
.tab-panel#desc .zn-recommandation a{color:var(--orange) !important;font-weight:600 !important}

@media (max-width:768px){
  .tab-panel#desc .zn-recommandation{padding:24px 22px 22px;margin:28px 0}
  .tab-panel#desc .zn-recommandation::before{top:18px;right:20px;font-size:18px}
  .tab-panel#desc .zn-recommandation h2,
  .tab-panel#desc .zn-recommandation h3,
  .tab-panel#desc .zn-recommandation h4{font-size:15px !important;letter-spacing:1.2px}
}

/* ═══════════════════════════════════════════════════════════════════════
 * RYTHME VERTICAL UHNW DESCRIPTION — sprint 2026-04-27
 *  Eric audit : "fin de description pas pro" — espacements verticaux
 *  incohérents entre h2/h3/h4/p/ul. Forcer marges constantes :
 *    h2 → 48 / 16  h3 → 32 / 12  h4 → 24 / 10  p → 0 / 16  ul → 18 / 26
 *  Override cumulatif (les sections h2/h3 plus haut posent déjà
 *  margin:36px 0 18px — ce bloc consolide le rythme final). */
.tab-panel#desc h2,
.tab-panel#desc .zn-hero-title{margin:48px 0 16px !important}
.tab-panel#desc h3,
.tab-panel#desc .zn-section-title{margin:32px 0 12px !important}
.tab-panel#desc h4{margin:24px 0 10px !important}
.tab-panel#desc h2:first-child,
.tab-panel#desc h3:first-child,
.tab-panel#desc h4:first-child,
.tab-panel#desc .zn-hero-title:first-child{margin-top:0 !important}
.tab-panel#desc h2 + p,
.tab-panel#desc h3 + p,
.tab-panel#desc h4 + p{margin-top:0 !important}

/* ═══════════════════════════════════════════════════════════════════════
 * ZN-CTA-FOOTER — bloc CTA "Protégez vos yeux sur le terrain" UHNW
 * (1212 produits ont ce gabarit BO).
 * ═══════════════════════════════════════════════════════════════════════ */
.tab-panel#desc .zn-cta-footer{position:relative;background:linear-gradient(135deg,#fafafa 0%,#f0f0f0 100%);border-left:3px solid var(--orange);padding:30px 32px 28px;margin:48px 0 0;border-radius:0}
.tab-panel#desc .zn-cta-footer-title,
.tab-panel#desc .zn-cta-footer h2,
.tab-panel#desc .zn-cta-footer h3{font-family:'Rajdhani',sans-serif !important;font-weight:700 !important;text-transform:uppercase !important;letter-spacing:1.5px !important;color:var(--black) !important;font-size:17px !important;margin:0 0 16px !important;padding-bottom:12px !important;border-bottom:1px solid var(--gray-200) !important;display:block;line-height:1.25}
.tab-panel#desc .zn-cta-footer-title::after,
.tab-panel#desc .zn-cta-footer h2::after,
.tab-panel#desc .zn-cta-footer h3::after{display:none !important;content:none}
.tab-panel#desc .zn-cta-footer p{margin:0 !important;font-family:'DM Sans',sans-serif !important;font-size:14.5px !important;line-height:1.7 !important;color:var(--gray-700,#2a2a2a) !important}
.tab-panel#desc .zn-cta-footer a{color:var(--orange) !important;font-weight:600 !important}

/* ═══════════════════════════════════════════════════════════════════════
 * ZN-ARTICLE-META — signature "Fiche produit rédigée par l'équipe
 * technique ZN-Airsoft · Mars 2026" en fin de description (1500
 * produits). Style discret avec un check orange en kicker.
 * ═══════════════════════════════════════════════════════════════════════ */
.tab-panel#desc .zn-article-meta{margin:48px 0 0 !important;padding:20px 0 0 !important;border-top:1px solid var(--gray-200);font-family:'DM Sans',sans-serif !important;font-size:11.5px !important;color:var(--gray-500) !important;letter-spacing:.5px;text-transform:none;font-weight:500;display:flex;align-items:center;gap:10px;line-height:1.5;background:none !important}
.tab-panel#desc .zn-article-meta::before{content:'';display:inline-block;width:14px;height:14px;flex-shrink:0;background:var(--orange);clip-path:polygon(20% 50%,40% 70%,80% 25%,90% 35%,40% 90%,10% 60%);}
.tab-panel#desc .zn-article-meta::after{content:none}

/* ═══════════════════════════════════════════════════════════════════════
 * ZN-KV-ROW (specs inline) — gabarit BO type "Norme EN166 Verre Vert
 * Coating Platinum Poids 26g Anti-buée Oui Marque Bollé". Avant : ligne
 * plate de spans. Après : pills compactes UHNW.
 * ═══════════════════════════════════════════════════════════════════════ */
.tab-panel#desc .zn-kv-row{display:flex !important;flex-wrap:wrap;gap:8px;margin:18px 0 26px !important;padding:0;background:transparent !important}
.tab-panel#desc .zn-kv-row .zn-kv{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--gray-100,#F0F0F0) !important;border-radius:0;font-family:'DM Sans',sans-serif !important;font-size:12.5px;line-height:1.3;border:1px solid var(--gray-200);background-color:transparent !important}
.tab-panel#desc .zn-kv-row .zn-kv-label{font-family:'Rajdhani',sans-serif !important;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--gray-500) !important}
.tab-panel#desc .zn-kv-row .zn-kv-value{font-weight:600;color:var(--black) !important}

@media (max-width:768px){
  .tab-panel#desc .zn-cta-footer{padding:22px 20px;margin-top:36px}
  .tab-panel#desc .zn-cta-footer-title,
  .tab-panel#desc .zn-cta-footer h3{font-size:15px !important;letter-spacing:1.2px}
  .tab-panel#desc .zn-article-meta{font-size:11px !important;margin-top:36px !important}
  .tab-panel#desc .zn-kv-row{gap:6px}
  .tab-panel#desc .zn-kv-row .zn-kv{padding:5px 10px;font-size:11.5px}
}
