
.zoomby {
  position: relative;
  display: inline-block;
  max-width: 100%;
  user-select: none;
}

.zoomby.zoomby--active img,
.zoomby.zoomby--active .zoomby__image {
  cursor: none;
}

.zoomby img,
.zoomby .zoomby__image {
  display: block;
  max-width: 100%;
  height: auto;
}

.zoomby__toggle {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(17, 24, 39, 0.08);
  border-radius: 10px;
  background: rgba(255,255,255,0.92);
  box-shadow: 0 8px 24px rgba(17, 24, 39, 0.12);
  cursor: pointer;
  transition: transform 160ms ease, opacity 160ms ease, background-color 160ms ease, box-shadow 160ms ease;
  z-index: 5;
}

.zoomby__toggle:hover { transform: scale(1.04); }
.zoomby__toggle:active { transform: scale(0.97); }
.zoomby__toggle.is-active { opacity: 1; }
.zoomby__toggle:not(.is-active) { opacity: 0.58; }
.zoomby__toggle.is-hidden { display: none; }
.zoomby__toggle-icon { font-size: 18px; line-height: 1; }

.zoomby__lens {
  position: fixed;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--zoomby-fade-duration, 180ms) ease;
  z-index: 2147483647;
  will-change: left, top, opacity;
}

.zoomby__lens.is-visible { opacity: 1; }

.zoomby__lens-shell {
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: var(--zoomby-stage-bg, #fff);
  /* border: 10px solid rgba(10, 10, 10, 0.5); */
  border: 6px solid #fff;
  box-shadow:
      0 0 0 10px rgba(128,128,128,1),
      0 10px 28px rgba(0,0,0,.12); 
  transform: translateZ(0);
}

.zoomby__lens-shell.is-soft {
  border-color: transparent;
  box-shadow: none;
}

.zoomby__lens-inner {
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  will-change: background-position, background-size;
  transform: translateZ(0);
}
