body.pe-open{overflow:hidden!important;}
.store-product-list{
  display:grid!important;
  grid-template-columns:repeat(12,minmax(0,1fr))!important;
  gap:12px!important;
  padding:16px!important;
  max-width:none!important;
  margin:0 auto!important;
}
.store-product-list .card{
  width:auto!important;
  min-width:0!important;
  min-height:226px!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:stretch!important;
  gap:0!important;
  border-radius:12px!important;
  border:1px solid #dbeafe!important;
  background:#fff!important;
  box-shadow:0 8px 18px rgba(15,23,42,.045)!important;
  overflow:visible!important;
}
.store-product-list .card:hover{
  transform:none!important;
  border-color:#93c5fd!important;
  box-shadow:0 12px 24px rgba(15,23,42,.08)!important;
}
.store-product-list .cimg{
  width:100%!important;
  height:118px!important;
  min-height:118px!important;
  border-radius:11px 11px 0 0!important;
  border-right:none!important;
  border-bottom:1px solid #e5efff!important;
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%)!important;
}
.store-product-list .cimg img{
  max-width:88%!important;
  max-height:88%!important;
  object-fit:contain!important;
}
.store-product-list .cbody{
  padding:10px 10px 12px!important;
  min-width:0!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:flex-start!important;
  gap:5px!important;
  flex:1!important;
}
.store-product-list .cmini{
  order:1!important;
  margin:0!important;
  color:#64748b!important;
  font:900 .58rem "Outfit",sans-serif!important;
  text-transform:uppercase!important;
  letter-spacing:.06em!important;
}
.store-product-list .cname{
  order:2!important;
  margin:0!important;
  color:#0f172a!important;
  font:950 .68rem/1.12 "Outfit",sans-serif!important;
  letter-spacing:0!important;
  display:-webkit-box!important;
  -webkit-line-clamp:3!important;
  -webkit-box-orient:vertical!important;
  overflow:hidden!important;
}
.store-product-list .ccode{
  order:3!important;
  margin-top:auto!important;
  color:#475569!important;
  font:850 .58rem "Outfit",sans-serif!important;
}
.store-product-list .pe-card-actions{
  position:absolute!important;
  top:7px!important;
  left:7px!important;
  right:7px!important;
  opacity:0!important;
  transform:translateY(-3px)!important;
  pointer-events:none!important;
  justify-content:flex-end!important;
  padding-right:0!important;
  min-width:0!important;
}
.product-editor-enabled .store-product-list .card:hover .pe-card-actions,
.product-editor-enabled .store-product-list .card:focus-within .pe-card-actions{
  opacity:1!important;
  transform:none!important;
  pointer-events:auto!important;
}
.store-product-list .pe-icon-btn{
  height:26px!important;
  padding:0 7px!important;
  font-size:.56rem!important;
  background:#f8fafc!important;
}
.store-product-list .new-badge,
.store-product-list .list-badge{
  transform:scale(.86)!important;
  transform-origin:top left!important;
}
@media(max-width:820px){
  .store-product-list{padding:10px!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;}
  .store-product-list .card{
    min-height:218px!important;
  }
  .store-product-list .cimg{
    height:112px!important;
    min-height:112px!important;
  }
  .store-product-list .cbody{
    gap:4px!important;
  }
}
@media(min-width:821px) and (max-width:1100px){
  .store-product-list{grid-template-columns:repeat(6,minmax(0,1fr))!important;}
}
@media(min-width:1101px){
  .store-product-list{grid-template-columns:repeat(12,minmax(0,1fr))!important;}
}
#vs #shead{
  position:sticky!important;
  top:0!important;
  z-index:160!important;
  background:rgba(255,255,255,.96)!important;
  backdrop-filter:blur(12px) saturate(115%)!important;
  -webkit-backdrop-filter:blur(12px) saturate(115%)!important;
  border-bottom:1px solid rgba(219,234,254,.9)!important;
  box-shadow:0 12px 28px rgba(15,23,42,.08)!important;
}
.product-editor-enabled #shead{position:sticky!important;}
.pe-toolbar{
  margin-left:auto;
  display:flex;
  align-items:center;
  gap:9px;
  flex-wrap:wrap;
}
.pe-toolbar span{
  height:28px;
  display:inline-flex;
  align-items:center;
  padding:0 10px;
  border-radius:999px;
  background:#eef5ff;
  color:#005EB8;
  font:900 .66rem "Outfit",sans-serif;
  letter-spacing:.08em;
}
.pe-new-btn{
  border:none;
  height:34px;
  padding:0 13px;
  border-radius:999px;
  background:#005EB8;
  color:#fff;
  font:900 .76rem "Outfit",sans-serif;
  cursor:pointer;
  box-shadow:0 10px 22px rgba(0,94,184,.18);
}
.product-editor-enabled #grid .card{
  position:relative;
  overflow:visible!important;
}
.product-editor-enabled #grid .card.pe-dragging{
  opacity:.55;
  transform:scale(.985);
  box-shadow:0 18px 36px rgba(0,94,184,.2);
}
.pe-card-actions{
  position:absolute;
  top:8px;
  left:8px;
  right:8px;
  z-index:20;
  display:flex;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:6px;
  opacity:0;
  transform:translateY(-3px);
  transition:opacity .16s ease,transform .16s ease;
  pointer-events:none;
}
.product-editor-enabled .card:hover .pe-card-actions,
.product-editor-enabled .card:focus-within .pe-card-actions{
  opacity:1;
  transform:none;
  pointer-events:auto;
}
.pe-icon-btn{
  border:1px solid rgba(0,94,184,.18);
  background:rgba(255,255,255,.96);
  color:#005EB8;
  border-radius:999px;
  height:28px;
  padding:0 9px;
  font:900 .64rem "Outfit",sans-serif;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(15,23,42,.12);
}
.pe-icon-btn.pe-drag-handle{
  cursor:grab;
  color:#334155;
}
.pe-icon-btn.danger{
  border-color:rgba(220,38,38,.18);
  color:#dc2626;
}
.pe-save-order,.pe-cancel-order{
  border:none;
  height:34px;
  padding:0 13px;
  border-radius:999px;
  font:900 .76rem "Outfit",sans-serif;
  cursor:pointer;
}
.pe-save-order{background:#16a34a;color:#fff;box-shadow:0 10px 22px rgba(22,163,74,.18);}
.pe-cancel-order{background:#f1f5f9;color:#475569;}
.pe-save-order:disabled,.pe-cancel-order:disabled{
  opacity:.45;
  cursor:not-allowed;
  box-shadow:none;
}
body.pe-order-dirty .pe-toolbar span{
  background:#ecfdf5;
  color:#047857;
}
.pe-bk{
  position:fixed;
  inset:0;
  z-index:17000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(15,23,42,.58);
  backdrop-filter:blur(14px) saturate(112%);
  -webkit-backdrop-filter:blur(14px) saturate(112%);
  overflow:auto;
}
.pe-bk.open{display:flex;}
.pe-modal{
  width:min(920px,calc(100vw - 32px));
  max-height:calc(100dvh - 32px);
  display:grid;
  grid-template-columns:minmax(0,1fr) 240px;
  background:#fff;
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 34px 90px rgba(15,23,42,.42);
  position:relative;
}
.pe-close{
  position:absolute;
  right:16px;
  top:16px;
  z-index:2;
  width:34px;
  height:34px;
  border:none;
  border-radius:50%;
  background:#f8fafc;
  color:#64748b;
  cursor:pointer;
  font:900 1rem "Outfit",sans-serif;
}
.pe-head{
  grid-column:1/-1;
  padding:24px 28px 16px;
  border-bottom:1px solid #edf1f6;
}
.pe-head span{
  color:#005EB8;
  font:950 .68rem "Outfit",sans-serif;
  letter-spacing:.1em;
}
.pe-head h3{
  margin:5px 0 2px;
  color:#0f172a;
  font:950 1.25rem/1.15 "Outfit",sans-serif;
}
.pe-head p{margin:0;color:#64748b;font:750 .78rem/1.4 "Outfit",sans-serif;}
.pe-form{
  padding:20px 28px 24px;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:13px;
  overflow:auto;
}
.pe-form label{display:flex;flex-direction:column;gap:6px;min-width:0;}
.pe-form label.wide{grid-column:1/-1;}
.pe-form label span{
  color:#64748b;
  font:900 .66rem "Outfit",sans-serif;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.pe-form input,.pe-form select,.pe-form textarea{
  width:100%;
  border:1px solid #dbe4ef;
  border-radius:13px;
  background:#fbfcfe;
  color:#0f172a;
  font:750 .86rem "Outfit",sans-serif;
  outline:none;
  padding:11px 12px;
  box-sizing:border-box;
}
.pe-form textarea{resize:vertical;line-height:1.45;}
.pe-form input:focus,.pe-form select:focus,.pe-form textarea:focus{
  border-color:#8bbdf1;
  box-shadow:0 0 0 4px rgba(0,94,184,.08);
  background:#fff;
}
.pe-check{
  flex-direction:row!important;
  align-items:center;
  gap:10px!important;
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-radius:13px;
  padding:11px 12px;
}
.pe-check input{width:16px!important;height:16px;padding:0;}
.pe-preview{
  border-left:1px solid #edf1f6;
  background:linear-gradient(180deg,#f8fbff 0%,#fff 100%);
  padding:22px;
  display:flex;
  flex-direction:column;
  gap:10px;
  min-width:0;
}
#pe-preview-img{
  aspect-ratio:1;
  border:1px solid #dbeafe;
  border-radius:20px;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  padding:12px;
}
#pe-preview-img img{width:100%;height:100%;object-fit:contain;}
#pe-preview-img span{color:#94a3b8;font:850 .8rem "Outfit",sans-serif;}
.pe-preview strong{color:#0f172a;font:950 .86rem/1.2 "Outfit",sans-serif;}
.pe-preview small{color:#64748b;font:850 .72rem "Outfit",sans-serif;}
.pe-actions{
  grid-column:1/-1;
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  gap:10px;
  align-items:center;
  padding:16px 28px 22px;
  border-top:1px solid #edf1f6;
}
.pe-actions button{
  border:none;
  border-radius:999px;
  height:40px;
  padding:0 16px;
  cursor:pointer;
  font:900 .8rem "Outfit",sans-serif;
}
.pe-delete{background:#fff1f2;color:#dc2626;}
.pe-cancel{background:#f1f5f9;color:#475569;}
.pe-save{background:#005EB8;color:#fff;box-shadow:0 12px 24px rgba(0,94,184,.18);}
.pe-confirm-bk{
  position:fixed;
  inset:0;
  z-index:18000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
  background:rgba(15,23,42,.55);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.pe-confirm-bk.open{display:flex;}
.pe-confirm{
  width:min(420px,100%);
  background:#fff;
  border-radius:22px;
  padding:24px;
  box-shadow:0 28px 70px rgba(15,23,42,.35);
}
.pe-confirm h3{margin:0 0 8px;color:#0f172a;font:950 1.12rem/1.15 "Outfit",sans-serif;}
.pe-confirm p{margin:0;color:#64748b;font:750 .86rem/1.5 "Outfit",sans-serif;}
.pe-confirm-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px;}
.pe-confirm-actions button{
  border:none;
  border-radius:999px;
  height:40px;
  padding:0 18px;
  cursor:pointer;
  font:900 .82rem "Outfit",sans-serif;
}
.pe-confirm-no{background:#f1f5f9;color:#475569;}
.pe-confirm-yes,.pe-confirm-ok{background:#dc2626;color:#fff;}
@media(max-width:760px){
  .pe-bk{padding:12px;}
  .pe-modal{grid-template-columns:1fr;width:100%;border-radius:20px;}
  .pe-preview{display:none;}
  .pe-form{grid-template-columns:1fr;padding:18px;}
  .pe-head{padding:22px 18px 14px;}
  .pe-actions{grid-template-columns:1fr; padding:14px 18px 18px;}
  .pe-actions span{display:none;}
  .pe-actions button{width:100%;}
  .pe-toolbar{width:100%;margin-left:0;justify-content:flex-start;}
}
