/* ── Masquage prix/panier natif PS ── */
.current-price { display:none !important; }
.product-add-to-cart { display:none !important; }

/* ── Cart / order display ── */
.stickersvgimg-cart-details { margin:0 0 8px; padding:0; list-style:none; font-size:.82em; color:#555; }
.stickersvgimg-cart-details li { padding:1px 0; }
.stickersvgimg-svg-previews { display:flex; flex-wrap:wrap; gap:10px; margin:6px 0 8px; }
.stickersvgimg-svg-preview-item { display:flex; flex-direction:column; align-items:center; gap:5px; }
.stickersvgimg-svg-preview-label { font-size:.75em; font-weight:600; color:#444; text-transform:uppercase; letter-spacing:.03em; }
.stickersvgimg-svg-inline { width:120px; height:120px; border:1px solid #e0e0e0; border-radius:4px; background:#fafafa; display:flex; align-items:center; justify-content:center; overflow:hidden; padding:4px; box-sizing:border-box; }
.stickersvgimg-svg-inline svg { max-width:100%; max-height:100%; }

/* ── Fullwidth slot ── */
.ssi-fullwidth-slot {
  width:100vw;
  position:relative;
  left:50%;
  right:50%;
  margin-left:-50vw;
  margin-right:-50vw;
  box-sizing:border-box;
  padding:0 20px;
  margin-bottom:40px;
}
body.ssi-active .social-sharing,
body.ssi-active .ps-sharebuttons,
body.ssi-active .product__prices,
body.ssi-active .js-product-prices,
body.ssi-active .product__add-to-cart-container,
body.ssi-active .js-product-add-to-cart,
body.ssi-active .product-quantity,
body.ssi-active .product__add-to-cart,
body.ssi-active .product__add-to-cart-button { display:none !important; }

/* ── Wrapper ── */
.ssi-wrapper { width:100%; margin:0 0 30px; font-family:inherit; box-sizing:border-box; }

/* ── 2 colonnes upload ── */
.ssi-upload-cols { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:28px; }

.ssi-col-upload {
  border:2px dashed #ccc; border-radius:10px; padding:28px 20px;
  text-align:center; background:#fafafa;
  display:flex; flex-direction:column; align-items:center; gap:14px;
  box-sizing:border-box;
}
.ssi-col-img { cursor:pointer; }
.ssi-col-img:hover { border-color:#cc0000; background:#fff5f5; }
.ssi-col-title { font-size:.95em; font-weight:700; color:#333; }
.ssi-col-desc { font-size:.88em; color:#777; line-height:1.5; margin:0; }
.ssi-col-hint { font-size:.78em; color:#aaa; }

.ssi-btn-upload {
  background:#cc0000; color:#fff; border:none;
  padding:10px 22px; border-radius:6px; font-size:.9em;
  font-weight:600; cursor:pointer;
}
.ssi-btn-upload:hover { background:#aa0000; }
.ssi-btn-upload:disabled { background:#ccc; cursor:default; }

/* ── Tooltip ── */
.ssi-tooltip-wrap { position:relative; display:inline-block; cursor:help; }
.ssi-tooltip-icon { display:inline-flex; align-items:center; justify-content:center; width:17px; height:17px; border-radius:50%; background:#bbb; color:#fff; font-size:.72em; font-weight:800; margin-left:5px; vertical-align:middle; user-select:none; }
.ssi-tooltip-box { display:none; position:absolute; bottom:calc(100% + 8px); left:50%; transform:translateX(-50%); background:#333; color:#fff; font-size:.78em; font-weight:400; border-radius:7px; padding:8px 12px; width:230px; line-height:1.4; text-align:center; z-index:1000; box-shadow:0 3px 10px rgba(0,0,0,.2); }
.ssi-tooltip-box::after { content:''; position:absolute; top:100%; left:50%; transform:translateX(-50%); border:6px solid transparent; border-top-color:#333; }
.ssi-tooltip-wrap:hover .ssi-tooltip-box { display:block; }

/* ── Configurateur ── */
.ssi-configurator { width:100%; }

.ssi-preview-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.ssi-filename { font-size:.85rem; color:#777; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:70%; }
.ssi-header-actions { display:flex; gap:8px; }
.ssi-btn-reset { background:linear-gradient(135deg,#ef4444,#b91c1c); color:#fff; box-shadow:0 4px 12px rgba(239,68,68,.4); }
.ssi-btn-reinit { background:linear-gradient(135deg,#3b82f6,#1d4ed8); color:#fff; box-shadow:0 4px 12px rgba(59,130,246,.4); }
.ssi-btn-reset:hover { transform:translateY(-2px); box-shadow:0 7px 18px rgba(239,68,68,.55); }
.ssi-btn-reinit:hover { transform:translateY(-2px); box-shadow:0 7px 18px rgba(59,130,246,.55); }

/* SVG preview */
.ssi-preview-area { margin-bottom:20px; }
.ssi-svg-container { width:100%; min-height:200px; display:flex; align-items:center; justify-content:center; background:#fff; border:1px solid #e0e0e0; border-radius:6px; padding:20px; overflow:hidden; }
.ssi-svg-container svg { max-width:100%; max-height:500px; width:auto; height:auto; }

/* File input hidden */
.ssi-file-input { position:absolute; width:0; height:0; opacity:0; pointer-events:none; }

/* Dimensions */
.ssi-dimensions-row { display:flex; align-items:flex-end; gap:12px; margin-bottom:22px; flex-wrap:wrap; }
.ssi-dim-group { display:flex; flex-direction:column; gap:4px; }
.ssi-dim-group label { font-size:.8rem; color:#777; text-transform:uppercase; letter-spacing:.05em; margin:0; }
.ssi-dim-input { width:110px; padding:8px 10px; border:1px solid #d0d0d0; border-radius:5px; font-size:.95rem; text-align:center; }
.ssi-dim-input:focus { outline:none; border-color:#222; }
.ssi-elements-count { min-width:80px; }
.ssi-count-value { font-size:1.3rem; font-weight:600; color:#222; }

/* Small warning */
.ssi-small-warning { background:#fff8e1; border:1px solid #ffd54f; border-radius:6px; padding:14px 18px; margin-bottom:18px; }
.ssi-warning-text { margin:0 0 8px; color:#555; font-size:.9rem; }
.ssi-warning-hint { color:#888; font-size:.85rem; font-style:italic; }
.ssi-warning-icon { margin-right:6px; font-size:1.1rem; }
.ssi-small-actions { display:flex; gap:10px; flex-wrap:wrap; }

/* Couleurs */
.ssi-colors-row { margin-bottom:24px; }
.ssi-section-label { display:block; font-size:.8rem; color:#777; text-transform:uppercase; letter-spacing:.05em; margin-bottom:8px; }
.ssi-colors-inner { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.ssi-color-label { display:inline-flex; align-items:center; margin-bottom:0; white-space:nowrap; }
.ssi-color-name-box { border:1.5px solid #ddd; border-radius:7px; padding:8px 14px; font-size:.88em; font-weight:600; color:#333; background:#fafafa; min-width:90px; text-align:center; }
.ssi-color-swatches { display:flex; gap:10px; flex-wrap:wrap; }
.ssi-swatch {
  width:58px; height:58px; border-radius:50%;
  border:3px solid transparent;
  outline:3px solid transparent; outline-offset:3px;
  cursor:pointer; flex-shrink:0;
  transition:outline-color .15s;
  position:relative; padding:0;
}
.ssi-swatch.active { outline-color:#cc0000; }
.ssi-swatch.active::after {
  content:'✓'; position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-size:1.4em; font-weight:900;
  color:rgba(255,255,255,.9); text-shadow:0 1px 3px rgba(0,0,0,.5);
}

/* Paliers */
.ssi-price-tiers { display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; margin-bottom:24px; }
.ssi-tier-btn {
  border:2px solid #ddd; border-radius:8px; background:#fafafa;
  cursor:pointer; padding:14px 8px 0;
  display:flex; flex-direction:column; align-items:center; gap:4px;
  transition:border-color .15s, background .15s;
  font-family:inherit; overflow:hidden; position:relative;
}
.ssi-tier-btn:hover { border-color:#cc0000; background:#fff5f5; }
.ssi-tier-btn.active { border-color:#cc0000; background:#fff5f5; }
.ssi-tier-num { font-size:3em; font-weight:800; color:#222; line-height:1; }
.ssi-tier-btn.active .ssi-tier-num { color:#cc0000; }
.ssi-tier-price { font-size:1.1em; font-weight:800; color:#222; margin-top:4px; }
.ssi-tier-btn.active .ssi-tier-price { color:#cc0000; }
.ssi-tier-promo { font-size:1em; font-weight:800; color:#fff; background:#cc0000; border-radius:5px; padding:3px 10px; margin-top:4px; display:inline-block; }
.ssi-tier-promo-empty { background:transparent; color:transparent; }
.ssi-tier-check { display:none; font-size:.82em; font-weight:800; background:#cc0000; color:#fff; width:100%; padding:7px 0; text-align:center; margin-top:8px; }
.ssi-tier-btn.active .ssi-tier-check { display:block; }

/* Total + panier */
.ssi-cart-row { display:flex; flex-direction:column; gap:10px; }
.ssi-total-bar { display:flex; align-items:center; justify-content:space-between; width:100%; background:linear-gradient(135deg,#1e1e2e,#2d2d44); color:#fff; border-radius:14px; padding:16px 24px; box-shadow:0 4px 18px rgba(0,0,0,.2); }
.ssi-total-label { font-size:.8rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; opacity:.65; }
.ssi-total-price { font-size:1.8rem; font-weight:900; }

/* Buttons */
.ssi-btn { padding:9px 20px; border-radius:6px; border:none; cursor:pointer; font-size:.9em; font-weight:600; transition:background .2s; font-family:inherit; }
.ssi-btn-outline { background:transparent; color:#333; border:1px solid #ccc; }
.ssi-btn-outline:hover { background:#f5f5f5; }
.ssi-btn-danger { background:#c0392b; color:#fff; }
.ssi-btn-danger:hover { background:#a93226; }
.ssi-btn-primary {
  width:100%; padding:16px 24px; font-size:1.05rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.06em;
  background:linear-gradient(135deg,#e02020,#a00000); color:#fff;
  border-radius:14px; box-shadow:0 6px 20px rgba(192,0,0,.45);
  animation:ssi-pulse 2.4s ease-in-out infinite;
  border:none; cursor:pointer; font-family:inherit;
}
.ssi-btn-primary:hover { background:linear-gradient(135deg,#c01010,#800000); animation:none; }
@keyframes ssi-pulse {
  0%,100% { box-shadow:0 6px 20px rgba(192,0,0,.45); }
  50% { box-shadow:0 8px 30px rgba(192,0,0,.75),0 0 0 5px rgba(192,0,0,.12); }
}

/* Loading */
.ssi-col-upload.loading { opacity:.6; pointer-events:none; }

/* Blink */
@keyframes ssi-blink { 0%,100% { opacity:1; } 50% { opacity:.15; } }
.ssi-blink { animation:ssi-blink 1s ease-in-out infinite; }

/* ── MODALE VECTORISATEUR ── */
.ssi-modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:9999; align-items:center; justify-content:center; }
.ssi-modal-overlay.open { display:flex; }
.ssi-modal { background:#fff; border-radius:12px; width:90%; max-width:700px; max-height:90vh; overflow-y:auto; padding:24px; display:flex; flex-direction:column; gap:16px; position:relative; }
.ssi-modal-close { position:absolute; top:12px; right:16px; background:none; border:none; font-size:1.4em; cursor:pointer; color:#888; }
.ssi-modal-close:hover { color:#333; }
.ssi-modal-title { font-size:1em; font-weight:700; color:#333; margin:0; }
.ssi-modal-drop { border:2px dashed #ccc; border-radius:8px; padding:30px; text-align:center; background:#fafafa; cursor:pointer; font-size:.88em; color:#999; position:relative; }
.ssi-modal-drop:hover { border-color:#cc0000; background:#fff5f5; }
.ssi-modal-drop.has-file { border-color:#22a; background:#f0f4ff; color:#333; font-weight:600; }
.ssi-modal-actions { display:flex; gap:10px; justify-content:center; }
.ssi-btn-outline-modal { background:transparent; color:#555; border:1.5px solid #ccc; padding:10px 18px; border-radius:6px; font-size:.9em; font-weight:600; cursor:pointer; }
.ssi-btn-accept { background:#22a355; color:#fff; border:none; padding:10px 20px; border-radius:6px; font-size:.9em; font-weight:700; cursor:pointer; }
.ssi-btn-accept:hover { background:#1a8043; }
.ssi-btn-restart { background:transparent; color:#555; border:1.5px solid #ccc; padding:10px 18px; border-radius:6px; font-size:.9em; font-weight:600; cursor:pointer; }
.ssi-btn-restart:hover { background:#f5f5f5; }
.ssi-modal-preview { background:#fff; width:100%; }
.ssi-modal-svg-wrap { width:100%; }
.ssi-modal-svg-wrap svg { width:100%; height:auto; display:block; }

/* ── Liens ressources ── */
.ssi-links-block { margin:0 0 28px; }
.ssi-links-intro { font-size:.88em; color:#555; margin:0 0 10px; }
.ssi-links-grid {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.ssi-link-item {
  display:inline-flex;
  align-items:center;
  padding:7px 16px;
  background:#f5f5f5;
  border:1px solid #e0e0e0;
  border-radius:20px;
  font-size:.83em;
  font-weight:600;
  color:#333;
  text-decoration:none;
  transition:background .15s, border-color .15s, color .15s;
  white-space:nowrap;
}
.ssi-link-item:hover {
  background:#cc0000;
  border-color:#cc0000;
  color:#fff;
  text-decoration:none;
}

/* Responsive */
@media (max-width:640px) {
  .ssi-upload-cols { grid-template-columns:1fr; }
  .ssi-price-tiers { gap:8px; }
}
