/**
 * Beau Nuage — Category & Creative Quick-Shop v1.1.0
 * Palette neutre adaptable au thème Beau Nuage.
 *
 * Mode Catégorie  : overlay sur .product-miniature des pages catégorie PS.
 * Mode Creative   : overlay sur les visuels des pages CMS/homepage créées
 *                   avec le page builder — carte détectée par id_product en
 *                   fin de titre (ex : "La Polaire pour Elle 207").
 *
 * Desktop hover + tablette touch (IntersectionObserver).
 * Mobile ≤599px : désactivé.
 */
:root {
  --mmcs-bg:      #f9f9f7;
  --mmcs-ivory:   #ffffff;
  --mmcs-ink:     #1c1c1c;
  --mmcs-accent:  #1c1c1c;
  --mmcs-muted:   #888888;
  --mmcs-line:    #e8e8e8;
  --mmcs-sold:    #c8c8c8;
}

/* ── Hide on mobile only (≤599px) ── */
@media (max-width:599px) {
  .mmcs-overlay { display:none !important; }
  .mmcs-sidebar-backdrop, .mmcs-sidebar { display:none !important; }
  .mmcs-toast { display:none !important; }
}

/* ── Miniature wrapper ── */
.mmcs-enhanced { position:relative !important; }

/* ── Overlay — positioned inside the IMAGE container only ── */
.mmcs-overlay {
  position:absolute; left:0; right:0; bottom:0;
  background:rgba(255,255,255,.78); backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px);
  padding:10px 12px 12px;
  transform:translateY(100%); transition:transform .35s cubic-bezier(.2,.7,.2,1);
  z-index:6; border-top:1px solid var(--mmcs-line);
  font-family:inherit; font-weight:300; color:var(--mmcs-ink);
  box-sizing:border-box;
  pointer-events:none;
}

/* ── Desktop : slide-up au hover ── */
@media (hover: hover) {
  .mmcs-img-container:hover .mmcs-overlay {
    transform:translateY(0);
    pointer-events:auto;
  }
}

/* ── Tablette touch : slide-up déclenché par JS (.mmcs-visible) ── */
@media (hover: none) and (min-width:600px) {
  .mmcs-img-container .mmcs-overlay.mmcs-visible {
    transform:translateY(0);
    pointer-events:auto;
  }
  .mmcs-size { min-width:34px; height:30px; font-size:11px; }
  .mmcs-color { width:18px; height:18px; }
  .mmcs-btn-buy { height:38px; }
  .mmcs-sidebar-close { min-width:48px; min-height:48px; }
}

/* ── Attribute row (sizes + colors on ONE line) ── */
.mmcs-attr-row { display:flex; gap:8px; margin-bottom:8px; align-items:center; flex-wrap:nowrap; }
.mmcs-attr-group { display:flex; align-items:center; gap:4px; flex-shrink:0; }

/* ── Labels ── */
.mmcs-label {
  font-size:9px; letter-spacing:1.8px; text-transform:uppercase;
  color:var(--mmcs-muted); font-weight:500; white-space:nowrap; font-family:inherit;
}

/* ── Sizes ── */
.mmcs-sizes { display:flex; gap:3px; flex-wrap:nowrap; }
.mmcs-size {
  min-width:28px; height:24px; padding:0 5px;
  border:1px solid var(--mmcs-line); background:#fff;
  font-size:10px; letter-spacing:.5px; color:var(--mmcs-ink);
  display:inline-flex; align-items:center; justify-content:center;
  cursor:pointer; font-weight:400; font-family:inherit;
}
.mmcs-size:hover:not(.mmcs-sold) { border-color:var(--mmcs-ink); }
.mmcs-size.mmcs-active { background:var(--mmcs-ink); color:#fff; border-color:var(--mmcs-ink); }
.mmcs-size.mmcs-sold { color:var(--mmcs-sold); text-decoration:line-through; cursor:not-allowed; background:rgba(248,248,248,.8); }

/* ── Colors ── */
.mmcs-colors { display:flex; gap:6px; align-items:center; }
.mmcs-color {
  width:14px; height:14px; border-radius:50%;
  border:1px solid var(--mmcs-line); cursor:pointer;
  position:relative; padding:0;
}
.mmcs-color.mmcs-active::after {
  content:""; position:absolute; inset:-3px;
  border:1px solid var(--mmcs-ink); border-radius:50%;
}
.mmcs-color-sold { opacity:.45; cursor:not-allowed; }
.mmcs-color-sold::before {
  content:""; position:absolute; top:50%; left:-1px; right:-1px;
  height:1px; background:var(--mmcs-ink);
  transform:rotate(-45deg); z-index:1;
}

/* ── Dual buttons ── */
.mmcs-btn-row { display:flex; gap:5px; }
.mmcs-btn-buy {
  height:32px; border:none; font-size:9px; letter-spacing:1.2px;
  text-transform:uppercase; cursor:pointer; font-weight:500; font-family:inherit;
  display:inline-flex; align-items:center; justify-content:center; gap:4px;
  transition:all .2s ease; white-space:nowrap;
}
.mmcs-btn-buy.mmcs-loading { opacity:.7; cursor:wait; }

.mmcs-btn-primary { flex:1; background:var(--mmcs-ink); color:#fff; }
.mmcs-btn-primary:hover { background:#fff; color:var(--mmcs-ink); border:1px solid var(--mmcs-ink); }
.mmcs-btn-primary.mmcs-added { background:#555; }

.mmcs-btn-secondary { flex:0 0 auto; padding:0 10px; background:transparent; color:var(--mmcs-ink); border:1px solid var(--mmcs-ink) !important; }
.mmcs-btn-secondary:hover { background:var(--mmcs-ink); color:#fff; }
.mmcs-btn-secondary.mmcs-added { background:#555; color:#fff; border-color:#555 !important; }
.mmcs-btn-secondary svg { flex-shrink:0; }

.mmcs-ic { display:inline-block; margin-right:6px; }

/* ── Image nav arrows ── */
.mmcs-nav {
  position:absolute; top:50%; transform:translateY(-50%);
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,.85); border:1px solid var(--mmcs-line);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; z-index:5; color:var(--mmcs-ink);
  transition:all .2s ease; padding:0;
  box-shadow:0 1px 4px rgba(0,0,0,.08);
}
.mmcs-nav:hover { background:#fff; border-color:var(--mmcs-ink); }
.mmcs-nav-prev { left:8px; }
.mmcs-nav-next { right:8px; }

/* ── Toast ── */
.mmcs-toast {
  position:fixed; top:24px; right:24px; background:var(--mmcs-ink); color:#fff;
  padding:14px 22px; font-size:11px; letter-spacing:2px; text-transform:uppercase;
  opacity:0; transform:translateY(-8px); transition:all .3s ease; pointer-events:none;
  z-index:9999; display:flex; gap:12px; align-items:center;
  font-family:inherit;
}
.mmcs-toast.mmcs-show { opacity:1; transform:translateY(0); }
.mmcs-check {
  width:18px; height:18px; border:1.5px solid rgba(255,255,255,.6); border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.9); font-size:11px;
}

/* ═══════════════════════════════════════════
   CART SIDEBAR
   (fallback — le drawer principal est géré par mmquickshop / window.MMQS)
   ═══════════════════════════════════════════ */
.mmcs-sidebar-backdrop {
  position:fixed; inset:0; background:rgba(0,0,0,.3);
  z-index:10000; opacity:0; visibility:hidden;
  transition:opacity .3s ease, visibility .3s ease;
}
.mmcs-sidebar-backdrop.mmcs-open { opacity:1; visibility:visible; }

.mmcs-sidebar {
  position:fixed; top:0; right:0; bottom:0; width:420px; max-width:92vw;
  background:#fff; z-index:10001; display:flex; flex-direction:column;
  transform:translateX(100%); transition:transform .35s cubic-bezier(.2,.7,.2,1);
  font-family:inherit; color:var(--mmcs-ink);
}
.mmcs-sidebar.mmcs-open { transform:translateX(0); }

.mmcs-sidebar-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:22px 24px 18px; border-bottom:1px solid var(--mmcs-line);
}
.mmcs-sidebar-title { font-size:14px; letter-spacing:3px; text-transform:uppercase; font-weight:500; }
.mmcs-sidebar-close {
  background:none; border:none; cursor:pointer; padding:4px; color:var(--mmcs-ink);
  display:flex; align-items:center; justify-content:center;
  min-width:44px; min-height:44px;
}
.mmcs-sidebar-close:hover { color:var(--mmcs-muted); }

.mmcs-sidebar-body {
  flex:1; overflow-y:auto; padding:16px 24px; min-height:0;
  -webkit-overflow-scrolling:touch;
}

.mmcs-cart-item { display:flex; gap:14px; padding:14px 0; border-bottom:1px solid var(--mmcs-line); }
.mmcs-cart-item:last-child { border-bottom:none; }
.mmcs-cart-img { width:72px; height:96px; object-fit:cover; background:var(--mmcs-bg); flex-shrink:0; }
.mmcs-cart-info { flex:1; min-width:0; display:flex; flex-direction:column; justify-content:center; gap:3px; }
.mmcs-cart-name { font-size:12px; letter-spacing:.3px; font-weight:500; color:var(--mmcs-ink); }
.mmcs-cart-variant { font-size:11px; color:var(--mmcs-muted); letter-spacing:.5px; }
.mmcs-cart-qty { font-size:11px; color:var(--mmcs-muted); }
.mmcs-cart-qty .mmcs-qty-badge {
  display:inline-flex; align-items:center; justify-content:center;
  background:var(--mmcs-ink); color:#fff;
  width:18px; height:18px; border-radius:50%; font-size:10px; font-weight:600;
  margin-right:4px; vertical-align:middle;
}
.mmcs-cart-price { font-size:12px; font-weight:500; white-space:nowrap; flex-shrink:0; align-self:center; }
.mmcs-cart-empty { text-align:center; padding:48px 0; font-size:12px; letter-spacing:1px; color:var(--mmcs-muted); text-transform:uppercase; }

.mmcs-sidebar-footer {
  padding:18px 24px 22px; border-top:1px solid var(--mmcs-line);
  display:flex; flex-direction:column; gap:10px;
}
.mmcs-sidebar-subtotal { display:flex; justify-content:space-between; align-items:baseline; font-size:13px; letter-spacing:1px; }
.mmcs-sidebar-total-price { font-weight:600; font-size:15px; }
.mmcs-sidebar-btn {
  display:flex; width:100%; height:42px; text-align:center;
  font-size:10px; letter-spacing:2.5px; text-transform:uppercase; font-weight:500;
  font-family:inherit; cursor:pointer; text-decoration:none;
  align-items:center; justify-content:center;
}
.mmcs-sidebar-btn-primary { background:var(--mmcs-ink); color:#fff; border:none; transition:background .2s ease; }
.mmcs-sidebar-btn-primary:hover { background:#444; color:#fff; text-decoration:none; }
.mmcs-sidebar-btn-secondary { background:transparent; color:var(--mmcs-ink); border:1px solid var(--mmcs-ink); transition:all .2s ease; }
.mmcs-sidebar-btn-secondary:hover { background:var(--mmcs-ink); color:#fff; }

/* ═══════════════════════════════════════════
   MODE CREATIVE — spécifique
   ═══════════════════════════════════════════ */

/*
 * En mode Creative, les cartes produit n'ont pas de classe PS standard.
 * On applique juste les règles nécessaires à l'overlay.
 */

/* La carte Creative (conteneur détecté automatiquement) */
.mmcs-creative-card {
  position: relative; /* garantie pour l'overlay child */
}

/*
 * Sur les pages Creative, les images peuvent avoir un aspect-ratio fixe
 * défini par le page builder. On s'assure que le wrapper créé dynamiquement
 * (span.display-block) occupe bien toute la place.
 */
.mmcs-img-container > img {
  display: block;
  width: 100%;
  height: auto;
}

/*
 * Overlay en mode Creative : identique au mode Catégorie,
 * mais on désactive le clip sur mobile pour les wrappers inline.
 */
@media (max-width:599px) {
  .mmcs-creative-card .mmcs-overlay { display:none !important; }
}

/* ── Loading spinner ── */
.mmcs-overlay-loading {
  display:flex; align-items:center; justify-content:center; padding:24px 0;
}
.mmcs-spinner {
  width:22px; height:22px; border:2px solid var(--mmcs-line);
  border-top-color:var(--mmcs-ink); border-radius:50%;
  animation:mmcs-spin .6s linear infinite;
}
@keyframes mmcs-spin { to { transform:rotate(360deg); } }
