/* ================== THEME & BASE ================== */
:root{
  --bg:#f6f7fb;
  --card:#fff;
  --ink:#0b1324;
  --muted:#667085;
  --line:#e9edf4;
  --shadow:0 22px 48px rgba(18,27,48,.10);
  --accent:#ff9900;
  --ok:#10b981;
  --err:#dc2626;

  --r:20px;
  --r-md:14px;
  --right-col:520px;
  --thumb-pc:96px;
  --viewer-h:560px;

  --page-pad:18px;
  --arrow:42px;
  --rail-gap:10px;
  --rail-pad:10px;
  --track-gap:14px;
  --viewer-h-m:clamp(280px,46vh,420px);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:linear-gradient(180deg,#f9fbff 0,#f6f7fb 240px);
  color:var(--ink);
  font:15px/1.58 Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font:inherit}

/* Conteneur */
.wrap{
  max-width:1320px;
  margin:10px auto;
  padding-inline:18px;
}
@media (max-width:1024px){
  .wrap{padding-inline:var(--page-pad)}
}
@media (max-width:420px){
  :root{--page-pad:10px}
}

/* Fil d’Ariane */
.crumbs{
  font-size:13px;
  color:var(--muted);
  display:flex;
  gap:6px;
  align-items:center;
  margin-bottom:10px;
}
.crumb-sep{opacity:.55}
.shop-link{
  color:#1f2937;
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.shop-link i{color:#ff7b00}

/* Grille page */
.grid{
  display:grid;
  gap:20px;
  grid-template-columns:minmax(0,1fr) var(--right-col);
}
@media (max-width:1180px){
  .grid{grid-template-columns:1fr;gap:16px}
}

/* ================== GALERIE ================== */
.gallery{
  background:linear-gradient(180deg,#fff,#fbfcff);
  border:1px solid var(--line);
  border-radius:var(--r);
  box-shadow:var(--shadow);
  padding:16px;
}
.gallery-grid{
  display:grid;
  align-items:start;
  column-gap:16px;
  grid-template-columns:var(--thumb-pc) minmax(0,1fr);
}
@media (max-width:1024px){
  .gallery{padding:12px}
  .gallery-grid{grid-template-columns:1fr;row-gap:10px}
}

/* viewer */
.viewer{
  position:relative;
  width:100%;
  height:var(--viewer-h);
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
}
.viewer img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:50% 50%;
  user-select:none;
  pointer-events:none;
  transition:object-position .12s ease-out, transform .08s linear;
}
.viewer-tools{
  position:absolute;
  top:10px;
  right:10px;
  z-index:3;
  display:flex;
  gap:8px;
}
.tool-glass{
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  cursor:pointer;
  border:1px solid #e5e7eb;
  background:#fff;
  box-shadow:0 8px 18px rgba(15,23,42,.08);
}
@media (max-width:1024px){
  .viewer{height:var(--viewer-h-m)}
}

/* Vignettes PC */
.thumb-col{
  position:relative;
  height:var(--viewer-h);
}
.tnav{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  width:40px;
  height:40px;
  border-radius:12px;
  border:1px solid #e5e7eb;
  background:#fff;
  box-shadow:0 10px 22px rgba(22,28,45,.08);
  display:grid;
  place-items:center;
  cursor:pointer;
  z-index:4;
}
.tnav.top{top:0}
.tnav.bot{bottom:0}

.thumb-viewport{
  position:absolute;
  top:46px;
  bottom:46px;
  left:0;
  right:0;
  overflow:hidden;
}
.thumb-track{
  display:flex;
  flex-direction:column;
  transition:transform .28s cubic-bezier(.25,.8,.25,1);
}
.thumb{
  width:var(--thumb-pc);
  height:var(--thumb-pc);
  flex:0 0 var(--thumb-pc);
  border:1px solid var(--line);
  background:#fff;
  border-radius:14px;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.thumb:not(:last-child){margin-bottom:12px}
.thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.thumb.active{
  border-color:var(--accent);
  box-shadow:0 0 0 4px rgba(255,153,0,.18), inset 0 0 0 1px rgba(255,255,255,.8);
}

/* Rail MOBILE */
.cnav{display:none}
@media (max-width:1024px){
  .thumb-col{
    order:2;
    height:auto;
    position:static;
  }
  .tnav{display:none}
  .thumb-viewport{
    position:static;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .thumb-viewport::-webkit-scrollbar{display:none}

  .thumb-rail{
    display:grid;
    grid-template-columns:44px 1fr 44px;
    gap:var(--rail-gap);
    align-items:center;
    background:linear-gradient(180deg, rgba(255,255,255,.50), rgba(255,255,255,.35));
    border:1px solid rgba(0,0,0,.06);
    border-radius:14px;
    padding:var(--rail-pad);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.8), 0 6px 16px rgba(15,23,42,.08);
    backdrop-filter:saturate(130%) blur(8px);
  }
  .thumb-track{
    flex-direction:row;
    gap:var(--track-gap);
    transform:none!important;
  }
  .thumb{
    height:auto;
    aspect-ratio:1/1;
    flex:0 0 auto;
    width:clamp(
      76px,
      calc(
        (100vw - (var(--page-pad)*2) - (var(--arrow)*2) - (var(--rail-gap)*2) - (var(--rail-pad)*2) - (var(--track-gap)*2))
        / 3
      ),
      130px
    );
  }
  .cnav{
    display:grid;
    width:var(--arrow);
    height:var(--arrow);
    border-radius:14px;
    border:1px solid #e5e7eb;
    background:#fff;
    place-items:center;
    box-shadow:0 10px 22px rgba(22,28,45,.10);
  }
  .cnav[aria-disabled="true"]{
    opacity:.35;
    pointer-events:none;
  }
}

/* ================== PANNEAU ================== */
.panel{
  background:linear-gradient(180deg,#fff,#fbfcff);
  border:1px solid var(--line);
  border-radius:var(--r);
  box-shadow:var(--shadow);
  padding:22px;
  min-height:var(--viewer-h);
}
.page-head{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:10px;
  margin-bottom:6px;
}
.titleblk{
  display:flex;
  gap:10px;
  align-items:center;
  min-width:0;
}
.titleblk h1{
  font-size:26px;
  margin:0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.rating{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:13px;
  color:#f59e0b;
  background:#fff7ed;
  border:1px solid #fde68a;
  padding:4px 10px;
  border-radius:999px;
  flex:0 0 auto;
}
.actions{
  display:flex;
  gap:10px;
}
.iconbtn{
  height:42px;
  width:42px;
  border-radius:14px;
  border:1px solid #e5e7eb;
  background:#fff;
  box-shadow:0 10px 22px rgba(22,28,45,.08);
  display:grid;
  place-items:center;
  cursor:pointer;
}

/* Badges */
.badges{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:4px 0 8px;
}
.badge{
  font-size:11px;
  border-radius:999px;
  padding:4px 10px;
  border:1px solid transparent;
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-weight:700;
  letter-spacing:.01em;
}
.badge i{font-size:11px}
.badge--status.status-ok{
  background:#ecfdf5;
  border-color:#bbf7d0;
  color:#166534;
}
.badge--status.status-info{
  background:#eff6ff;
  border-color:#bfdbfe;
  color:#1d4ed8;
}
.badge--status.status-danger{
  background:#fef2f2;
  border-color:#fecaca;
  color:#b91c1c;
}
.badge--status.status-muted{
  background:#f3f4f6;
  border-color:#e5e7eb;
  color:#4b5563;
}
.badge--promo{
  background:#fef3c7;
  border-color:#fde68a;
  color:#92400e;
}
.badge--new{
  background:#ecfdf5;
  border-color:#a7f3d0;
  color:#047857;
}
.badge--warn{
  background:#fffbeb;
  border-color:#facc15;
  color:#92400e;
}
.badge--soft{
  background:#eff6ff;
  border-color:#bfdbfe;
  color:#111827;
}

/* Prix */
.price-row{
  display:flex;
  align-items:baseline;
  gap:10px;
  margin:4px 0 12px;
  flex-wrap:wrap;
}
.price{
  font-size:34px;
  font-weight:900;
  color:#0b1324;
}
.strike{
  color:var(--err);
  text-decoration:line-through;
  text-decoration-thickness:1.3px;
  font-size:14px;
}

/* Stock pill */
.stockpill{
  display:inline-flex;
  gap:8px;
  align-items:center;
  font-size:12px;
  border-radius:999px;
  padding:6px 10px;
  border:1px solid transparent;
  font-weight:700;
}
.stockpill--ok{
  background:#ecfdf5;
  border-color:#c8f4de;
  color:#065f46;
}
.stockpill--info{
  background:#eff6ff;
  border-color:#bfdbfe;
  color:#1d4ed8;
}
.stockpill--warn{
  background:#fffbeb;
  border-color:#facc15;
  color:#92400e;
}
.stockpill--danger{
  background:#fef2f2;
  border-color:#fecaca;
  color:#b91c1c;
}

.progress{
  height:8px;
  border-radius:999px;
  background:#eef2f7;
  overflow:hidden;
  margin-top:10px;
}
.progress>span{
  display:block;
  height:100%;
  background:var(--ok);
}
.muted{color:var(--muted)}

.label{font-size:13px;font-weight:600;margin-top:10px}

/* Variantes */
.chips{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:10px 0;
}
.chip{
  border:1px solid var(--line);
  border-radius:12px;
  height:40px;
  min-width:54px;
  padding:0 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  background:#fff;
  font-size:13px;
}
.chip.active{
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(255,153,0,.14);
}
.chip.swatch{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 14px;
  border:1px solid #e5e7eb;
}
.chip.swatch span{
  width:18px;
  height:18px;
  border-radius:6px;
  border:1px solid rgba(0,0,0,.15);
}

/* Quantité & CTA */
.qty{
  display:inline-flex;
  align-items:center;
  gap:12px;
  margin:10px 0;
  padding:6px 12px;
  border:1px solid #e8ecf5;
  border-radius:999px;
  background:#fff;
}
.step{
  width:36px;
  height:36px;
  border-radius:999px;
  border:1px solid #e6ebf6;
  background:#111827;
  color:#fff;
  display:grid;
  place-items:center;
  cursor:pointer;
}
.qtyval{
  min-width:20px;
  text-align:center;
  font-weight:800;
}
.cta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:6px;
}
.btn-primary{
  height:44px;
  padding:0 16px;
  border-radius:999px;
  border:1px solid #0f0f10;
  background:#0f0f10;
  color:#fff;
  font-weight:800;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.btn-ghost{
  height:44px;
  padding:0 16px;
  border-radius:999px;
  border:1px solid #e6ebf6;
  background:#fff;
  color:#0f0f10;
  font-weight:800;
  display:inline-flex;
  align-items:center;
  gap:8px;
}

/* Infos livraison */
.info-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:14px;
}
.info{
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px;
  background:#fff;
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.info .ico{
  width:22px;
  height:22px;
  flex:0 0 22px;
  color:#ff9900;
}
.info .btitle{
  font-weight:800;
  margin-bottom:3px;
}
.info .bhint{
  color:#667085;
  font-size:13px;
}

/* Description + pastilles */
.desc-card{
  margin-top:16px;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.desc-head{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-bottom:1px dashed #e9edf4;
  background:linear-gradient(180deg,#fafbff,#fff 70%);
}
.desc-head h3{
  margin:0;
  font-size:16px;
  font-weight:800;
  letter-spacing:.2px;
  color:#111827;
  min-width:0;
}
.desc-head .full{display:inline}
.desc-head .short{display:none}
.meta-tog{
  margin-left:auto;
  display:flex;
  gap:8px;
  flex-wrap:nowrap;
}
.meta-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  border:1px solid #e5e7eb;
  background:#fff;
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  white-space:nowrap;
}
.meta-pill .val{
  display:none;
  color:#111827;
  font-weight:700;
}
.meta-pill[data-open="true"] .val{display:inline}
.meta-pill[data-open="true"] .sep{display:inline}
.meta-pill .sep{
  display:none;
  color:#98a2b3;
}

.desc-body{
  padding:12px 14px;
}
.desc-text{
  position:relative;
  overflow:hidden;
  line-height:1.7;
  color:#0b1324;
  --collapsed-h:92px;
  max-height:var(--collapsed-h);
  transition:max-height .35s;
}
.desc-text::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:38px;
  background:linear-gradient(180deg,rgba(255,255,255,0),#fff);
}
.desc-text[data-collapsed="false"]{
  max-height:none;
}
.desc-text[data-collapsed="false"]::after{display:none}
.pro-toggle{
  margin-top:8px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  border-radius:999px;
  height:42px;
  padding:0 14px;
  border:1px solid #e8ecf5;
  background:#fff;
  font-weight:700;
  cursor:pointer;
}
.rm-icon{transition:transform .3s}
.pro-toggle[aria-expanded="true"] .rm-icon{transform:rotate(180deg)}

/* Toast */
.toast{
  position:fixed;
  right:18px;
  bottom:18px;
  background:#111827;
  color:#fff;
  padding:12px 14px;
  border-radius:14px;
  box-shadow:0 14px 30px rgba(12,20,40,.22);
  display:flex;
  gap:10px;
  align-items:flex-start;
  max-width:86vw;
  transform:translateY(14px);
  opacity:0;
  pointer-events:none;
  transition:.25s;
  z-index:40;
}
.toast.show{
  opacity:1;
  transform:none;
  pointer-events:auto;
}
.toast .close{
  margin-left:8px;
  cursor:pointer;
  opacity:.8;
}

/* Lightbox */
.lightbox{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.85);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:60;
}
.lightbox.show{display:flex}
.lightbox img{
  max-width:92vw;
  max-height:92vh;
  border-radius:14px;
}

/* Mobile ajustements */
@media (max-width:1024px){
  .panel{
    min-height:unset;
    padding:18px;
  }
  .titleblk h1{font-size:20px}
  .rating{
    font-size:11px;
    padding:3px 8px;
  }
  .iconbtn{
    width:38px;
    height:38px;
    border-radius:12px;
  }
  .price{font-size:28px}
  .strike{font-size:12px}
}
@media (max-width:640px){
  .chips{gap:8px;margin:8px 0}
  .cta{gap:8px}
  .info-grid{grid-template-columns:1fr 1fr}
  .desc-head .full{display:none}
  .desc-head .short{display:inline}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important}
}

/* ===== Fix bloc avis rating2 ===== */
#rating2 .panel,
#rating2 .card.panel{
  min-height:0!important;
  padding:10px 12px;
  box-shadow:none;
}
#rating2 .panel .top{
  gap:12px;
  padding:6px 12px;
  white-space:nowrap;
}
#rating2 .panel .top .msg{
  overflow:hidden;
  text-overflow:ellipsis;
}
#rating2 .reviews{padding:8px 10px}
#rating2 .review{margin:8px 0;padding:10px 12px}
#rating2 .r-text{margin-top:6px}
#rating2 .foot{padding:8px 10px 10px}
@media (max-width:480px){
  #rating2 .panel{padding:8px 10px!important}
  #rating2 .panel .top{gap:8px;padding:6px 10px}
  #rating2 .panel .top .msg{font-size:13px}
}

/* ===== POPUP LOGIN ===== */
.eg-popup-backdrop{
  position:fixed;
  inset:0;
  background:rgba(2,6,23,.45);
  backdrop-filter:blur(2px);
  z-index:9997;
  opacity:0;
  transition:opacity .18s ease;
}
.eg-popup{
  position:fixed;
  inset:0;
  display:grid;
  place-items:center;
  z-index:9998;
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease;
}
.eg-popup[open],
.eg-popup-backdrop[open]{
  opacity:1;
}
.eg-popup[open]{pointer-events:auto}
.eg-popup[hidden],
.eg-popup-backdrop[hidden]{
  display:block;
  opacity:0;
  pointer-events:none;
}

.eg-popup-card{
  position:relative;
  width:min(92vw,360px);
  border-radius:12px;
  background:#fff;
  box-shadow:0 18px 50px rgba(2,6,23,.28);
  border:1px solid rgba(15,23,42,.08);
  padding:18px 16px 16px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  transform:translateY(6px) scale(.98);
  transition:transform .18s ease;
}
.eg-popup[open] .eg-popup-card{transform:none}

.eg-popup-card i.fa-user-lock{
  font-size:30px;
  color:#1e6bd7;
  margin-bottom:4px;
}
.eg-popup-card h3{
  margin:0;
  font:800 16px/1.2 system-ui, -apple-system, Segoe UI, sans-serif;
  color:#0f172a;
}
.eg-popup-card p{
  margin:0;
  text-align:center;
  color:#334155;
  font:600 12px/1.5 system-ui, -apple-system, Segoe UI, sans-serif;
}

.eg-popup-actions{
  display:flex;
  gap:12px;
  margin-top:6px;
}
.eg-btn{
  padding:8px 14px;
  border-radius:8px;
  border:1px solid rgba(15,23,42,.08);
  font:800 12px/1 system-ui, -apple-system, Segoe UI, sans-serif;
  cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease, color .12s ease, border-color .12s ease;
}
.eg-btn:active{transform:scale(.98)}
.eg-btn-primary{
  background:linear-gradient(135deg,#1e6bd7,#2563eb);
  color:#fff;
  border-color:#1e6bd7;
  box-shadow:0 8px 20px rgba(30,107,215,.24), inset 0 1px 0 rgba(255,255,255,.35);
}
.eg-btn-primary:hover{filter:brightness(1.03)}
.eg-btn-ghost{
  background:#f1f5f9;
  color:#0f172a;
}
.eg-btn-ghost:hover{background:#e2e8f0}

.eg-popup-close-x{
  position:absolute;
  top:8px;
  right:8px;
  width:30px;
  height:30px;
  border-radius:8px;
  border:1px solid rgba(15,23,42,.08);
  background:#fff;
  color:#0f172a;
  display:grid;
  place-items:center;
  cursor:pointer;
}
.eg-popup-close-x:hover{background:#f8fafc}


/* ===== Breadcrumbs: horizontal scroll on mobile (scrollbar invisible) ===== */
.crumbs{
  /* desktop stays normal */
  display:flex;
  gap:6px;
  align-items:center;
}

/* mobile: make it scroll horizontally + hide scrollbar */
@media (max-width:640px){
  .crumbs{
    overflow-x:auto;
    overflow-y:hidden;
    white-space:nowrap;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;            /* Firefox */
  }
  .crumbs::-webkit-scrollbar{        /* Chrome/Safari */
    display:none;
  }

  /* optional: nicer "scroll feel" */
  .crumbs a,
  .crumbs span{
    flex:0 0 auto;
  }

  /* optional: avoid shrinking shop label too much */
  .shop-link span{
    white-space:nowrap;
  }
}
/* @media (max-width:640px){
  .crumbs{
    -webkit-mask-image: linear-gradient(90deg, #000 0, #000 85%, transparent 100%);
            mask-image: linear-gradient(90deg, #000 0, #000 85%, transparent 100%);
  }
} */
