/* =============================================================
   SG STAFGROS — Single Product Widgets CSS v2
   ============================================================= */

/* Scoped CSS variables — single product widgets only */
.sg-sp-info,
.sg-sp-gallery,
.sg-sp-tabs,
.sg-sp-meta,
.sg-sp-quote-btn-wrap,
.sg-sp-variations,
.sg-sp-var-group,
.sg-swatch,
.sg-qp-backdrop,
.sg-qp-modal {
  --sg-red:       #e63128;
  --sg-red-dark:  #c52a22;
  --sg-dark:      #0d1b2a;
  --sg-mid:       #374151;
  --sg-muted:     #6b7280;
  --sg-light:     #9ca3af;
  --sg-green:     #0ea970;
  --sg-border:    #e5e7eb;
  --sg-bg:        #f8fafc;
  --sg-white:     #ffffff;
  --sg-radius:    12px;
  --sg-radius-lg: 18px;
  --sg-shadow-xs: 0 1px 4px rgba(0,0,0,.07);
  --sg-shadow:    0 4px 20px rgba(13,27,42,.09);
  --sg-ease:      cubic-bezier(.4,0,.2,1);
  --sg-dur:       .2s;
  /* Aliases for sg-variations.css compatibility */
  --sg-sp-red:    var(--wcdd-primary, #e63128);
  --sg-sp-dark:   var(--wcdd-dark, #0d1b2a);
  --sg-sp-green:  var(--wcdd-accent, #0ea970);
  --sg-sp-gray:   #718096;
  --sg-sp-border: #e5e7eb;
  --sg-sp-bg:     #f8fafc;
  --sg-sp-trans:  .2s ease;
}

.sg-sp-placeholder {
  background:#f0f4f8; border:2px dashed #c5cdd6;
  border-radius:var(--sg-radius); padding:32px;
  text-align:center; color:var(--sg-muted); font-size:14px;
}

/* ════ GALLERY ════════════════════════════════════════════════ */

.sg-sp-gallery { position:relative; user-select:none; }

.sg-sp-badge {
  position:absolute; top:14px; left:14px; z-index:10;
  padding:4px 11px; border-radius:30px;
  font-size:10px; font-weight:800; letter-spacing:.6px; text-transform:uppercase;
}
.sg-sp-badge--sale { background:var(--sg-red); color:#fff; }
.sg-sp-badge--new  { background:var(--sg-green); color:#fff; top:46px; }

.sg-sp-gallery__main {
  position:relative; overflow:hidden;
  border-radius:var(--sg-radius-lg);
  background:var(--sg-bg);
  aspect-ratio:1/1;
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--sg-shadow-xs);
}
.sg-sp-gallery__main-img {
  width:100%; height:100%; object-fit:contain;
  transition:transform .35s var(--sg-ease);
}
.sg-sp-gallery--zoom .sg-sp-gallery__main:hover .sg-sp-gallery__main-img { transform:scale(1.05); }
.sg-sp-gallery__main-link { display:block; width:100%; height:100%; }

.sg-sp-gallery__zoom-hint {
  position:absolute; bottom:12px; right:12px;
  width:32px; height:32px;
  background:rgba(255,255,255,.92); backdrop-filter:blur(4px);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  color:var(--sg-dark); opacity:0; transition:opacity var(--sg-dur);
  box-shadow:var(--sg-shadow-xs);
}
.sg-sp-gallery__main:hover .sg-sp-gallery__zoom-hint { opacity:1; }

.sg-sp-gallery--thumbs-bottom .sg-sp-gallery__thumbs {
  display:flex; gap:8px; margin-top:10px;
  overflow-x:auto; padding-bottom:2px; scrollbar-width:none;
}
.sg-sp-gallery--thumbs-bottom .sg-sp-gallery__thumbs::-webkit-scrollbar { display:none; }

.sg-sp-gallery--thumbs-left { display:flex; gap:10px; align-items:flex-start; }
.sg-sp-gallery--thumbs-left .sg-sp-gallery__thumbs {
  display:flex; flex-direction:column; gap:8px;
  flex-shrink:0; order:-1; max-height:480px;
  overflow-y:auto; scrollbar-width:none;
}
.sg-sp-gallery--thumbs-left .sg-sp-gallery__main { flex:1; }

.sg-sp-gallery__thumb {
  flex-shrink:0; width:70px; height:70px;
  border-radius:10px; border:2px solid var(--sg-border);
  overflow:hidden; background:var(--sg-bg); cursor:pointer; padding:0;
  transition:border-color var(--sg-dur),transform var(--sg-dur),box-shadow var(--sg-dur);
}
.sg-sp-gallery__thumb img { width:100%; height:100%; object-fit:contain; }
.sg-sp-gallery__thumb:hover { border-color:var(--sg-light); transform:translateY(-1px); box-shadow:var(--sg-shadow-xs); }
.sg-sp-gallery__thumb.is-active { border-color:var(--sg-red); transform:translateY(-1px); box-shadow:0 0 0 3px rgba(230,49,40,.15); }

/* Lightbox */
.sg-sp-lightbox { position:fixed; inset:0; z-index:99999; background:rgba(0,0,0,.9); backdrop-filter:blur(6px); display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity .25s; }
.sg-sp-lightbox.is-open { opacity:1; pointer-events:all; }
.sg-sp-lightbox__img { max-width:90vw; max-height:90vh; object-fit:contain; border-radius:4px; }
.sg-sp-lightbox__close { position:fixed; top:20px; right:24px; color:#fff; background:rgba(255,255,255,.14); border:none; width:44px; height:44px; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:26px; transition:background .15s; }
.sg-sp-lightbox__close:hover { background:rgba(255,255,255,.24); }
.sg-sp-lightbox__prev, .sg-sp-lightbox__next { position:fixed; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.13); border:none; color:#fff; width:48px; height:48px; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .15s; }
.sg-sp-lightbox__prev { left:20px; } .sg-sp-lightbox__next { right:20px; }
.sg-sp-lightbox__prev:hover, .sg-sp-lightbox__next:hover { background:rgba(255,255,255,.26); }

/* ════ INFO WIDGET ════════════════════════════════════════════ */

.sg-sp-info { display:flex; flex-direction:column; gap:16px; }

/* Brand */
.sg-sp-info__meta-top { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }

.sg-sp-info__brand-wrap {
  display:inline-flex; align-items:center; gap:8px;
  text-decoration:none; transition:opacity var(--sg-dur);
}
.sg-sp-info__brand-wrap:hover { opacity:.8; }

.sg-sp-info__brand-logo {
  max-height:36px; width:auto; max-width:130px;
  object-fit:contain; display:block;
  filter:grayscale(10%);
  transition:filter var(--sg-dur);
}
.sg-sp-info__brand-wrap:hover .sg-sp-info__brand-logo { filter:grayscale(0); }

.sg-sp-info__brand-name {
  font-size:11px; font-weight:700; text-transform:uppercase;
  letter-spacing:.7px; color:var(--sg-muted);
  background:var(--sg-bg); padding:3px 10px;
  border-radius:20px; border:1px solid var(--sg-border);
}

.sg-sp-info__sku { font-size:12px; color:var(--sg-light); }

/* Title */
.sg-sp-info__title {
  font-size:clamp(1.35rem,3vw,1.9rem); font-weight:800;
  color:var(--sg-dark); line-height:1.22; margin:0; letter-spacing:-.02em;
}

/* Rating */
.sg-sp-info__rating { display:flex; align-items:center; gap:8px; }
.sg-sp-stars { display:inline-flex; gap:2px; line-height:1; }
.sg-sp-info__rating-link { font-size:12px; color:var(--sg-muted); text-decoration:underline; text-underline-offset:2px; transition:color var(--sg-dur); }
.sg-sp-info__rating-link:hover { color:var(--sg-red); }

/* Price */
.sg-sp-info__price .price { font-size:2rem; font-weight:900; color:var(--sg-red); letter-spacing:-.03em; line-height:1; }
.sg-sp-info__price .price ins { text-decoration:none; }
.sg-sp-info__price .price del { font-size:1.1rem; color:var(--sg-light); margin-right:8px; font-weight:400; opacity:.75; }
.sg-price-hidden { display:inline-block; font-size:13px; font-weight:600; color:var(--sg-muted); background:var(--sg-bg); border:1.5px dashed var(--sg-border); border-radius:6px; padding:8px 16px; font-style:italic; }

/* Stock */
.sg-sp-info__stock {
  display:inline-flex; align-items:center; gap:7px;
  font-size:12px; font-weight:700; letter-spacing:.2px;
  padding:5px 14px; border-radius:30px; width:fit-content;
}
.sg-sp-info__stock-dot { width:7px; height:7px; border-radius:50%; display:inline-block; flex-shrink:0; }
.sg-sp-info__stock--in { color:var(--sg-green); background:rgba(14,169,112,.1); }
.sg-sp-info__stock--in .sg-sp-info__stock-dot { background:var(--sg-green); box-shadow:0 0 0 3px rgba(14,169,112,.2); }
.sg-sp-info__stock--out { color:#c53030; background:#fef2f2; }
.sg-sp-info__stock--out .sg-sp-info__stock-dot { background:#c53030; box-shadow:0 0 0 3px rgba(197,48,48,.18); }
.sg-sp-info__stock-qty { opacity:.7; font-weight:500; }

/* Short desc */
.sg-sp-info__short-desc { color:var(--sg-mid); font-size:14px; line-height:1.75; }
.sg-sp-info__short-desc p { margin:0 0 8px; }
.sg-sp-info__short-desc ul, .sg-sp-info__short-desc ol { padding-left:18px; margin:0; }

/* Divider */
.sg-sp-info__divider { border:none; border-top:1.5px solid var(--sg-border); margin:4px 0; }

/* Quantity */
.sg-sp-info__qty-wrap { display:flex; align-items:center; gap:14px; margin-bottom:12px; }
.sg-sp-info__qty-label { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; color:var(--sg-mid); min-width:60px; }
.sg-sp-info__qty-ctrl { display:inline-flex; align-items:center; border:1.5px solid var(--sg-border); border-radius:10px; overflow:hidden; height:46px; background:#fff; }
.sg-sp-info__qty-btn { width:44px; height:46px; background:var(--sg-bg); border:none; font-size:22px; font-weight:300; cursor:pointer; color:var(--sg-dark); display:flex; align-items:center; justify-content:center; transition:background var(--sg-dur),color var(--sg-dur); line-height:1; user-select:none; }
.sg-sp-info__qty-btn:hover { background:#eef0f3; color:var(--sg-red); }
.sg-sp-info__qty-input { width:54px; height:46px; text-align:center; border:none; border-left:1.5px solid var(--sg-border); border-right:1.5px solid var(--sg-border); font-size:16px; font-weight:700; color:var(--sg-dark); background:#fff; -moz-appearance:textfield; }
.sg-sp-info__qty-input::-webkit-inner-spin-button, .sg-sp-info__qty-input::-webkit-outer-spin-button { -webkit-appearance:none; }

/* Buttons */
.sg-sp-info__btn-row { display:flex; gap:10px; flex-wrap:wrap; }

.sg-sp-info__add-cart {
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  background:var(--sg-red); color:#fff; border:none; border-radius:12px;
  padding:0 26px; height:52px; font-size:14px; font-weight:800; letter-spacing:.02em;
  cursor:pointer; flex:1; min-width:160px;
  box-shadow:0 4px 14px rgba(230,49,40,.28);
  transition:background var(--sg-dur) var(--sg-ease),transform var(--sg-dur),box-shadow var(--sg-dur);
}
.sg-sp-info__add-cart:hover:not(:disabled) { background:var(--sg-red-dark); transform:translateY(-2px); box-shadow:0 8px 22px rgba(230,49,40,.35); }
.sg-sp-info__add-cart:disabled { opacity:.45; cursor:not-allowed; box-shadow:none; transform:none; }

.sg-sp-info__add-quote {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  background:transparent; color:var(--sg-dark); border:2px solid var(--sg-border);
  border-radius:12px; padding:0 20px; height:52px; font-size:13px; font-weight:700;
  cursor:pointer; white-space:nowrap;
  transition:border-color var(--sg-dur),background var(--sg-dur),transform var(--sg-dur);
}
.sg-sp-info__add-quote:hover:not(:disabled) { border-color:var(--sg-dark); background:var(--sg-bg); transform:translateY(-1px); }
.sg-sp-info__add-quote:disabled { opacity:.4; cursor:not-allowed; transform:none; }

.sg-sp-info__add-quote--primary {
  background:var(--sg-dark); color:#fff; border-color:var(--sg-dark);
  flex:1; min-width:200px;
  box-shadow:0 4px 14px rgba(13,27,42,.22);
}
.sg-sp-info__add-quote--primary:hover:not(:disabled) { background:var(--sg-red); border-color:var(--sg-red); box-shadow:0 8px 22px rgba(230,49,40,.28); }
.sg-sp-info__add-quote.is-added { background:var(--sg-green); border-color:var(--sg-green); color:#fff; pointer-events:none; }

.sg-sp-info__mode-hint { margin-top:6px; padding:8px 14px; background:#f0f4f8; border-radius:6px; color:var(--sg-muted); font-size:12px; }
.sg-sp-info__mode-hint a { color:var(--sg-red); }

/* Trust icons */
.sg-sp-info__trust {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:10px; padding:16px;
  background:linear-gradient(135deg,var(--sg-bg) 0%,#fff 100%);
  border-radius:var(--sg-radius); border:1px solid var(--sg-border);
  margin-top:4px;
}
.sg-sp-info__trust-item { display:flex; flex-direction:column; align-items:center; gap:7px; text-align:center; padding:12px 8px; border-radius:6px; transition:background var(--sg-dur); }
.sg-sp-info__trust-item:hover { background:rgba(230,49,40,.04); }
.sg-sp-info__trust-icon { color:var(--sg-red); width:36px; height:36px; background:rgba(230,49,40,.08); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.sg-sp-info__trust-item strong { display:block; font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.4px; color:var(--sg-dark); line-height:1.3; }
.sg-sp-info__trust-item span { font-size:11px; color:var(--sg-muted); line-height:1.4; }

/* ════ TABS WIDGET ════════════════════════════════════════════ */

.sg-sp-tabs__nav { display:flex; border-bottom:2px solid var(--sg-border); gap:2px; flex-wrap:wrap; margin-bottom:24px; }

.sg-sp-tabs--underline .sg-sp-tabs__tab { background:none; border:none; padding:13px 20px; font-size:14px; font-weight:700; color:var(--sg-muted); cursor:pointer; position:relative; transition:color var(--sg-dur); border-radius:6px 6px 0 0; }
.sg-sp-tabs--underline .sg-sp-tabs__tab::after { content:''; position:absolute; bottom:-2px; left:12px; right:12px; height:2px; background:transparent; border-radius:2px; transition:background var(--sg-dur); }
.sg-sp-tabs--underline .sg-sp-tabs__tab:hover { color:var(--sg-dark); }
.sg-sp-tabs--underline .sg-sp-tabs__tab.is-active { color:var(--sg-red); }
.sg-sp-tabs--underline .sg-sp-tabs__tab.is-active::after { background:var(--sg-red); }

.sg-sp-tabs--pill .sg-sp-tabs__nav { border-bottom:none; gap:8px; margin-bottom:20px; }
.sg-sp-tabs--pill .sg-sp-tabs__tab { background:var(--sg-bg); border:1.5px solid var(--sg-border); border-radius:30px; padding:9px 22px; font-size:13px; font-weight:700; cursor:pointer; color:var(--sg-muted); transition:all var(--sg-dur); }
.sg-sp-tabs--pill .sg-sp-tabs__tab:hover { border-color:var(--sg-dark); color:var(--sg-dark); }
.sg-sp-tabs--pill .sg-sp-tabs__tab.is-active { background:var(--sg-red); color:#fff; border-color:var(--sg-red); box-shadow:0 4px 12px rgba(230,49,40,.25); }

.sg-sp-tabs--boxed .sg-sp-tabs__nav { border-bottom:none; gap:0; }
.sg-sp-tabs--boxed .sg-sp-tabs__tab { border:1.5px solid var(--sg-border); border-bottom:none; background:var(--sg-bg); padding:13px 24px; font-size:13px; font-weight:700; cursor:pointer; color:var(--sg-muted); margin-right:-1px; transition:all var(--sg-dur); }
.sg-sp-tabs--boxed .sg-sp-tabs__tab.is-active { background:#fff; color:var(--sg-red); border-bottom:2px solid #fff; position:relative; z-index:1; }
.sg-sp-tabs--boxed .sg-sp-tabs__panel { border:1.5px solid var(--sg-border); border-radius:0 var(--sg-radius) var(--sg-radius); padding:24px; }

.sg-sp-tabs__panel { display:none; }
.sg-sp-tabs__panel.is-active { display:block; animation:sgTabIn .22s var(--sg-ease); }
@keyframes sgTabIn { from{opacity:0;transform:translateY(5px);}to{opacity:1;transform:translateY(0);} }

.sg-sp-tabs__description { line-height:1.8; color:var(--sg-mid); font-size:15px; }
.sg-sp-tabs__description h2, .sg-sp-tabs__description h3 { color:var(--sg-dark); margin-top:24px; }
.sg-sp-tabs__description img { max-width:100%; border-radius:var(--sg-radius); }

.sg-sp-attrs-table { width:100%; border-collapse:collapse; font-size:14px; }
.sg-sp-attrs-table th, .sg-sp-attrs-table td { padding:12px 16px; border-bottom:1px solid var(--sg-border); text-align:left; vertical-align:top; }
.sg-sp-attrs-table th { width:38%; font-weight:700; color:var(--sg-dark); background:var(--sg-bg); }
.sg-sp-attrs-table td { color:var(--sg-mid); }
.sg-sp-attrs-table tr:last-child th, .sg-sp-attrs-table tr:last-child td { border-bottom:none; }

/* ════ META WIDGET ════════════════════════════════════════════ */

.sg-sp-meta { display:flex; flex-direction:column; gap:10px; font-size:13px; }
.sg-sp-meta__row { display:flex; align-items:flex-start; gap:10px; flex-wrap:wrap; }
.sg-sp-meta__label { color:var(--sg-light); min-width:86px; flex-shrink:0; padding-top:2px; font-size:12px; text-transform:uppercase; letter-spacing:.4px; font-weight:600; }

.sg-sp-meta__brand-link { display:inline-flex; align-items:center; gap:6px; text-decoration:none; transition:opacity var(--sg-dur); }
.sg-sp-meta__brand-link:hover { opacity:.8; }
.sg-sp-meta__brand-logo { max-height:28px; width:auto; max-width:90px; object-fit:contain; filter:grayscale(15%); transition:filter var(--sg-dur); }
.sg-sp-meta__brand-link:hover .sg-sp-meta__brand-logo { filter:grayscale(0); }

.sg-sp-meta__value a { color:var(--sg-red); text-decoration:none; transition:opacity var(--sg-dur); }
.sg-sp-meta__value a:hover { opacity:.75; }

.sg-sp-meta__tag { display:inline-block; background:var(--sg-bg); border:1px solid var(--sg-border); border-radius:20px; padding:2px 10px; margin:2px; font-size:12px; color:var(--sg-mid); transition:border-color var(--sg-dur),color var(--sg-dur); }
.sg-sp-meta__tag:hover { border-color:var(--sg-red); color:var(--sg-red); }

.sg-sp-meta__share { display:flex; align-items:center; gap:10px; padding-top:6px; }
.sg-sp-meta__share-btns { display:flex; gap:7px; }
.sg-sp-meta__share-btn { width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; text-decoration:none; transition:transform var(--sg-dur),box-shadow var(--sg-dur); }
.sg-sp-meta__share-btn:hover { transform:translateY(-2px); box-shadow:0 4px 12px rgba(0,0,0,.2); }
.sg-sp-meta__share-btn--fb { background:#1877f2; } .sg-sp-meta__share-btn--wa { background:#25d366; } .sg-sp-meta__share-btn--li { background:#0a66c2; }

/* ════ QUOTE BUTTON WIDGET ════════════════════════════════════ */

.sg-sp-quote-btn-wrap--full { display:flex; flex-direction:column; gap:8px; }
.sg-sp-quote-btn-wrap--auto { display:inline-flex; align-items:center; gap:14px; flex-wrap:wrap; }

.sg-sp-quote-btn {
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  background:var(--sg-dark); color:#fff; border:none; border-radius:12px;
  padding:0 30px; height:52px; font-size:14px; font-weight:800; letter-spacing:.02em;
  cursor:pointer; width:100%; max-width:380px;
  box-shadow:0 4px 14px rgba(13,27,42,.2);
  transition:background var(--sg-dur) var(--sg-ease),transform var(--sg-dur),box-shadow var(--sg-dur);
}
.sg-sp-quote-btn-wrap--auto .sg-sp-quote-btn { width:auto; max-width:none; }
.sg-sp-quote-btn:hover:not(:disabled) { background:var(--sg-red); transform:translateY(-2px); box-shadow:0 8px 22px rgba(230,49,40,.3); }
.sg-sp-quote-btn:disabled { opacity:.42; cursor:not-allowed; transform:none; box-shadow:none; }
.sg-sp-quote-btn.is-added { background:var(--sg-green); pointer-events:none; }

.sg-sp-quote-btn-note { font-size:12px; color:var(--sg-light); text-align:center; margin:0; display:flex; align-items:center; justify-content:center; gap:5px; }
.sg-sp-quote-btn-note--prompt { color:var(--sg-red); font-weight:600; font-size:12px; display:flex; align-items:center; gap:5px; }

/* ════ RESPONSIVE ═════════════════════════════════════════════ */

@media (max-width:768px) {
  .sg-sp-info__btn-row { flex-direction:column; }
  .sg-sp-info__add-cart, .sg-sp-info__add-quote--primary { min-width:0; width:100%; }
  .sg-sp-info__add-quote { width:100%; justify-content:center; }
  .sg-sp-info__trust { grid-template-columns:1fr; gap:6px; padding:12px; }
  .sg-sp-info__trust-item { flex-direction:row; text-align:left; padding:10px; }
  .sg-sp-info__trust-icon { width:32px; height:32px; flex-shrink:0; }
  .sg-sp-gallery--thumbs-left { flex-direction:column; }
  .sg-sp-gallery--thumbs-left .sg-sp-gallery__thumbs { flex-direction:row; order:1; max-height:none; }
  .sg-sp-quote-btn { max-width:100%; }
  .sg-sp-info__qty-wrap { flex-direction:column; align-items:flex-start; gap:8px; }
}

@media (max-width:480px) {
  .sg-sp-info__title { font-size:1.4rem; }
  .sg-sp-info__price .price { font-size:1.7rem; }
}
