:root{
  --pm-overlay: rgba(11,11,15,.58);
}

.pm-overlay{
  position:fixed;
  inset:0;
  background:var(--pm-overlay);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  z-index:120;
}

.pm-dialog{
  width:min(1040px, 100%);
  max-height:min(86vh, 900px);
  overflow:hidden;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.98);
  box-shadow: 0 30px 80px rgba(16,24,40,.30);
  transform: translateY(6px);
  opacity:0;
  transition: opacity .18s ease, transform .18s ease;
}

.pm-dialog{
  opacity:1;
  transform: translateY(0);
}

.pm-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 14px;
  border-bottom:1px solid rgba(16,24,40,.08);
}

.pm-title{
  font-weight:950;
  letter-spacing:-.3px;
  font-size:15px;
}

.pm-close{
  width:40px;
  height:40px;
  border-radius:14px;
  border:1px solid rgba(16,24,40,.12);
  background:#fff;
  cursor:pointer;
  font-weight:900;
  color:var(--text);
}

.pm-close:hover{border-color:rgba(225,6,0,.30)}

.pm-body{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:0;
  max-height:calc(86vh - 64px);
  min-height:0;
}

.pm-media{
  padding:14px;
  border-right:1px solid rgba(16,24,40,.08);
  display:flex;
  flex-direction:column;
  gap:10px;
  min-height:0;
}

.pm-stage{
  position:relative;
  border-radius:18px;
  border:1px solid rgba(16,24,40,.10);
  background:linear-gradient(135deg, rgba(0,0,0,.03), rgba(225,6,0,.08));
  overflow:hidden;
  height:min(420px, 44vh);
  user-select:none;
  touch-action:pan-y;
}

.pm-stage img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
  transform:scale(1);
  transition: transform .22s cubic-bezier(.2,.9,.2,1);
  will-change: transform;
}

.pm-stage{cursor:zoom-in}
.pm-stage.is-zoom{cursor:zoom-out}
.pm-stage.is-zoom img{transform:scale(2.2)}

.pm-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:44px;
  height:44px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.45);
  background:rgba(255,255,255,.92);
  cursor:pointer;
  font-weight:900;
  color:var(--text);
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 12px 28px rgba(16,24,40,.16);
}

.pm-nav:hover{filter:brightness(1.02)}
.pm-nav.prev{left:10px}
.pm-nav.next{right:10px}

.pm-thumbs{
  display:flex;
  gap:10px;
  overflow:auto;
  padding-bottom:4px;
}

.pm-thumb{
  width:64px;
  height:64px;
  flex:0 0 auto;
  border-radius:16px;
  border:1px solid rgba(16,24,40,.12);
  background:#fff;
  overflow:hidden;
  cursor:pointer;
}

.pm-thumb img{width:100%;height:100%;object-fit:contain;display:block}
.pm-thumb[aria-current="true"]{border-color:rgba(225,6,0,.55); box-shadow:0 0 0 3px rgba(225,6,0,.10)}

.pm-info{
  padding:14px;
  overflow:auto;
  min-height:0;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
}

.pm-brand{color:var(--muted2); font-size:12px; margin-top:2px}
.pm-price{color:var(--red); font-weight:950; font-size:18px; margin-top:10px}
.pm-price.locked{color:var(--muted2); font-weight:850; font-size:14px}
.pm-desc{color:var(--muted); margin-top:12px; line-height:1.7}

.pm-actions{margin-top:14px; display:flex; gap:10px; flex-wrap:wrap; align-items:center}

.pm-loading{
  color:var(--muted);
  padding:14px;
}

.product .img img{
  transform:scale(1);
  transition: transform .22s cubic-bezier(.2,.9,.2,1);
  will-change: transform;
}

.product .img:hover img,
.product .img.is-zoom img{
  transform:scale(1.06);
}

.pm-lightbox{
  position:fixed;
  inset:0;
  background:rgba(11,11,15,.72);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  z-index:130;
}

.pm-lb{
  width:min(1040px, 100%);
  max-height:min(86vh, 900px);
  border-radius:20px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.20);
  box-shadow: 0 30px 80px rgba(16,24,40,.30);
  position:relative;
  overflow:hidden;
}

.pm-lb-img{
  width:100%;
  height:min(86vh, 900px);
  object-fit:contain;
  display:block;
}

.pm-lb-close{
  position:absolute;
  top:12px;
  right:12px;
  width:42px;
  height:42px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.30);
  background:rgba(255,255,255,.10);
  color:#fff;
  cursor:pointer;
  font-weight:900;
}

.pm-lb-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:44px;
  height:44px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.30);
  background:rgba(255,255,255,.10);
  cursor:pointer;
  font-weight:900;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 12px 28px rgba(0,0,0,.22);
}

.pm-lb-nav.prev{left:12px}
.pm-lb-nav.next{right:12px}

@media (max-width: 980px){
  .pm-body{grid-template-columns:1fr}
  .pm-media{border-right:0;border-bottom:1px solid rgba(16,24,40,.08)}
  .pm-stage{height:min(360px, 42vh)}
}
