
.pps-wrap{max-width:1320px;margin:0 auto;padding:140px 18px 40px;box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;color:#111}
.pps-product-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(360px,.95fr);gap:32px;align-items:start}
.pps-gallery-panel,.pps-product-panel,.pps-history{min-width:0}
.pps-product-panel{background:#fff;border:1px solid #ddd2c8;border-radius:28px;padding:28px 32px;position:sticky;top:120px;align-self:start}
.pps-kicker{letter-spacing:.18em;text-transform:uppercase;color:#8a837b;font-size:14px;margin-bottom:18px}.pps-title{font-size:62px;line-height:.98;margin:0 0 12px;font-weight:700}.pps-price{font-size:26px;margin-bottom:12px}.pps-subtitle{font-size:18px;line-height:1.6;color:#555;margin-bottom:22px}
.pps-gallery,.pps-main-media{position:relative}.pps-main-media{border-radius:28px;overflow:hidden;background:#eee;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center}.pps-slide{display:none;width:100%;height:100%}.pps-slide.is-active{display:block}.pps-slide img,.pps-slide video{width:100%;height:100%;object-fit:cover;display:block}
.pps-nav,.pps-history-arrow{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;border:none;border-radius:999px;background:rgba(140,140,140,.8);color:#fff;font-size:44px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:4}.pps-prev,.pps-history-prev{left:18px}.pps-next,.pps-history-next{right:18px}
.pps-thumbs,.pps-history-thumbs{display:flex;gap:14px;flex-wrap:wrap;margin-top:18px}.pps-thumbs button,.pps-history-thumbs button{border:2px solid #ddd2c8;border-radius:18px;background:#fff;padding:0;cursor:pointer;overflow:hidden}.pps-thumbs button.is-active,.pps-history-thumbs button.is-active{border-color:#111}.pps-thumbs img,.pps-history-thumbs img{width:160px;height:160px;object-fit:cover;display:block}.pps-thumbs span{display:block;padding:18px}
.pps-option-group,.pps-field{margin-bottom:22px}.pps-option-label,.pps-field>label{display:block;font-weight:700;font-size:18px;margin-bottom:12px}.pps-option-label span,.pps-field>label span{color:#e5527a}.pps-choice-row{display:flex;flex-wrap:wrap;gap:12px}.pps-choice{position:relative;display:block}.pps-choice input{position:absolute;opacity:0;pointer-events:none}.pps-choice span{display:inline-flex;align-items:center;justify-content:center;min-width:74px;padding:13px 18px;border:1.5px solid #111;border-radius:999px;background:#fff;color:#111;font-size:24px;line-height:1.1}.pps-choice input:checked+span{background:#111;color:#fff}.pps-swatch-choice span{padding:8px;border:none;background:transparent}.pps-swatch-choice em{display:block;width:44px;height:44px;background:var(--pps-swatch,#ddd);border:1px solid #bbb}.pps-swatch-choice b{display:none}.pps-swatch-choice input:checked+span em{outline:3px solid #111;outline-offset:3px}
.pps-option-select select,.pps-field input[type=text],.pps-field textarea{width:100%;border:1.5px solid #ddd2c8;border-radius:20px;padding:18px 20px;font-size:17px;box-sizing:border-box}.pps-field textarea{min-height:120px}
.pps-upload-wrap{display:flex;align-items:center;gap:14px;flex-wrap:wrap;border:1.5px solid #ddd2c8;border-radius:20px;padding:16px;background:#fff}.pps-real-file{position:absolute;opacity:0;pointer-events:none;width:0;height:0}.pps-change-photo-btn{border:1.5px solid #c2b5a8;background:#fff;color:#111;border-radius:14px;padding:12px 16px;font-size:17px;cursor:pointer}.pps-file-name{color:#666;word-break:break-all;flex:1}.pps-upload-preview{margin-bottom:12px}.pps-upload-preview img{width:140px;height:140px;object-fit:cover;border-radius:18px;border:1px solid #ddd2c8;display:block}
.pps-help{font-size:14px;color:#7a7670;margin-top:10px;line-height:1.6}.pps-confirm{display:flex;gap:12px;align-items:flex-start;margin:22px 0;font-size:17px;line-height:1.6}.pps-confirm input{margin-top:5px}
.pps-generate-btn,.pps-use-image-btn,.pps-delete-image-btn{width:100%;border-radius:999px;padding:20px 24px;font-size:21px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:.2s}.pps-generate-btn,.pps-use-image-btn{background:#111;color:#fff;border:none}.pps-delete-image-btn{background:#fff;color:#7b2b2b;border:1.5px solid #d6c7bb}.pps-generate-btn:hover,.pps-generate-btn:focus,.pps-use-image-btn:hover,.pps-use-image-btn:focus{background:#111;color:#fff}.pps-delete-image-btn:hover,.pps-delete-image-btn:focus{background:#fff;color:#7b2b2b}
.pps-status{margin-top:12px;min-height:24px;color:#666}.pps-accordions details{border-top:1px solid #e7ddd4;padding:18px 0}.pps-accordions summary{cursor:pointer;font-weight:700;font-size:18px}.pps-history{margin-top:34px;border:1px solid #ddd2c8;border-radius:28px;padding:30px;background:#fff}.pps-history-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.pps-history-head h2{margin:0;font-size:34px;line-height:1.05}.pps-history-count{font-size:18px;color:#666}.pps-history-main-wrap{position:relative}.pps-history-main{margin-top:18px;border-radius:28px;background:#f6f5f3;overflow:hidden;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center}.pps-history-main img{width:100%;height:100%;object-fit:contain;display:block}.pps-history-edit-row{display:flex;gap:14px;flex-wrap:wrap;margin:16px 0 8px}.pps-edit-feature-btn{display:flex;flex-direction:column;align-items:center;gap:10px;min-width:110px;padding:12px;background:#fff;border:1.5px solid #ddd2c8;border-radius:20px;cursor:pointer;color:#111}.pps-edit-feature-btn span,.pps-edit-feature-btn img{display:flex;align-items:center;justify-content:center;width:68px;height:68px;border-radius:18px;background:#111;color:#fff;object-fit:cover}.pps-edit-feature-btn em{font-style:normal;font-size:14px;text-align:center;display:block;max-width:96px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#111}.pps-edit-feature-btn:hover,.pps-edit-feature-btn:focus,.pps-edit-feature-btn:hover em,.pps-edit-feature-btn:focus em{color:#111;background:#fff}.pps-history-actions{display:grid;grid-template-columns:1fr;gap:14px;margin:14px 0}.pps-history-thumbs img{width:90px;height:90px}
.pps-global-toast{position:fixed;right:18px;bottom:18px;background:#111;color:#fff;width:min(360px,calc(100vw - 24px));border-radius:28px;padding:22px;z-index:9999;box-shadow:0 24px 56px rgba(0,0,0,.25)}.pps-global-toast strong{display:block;font-size:20px;margin-bottom:10px}.pps-global-toast .pps-toast-text{line-height:1.55;color:#e6e6e6;margin-bottom:14px}.pps-toast-actions{display:flex;gap:12px;flex-wrap:wrap}.pps-toast-actions button{border-radius:999px;padding:12px 18px;font-size:15px;font-weight:700;cursor:pointer}.pps-toast-view{background:#fff;color:#111;border:none}.pps-toast-cancel{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4)}.pps-toast-view:hover,.pps-toast-view:focus{background:#fff;color:#111}.pps-toast-cancel:hover,.pps-toast-cancel:focus{background:transparent;color:#fff}
.pps-crop-modal{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;padding:18px;z-index:10000}.pps-crop-card{background:#fff;border-radius:24px;padding:20px;max-width:820px;width:min(92vw,820px)}.pps-crop-stage{position:relative;overflow:hidden;background:#f0eee9;border-radius:20px;border:1px solid #ddd2c8;margin-bottom:16px}.pps-crop-stage::before{content:'';display:block;padding-top:100%}.pps-crop-stage img{position:absolute;top:0;left:0;transform-origin:center center;will-change:transform;max-width:none;user-select:none;-webkit-user-drag:none}.pps-crop-controls label{display:block;font-weight:700}.pps-crop-zoom{width:100%}.pps-rotate-row{display:flex;gap:10px;margin-top:12px}.pps-rotate-row button,.pps-crop-actions button{border-radius:999px;border:1px solid #ddd2c8;background:#fff;padding:12px 16px;cursor:pointer}.pps-crop-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.pps-crop-apply{background:#111 !important;color:#fff !important;border-color:#111 !important}
@media (max-width: 1100px){.pps-title{font-size:48px}.pps-product-grid{grid-template-columns:1fr}.pps-product-panel{position:relative;top:0}.pps-thumbs img{width:120px;height:120px}}
@media (max-width: 767px){.pps-wrap{padding:114px 14px 30px}.pps-product-grid{gap:18px}.pps-main-media{aspect-ratio:1/1}.pps-product-panel{padding:22px 18px}.pps-title{font-size:40px}.pps-kicker{font-size:12px}.pps-nav,.pps-history-arrow{width:48px;height:48px;font-size:38px}.pps-thumbs{display:flex;overflow-x:auto;flex-wrap:nowrap}.pps-thumbs img{width:94px;height:94px}.pps-history-head h2{font-size:28px}.pps-history-thumbs{overflow-x:auto;flex-wrap:nowrap}.pps-history{padding:18px}.pps-crop-card{padding:16px}}


/* v0.4.5 critical fixes */
.pps-crop-modal[hidden],
.pps-crop-modal[hidden="hidden"] {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.pps-crop-modal:not([hidden]) {
  display: flex !important;
}

.pps-wrap button,
.pps-global-toast button {
  text-decoration: none !important;
}

.pps-wrap button:hover,
.pps-wrap button:focus,
.pps-wrap button:active,
.pps-wrap button:visited,
.pps-wrap button:hover *,
.pps-wrap button:focus *,
.pps-wrap button:active *,
.pps-wrap button:visited *,
.pps-global-toast button:hover,
.pps-global-toast button:focus,
.pps-global-toast button:active,
.pps-global-toast button:visited,
.pps-global-toast button:hover *,
.pps-global-toast button:focus *,
.pps-global-toast button:active *,
.pps-global-toast button:visited * {
  text-decoration: none !important;
}

.pps-change-photo-btn,
.pps-change-photo-btn:hover,
.pps-change-photo-btn:focus,
.pps-change-photo-btn:active,
.pps-crop-cancel,
.pps-crop-cancel:hover,
.pps-crop-cancel:focus,
.pps-crop-cancel:active,
.pps-rotate-left,
.pps-rotate-left:hover,
.pps-rotate-left:focus,
.pps-rotate-left:active,
.pps-rotate-right,
.pps-rotate-right:hover,
.pps-rotate-right:focus,
.pps-rotate-right:active,
.pps-edit-feature-btn,
.pps-edit-feature-btn:hover,
.pps-edit-feature-btn:focus,
.pps-edit-feature-btn:active,
.pps-edit-feature-btn em,
.pps-edit-feature-btn:hover em,
.pps-edit-feature-btn:focus em,
.pps-edit-feature-btn:active em,
.pps-delete-image-btn,
.pps-delete-image-btn:hover,
.pps-delete-image-btn:focus,
.pps-delete-image-btn:active,
.pps-toast-view,
.pps-toast-view:hover,
.pps-toast-view:focus,
.pps-toast-view:active {
  color: #111 !important;
}

.pps-delete-image-btn,
.pps-delete-image-btn:hover,
.pps-delete-image-btn:focus,
.pps-delete-image-btn:active {
  color: #7b2b2b !important;
  background: #fff !important;
}

.pps-generate-btn,
.pps-generate-btn:hover,
.pps-generate-btn:focus,
.pps-generate-btn:active,
.pps-use-image-btn,
.pps-use-image-btn:hover,
.pps-use-image-btn:focus,
.pps-use-image-btn:active,
.pps-crop-apply,
.pps-crop-apply:hover,
.pps-crop-apply:focus,
.pps-crop-apply:active {
  color: #fff !important;
  background: #111 !important;
}

.pps-toast-cancel,
.pps-toast-cancel:hover,
.pps-toast-cancel:focus,
.pps-toast-cancel:active {
  color: #fff !important;
  background: transparent !important;
}

.pps-crop-card {
  max-height: 92vh;
  overflow: auto;
}

.pps-crop-stage {
  max-height: 62vh;
}

@media (min-width: 768px) {
  .pps-crop-card {
    width: min(760px, 82vw);
  }
}

@media (max-width: 767px) {
  .pps-crop-stage {
    max-height: 52vh;
  }
}


/* v0.4.6 stability/layout fixes */
.pps-product-grid { align-items: start !important; }
.pps-product-panel { position: relative !important; top: auto !important; }
.pps-gallery-panel, .pps-product-panel { align-self: start !important; }
.pps-history[hidden], .pps-crop-modal[hidden] { display: none !important; }

.pps-swatch-choice input:checked + span { background: transparent !important; color: inherit !important; }
.pps-swatch-choice span { background: transparent !important; border-radius: 0 !important; min-width: 0 !important; padding: 8px !important; }
.pps-swatch-choice em { border-radius: 0 !important; }
.pps-swatch-choice input:checked + span em { outline: 3px solid #111 !important; outline-offset: 4px !important; }

.pps-upload-preview { cursor: pointer; }
.pps-crop-stage img {
  position: absolute !important;
  max-width: none !important;
  object-fit: initial !important;
  transform-origin: center center !important;
  user-select: none !important;
  -webkit-user-drag: none !important;
  cursor: grab;
}
.pps-crop-stage:active img { cursor: grabbing; }
.pps-crop-controls label { margin: 12px 0 !important; display:block !important; }
.pps-crop-controls input[type="range"] { width: 100% !important; }

.pps-wrap button, .pps-wrap button *, .pps-global-toast button, .pps-global-toast button * { color: inherit !important; }
.pps-edit-feature-btn, .pps-edit-feature-btn *, .pps-change-photo-btn, .pps-change-photo-btn *, .pps-toast-view, .pps-toast-view * { color: #111 !important; }
.pps-delete-image-btn, .pps-delete-image-btn * { color: #7b2b2b !important; }
.pps-generate-btn, .pps-generate-btn *, .pps-use-image-btn, .pps-use-image-btn *, .pps-crop-apply, .pps-crop-apply * { color: #fff !important; }
.pps-toast-cancel, .pps-toast-cancel * { color: #fff !important; }
.pps-edit-feature-btn:hover, .pps-edit-feature-btn:focus { background: #fff !important; color: #111 !important; }

.pps-history-main { background: #f7f6f3 !important; }
.pps-history-main img[src=""] { display: none !important; }

@media (min-width: 1101px) {
  .pps-wrap { max-width: 1420px !important; padding-top: 145px !important; }
  .pps-product-grid { grid-template-columns: minmax(0, 1fr) minmax(390px, .82fr) !important; }
}


/* v0.4.8 fixes */
.pps-crop-controls,
.pps-crop-controls *,
.pps-crop-controls input[type="range"] {
  pointer-events: auto !important;
  touch-action: auto !important;
  -webkit-user-select: auto !important;
  user-select: auto !important;
}

.pps-crop-controls input[type="range"] {
  display: block !important;
  width: 100% !important;
  height: 38px !important;
  margin: 8px 0 16px !important;
  position: relative !important;
  z-index: 10002 !important;
}

.pps-crop-stage {
  touch-action: none !important;
}

@media (max-width: 767px) {
  .pps-global-toast {
    left: 14px !important;
    right: 14px !important;
    bottom: 14px !important;
    width: auto !important;
    max-width: none !important;
    border-radius: 20px !important;
    padding: 16px !important;
  }

  .pps-global-toast strong {
    font-size: 18px !important;
    margin-bottom: 6px !important;
  }

  .pps-global-toast .pps-toast-text {
    font-size: 14px !important;
    line-height: 1.35 !important;
    margin-bottom: 10px !important;
  }

  .pps-toast-actions button {
    padding: 10px 14px !important;
    font-size: 13px !important;
  }

  .pps-crop-card {
    width: calc(100vw - 24px) !important;
    max-height: 88vh !important;
    padding: 14px !important;
    border-radius: 18px !important;
  }

  .pps-crop-stage {
    max-height: 46vh !important;
  }
}


/* v0.4.9 persistent popup / buttons / selected indicator fixes */
.pps-generate-btn,
.pps-generate-btn:hover,
.pps-generate-btn:focus,
.pps-generate-btn:active,
.pps-use-image-btn,
.pps-use-image-btn:hover,
.pps-use-image-btn:focus,
.pps-use-image-btn:active,
button.pps-generate-btn,
button.pps-use-image-btn {
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  background: #111111 !important;
  border-color: #111111 !important;
  opacity: 1 !important;
}

.pps-generate-btn *,
.pps-use-image-btn *,
.pps-generate-btn:hover *,
.pps-use-image-btn:hover * {
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
}

.pps-delete-image-btn,
.pps-delete-image-btn:hover,
.pps-delete-image-btn:focus,
.pps-delete-image-btn:active {
  color: #7b2b2b !important;
  -webkit-text-fill-color: #7b2b2b !important;
  background: #ffffff !important;
}

.pps-edit-feature-btn,
.pps-edit-feature-btn:hover,
.pps-edit-feature-btn:focus,
.pps-edit-feature-btn:active,
.pps-edit-feature-btn em,
.pps-edit-feature-btn:hover em,
.pps-edit-feature-btn:focus em,
.pps-edit-feature-btn:active em {
  color: #111111 !important;
  -webkit-text-fill-color: #111111 !important;
}

.pps-selected-badge {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 5;
  background: #159947;
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
  font-weight: 700;
  font-size: 13px;
  border-radius: 999px;
  padding: 8px 12px;
  box-shadow: 0 6px 18px rgba(0,0,0,.18);
}

.pps-history-thumbs button {
  position: relative;
}

.pps-thumb-tick {
  display: none;
  position: absolute;
  top: 6px;
  right: 6px;
  z-index: 3;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: #159947;
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
  font-weight: 800;
  line-height: 22px;
  text-align: center;
  font-size: 13px;
}

.pps-history-thumbs button.is-selected .pps-thumb-tick {
  display: block;
}

.pps-history-thumbs button.is-selected {
  border-color: #159947 !important;
}

.pps-global-toast {
  z-index: 999999 !important;
}


/* v0.5.0 mobile polish / cropper / popup fixes */
@media (max-width: 767px) {
  .pps-wrap { padding-left: 10px !important; padding-right: 10px !important; }
  .pps-product-panel, .pps-history { padding: 16px 14px !important; border-radius: 20px !important; }
  .pps-option-label, .pps-field > label { font-size: 24px !important; margin-bottom: 10px !important; }
  .pps-choice span { min-width: 58px !important; padding: 10px 14px !important; font-size: 24px !important; }
  .pps-swatch-choice span { padding: 6px !important; }
  .pps-swatch-choice em { width: 42px !important; height: 42px !important; }
  .pps-upload-wrap { padding: 12px !important; gap: 10px !important; }
  .pps-change-photo-btn { padding: 10px 12px !important; font-size: 18px !important; letter-spacing: .08em !important; }
  .pps-edit-feature-btn { min-width: 92px !important; padding: 10px 8px !important; border-radius: 16px !important; }
  .pps-edit-feature-btn img, .pps-edit-feature-btn span { width: 54px !important; height: 54px !important; border-radius: 14px !important; }
  .pps-edit-feature-btn em { max-width: 78px !important; font-size: 12px !important; }
  .pps-use-image-btn, .pps-delete-image-btn, .pps-generate-btn { font-size: 20px !important; padding: 17px 18px !important; letter-spacing: .08em !important; }
  .pps-crop-modal { align-items: center !important; padding: 8px !important; }
  .pps-crop-card { width: calc(100vw - 18px) !important; max-height: calc(100vh - 42px) !important; overflow: hidden !important; display: grid !important; grid-template-rows: auto minmax(0, 1fr) auto auto auto !important; gap: 8px !important; padding: 14px !important; border-radius: 20px !important; }
  .pps-crop-card h3 { font-size: 28px !important; margin: 0 0 4px !important; }
  .pps-crop-stage { max-height: 38vh !important; min-height: 190px !important; }
  .pps-crop-controls label { font-size: 18px !important; margin: 6px 0 !important; }
  .pps-crop-controls input[type="range"] { height: 34px !important; margin: 2px 0 8px !important; }
  .pps-crop-card .pps-help { font-size: 15px !important; line-height: 1.35 !important; margin: 2px 0 !important; }
  .pps-crop-actions { margin-top: 4px !important; gap: 8px !important; }
  .pps-crop-actions button { padding: 12px 14px !important; min-height: 48px !important; }
}

.pps-use-photo-btn, .pps-use-photo-btn:hover, .pps-use-photo-btn:focus, .pps-use-photo-btn:active,
.pps-crop-apply, .pps-crop-apply:hover, .pps-crop-apply:focus, .pps-crop-apply:active,
.pps-generate-btn, .pps-generate-btn:hover, .pps-generate-btn:focus, .pps-generate-btn:active,
.pps-use-image-btn, .pps-use-image-btn:hover, .pps-use-image-btn:focus, .pps-use-image-btn:active {
  background: #111 !important; color: #fff !important; -webkit-text-fill-color: #fff !important; border-color: #111 !important; opacity: 1 !important;
}
.pps-toast-view, .pps-toast-view:hover, .pps-toast-view:focus, .pps-toast-view:active { background: #fff !important; color: #111 !important; -webkit-text-fill-color: #111 !important; opacity: 1 !important; }
.pps-toast-view *, .pps-toast-view:hover *, .pps-toast-view:focus * { color: #111 !important; -webkit-text-fill-color: #111 !important; }
.pps-toast-cancel, .pps-toast-cancel:hover, .pps-toast-cancel:focus, .pps-toast-cancel:active { color: #fff !important; -webkit-text-fill-color: #fff !important; background: transparent !important; }
.pps-crop-controls, .pps-crop-controls input[type="range"] { touch-action: pan-x !important; }
.pps-crop-stage { touch-action: none !important; }


/* v0.5.1 mobile sizing + generated thumbnail order */
.pps-history-thumbs {
  order: 2;
  margin: 12px 0 10px !important;
}

.pps-history-edit-row {
  order: 3;
}

.pps-history-actions {
  order: 4;
}

@media (max-width: 767px) {
  .pps-history {
    padding: 14px 12px !important;
  }

  .pps-history-main-wrap {
    margin-bottom: 8px !important;
  }

  .pps-history-thumbs {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    gap: 10px !important;
    margin: 10px 0 12px !important;
    padding-bottom: 2px !important;
    -webkit-overflow-scrolling: touch;
  }

  .pps-history-thumbs button {
    width: 72px !important;
    min-width: 72px !important;
    height: 72px !important;
    border-radius: 14px !important;
  }

  .pps-history-thumbs img {
    width: 72px !important;
    height: 72px !important;
    border-radius: 12px !important;
  }

  .pps-thumb-tick {
    width: 21px !important;
    height: 21px !important;
    line-height: 21px !important;
    font-size: 12px !important;
    top: 5px !important;
    right: 5px !important;
  }

  .pps-history-edit-row {
    display: flex !important;
    gap: 10px !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    margin: 10px 0 14px !important;
    padding-bottom: 2px !important;
    -webkit-overflow-scrolling: touch;
  }

  .pps-edit-feature-btn {
    width: 82px !important;
    min-width: 82px !important;
    max-width: 82px !important;
    min-height: 92px !important;
    padding: 8px 6px !important;
    border-radius: 15px !important;
    gap: 6px !important;
  }

  .pps-edit-feature-btn img,
  .pps-edit-feature-btn span {
    width: 46px !important;
    height: 46px !important;
    border-radius: 12px !important;
    margin: 0 auto !important;
  }

  .pps-edit-feature-btn em {
    display: block !important;
    max-width: 72px !important;
    min-height: 24px !important;
    font-size: 10px !important;
    line-height: 1.15 !important;
    letter-spacing: .03em !important;
    white-space: normal !important;
    overflow: hidden !important;
    text-overflow: clip !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
  }

  .pps-history-actions {
    gap: 10px !important;
    margin: 8px 0 4px !important;
  }

  .pps-use-image-btn,
  .pps-delete-image-btn {
    min-height: 58px !important;
    padding: 13px 16px !important;
    font-size: 15px !important;
    line-height: 1.2 !important;
    letter-spacing: .08em !important;
    border-radius: 999px !important;
  }

  .pps-use-image-btn {
    margin-top: 0 !important;
  }

  .pps-delete-image-btn {
    margin-top: 0 !important;
  }

  .pps-selected-badge {
    font-size: 11px !important;
    padding: 6px 9px !important;
    top: 10px !important;
    left: 10px !important;
  }
}

/* Sticker book kit builder */
.pps-field-multi_image .pps-multi-upload-preview{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin:10px 0;}
.pps-field-multi_image .pps-multi-upload-preview img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:12px;border:1px solid rgba(0,0,0,.08);background:#fff;}
.pps-kit-panel{margin-top:22px;}
.pps-kit-card{background:#fff;border:1px solid rgba(0,0,0,.09);border-radius:22px;padding:20px;box-shadow:0 16px 45px rgba(0,0,0,.06);}
.pps-kit-card h2{margin:0 0 8px;font-size:24px;line-height:1.15;}
.pps-kit-card p{margin:0 0 16px;color:#59606b;}
.pps-kit-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:16px 0;}
.pps-kit-item{border:1px solid rgba(0,0,0,.08);border-radius:18px;padding:10px;background:#fafafa;}
.pps-kit-image{background:#fff;border-radius:14px;border:1px solid rgba(0,0,0,.06);display:flex;align-items:center;justify-content:center;overflow:hidden;aspect-ratio:1/1;}
.pps-kit-image img{max-width:100%;max-height:100%;object-fit:contain;display:block;}
.pps-kit-item label{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px;font-weight:700;font-size:14px;}
.pps-kit-qty{min-width:80px;border-radius:999px;border:1px solid rgba(0,0,0,.14);padding:8px 10px;background:#fff;}
.pps-finalise-kit-btn{width:100%;border:0;border-radius:999px;padding:14px 18px;background:#111;color:#fff;font-weight:800;cursor:pointer;font-size:16px;}
.pps-finalise-kit-btn:disabled{opacity:.55;cursor:not-allowed;}
.pps-kit-status{margin-top:10px;font-weight:700;color:#59606b;}
.pps-kit-spinner{width:44px;height:44px;border:4px solid rgba(0,0,0,.08);border-top-color:#111;border-radius:50%;animation:ppsSpin 1s linear infinite;margin:18px auto 4px;}
@keyframes ppsSpin{to{transform:rotate(360deg)}}
.pps-kit-final-preview{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:18px;padding:8px;margin:14px 0;}
.pps-kit-final-preview img{width:100%;height:auto;display:block;border-radius:12px;}
.pps-kit-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px;}
.pps-kit-links a{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:10px 14px;background:#111;color:#fff;text-decoration:none;font-weight:800;}
@media (max-width:700px){.pps-kit-grid{grid-template-columns:1fr}.pps-field-multi_image .pps-multi-upload-preview{grid-template-columns:repeat(3,minmax(0,1fr));}}

/* Sticker Book Kit v0.8 */
.pps-kit-summary{background:#fff8dc;border:1px solid #f3d36b;border-radius:12px;padding:12px 14px;margin:12px 0;font-size:15px}
.pps-kit-summary strong{font-size:22px}
.pps-kit-actions-top{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0 16px}
.pps-kit-actions-top button,.pps-finalise-kit-btn,.pps-add-to-cover-btn{border:0;border-radius:999px;background:#111;color:#fff;padding:10px 14px;font-weight:700;cursor:pointer}
.pps-kit-actions-top .pps-clear-kit-btn{background:#eee;color:#111}
.pps-kit-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;margin:14px 0}
.pps-kit-grid-compact{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}
.pps-kit-item{position:relative;background:#fff;border:1px solid #eee;border-radius:16px;padding:10px;box-shadow:0 8px 24px rgba(0,0,0,.06)}
.pps-kit-image{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;background:#fafafa;border-radius:12px;overflow:hidden}
.pps-kit-image img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.pps-remove-kit-item{position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:999px;border:0;background:#111;color:#fff;font-size:18px;line-height:28px;cursor:pointer;z-index:2}
.pps-kit-controls{display:flex;gap:8px;align-items:center;justify-content:space-between;margin-top:10px;flex-wrap:wrap}
.pps-kit-controls select{min-width:56px}
.pps-add-to-cover-btn{font-size:12px;padding:7px 10px;background:#5b35d5}
.pps-cover-mini{background:#f7f5ff;border:1px solid #e3dcff;border-radius:14px;padding:12px;margin:12px 0}
.pps-cover-mini h3{margin:0 0 5px}
.pps-cover-chip-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.pps-cover-chip{background:#fff;border:1px solid #ddd;border-radius:999px;padding:6px 8px;font-size:12px}
.pps-cover-chip button{border:0;background:transparent;font-weight:bold;cursor:pointer}
.pps-kit-message{background:#eef8ff;border:1px solid #bde2ff;border-radius:10px;padding:10px;margin:10px 0}
.pps-kit-status{margin-top:10px;font-weight:700}

/* Sticker Book Kit v0.9 creative cover builder fixes */
.pps-kit-builder-card{padding:22px!important;}
.pps-kit-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px;}
.pps-kit-head h2{font-size:28px;margin:0 0 6px;}
.pps-kit-head p{margin:0;color:#59606b;}
.pps-kit-total{background:#111;color:#fff;border-radius:18px;padding:12px 16px;text-align:right;min-width:135px;}
.pps-kit-total strong{display:block;font-size:24px;line-height:1;}
.pps-kit-total span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.08em;margin-top:4px;opacity:.75;}
.pps-kit-workspace{display:grid;grid-template-columns:minmax(320px,44%) 1fr;gap:22px;align-items:start;}
.pps-kit-cover-column,.pps-kit-sticker-column{min-width:0;}
.pps-kit-cover-column>h3{font-size:20px;margin:0 0 10px;}
.pps-cover-editor{position:sticky;top:16px;}
.pps-cover-stage{width:100%;background:#f5f5f5;border:1px solid #e8e8e8;border-radius:24px;padding:16px;box-shadow:0 18px 50px rgba(0,0,0,.07);}
.pps-cover-paper{position:relative;width:100%;height:100%;overflow:hidden;background:#fffaf6;border:2px solid #111;border-radius:10px;touch-action:none;}
.pps-cover-dots:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 20%,rgba(255,206,221,.75) 0 6px,transparent 7px),radial-gradient(circle at 70% 35%,rgba(210,238,255,.85) 0 5px,transparent 6px),radial-gradient(circle at 40% 75%,rgba(222,255,222,.85) 0 6px,transparent 7px),radial-gradient(circle at 85% 80%,rgba(255,240,190,.85) 0 7px,transparent 8px);background-size:120px 120px;opacity:.65;}
.pps-cover-el{position:absolute;z-index:2;cursor:grab;transform-origin:center center;user-select:none;touch-action:none;}
.pps-cover-el:active{cursor:grabbing;}
.pps-cover-el:hover{outline:2px dashed rgba(17,17,17,.35);outline-offset:4px;}
.pps-cover-photo{width:62%;}
.pps-cover-photo img{display:block;width:100%;height:auto;border-radius:18px;box-shadow:0 10px 28px rgba(0,0,0,.18);}
.pps-cover-sticker{width:34%;}
.pps-cover-sticker img{display:block;width:100%;height:auto;filter:drop-shadow(0 6px 10px rgba(0,0,0,.16));}
.pps-cover-remove-el{position:absolute;right:-12px;top:-12px;width:28px;height:28px;border-radius:50%;border:2px solid #fff;background:#111;color:#fff;font-size:18px;line-height:22px;cursor:pointer;}
.pps-cover-text{font-weight:900;text-align:center;white-space:nowrap;font-size:28px;text-shadow:0 2px 0 rgba(255,255,255,.8);}
.pps-cover-subtitle{font-weight:700;font-size:15px;}
.pps-cover-text.is-arched span{display:inline-block;transform:perspective(220px) rotateX(18deg);letter-spacing:.03em;border-radius:50%;}
.pps-cover-help{font-size:13px!important;margin:10px 0 0!important;color:#59606b!important;}
.pps-cover-controls{margin-top:14px;background:#f7f7f7;border:1px solid #e6e6e6;border-radius:16px;padding:14px;display:grid;gap:10px;}
.pps-cover-controls h3{margin:0;font-size:16px;}
.pps-cover-controls label{display:grid;gap:5px;font-weight:800;font-size:13px;color:#111;}
.pps-cover-controls input[type="range"]{width:100%;}
.pps-cover-controls select,.pps-cover-controls input[type="color"]{height:38px;border:1px solid #ddd;border-radius:10px;background:#fff;padding:4px 8px;}
.pps-inline-check{display:flex!important;align-items:center!important;gap:8px!important;grid-template-columns:auto!important;}
.pps-cover-delete-selected{background:#111;color:#fff;border:0;border-radius:999px;padding:10px 14px;font-weight:800;cursor:pointer;}
.pps-selected-name{font-weight:900;background:#fff;border-radius:12px;padding:9px 10px;}
.pps-live-status{display:flex;align-items:center;gap:10px;background:#eef8ff;border:1px solid #bee4ff;border-radius:14px;padding:11px 13px;font-weight:800;margin:12px 0;}
.pps-kit-spinner-mini{width:18px;height:18px;border:3px solid rgba(0,0,0,.1);border-top-color:#111;border-radius:50%;animation:ppsSpin 1s linear infinite;flex:0 0 auto;}
.pps-kit-actions-top button,.pps-finalise-kit-btn,.pps-add-to-cover-btn{background:#111!important;color:#fff!important;border:0!important;border-radius:999px!important;font-weight:900!important;cursor:pointer!important;}
.pps-kit-actions-top .pps-clear-kit-btn{background:#eee!important;color:#111!important;}
.pps-add-to-cover-btn{font-size:12px!important;padding:8px 11px!important;letter-spacing:.02em;}
.pps-kit-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr))!important;}
.pps-kit-item{position:relative;background:#fff;border:1px solid #ececec;border-radius:18px;padding:12px;box-shadow:0 10px 28px rgba(0,0,0,.06);}
.pps-kit-image{width:100%;border:0;background:#fafafa;border-radius:14px;display:flex;align-items:center;justify-content:center;aspect-ratio:1/1;overflow:hidden;cursor:zoom-in;padding:0;transition:transform .18s ease, box-shadow .18s ease;}
.pps-kit-image:hover{transform:scale(1.04);box-shadow:0 14px 38px rgba(0,0,0,.14);z-index:5;}
.pps-kit-image img{max-width:100%;max-height:100%;object-fit:contain;display:block;}
.pps-remove-kit-item{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:999px;border:2px solid #fff!important;background:#111!important;color:#fff!important;font-size:20px;line-height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:3;padding:0;box-shadow:0 4px 12px rgba(0,0,0,.22);}
.pps-kit-controls{display:flex;gap:8px;align-items:center;justify-content:space-between;margin-top:10px;flex-wrap:wrap;}
.pps-kit-controls label{display:flex;gap:8px;align-items:center;font-weight:900;margin:0;}
.pps-kit-qty{min-width:58px;border:1px solid #ddd;border-radius:999px;padding:8px 10px;background:#fff;}
.pps-empty-stickers{background:#fafafa;border:1px dashed #d5d5d5;border-radius:18px;padding:18px;text-align:center;color:#59606b;}
.pps-sticker-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:999999;display:flex;align-items:center;justify-content:center;padding:24px;}
.pps-sticker-lightbox-inner{position:relative;background:#fff;border-radius:24px;padding:22px;box-shadow:0 30px 90px rgba(0,0,0,.45);}
.pps-sticker-lightbox-inner img{max-width:min(80vw,760px);max-height:80vh;display:block;object-fit:contain;}
.pps-sticker-lightbox-inner button{position:absolute;right:-12px;top:-12px;width:38px;height:38px;border-radius:50%;border:2px solid #fff;background:#111;color:#fff;font-size:26px;line-height:32px;cursor:pointer;}
@media (max-width:900px){.pps-kit-workspace{grid-template-columns:1fr}.pps-cover-editor{position:relative;top:auto}.pps-kit-head{display:block}.pps-kit-total{text-align:left;margin-top:12px}.pps-cover-stage{padding:10px}.pps-kit-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))!important}}

/* v1.0.0 Sticker Book Designer: clean modal workflow */
.pps-kit-mode .pps-form{position:absolute!important;left:-99999px!important;width:1px!important;height:1px!important;overflow:hidden!important;opacity:0!important;pointer-events:none!important;}
.pps-kit-mode .pps-accordions{display:none!important;}
.pps-kit-panel[hidden]{display:none!important;}
.pps-kit-launch-card{border:1px solid #e8e0d8;background:#fff;border-radius:30px;padding:28px;margin:24px 0;box-shadow:0 16px 40px rgba(0,0,0,.05)}
.pps-kit-launch-card h2{margin:0 0 10px;font-size:34px;line-height:1.05;color:#111}.pps-kit-launch-card p{color:#575f6b;line-height:1.55}.pps-kit-mini-summary{margin:18px 0;background:#fff6d9;border:1px solid #f4d47a;border-radius:16px;padding:14px;color:#111}.pps-live-small{font-weight:700;color:#365a2f!important}.pps-open-designer-btn{border:0;border-radius:999px;background:#111!important;color:#fff!important;padding:17px 28px;font-weight:900;letter-spacing:.03em;text-transform:uppercase;cursor:pointer}.pps-open-designer-btn:hover,.pps-open-designer-btn:focus{background:#111!important;color:#fff!important}
body.pps-designer-open{overflow:hidden!important}.pps-designer-host:empty{display:none}.pps-designer-modal{position:fixed;inset:0;z-index:99999;background:#f6f7f9;color:#111;font-family:inherit;display:flex;flex-direction:column}.pps-designer-topbar{height:68px;background:#fff;border-bottom:1px solid #dde1e7;display:grid;grid-template-columns:170px 1fr 190px;align-items:center;gap:12px;padding:0 18px;box-shadow:0 2px 16px rgba(0,0,0,.08)}.pps-designer-title{text-align:center;font-weight:900;font-size:20px}.pps-designer-exit{background:transparent;border:0;color:#0757c8!important;text-decoration:underline;font-weight:700;font-size:16px;text-align:left;cursor:pointer}.pps-finalise-kit-btn{border:0;border-radius:12px;background:#0757c8!important;color:#fff!important;font-weight:900;padding:14px 18px;cursor:pointer}.pps-finalise-kit-btn:disabled{opacity:.55;cursor:wait}.pps-designer-body{flex:1;display:grid;grid-template-columns:280px minmax(520px,1fr) 360px;gap:0;min-height:0}.pps-designer-left,.pps-designer-right{background:#fff;border-right:1px solid #dde1e7;overflow:auto;padding:18px}.pps-designer-right{border-right:0;border-left:1px solid #dde1e7}.pps-designer-main{overflow:auto;padding:28px 34px;display:flex;flex-direction:column;align-items:center}.pps-page-tab{width:100%;display:flex;align-items:center;gap:12px;background:#fff;border:1px solid #e2e6ee;border-radius:16px;padding:14px;margin:0 0 10px;font-weight:900;cursor:pointer;color:#111!important;text-align:left}.pps-page-tab span{width:30px;height:30px;border-radius:50%;background:#edf1f6;display:inline-flex;align-items:center;justify-content:center}.pps-page-tab.is-active{border-color:#111;background:#111;color:#fff!important}.pps-page-tab.is-active span{background:#fff;color:#111}.pps-upload-actions{margin-top:24px;display:grid;gap:10px}.pps-upload-actions button,.pps-tool-add-stickers,.pps-layer-actions button,.pps-cover-delete-selected{border:1px solid #111;background:#111!important;color:#fff!important;border-radius:999px;padding:13px 15px;font-weight:900;cursor:pointer}.pps-upload-actions .pps-tool-cover-photo{background:#fff!important;color:#111!important}.pps-tool-message,.pps-live-status{margin-top:16px;border-radius:16px;padding:12px 14px;background:#fff6d9;border:1px solid #f4d47a;line-height:1.45}.pps-kit-spinner-mini{display:inline-block;width:14px;height:14px;border-radius:50%;border:2px solid #bbb;border-top-color:#111;animation:ppsSpin 1s linear infinite;vertical-align:-2px;margin-right:6px}@keyframes ppsSpin{to{transform:rotate(360deg)}}
.pps-page-heading{width:min(720px,100%);margin:0 0 16px}.pps-page-heading h2{font-size:32px;margin:0 0 6px}.pps-page-heading p{margin:0;color:#626b77}.pps-designer-canvas-wrap{width:min(720px,100%);margin:auto}.pps-cover-stage{width:100%;background:#e9edf3;border-radius:20px;padding:22px;box-shadow:inset 0 0 0 1px #d7dce5}.pps-cover-paper{position:relative;width:100%;height:100%;overflow:hidden;border:3px solid #111;background:#fffdfa;border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,.12);touch-action:none}.pps-cover-dots{position:absolute;inset:0;background-image:radial-gradient(circle at 18% 15%,rgba(255,194,214,.65) 0 7px,transparent 8px),radial-gradient(circle at 76% 13%,rgba(255,194,214,.45) 0 7px,transparent 8px),radial-gradient(circle at 28% 32%,rgba(185,226,255,.4) 0 6px,transparent 7px),radial-gradient(circle at 82% 42%,rgba(255,230,134,.38) 0 7px,transparent 8px),radial-gradient(circle at 20% 75%,rgba(196,255,210,.4) 0 6px,transparent 7px);pointer-events:none}.pps-cover-el{position:absolute;transform-origin:center center;cursor:move;user-select:none}.pps-cover-el img{display:block;width:100%;height:auto;pointer-events:none}.pps-cover-photo{width:58%;}.pps-cover-sticker{width:34%;}.pps-cover-text{font-size:34px;font-weight:900;white-space:nowrap;text-align:center;line-height:1.1;text-shadow:0 2px 0 rgba(255,255,255,.8)}.pps-cover-text.is-arched span{display:inline-block;transform:rotate(-12deg);letter-spacing:.02em}.pps-cover-el:hover,.pps-cover-el:focus{outline:2px dashed #1672e8;outline-offset:8px}.pps-cover-remove-el{position:absolute;right:-12px;top:-12px;width:28px;height:28px;border:0;border-radius:50%;background:#111!important;color:#fff!important;font-size:18px;line-height:28px;cursor:pointer}.pps-side-card{background:#fff;border:1px solid #e2e6ee;border-radius:18px;padding:16px;margin-bottom:16px}.pps-side-card h3{margin:0 0 12px;font-size:22px}.pps-side-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.pps-layer-list{display:grid;gap:8px;margin-bottom:14px}.pps-layer-btn{border:1px solid #dbe1ea;background:#fff;color:#111!important;border-radius:12px;padding:10px 12px;text-align:left;font-weight:700;cursor:pointer}.pps-layer-btn.is-active{border-color:#111;background:#111;color:#fff!important}.pps-selected-name{background:#f5f6f8;border-radius:12px;padding:12px;font-weight:900;margin-bottom:14px}.pps-side-card label{display:block;font-weight:800;margin:10px 0}.pps-side-card input[type=range],.pps-side-card select{width:100%}.pps-inline-check{display:flex!important;align-items:center;gap:8px}.pps-layer-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:12px 0}.pps-cover-delete-selected{background:#8e1d1d!important;border-color:#8e1d1d!important}.pps-price-card{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.pps-price-card strong{font-size:30px}.pps-price-card span{color:#5f6874}.pps-price-card em{font-style:normal;background:#fff6d9;border:1px solid #f4d47a;border-radius:999px;padding:5px 9px}.pps-sticker-page{width:min(980px,100%)}.pps-sticker-page h2{font-size:34px;margin:0 0 6px}.pps-sticker-page p{color:#626b77}.pps-sticker-tools{display:grid;gap:16px}.pps-sticker-list{display:grid;gap:12px}.pps-sticker-row{display:grid;grid-template-columns:92px 1fr 34px;gap:12px;align-items:center;border:1px solid #edf0f4;border-radius:16px;padding:10px;background:#fff}.pps-sticker-thumb{border:0;background:#f8f9fb;border-radius:12px;padding:6px;cursor:zoom-in}.pps-sticker-thumb img{display:block;width:80px;height:80px;object-fit:contain}.pps-sticker-row-main{display:grid;gap:8px}.pps-sticker-row-main label{display:flex;align-items:center;gap:8px;font-weight:900}.pps-sticker-row-main select{width:80px;border-radius:999px;border:1px solid #ddd;padding:8px 10px}.pps-add-to-page-btn{border:1px solid #111;border-radius:999px;background:#111!important;color:#fff!important;padding:10px 12px;font-weight:900;cursor:pointer}.pps-remove-kit-item{border:0;border-radius:50%;width:30px;height:30px;background:#111!important;color:#fff!important;font-size:20px;line-height:30px;cursor:pointer}.pps-empty-stickers{background:#f8f9fb;border:1px dashed #cfd6df;border-radius:18px;padding:18px;color:#66707d}.pps-sticker-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.68);z-index:100001;display:flex;align-items:center;justify-content:center;padding:24px}.pps-sticker-lightbox[hidden]{display:none}.pps-sticker-lightbox-inner{position:relative;background:#fff;border-radius:24px;padding:24px;max-width:min(760px,90vw);max-height:90vh}.pps-sticker-lightbox-inner img{max-width:100%;max-height:78vh;display:block;object-fit:contain}.pps-sticker-lightbox-inner button{position:absolute;right:-12px;top:-12px;width:40px;height:40px;border:0;border-radius:50%;background:#111!important;color:#fff!important;font-size:24px;cursor:pointer}.pps-kit-ready{border:1px solid #e2e6ee;background:#fff;border-radius:30px;padding:28px}.pps-kit-final-preview{background:#f7f8fa;border:1px solid #e2e6ee;border-radius:24px;padding:18px;margin:18px 0}.pps-kit-final-preview img{display:block;max-width:100%;height:auto;margin:auto}.pps-kit-links{display:flex;flex-wrap:wrap;gap:12px}.pps-kit-links a{display:inline-flex;background:#111;color:#fff!important;border-radius:999px;padding:13px 18px;text-decoration:none;font-weight:900}
@media (max-width: 1050px){.pps-designer-body{grid-template-columns:1fr}.pps-designer-left,.pps-designer-right{border:0;border-bottom:1px solid #dde1e7;max-height:none}.pps-designer-topbar{grid-template-columns:90px 1fr 130px}.pps-designer-main{padding:18px}.pps-designer-right{order:3}.pps-designer-left{order:1}.pps-designer-main{order:2}.pps-cover-stage{padding:12px}.pps-designer-title{font-size:16px}}

/* v1.1 sticker book project/designer reset */
.pps-kit-mode .pps-product-grid{grid-template-columns:minmax(280px,440px) minmax(360px,1fr);align-items:start;}
.pps-kit-mode .pps-product-panel .pps-form .pps-field:not(.pps-field-multi_image),
.pps-kit-mode .pps-product-panel .pps-form .pps-option-group,
.pps-kit-mode .pps-product-panel .pps-form .pps-generate-btn,
.pps-kit-mode .pps-product-panel .pps-form .pps-status{display:none!important;}
.pps-kit-mode .pps-product-panel .pps-form{border:0;padding:0;margin:0;}
.pps-kit-mode .pps-product-panel .pps-confirm{display:block;margin:14px 0;color:#4b5563;}
.pps-kit-mode .pps-field-multi_image{border:1px dashed #d8dce4;border-radius:20px;padding:18px;background:#fff;margin:14px 0;}
.pps-kit-project{margin-top:18px;border:1px solid #e5e7eb;border-radius:28px;padding:22px;background:#fff;box-shadow:0 14px 38px rgba(15,23,42,.06);}
.pps-kit-hero{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;margin-bottom:18px;}
.pps-kit-hero h2{font-size:32px;line-height:1.05;margin:4px 0 8px;}
.pps-kit-hero p{margin:0;color:#667085;font-size:16px;}
.pps-kit-summary{display:flex;flex-wrap:wrap;gap:8px;align-items:center;background:#fff8db;border:1px solid #f4d06f;border-radius:16px;padding:12px 14px;margin:12px 0 18px;color:#111;}
.pps-kit-summary strong{font-size:22px;}
.pps-kit-summary span{background:#fff;border-radius:999px;padding:6px 10px;border:1px solid #f1e2a5;}
.pps-kit-summary.mini{font-size:13px;margin:0 0 14px;}
.pps-kit-message,.pps-kit-progress{border-radius:14px;padding:12px 14px;margin:12px 0;background:#eef6ff;color:#164a7a;border:1px solid #b8dcff;}
.pps-kit-progress span{display:inline-block;width:10px;height:10px;border-radius:999px;background:#1463d8;margin-right:8px;animation:ppsPulse 1s infinite alternate;}
@keyframes ppsPulse{from{opacity:.25}to{opacity:1}}
.pps-kit-actions,.pps-kit-bottom{display:flex;flex-wrap:wrap;gap:10px;margin:16px 0;}
.pps-kit-actions button,.pps-kit-bottom button,.pps-open-designer,.pps-editor-add-text,.pps-editor-cover-photo{border:0;border-radius:999px;background:#111;color:#fff;font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:15px 22px;cursor:pointer;}
.pps-kit-actions .pps-clear-kit{background:#eef0f3;color:#111;}
.pps-open-designer{background:#1463d8;white-space:nowrap;}
.pps-open-designer:disabled,.pps-finalise-kit:disabled{opacity:.45;cursor:not-allowed;}
.pps-finalise-kit{background:#1463d8!important;color:#fff!important;}
.pps-kit-library{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:16px;margin-top:16px;}
.pps-empty-library{grid-column:1/-1;border:1px dashed #d8dce4;border-radius:22px;background:#f8fafc;text-align:center;padding:36px;color:#667085;}
.pps-sticker-card{position:relative;border:1px solid #e6eaf0;border-radius:24px;background:#fff;padding:14px;box-shadow:0 8px 22px rgba(15,23,42,.05);}
.pps-remove-sticker{position:absolute;top:8px;right:8px;width:30px;height:30px;border-radius:999px;border:0;background:#111;color:#fff;font-size:18px;line-height:1;z-index:2;cursor:pointer;}
.pps-sticker-preview-btn{width:100%;aspect-ratio:1/1;border:0;border-radius:18px;background:#f9fafb;display:flex;align-items:center;justify-content:center;cursor:zoom-in;padding:8px;}
.pps-sticker-preview-btn img{max-width:100%;max-height:100%;object-fit:contain;}
.pps-sticker-card-row{display:flex;gap:8px;align-items:center;justify-content:space-between;margin-top:12px;}
.pps-sticker-card-row label{font-weight:800;display:flex;align-items:center;gap:8px;}
.pps-sticker-card-row select{border:1px solid #d8dce4;border-radius:999px;padding:8px 12px;background:#fff;}
.pps-add-sticker-cover{border:0;border-radius:999px;background:#111!important;color:#fff!important;font-weight:800;padding:10px 14px;cursor:pointer;}
.pps-sticker-zoom{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:999999;display:flex;align-items:center;justify-content:center;padding:30px;}
.pps-sticker-zoom img{max-width:min(760px,90vw);max-height:85vh;object-fit:contain;background:#fff;border-radius:24px;padding:24px;}
.pps-sticker-zoom button{position:fixed;top:22px;right:22px;width:44px;height:44px;border-radius:999px;border:0;background:#fff;color:#111;font-size:28px;cursor:pointer;}
.pps-designer-open{overflow:hidden;}
.pps-designer-modal{position:fixed;inset:0;background:#f4f6f8;z-index:999998;display:flex;flex-direction:column;color:#111;font-family:inherit;}
.pps-designer-top{height:68px;background:#fff;border-bottom:1px solid #d8dce4;display:flex;align-items:center;justify-content:space-between;padding:0 22px;box-shadow:0 4px 14px rgba(0,0,0,.08);}
.pps-designer-top strong{font-size:22px;}
.pps-designer-exit{background:transparent;border:0;color:#1463d8;font-weight:800;text-decoration:underline;cursor:pointer;}
.pps-designer-finalise{border:0;border-radius:999px;background:#1463d8;color:#fff;font-weight:900;text-transform:uppercase;padding:16px 24px;cursor:pointer;}
.pps-designer-layout{display:grid;grid-template-columns:240px minmax(480px,1fr) 330px;gap:0;min-height:0;flex:1;}
.pps-editor-left{background:#fff;border-right:1px solid #d8dce4;padding:22px;overflow:auto;}
.pps-page-tab{width:100%;border:1px solid #e2e6ee;background:#fff;border-radius:18px;padding:18px;text-align:left;font-weight:900;text-transform:uppercase;letter-spacing:.03em;margin-bottom:12px;display:flex;align-items:center;gap:12px;cursor:pointer;}
.pps-page-tab b{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:999px;background:#eef2f7;}
.pps-page-tab.is-active{background:#111;color:#fff;border-color:#111;}
.pps-page-tab.is-active b{background:#fff;color:#111;}
.pps-editor-upload-buttons{margin-top:22px;display:grid;gap:12px;}
.pps-editor-main{padding:28px;overflow:auto;display:flex;flex-direction:column;align-items:center;}
.pps-editor-heading{width:min(760px,100%);margin-bottom:18px;}
.pps-editor-heading h2{font-size:34px;line-height:1;margin:0 0 10px;}
.pps-editor-heading p{margin:0;color:#667085;}
.pps-editor-canvas-shell{width:min(720px,88vw);background:#dde4ed;border-radius:26px;padding:22px;box-shadow:inset 0 0 0 1px #c9d2df;}
.pps-editor-paper{position:relative;background:#fffaf6;border:4px solid #111;border-radius:12px;overflow:hidden;user-select:none;touch-action:none;box-shadow:0 20px 40px rgba(15,23,42,.08);}
.pps-editor-dot-bg{position:absolute;inset:0;background-image:radial-gradient(circle,#ffd9e3 0 6px,transparent 7px),radial-gradient(circle,#dff3ff 0 5px,transparent 6px),radial-gradient(circle,#e6ffe8 0 6px,transparent 7px),radial-gradient(circle,#fff0bf 0 7px,transparent 8px);background-size:90px 90px,100px 100px,110px 110px,120px 120px;background-position:22px 20px,55px 45px,72px 8px,40px 75px;opacity:.85;}
.pps-design-el{position:absolute;transform-origin:center;cursor:move;touch-action:none;}
.pps-design-el.is-selected{outline:2px dashed #1463d8;outline-offset:6px;}
.pps-design-el img{display:block;width:100%;height:auto;max-width:260px;pointer-events:none;}
.pps-design-photo img{width:340px;max-width:48vw;border-radius:12px;}
.pps-design-sticker img{width:220px;max-width:32vw;}
.pps-design-text{font-size:36px;font-weight:900;text-align:center;white-space:pre-wrap;line-height:1.05;min-width:120px;}
.pps-design-text.is-arched span{display:inline-block;transform:rotate(-10deg);}
.pps-editor-right{background:#fff;border-left:1px solid #d8dce4;padding:22px;overflow:auto;}
.pps-editor-card{border:1px solid #e2e6ee;border-radius:22px;padding:18px;margin-bottom:16px;background:#fff;}
.pps-editor-card h3{margin:0 0 14px;font-size:22px;}
.pps-editor-card label{display:block;font-weight:800;margin:12px 0 8px;}
.pps-editor-card input[type="range"],.pps-editor-card textarea,.pps-editor-card select{width:100%;}
.pps-editor-card textarea{min-height:86px;border:1px solid #d8dce4;border-radius:14px;padding:10px;}
.pps-selected-title{font-size:18px;font-weight:900;margin-bottom:12px;}
.pps-inline{display:flex!important;align-items:center;gap:8px;}
.pps-layer-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px;}
.pps-layer-actions button,.pps-delete-layer{border:0;border-radius:999px;background:#111;color:#fff;font-weight:800;padding:10px 12px;cursor:pointer;}
.pps-delete-layer{background:#e11d48!important;margin-top:12px;}
.pps-editor-sticker-tray{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.pps-editor-add-sticker{border:1px solid #e2e6ee;border-radius:16px;background:#f8fafc;padding:8px;cursor:pointer;}
.pps-editor-add-sticker img{width:100%;aspect-ratio:1/1;object-fit:contain;display:block;}
.pps-editor-add-sticker span{display:block;font-weight:800;margin-top:4px;}
@media(max-width:1100px){.pps-designer-layout{grid-template-columns:1fr}.pps-editor-left,.pps-editor-right{border:0}.pps-editor-left{display:flex;gap:10px}.pps-page-tab{width:auto}.pps-editor-upload-buttons{display:flex;margin-top:0}.pps-editor-right{max-height:40vh}.pps-kit-mode .pps-product-grid{grid-template-columns:1fr}}


/* v1.1.2 sticker book project fixes */
.pps-kit-mode .pps-form{
  position: static !important;
  left: auto !important;
  width: auto !important;
  height: auto !important;
  overflow: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}
.pps-kit-mode .pps-product-panel .pps-form .pps-field:not(.pps-field-multi_image),
.pps-kit-mode .pps-product-panel .pps-form .pps-option-group,
.pps-kit-mode .pps-product-panel .pps-form .pps-generate-btn,
.pps-kit-mode .pps-product-panel .pps-form .pps-status{
  display:none !important;
}
.pps-kit-mode .pps-field-multi_image{
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
  pointer-events:auto !important;
}
.pps-kit-actions button:not(.pps-clear-kit),
.pps-kit-actions button:not(.pps-clear-kit) *,
.pps-kit-bottom button,
.pps-kit-bottom button *,
.pps-open-designer,
.pps-open-designer *,
.pps-trigger-photo-upload,
.pps-trigger-photo-upload *,
.pps-trigger-generate,
.pps-trigger-generate *,
.pps-add-sticker-cover,
.pps-add-sticker-cover *,
.pps-finalise-kit,
.pps-finalise-kit *{
  background:#111 !important;
  color:#fff !important;
  border-color:#111 !important;
}
.pps-finalise-kit,
.pps-open-designer{
  background:#1463d8 !important;
  border-color:#1463d8 !important;
}
.pps-clear-kit,
.pps-clear-kit *{
  background:#eef0f3 !important;
  color:#111 !important;
  border-color:#eef0f3 !important;
}
.pps-remove-sticker,
.pps-remove-sticker *{
  background:#111 !important;
  color:#fff !important;
}

/* v1.2.0 Moonpig-style clean cover designer */
.pps-designer-modal.pps-mp-designer{background:#eef1f5!important;color:#111!important;font-family:inherit!important;display:flex!important;flex-direction:column!important;z-index:999999!important;}
.pps-mp-topbar{height:58px;background:#fff;border-bottom:1px solid #d9dee7;box-shadow:0 2px 10px rgba(0,0,0,.08);display:grid;grid-template-columns:160px 1fr 180px;align-items:center;padding:0 14px;gap:10px;flex:0 0 auto;}
.pps-mp-title{text-align:center;font-weight:900;font-size:20px;letter-spacing:.01em;}
.pps-mp-link{border:0;background:transparent!important;color:#075fd6!important;text-decoration:underline;font-weight:800;cursor:pointer;text-align:left;font-size:15px;}
.pps-mp-primary{border:0!important;background:#075fd6!important;color:#fff!important;border-radius:10px!important;font-weight:900!important;padding:12px 18px!important;text-transform:uppercase!important;letter-spacing:.03em!important;cursor:pointer!important;}
.pps-mp-workspace{flex:1;min-height:0;display:grid;grid-template-columns:330px minmax(520px,1fr);}
.pps-mp-panel{background:#fff;border-right:1px solid #d9dee7;overflow:auto;padding:18px;box-shadow:4px 0 18px rgba(0,0,0,.06);}
.pps-mp-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:16px;}
.pps-mp-panel-head strong{font-size:24px;line-height:1.05;}
.pps-mp-panel-head span{font-size:12px;color:#667085;background:#f2f4f7;border-radius:999px;padding:7px 9px;white-space:nowrap;}
.pps-mp-section{border:1px solid #e6eaf0;border-radius:18px;background:#fff;padding:14px;margin-bottom:12px;}
.pps-mp-section h3{font-size:18px;margin:0 0 10px;color:#111;}
.pps-mp-help,.pps-mp-empty{font-size:13px;line-height:1.45;color:#667085;margin:0 0 10px;}
.pps-mp-page-buttons{display:grid;gap:8px;}
.pps-mp-page-buttons .pps-page-tab{width:100%!important;margin:0!important;border:1px solid #d9dee7!important;background:#fff!important;color:#111!important;border-radius:12px!important;padding:12px!important;display:flex!important;align-items:center!important;gap:10px!important;text-transform:none!important;letter-spacing:0!important;font-size:15px!important;}
.pps-mp-page-buttons .pps-page-tab b{width:26px!important;height:26px!important;border-radius:999px!important;background:#eef2f7!important;color:#111!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;}
.pps-mp-page-buttons .pps-page-tab.is-active{background:#111!important;color:#fff!important;border-color:#111!important;}
.pps-mp-page-buttons .pps-page-tab.is-active b{background:#fff!important;color:#111!important;}
.pps-mp-button{width:100%;border:1px solid #111!important;border-radius:12px!important;background:#111!important;color:#fff!important;font-weight:900!important;padding:12px 14px!important;cursor:pointer!important;text-transform:none!important;letter-spacing:0!important;}
.pps-mp-sticker-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;max-height:265px;overflow:auto;padding-right:3px;}
.pps-mp-sticker-grid .pps-editor-add-sticker{border:1px solid #e2e6ee!important;background:#f8fafc!important;border-radius:14px!important;padding:8px!important;cursor:pointer!important;transition:transform .15s ease, box-shadow .15s ease;}
.pps-mp-sticker-grid .pps-editor-add-sticker:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(15,23,42,.13);}
.pps-mp-sticker-grid .pps-editor-add-sticker img{width:100%;aspect-ratio:1/1;object-fit:contain;display:block;background:#fff;border-radius:10px;}
.pps-mp-sticker-grid .pps-editor-add-sticker span{display:block;margin-top:5px;color:#111;font-weight:800;font-size:12px;}
.pps-mp-controls-wrap .pps-editor-card{border:0!important;padding:0!important;margin:0!important;background:transparent!important;}
.pps-mp-controls-wrap .pps-editor-card h3{font-size:18px!important;margin:0 0 10px!important;}
.pps-mp-controls-wrap .pps-selected-title{font-size:14px!important;text-transform:uppercase;letter-spacing:.06em;background:#f2f4f7;border-radius:12px;padding:9px 10px;margin-bottom:10px;}
.pps-mp-controls-wrap label{display:block!important;font-size:13px!important;font-weight:900!important;color:#111!important;margin:10px 0 7px!important;}
.pps-mp-controls-wrap textarea,.pps-mp-controls-wrap select{width:100%!important;border:1px solid #d9dee7!important;border-radius:12px!important;padding:9px!important;background:#fff!important;}
.pps-mp-controls-wrap input[type="range"]{width:100%!important;accent-color:#075fd6;}
.pps-mp-controls-wrap input[type="color"]{width:52px!important;height:38px!important;border:1px solid #d9dee7!important;border-radius:10px!important;background:#fff!important;padding:2px!important;}
.pps-mp-controls-wrap .pps-layer-actions{display:grid!important;grid-template-columns:1fr 1fr;gap:8px!important;margin-top:12px!important;}
.pps-mp-controls-wrap .pps-layer-actions button,.pps-mp-controls-wrap .pps-delete-layer{border:0!important;background:#111!important;color:#fff!important;border-radius:12px!important;padding:10px!important;font-weight:900!important;cursor:pointer!important;text-transform:none!important;}
.pps-mp-controls-wrap .pps-delete-layer{background:#e11d48!important;width:100%;margin-top:8px!important;}
.pps-mp-canvas-area{min-width:0;overflow:auto;padding:26px 34px;display:flex;flex-direction:column;align-items:center;}
.pps-mp-canvas-head{width:min(760px,100%);margin:0 0 16px;}
.pps-mp-canvas-head h2{font-size:30px;line-height:1;margin:0 0 7px;color:#111;}
.pps-mp-canvas-head p{margin:0;color:#667085;font-size:15px;}
.pps-mp-designer .pps-editor-canvas-shell{width:min(720px,86vw)!important;background:#dfe5ee!important;border-radius:22px!important;padding:18px!important;box-shadow:inset 0 0 0 1px #c9d2df,0 20px 50px rgba(15,23,42,.1)!important;}
.pps-mp-designer .pps-editor-paper{border:3px solid #111!important;border-radius:10px!important;background:#fffaf6!important;overflow:hidden!important;}
.pps-mp-designer .pps-design-el.is-selected{outline:2px dashed #075fd6!important;outline-offset:5px!important;}
.pps-mp-designer .pps-design-text{font-size:34px!important;font-weight:900!important;line-height:1.05!important;}
.pps-mp-designer .pps-design-sticker img{width:210px!important;max-width:32vw!important;filter:drop-shadow(0 5px 8px rgba(0,0,0,.13));}
.pps-mp-designer .pps-design-photo img{width:330px!important;max-width:48vw!important;border-radius:10px!important;}
@media(max-width:980px){.pps-mp-workspace{grid-template-columns:1fr}.pps-mp-panel{max-height:42vh;border-right:0;border-bottom:1px solid #d9dee7}.pps-mp-topbar{grid-template-columns:90px 1fr 140px}.pps-mp-primary{padding:10px!important;font-size:12px!important}.pps-mp-sticker-grid{grid-template-columns:repeat(4,minmax(80px,1fr));max-height:180px}.pps-mp-canvas-area{padding:18px}.pps-mp-designer .pps-editor-canvas-shell{width:94vw!important}}


/* v1.3.0 - cleaner Moonpig-style designer rebuild */
.pps-designer-modal.pps-moonpig-designer{position:fixed!important;inset:0!important;z-index:999999!important;background:#f0f2f5!important;color:#111!important;display:flex!important;flex-direction:column!important;font-family:Helvetica,Arial,sans-serif!important;}
.pps-moon-topbar{height:58px;flex:0 0 58px;background:#fff;border-bottom:1px solid #d7dde6;display:grid;grid-template-columns:160px 1fr 178px;align-items:center;box-shadow:0 1px 8px rgba(15,23,42,.14);}
.pps-moon-exit{border:0;background:transparent!important;color:#075fd6!important;text-decoration:underline;font-weight:800;font-size:16px;text-align:left;padding-left:22px;cursor:pointer;}
.pps-moon-top-title{text-align:center;font-size:21px;font-weight:900;letter-spacing:.01em;}
.pps-moon-finalise{height:58px;border:0!important;background:#075fd6!important;color:#fff!important;font-size:15px;font-weight:900;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;}
.pps-moon-workspace{flex:1;min-height:0;display:grid;grid-template-columns:84px 320px minmax(0,1fr);}
.pps-moon-rail{background:#fff;border-right:1px solid #d7dde6;display:flex;flex-direction:column;align-items:center;padding:16px 10px;gap:8px;overflow:auto;}
.pps-moon-tool,.pps-moon-done{width:64px;min-height:70px;border:0;background:#fff!important;color:#4b5563!important;border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;font-weight:700;}
.pps-moon-tool span,.pps-moon-done span{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:900;}
.pps-moon-tool em,.pps-moon-done em{font-style:normal;font-size:12px;line-height:1.1;text-align:center;}
.pps-moon-tool.is-active{background:#eef5ff!important;color:#075fd6!important;box-shadow:inset 0 0 0 2px #075fd6;}
.pps-moon-done{margin-top:auto;color:#087a2a!important;}
.pps-moon-done span{border:2px solid #087a2a;border-radius:999px;}
.pps-moon-drawer{background:#fff;border-right:1px solid #d7dde6;padding:22px 18px;overflow:auto;box-shadow:4px 0 18px rgba(15,23,42,.05);}
.pps-moon-drawer-head h2{font-size:24px;line-height:1.05;margin:0 0 6px;font-weight:900;}
.pps-moon-drawer-head p{font-size:14px;line-height:1.45;color:#667085;margin:0 0 18px;}
.pps-moon-page{width:100%!important;margin:0 0 10px!important;padding:14px!important;background:#fff!important;color:#111!important;border:1px solid #dfe5ed!important;border-radius:14px!important;display:flex!important;align-items:center!important;gap:12px!important;text-transform:none!important;letter-spacing:0!important;font-size:15px!important;}
.pps-moon-page span{width:32px!important;height:32px!important;border-radius:999px!important;background:#eef2f7!important;color:#111!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;font-weight:900!important;}
.pps-moon-page strong{font-weight:900;}
.pps-moon-page.is-active{background:#111!important;color:#fff!important;border-color:#111!important;}
.pps-moon-page.is-active span{background:#fff!important;color:#111!important;}
.pps-moon-note,.pps-moon-empty{border:1px solid #e2e8f0;background:#f8fafc;border-radius:16px;padding:14px;margin-top:14px;color:#667085;font-size:14px;line-height:1.45;}
.pps-moon-empty strong{display:block;color:#111;margin-bottom:6px;font-size:15px;}
.pps-moon-empty p{margin:0;}
.pps-moon-sticker-library{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.pps-moon-sticker-asset{border:1px solid #e2e8f0!important;background:#f8fafc!important;border-radius:16px!important;padding:10px!important;cursor:pointer!important;min-height:136px;display:flex;flex-direction:column;align-items:center;justify-content:space-between;}
.pps-moon-sticker-asset:hover{border-color:#075fd6!important;box-shadow:0 6px 18px rgba(7,95,214,.12);}
.pps-moon-sticker-asset img{width:100%;height:92px;object-fit:contain;background:#fff;border-radius:12px;display:block;}
.pps-moon-sticker-asset span{font-size:12px;font-weight:900;color:#111;margin-top:8px;}
.pps-moon-big-action{width:100%;border:0!important;background:#111!important;color:#fff!important;border-radius:14px!important;padding:16px!important;font-size:15px!important;font-weight:900!important;cursor:pointer!important;text-transform:none!important;letter-spacing:0!important;}
.pps-moon-photo-preview{margin-top:14px;border:1px solid #e2e8f0;border-radius:16px;background:#f8fafc;padding:12px;}
.pps-moon-photo-preview img{width:100%;display:block;border-radius:12px;object-fit:contain;max-height:220px;}
.pps-moon-edit-card{display:grid;gap:13px;}
.pps-moon-edit-title{font-size:13px;text-transform:uppercase;letter-spacing:.08em;font-weight:900;background:#eef2f7;border-radius:12px;padding:10px;color:#111;}
.pps-moon-field{display:grid;gap:7px;font-size:13px;font-weight:900;color:#111;}
.pps-moon-field textarea{width:100%;min-height:92px;border:1px solid #d7dde6;border-radius:13px;padding:11px;font-size:15px;resize:vertical;box-sizing:border-box;}
.pps-moon-field select{width:100%;height:42px;border:1px solid #d7dde6;border-radius:13px;padding:0 10px;background:#fff;font-size:14px;}
.pps-moon-field input[type=range]{width:100%;accent-color:#075fd6;}
.pps-moon-colour-row{grid-template-columns:1fr 54px;align-items:center;}
.pps-moon-colour-row span{grid-column:1 / 2;}
.pps-moon-colour-row input{grid-column:2 / 3;grid-row:1 / 3;width:48px;height:40px;border:1px solid #d7dde6;border-radius:10px;background:#fff;padding:2px;}
.pps-moon-check{display:flex;align-items:center;gap:8px;font-weight:900;font-size:13px;}
.pps-moon-layer-actions{display:grid;grid-template-columns:1fr 1fr;gap:9px;}
.pps-moon-layer-actions button{border:0!important;background:#111!important;color:#fff!important;border-radius:13px!important;padding:12px 10px!important;font-weight:900!important;cursor:pointer!important;}
.pps-moon-layer-actions .pps-danger{grid-column:1 / -1;background:#d11d48!important;}
.pps-moon-stage-area{min-width:0;overflow:auto;display:flex;flex-direction:column;align-items:center;padding:28px 34px;}
.pps-moon-stage-head{width:min(760px,100%);margin-bottom:16px;}
.pps-moon-stage-head h1{font-size:32px;line-height:1;margin:0 0 9px;font-weight:900;}
.pps-moon-stage-head p{margin:0;color:#667085;font-size:15px;}
.pps-moon-canvas-wrap{display:flex;align-items:center;justify-content:center;width:100%;}
.pps-moonpig-designer .pps-editor-canvas-shell{width:min(720px,72vh,90%)!important;background:#dfe7f1!important;border-radius:22px!important;padding:18px!important;box-shadow:inset 0 0 0 1px #c9d2df,0 22px 60px rgba(15,23,42,.12)!important;}
.pps-moonpig-designer .pps-editor-paper{border:3px solid #111!important;border-radius:10px!important;background:#fffaf6!important;overflow:hidden!important;}
.pps-moonpig-designer .pps-design-el.is-selected{outline:2px dashed #075fd6!important;outline-offset:5px!important;}
.pps-moonpig-designer .pps-design-text{font-size:34px!important;font-weight:900!important;line-height:1.05!important;}
.pps-moonpig-designer .pps-design-sticker img{width:190px!important;max-width:30vw!important;filter:drop-shadow(0 5px 8px rgba(0,0,0,.13));}
.pps-moonpig-designer .pps-design-photo img{width:320px!important;max-width:46vw!important;border-radius:10px!important;}
@media(max-width:980px){.pps-moon-workspace{grid-template-columns:72px 1fr}.pps-moon-stage-area{grid-column:1 / -1;padding:18px}.pps-moon-drawer{border-right:0}.pps-moon-topbar{grid-template-columns:80px 1fr 128px}.pps-moon-finalise{font-size:12px}.pps-moon-sticker-library{grid-template-columns:repeat(3,1fr)}.pps-moonpig-designer .pps-editor-canvas-shell{width:94vw!important}}

/* v1.3.1 designer fixes */
.pps-moon-tool,.pps-moon-done{width:58px!important;min-height:62px!important;padding:6px 4px!important;gap:3px!important;overflow:hidden!important;}
.pps-moon-tool span,.pps-moon-done span{width:26px!important;height:26px!important;font-size:17px!important;}
.pps-moon-tool em,.pps-moon-done em{font-size:10.5px!important;line-height:1!important;max-width:54px!important;white-space:normal!important;overflow:hidden!important;text-overflow:clip!important;}
.pps-moon-tool.is-active{box-shadow:inset 0 0 0 1.5px #075fd6!important;}
.pps-moon-edit-card{gap:8px!important;}
.pps-moon-drawer{padding:16px 14px!important;}
.pps-moon-drawer-head h2{font-size:22px!important;}
.pps-moon-drawer-head p{font-size:13px!important;margin-bottom:12px!important;}
.pps-moon-field{gap:5px!important;font-size:12px!important;}
.pps-moon-field select{height:36px!important;font-size:13px!important;border-radius:10px!important;}
.pps-moon-field input[type=range]{height:22px!important;margin:0!important;}
.pps-moon-check{font-size:12px!important;}
.pps-moon-layer-actions{gap:6px!important;}
.pps-moon-layer-actions button{padding:9px 7px!important;border-radius:10px!important;font-size:12px!important;}
.pps-moon-secondary-action{width:100%;border:0!important;background:#111!important;color:#fff!important;border-radius:12px!important;padding:11px 12px!important;font-weight:900!important;cursor:pointer!important;}
.pps-align-row{display:grid!important;grid-template-columns:1fr 1fr 1fr!important;gap:6px!important;margin:2px 0 4px!important;}
.pps-align-btn{height:38px!important;border:1px solid #d7dde6!important;background:#fff!important;color:#111!important;border-radius:10px!important;font-size:18px!important;font-weight:900!important;cursor:pointer!important;}
.pps-align-btn.is-active{background:#111!important;color:#fff!important;border-color:#111!important;}
.pps-text-note{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:8px!important;color:#667085!important;}
.pps-panel-subhead{font-size:13px!important;text-transform:uppercase;letter-spacing:.06em;margin:16px 0 8px!important;}
.pps-moonpig-designer .pps-design-sticker img{width:270px!important;max-width:42vw!important;filter:drop-shadow(0 5px 8px rgba(0,0,0,.13));pointer-events:none!important;}
.pps-moonpig-designer .pps-design-photo img{width:420px!important;max-width:60vw!important;border-radius:10px!important;pointer-events:none!important;}
.pps-moonpig-designer .pps-design-text{font-size:34px!important;font-weight:900!important;line-height:1.05!important;min-width:80px!important;min-height:24px!important;}
.pps-editable-text{display:inline-block;min-width:80px;outline:none!important;cursor:text!important;padding:2px 4px;}
.pps-design-el{touch-action:none!important;}
.pps-resize-handle{position:absolute;width:15px;height:15px;background:#fff;border:2px solid #075fd6;border-radius:3px;z-index:50;box-shadow:0 1px 4px rgba(0,0,0,.18);}
.pps-rh-nw{left:-12px;top:-12px;cursor:nwse-resize;}
.pps-rh-ne{right:-12px;top:-12px;cursor:nesw-resize;}
.pps-rh-sw{left:-12px;bottom:-12px;cursor:nesw-resize;}
.pps-rh-se{right:-12px;bottom:-12px;cursor:nwse-resize;}
.pps-moonpig-designer .pps-design-el.is-selected{outline:2px dashed #075fd6!important;outline-offset:7px!important;}
.pps-moon-big-action,.pps-moon-secondary-action,.pps-moon-finalise,.pps-moon-layer-actions button,.pps-trigger-generate,.pps-trigger-photo-upload,.pps-finalise-kit,.pps-add-sticker-cover{color:#fff!important;}
.pps-original-photo-library .pps-moon-sticker-asset img{object-fit:cover!important;}
@media(max-width:980px){.pps-moonpig-designer .pps-design-sticker img{width:210px!important}.pps-moonpig-designer .pps-design-photo img{width:320px!important}.pps-moon-tool em,.pps-moon-done em{font-size:10px!important}}


/* v1.3.2 mobile Moonpig-style designer layout */
@media (max-width: 767px) {
  body.pps-designer-open {
    overflow: hidden !important;
    position: fixed !important;
    width: 100% !important;
  }

  .pps-designer-modal.pps-moonpig-designer {
    background: #eef1f5 !important;
    overflow: hidden !important;
  }

  .pps-moon-topbar {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    height: 58px !important;
    flex: 0 0 58px !important;
    z-index: 50 !important;
    display: grid !important;
    grid-template-columns: 74px 1fr 142px !important;
    padding: 0 !important;
    background: #fff !important;
    box-shadow: 0 2px 12px rgba(15,23,42,.16) !important;
  }

  .pps-moon-exit {
    padding-left: 14px !important;
    font-size: 15px !important;
    height: 58px !important;
    display: flex !important;
    align-items: center !important;
    color: #075fd6 !important;
  }

  .pps-moon-top-title {
    font-size: 18px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    padding: 0 8px !important;
  }

  .pps-moon-finalise {
    height: 58px !important;
    border-radius: 0 0 0 20px !important;
    font-size: 13px !important;
    letter-spacing: .03em !important;
    padding: 0 12px !important;
    color: #fff !important;
  }

  .pps-moon-workspace {
    display: block !important;
    position: fixed !important;
    inset: 58px 0 0 0 !important;
    overflow: hidden !important;
    background: #eef1f5 !important;
  }

  /* Mobile top icon toolbar, like Moonpig */
  .pps-moon-rail {
    position: fixed !important;
    top: 58px !important;
    left: 0 !important;
    right: 0 !important;
    height: 78px !important;
    z-index: 45 !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 4px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    padding: 7px 8px !important;
    background: #fff !important;
    border-right: 0 !important;
    border-bottom: 1px solid #d7dde6 !important;
    box-shadow: 0 3px 16px rgba(15,23,42,.12) !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .pps-moon-tool,
  .pps-moon-done {
    flex: 0 0 68px !important;
    width: 68px !important;
    height: 64px !important;
    min-height: 64px !important;
    border-radius: 14px !important;
    padding: 5px 3px !important;
    gap: 3px !important;
  }

  .pps-moon-tool span,
  .pps-moon-done span {
    width: 27px !important;
    height: 27px !important;
    font-size: 17px !important;
  }

  .pps-moon-tool em,
  .pps-moon-done em {
    font-size: 11px !important;
    line-height: 1.05 !important;
    max-width: 64px !important;
  }

  .pps-moon-done {
    margin-top: 0 !important;
    margin-left: 2px !important;
    order: 99 !important;
  }

  .pps-moon-tool.is-active {
    box-shadow: inset 0 0 0 2px #075fd6 !important;
    background: #eef5ff !important;
  }

  /* The selected tool panel becomes a bottom sheet, not a left column */
  .pps-moon-drawer {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    height: 32vh !important;
    min-height: 210px !important;
    max-height: 330px !important;
    z-index: 48 !important;
    border-right: 0 !important;
    border-top: 1px solid #d7dde6 !important;
    border-radius: 18px 18px 0 0 !important;
    padding: 14px 18px calc(14px + env(safe-area-inset-bottom)) !important;
    overflow: auto !important;
    background: #fff !important;
    box-shadow: 0 -10px 28px rgba(15,23,42,.16) !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .pps-moon-drawer:before {
    content: '' !important;
    display: block !important;
    width: 46px !important;
    height: 4px !important;
    border-radius: 999px !important;
    background: #d7dde6 !important;
    margin: 0 auto 10px !important;
  }

  .pps-moon-drawer-head h2 {
    font-size: 22px !important;
    line-height: 1.05 !important;
    margin: 0 0 5px !important;
  }

  .pps-moon-drawer-head p {
    font-size: 13px !important;
    line-height: 1.3 !important;
    margin: 0 0 10px !important;
  }

  /* Canvas sits between top toolbar and bottom sheet */
  .pps-moon-stage-area {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    top: 136px !important;
    bottom: 31vh !important;
    min-height: 0 !important;
    padding: 12px 12px 18px !important;
    overflow: auto !important;
    align-items: center !important;
    justify-content: flex-start !important;
    background: #eef1f5 !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .pps-moon-stage-head {
    width: 100% !important;
    margin: 0 0 8px !important;
    text-align: center !important;
  }

  .pps-moon-stage-head h1 {
    font-size: 20px !important;
    margin: 0 0 4px !important;
    line-height: 1.05 !important;
  }

  .pps-moon-stage-head p {
    display: none !important;
  }

  .pps-moon-canvas-wrap {
    width: 100% !important;
    min-height: 0 !important;
    align-items: flex-start !important;
  }

  .pps-moonpig-designer .pps-editor-canvas-shell {
    width: min(92vw, 410px) !important;
    max-width: 92vw !important;
    padding: 10px !important;
    border-radius: 16px !important;
    margin: 0 auto 18px !important;
    box-shadow: inset 0 0 0 1px #c9d2df,0 14px 34px rgba(15,23,42,.12) !important;
  }

  .pps-moonpig-designer .pps-editor-paper {
    border-width: 2px !important;
    border-radius: 8px !important;
  }

  .pps-moon-sticker-library {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(86px, 1fr)) !important;
    gap: 10px !important;
    max-height: none !important;
  }

  .pps-moon-sticker-asset {
    min-height: 112px !important;
    border-radius: 14px !important;
    padding: 8px !important;
  }

  .pps-moon-sticker-asset img {
    height: 72px !important;
    border-radius: 10px !important;
  }

  .pps-moon-sticker-asset span {
    font-size: 11px !important;
    margin-top: 6px !important;
  }

  .pps-moon-big-action,
  .pps-moon-secondary-action,
  .pps-moon-layer-actions button {
    border-radius: 14px !important;
    padding: 12px 13px !important;
    font-size: 13px !important;
    color: #fff !important;
  }

  .pps-moon-edit-card {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  .pps-moon-edit-title {
    font-size: 12px !important;
    padding: 9px 10px !important;
  }

  .pps-moon-field {
    font-size: 12px !important;
    gap: 4px !important;
    margin: 0 !important;
  }

  .pps-moon-field textarea {
    min-height: 62px !important;
    font-size: 14px !important;
    padding: 9px !important;
  }

  .pps-moon-field select {
    height: 34px !important;
  }

  .pps-align-row {
    grid-template-columns: repeat(3, 44px) !important;
    justify-content: start !important;
  }

  .pps-align-btn {
    height: 34px !important;
    font-size: 15px !important;
  }

  .pps-moon-layer-actions {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 7px !important;
  }

  .pps-moon-layer-actions .pps-danger {
    grid-column: auto !important;
  }

  .pps-moonpig-designer .pps-design-sticker img {
    width: 150px !important;
    max-width: 58vw !important;
  }

  .pps-moonpig-designer .pps-design-photo img {
    width: 220px !important;
    max-width: 68vw !important;
  }

  .pps-moonpig-designer .pps-design-text {
    font-size: 28px !important;
  }

  .pps-resize-handle {
    width: 18px !important;
    height: 18px !important;
    border-width: 2px !important;
  }

  .pps-rh-nw { left: -14px !important; top: -14px !important; }
  .pps-rh-ne { right: -14px !important; top: -14px !important; }
  .pps-rh-sw { left: -14px !important; bottom: -14px !important; }
  .pps-rh-se { right: -14px !important; bottom: -14px !important; }
}

@media (max-width: 390px) {
  .pps-moon-topbar {
    grid-template-columns: 64px 1fr 128px !important;
  }
  .pps-moon-top-title {
    font-size: 16px !important;
  }
  .pps-moon-finalise {
    font-size: 12px !important;
  }
  .pps-moon-tool,
  .pps-moon-done {
    flex-basis: 62px !important;
    width: 62px !important;
  }
  .pps-moon-tool em,
  .pps-moon-done em {
    font-size: 10px !important;
  }
  .pps-moon-sticker-library {
    grid-template-columns: repeat(2, minmax(92px, 1fr)) !important;
  }
}

/* v1.3.3 mobile editor stability + Moonpig-like selected toolbar */
.pps-moonpig-designer .pps-design-el {
  -webkit-user-select: none !important;
  user-select: none !important;
  -webkit-touch-callout: none !important;
  touch-action: none !important;
  transform-style: flat !important;
  backface-visibility: hidden !important;
  -webkit-backface-visibility: hidden !important;
  contain: layout paint !important;
}
.pps-moonpig-designer .pps-design-el img.pps-ui-image {
  transform: translateZ(0) !important;
  -webkit-transform: translateZ(0) !important;
  backface-visibility: hidden !important;
  -webkit-backface-visibility: hidden !important;
  max-width: none !important;
}
.pps-editable-text:empty:before {
  content: attr(data-placeholder);
  color: rgba(17,17,17,.42);
}
.pps-editable-text {
  outline: none !important;
  min-width: 60px;
  min-height: 1em;
  display: inline-block;
  white-space: pre-wrap;
}
.pps-layer-quick {
  position: absolute !important;
  z-index: 70 !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: 999px !important;
  border: 2px solid #075fd6 !important;
  background: #fff !important;
  color: #075fd6 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 900 !important;
  font-size: 20px !important;
  line-height: 1 !important;
  box-shadow: 0 3px 10px rgba(15,23,42,.18) !important;
  cursor: pointer !important;
  touch-action: none !important;
}
.pps-layer-quick-rotate { left: 50% !important; top: -58px !important; transform: translateX(-120%) !important; }
.pps-layer-quick-delete { left: 50% !important; top: -58px !important; transform: translateX(20%) !important; }
.pps-edit-expand {
  width: 100% !important;
  border: 0 !important;
  background: #111 !important;
  color: #fff !important;
  border-radius: 18px !important;
  padding: 14px 18px !important;
  display: grid !important;
  gap: 3px !important;
  text-align: left !important;
  cursor: pointer !important;
  box-shadow: 0 8px 22px rgba(15,23,42,.2) !important;
}
.pps-edit-expand strong { color:#fff !important; font-size: 18px !important; line-height: 1.1 !important; }
.pps-edit-expand span { color: rgba(255,255,255,.82) !important; font-size: 13px !important; line-height: 1.25 !important; }

@media (max-width: 767px) {
  .pps-designer-modal.pps-has-collapsed-edit .pps-moon-stage-area {
    bottom: 94px !important;
  }
  .pps-moon-drawer.is-collapsed {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 12px 14px calc(12px + env(safe-area-inset-bottom)) !important;
    overflow: visible !important;
  }
  .pps-moon-drawer.is-collapsed:before {
    margin-bottom: 8px !important;
  }
  .pps-layer-quick {
    width: 34px !important;
    height: 34px !important;
    font-size: 18px !important;
  }
  .pps-layer-quick-rotate { top: -52px !important; }
  .pps-layer-quick-delete { top: -52px !important; }
  .pps-moonpig-designer .pps-design-sticker img.pps-ui-image {
    width: 175px !important;
    max-width: 62vw !important;
    filter: drop-shadow(0 3px 5px rgba(0,0,0,.12)) !important;
  }
  .pps-moonpig-designer .pps-design-photo img.pps-ui-image {
    width: 245px !important;
    max-width: 72vw !important;
  }
}


/* v1.3.4 layer-lock and mobile editing polish */
.pps-toggle-lock{width:100%;border:0!important;border-radius:12px!important;background:#eef2f7!important;color:#111!important;font-weight:900!important;padding:11px 12px!important;margin:0 0 10px!important;cursor:pointer!important;text-transform:none!important;}
.pps-toggle-lock.is-locked{background:#111!important;color:#fff!important;}
.pps-design-el.is-locked{cursor:default!important;}
.pps-design-el.is-locked.is-selected{outline-color:#111!important;outline-style:solid!important;}
.pps-design-el.is-locked.is-selected:after{content:'Locked';position:absolute;left:50%;top:-34px;transform:translateX(-50%);background:#111;color:#fff;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:900;white-space:nowrap;}
.pps-editable-text{cursor:text;min-width:80px;min-height:1.15em;display:inline-block;}
.pps-design-text.is-selected .pps-editable-text{outline:1px solid rgba(7,95,214,.28);background:rgba(255,255,255,.12);}
@media(max-width:767px){
  .pps-toggle-lock{font-size:13px!important;padding:10px!important;margin-bottom:8px!important;}
  .pps-moon-edit-card .pps-moon-field{margin:8px 0!important;}
}


/* v1.3.5 mobile/layer interaction fixes */
.pps-moon-finalise,.pps-finalise-kit-btn,.pps-finalise-kit,.pps-mp-primary{background:#111!important;border-color:#111!important;color:#fff!important;}
.pps-moon-exit,.pps-designer-exit,.pps-mp-link{color:#111!important;}
.pps-moon-field input[type=range],.pps-control-rotation,.pps-crop-controls input[type=range],.pps-side-card input[type=range],.pps-mp-controls-wrap input[type=range]{accent-color:#111!important;}
.pps-moon-layer-actions .pps-danger,.pps-delete-layer,.pps-cover-delete-selected{background:#111!important;border-color:#111!important;color:#fff!important;}
.pps-design-text{white-space:pre!important;width:max-content!important;max-width:none!important;}
.pps-editable-text{white-space:pre!important;width:max-content!important;max-width:none!important;}
.pps-design-text .pps-editable-text{line-height:1.05!important;}
.pps-moonpig-designer .pps-editor-canvas-shell,.pps-moonpig-designer .pps-editor-paper,.pps-moon-canvas-wrap,.pps-moon-stage-area{overflow:visible!important;}
.pps-moonpig-designer .pps-design-el{z-index:auto;}
.pps-resize-handle{width:20px!important;height:20px!important;border:3px solid #075fd6!important;background:#fff!important;z-index:90!important;border-radius:5px!important;}
.pps-rh-se{width:24px!important;height:24px!important;right:-18px!important;bottom:-18px!important;border-radius:4px!important;}
.pps-rh-se:after{content:'↘';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#075fd6;font-size:13px;font-weight:900;line-height:1;}
.pps-layer-quick{z-index:95!important;background:#fff!important;color:#075fd6!important;border-color:#075fd6!important;}
.pps-layer-quick-delete{font-size:0!important;}
.pps-layer-quick-delete:before{content:'🗑';font-size:18px;line-height:1;}
.pps-layer-quick-rotate{font-size:0!important;}
.pps-layer-quick-rotate:before{content:'⟳';font-size:20px;line-height:1;}
.pps-design-el.is-selected{z-index:9999!important;}
.pps-design-el.is-locked.is-selected{z-index:9999!important;}
@media(max-width:767px){
  .pps-moon-finalise{background:#111!important;color:#fff!important;border-radius:0 0 0 20px!important;}
  .pps-moon-exit{color:#111!important;font-weight:900!important;}
  .pps-moon-stage-area{overflow:auto!important;}
  .pps-moonpig-designer .pps-editor-canvas-shell,.pps-moonpig-designer .pps-editor-paper{overflow:visible!important;}
  .pps-layer-quick{width:36px!important;height:36px!important;}
  .pps-layer-quick-rotate{top:-54px!important;left:38%!important;transform:translateX(-50%)!important;}
  .pps-layer-quick-delete{top:-54px!important;left:62%!important;transform:translateX(-50%)!important;}
  .pps-resize-handle{width:22px!important;height:22px!important;}
  .pps-rh-se{width:28px!important;height:28px!important;right:-22px!important;bottom:-22px!important;}
  .pps-moon-drawer:not(.is-collapsed){max-height:42vh!important;height:38vh!important;}
}


/* v1.3.6 design-tool fixes */
.pps-moonpig-designer .pps-editor-paper{
  overflow: visible !important;
}
.pps-moonpig-designer .pps-editor-paper:before{
  content:'';
  position:absolute;
  inset:0;
  border-radius:10px;
  pointer-events:none;
  box-shadow: inset 0 0 0 0 transparent;
}
.pps-moonpig-designer .pps-design-el img.pps-ui-image{
  pointer-events:none!important;
}
.pps-moon-edit-card{
  gap:10px!important;
}
.pps-text-editor-field textarea.pps-control-text{
  min-height:64px!important;
  max-height:110px!important;
  resize:none!important;
  font-size:16px!important;
  line-height:1.2!important;
  border:1px solid #d7dde6!important;
  border-radius:12px!important;
  padding:10px!important;
  width:100%!important;
  box-sizing:border-box!important;
}
.pps-moon-layer-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr 1fr!important;
  gap:8px!important;
}
.pps-moon-layer-actions button,
.pps-moon-layer-actions .pps-danger,
.pps-delete-layer{
  grid-column:auto!important;
  background:#111!important;
  border-color:#111!important;
  color:#fff!important;
  min-height:44px!important;
  border-radius:13px!important;
  padding:10px 8px!important;
  font-size:12px!important;
  line-height:1.1!important;
}
.pps-flip-horizontal{
  background:#111!important;
  color:#fff!important;
}
.pps-moon-field input[type=range],
.pps-control-rotation,
.pps-control-scale{
  accent-color:#111!important;
}
.pps-moon-secondary-action,
.pps-moon-big-action,
.pps-moon-layer-actions button{
  background:#111!important;
  color:#fff!important;
}
.pps-resize-handle{
  position:absolute!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:36px!important;
  height:36px!important;
  border:3px solid #075fd6!important;
  background:#fff!important;
  color:#075fd6!important;
  z-index:120!important;
  border-radius:8px!important;
  box-shadow:0 4px 12px rgba(15,23,42,.22)!important;
  font-size:0!important;
  cursor:nwse-resize!important;
}
.pps-rh-se{
  right:-46px!important;
  bottom:-46px!important;
}
.pps-rh-se:after{
  content:'↘'!important;
  font-size:20px!important;
  line-height:1!important;
  color:#075fd6!important;
}
.pps-layer-quick{
  width:38px!important;
  height:38px!important;
  z-index:121!important;
  background:#fff!important;
  color:#075fd6!important;
  border:3px solid #075fd6!important;
  border-radius:999px!important;
  box-shadow:0 4px 12px rgba(15,23,42,.22)!important;
}
.pps-layer-quick-rotate{
  top:-52px!important;
  left:0!important;
  transform:translate(-35%,-35%)!important;
}
.pps-layer-quick-delete{
  top:-52px!important;
  right:0!important;
  left:auto!important;
  transform:translate(35%,-35%)!important;
}
.pps-design-el.is-selected{
  z-index:9999!important;
}
.pps-design-text{
  white-space:pre!important;
  width:max-content!important;
  max-width:none!important;
}
.pps-editable-text{
  white-space:pre!important;
  width:max-content!important;
  max-width:none!important;
}
@media(max-width:767px){
  .pps-moon-drawer:not(.is-collapsed){
    max-height:40vh!important;
    height:37vh!important;
  }
  .pps-moon-layer-actions{
    grid-template-columns:1fr 1fr 1fr!important;
    gap:6px!important;
  }
  .pps-moon-layer-actions button,
  .pps-delete-layer{
    min-height:48px!important;
    font-size:12px!important;
    border-radius:14px!important;
  }
  .pps-rh-se{
    right:-42px!important;
    bottom:-42px!important;
  }
  .pps-layer-quick-rotate{
    top:-48px!important;
    left:0!important;
  }
  .pps-layer-quick-delete{
    top:-48px!important;
    right:0!important;
    left:auto!important;
  }
}


/* v1.3.7 mobile designer fixes */
.pps-photo-clean-head p,
.pps-editor-cover-photo,
.pps-cover-photo-library,
.pps-panel-subhead { display:none !important; }
.pps-original-photo-library { margin-top: 6px !important; }
.pps-moonpig-designer .pps-design-el.is-selected,
.pps-moonpig-designer .pps-design-el.is-locked.is-selected,
.pps-design-el.is-selected,
.pps-design-el.is-locked.is-selected { z-index: inherit !important; }
.pps-moonpig-designer .pps-design-el.is-selected .pps-layer-quick,
.pps-moonpig-designer .pps-design-el.is-selected .pps-resize-handle { z-index: 99999 !important; }
.pps-moonpig-designer .pps-editor-paper { overflow: visible !important; }
.pps-moonpig-designer .pps-editor-paper:before { pointer-events:none !important; }
.pps-moonpig-designer .pps-design-el img.pps-ui-image { user-select:none !important; -webkit-user-drag:none !important; }
.pps-moon-layer-actions { grid-template-columns: repeat(3, minmax(0,1fr)) !important; }
.pps-moon-layer-actions button { min-width:0 !important; padding-left:8px !important; padding-right:8px !important; }
@media(max-width:767px){
  .pps-original-photo-library.pps-moon-sticker-library { grid-template-columns:repeat(2,minmax(0,1fr)) !important; }
  .pps-photo-clean-head h2 { margin-bottom:12px !important; }
  .pps-moonpig-designer .pps-editor-paper { overflow: visible !important; }
}

/* v1.3.8 layer clipping + mobile ordering fixes */
.pps-moonpig-designer .pps-design-el,
.pps-moonpig-designer .pps-design-el.is-selected,
.pps-moonpig-designer .pps-design-el.is-locked.is-selected,
.pps-design-el.is-selected,
.pps-design-el.is-locked.is-selected {
  z-index: var(--pps-z, 1) !important;
}
.pps-moonpig-designer .pps-editor-paper,
.pps-moonpig-designer .pps-editor-canvas-shell,
.pps-moon-canvas-wrap,
.pps-moon-stage-area {
  overflow: visible !important;
}
.pps-moonpig-designer .pps-design-el img.pps-ui-image {
  will-change: clip-path, transform;
}
.pps-control-scale {
  accent-color: #111 !important;
}
.pps-layer-quick,
.pps-resize-handle {
  pointer-events: auto !important;
}
.pps-moonpig-designer .pps-design-el.is-selected .pps-layer-quick,
.pps-moonpig-designer .pps-design-el.is-selected .pps-resize-handle {
  z-index: 99999 !important;
}
@media(max-width:767px){
  .pps-moonpig-designer .pps-design-el,
  .pps-moonpig-designer .pps-design-el.is-selected,
  .pps-design-el.is-selected {
    z-index: var(--pps-z, 1) !important;
  }
}


/* v1.3.9 stable clipping + photo panel recovery
   Stop Safari/iPhone flicker from dynamic image clip-path. Keep artwork clipped
   by the actual cover paper; layer z-order remains true to the user's choices. */
.pps-moonpig-designer .pps-editor-paper{
  overflow:hidden!important;
  contain:layout paint!important;
}
.pps-moonpig-designer .pps-editor-canvas-shell,
.pps-moon-canvas-wrap,
.pps-moon-stage-area{
  overflow:visible!important;
}
.pps-moonpig-designer .pps-design-el,
.pps-moonpig-designer .pps-design-el.is-selected,
.pps-moonpig-designer .pps-design-el.is-locked.is-selected,
.pps-design-el.is-selected,
.pps-design-el.is-locked.is-selected{
  z-index:var(--pps-z,1)!important;
}
.pps-moonpig-designer .pps-design-el img.pps-ui-image{
  clip-path:none!important;
  -webkit-clip-path:none!important;
  will-change:transform!important;
  backface-visibility:hidden!important;
  -webkit-backface-visibility:hidden!important;
  transform:translateZ(0);
}
.pps-photo-clean-head p,
.pps-editor-cover-photo,
.pps-cover-photo-library,
.pps-panel-subhead,
.pps-moon-photo-preview{
  display:none!important;
}
.pps-original-photo-library.pps-moon-sticker-library{
  margin-top:10px!important;
}
.pps-original-photo-library .pps-moon-sticker-asset img{
  object-fit:contain!important;
}
@media(max-width:767px){
  .pps-moonpig-designer .pps-editor-paper{overflow:hidden!important;}
  .pps-moonpig-designer .pps-design-el img.pps-ui-image{clip-path:none!important;-webkit-clip-path:none!important;}
  .pps-moon-drawer:not(.is-collapsed){max-height:40vh!important;height:37vh!important;}
}


/* v1.3.10/1.3.11 stable Moonpig-style selected overlay
   Artwork is clipped by the page, but the blue selection frame/handles are not clipped. */
.pps-moonpig-designer .pps-editor-paper{
  overflow:visible!important;
  isolation:isolate!important;
}
.pps-moonpig-designer .pps-editor-paper-clip{
  position:absolute!important;
  inset:0!important;
  overflow:hidden!important;
  border-radius:inherit!important;
  z-index:1!important;
  background:#fffaf6!important;
}
.pps-moonpig-designer .pps-editor-art-layer,
.pps-moonpig-designer .pps-editor-dot-bg{
  position:absolute!important;
  inset:0!important;
}
.pps-moonpig-designer .pps-editor-paper-clip .pps-design-el.is-selected,
.pps-moonpig-designer .pps-editor-paper-clip .pps-design-el.is-locked.is-selected{
  outline:none!important;
}
.pps-moonpig-designer .pps-selection-layer{
  position:absolute!important;
  inset:0!important;
  overflow:visible!important;
  z-index:100000!important;
  pointer-events:none!important;
}
.pps-moonpig-designer .pps-selection-box{
  position:absolute!important;
  transform-origin:center center!important;
  outline:4px dashed #075fd6!important;
  outline-offset:7px!important;
  z-index:100001!important;
  pointer-events:auto!important;
  touch-action:none!important;
  box-sizing:border-box!important;
}
.pps-moonpig-designer .pps-selection-box .pps-selection-measure{
  display:block!important;
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
}
.pps-moonpig-designer .pps-selection-box img.pps-selection-measure{
  width:100%!important;
  height:auto!important;
  max-width:260px!important;
  user-select:none!important;
  -webkit-user-drag:none!important;
}
.pps-moonpig-designer .pps-selection-text .pps-selection-measure{
  font:inherit!important;
  white-space:nowrap!important;
  line-height:1.1!important;
}
.pps-moonpig-designer .pps-selection-box .pps-layer-quick,
.pps-moonpig-designer .pps-selection-box .pps-resize-handle{
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
  z-index:100010!important;
}
.pps-moonpig-designer .pps-layer-quick-delete,
.pps-moonpig-designer .pps-layer-quick-rotate{
  background:#fff!important;
  color:#075fd6!important;
  border:2px solid #075fd6!important;
  box-shadow:0 2px 8px rgba(0,0,0,.16)!important;
}
/* Photos drawer: keep wording simple and make generated items available as photos too. */
.pps-photo-clean-head p{display:none!important;}
.pps-moonpig-designer .pps-moon-finalise,
.pps-moonpig-designer .pps-moon-exit{background:#111!important;color:#fff!important;border-color:#111!important;}
.pps-moonpig-designer .pps-editor-paper{contain:none!important;}


/* v1.3.11: keep artwork clipped, keep the selected frame independent and stable. */
.pps-moonpig-designer .pps-editor-paper{
  overflow:visible!important;
}
.pps-moonpig-designer .pps-editor-paper-clip{
  overflow:hidden!important;
  contain:paint!important;
}
.pps-moonpig-designer .pps-selection-layer{
  overflow:visible!important;
  pointer-events:none!important;
}
.pps-moonpig-designer .pps-selection-box{
  position:absolute!important;
  overflow:visible!important;
  background:transparent!important;
  pointer-events:auto!important;
  contain:none!important;
  will-change:transform!important;
}
.pps-moonpig-designer .pps-selection-box .pps-selection-measure{
  display:block!important;
  width:100%!important;
  height:100%!important;
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
}
.pps-moonpig-designer .pps-editor-paper-clip .pps-design-el,
.pps-moonpig-designer .pps-editor-paper-clip .pps-design-el *{
  pointer-events:auto!important;
}
.pps-moonpig-designer .pps-editor-paper-clip .pps-design-el.is-selected{
  outline:none!important;
}

/* v1.3.12 desktop polished centred cover designer
   Desktop only: keeps the existing mobile bottom-sheet layout unchanged. */
@media (min-width: 768px) {
  .pps-designer-modal.pps-moonpig-designer {
    background: #f3f6fa !important;
    font-family: Inter, Helvetica, Arial, sans-serif !important;
  }

  .pps-moon-topbar {
    height: 78px !important;
    flex: 0 0 78px !important;
    display: grid !important;
    grid-template-columns: 180px 1fr 220px !important;
    align-items: center !important;
    padding: 0 28px !important;
    background: rgba(255,255,255,.96) !important;
    border-bottom: 1px solid #dde3ec !important;
    box-shadow: 0 2px 14px rgba(15,23,42,.08) !important;
    box-sizing: border-box !important;
  }

  .pps-moon-exit {
    width: 112px !important;
    height: 52px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    border: 1px solid #cfd7e3 !important;
    border-radius: 12px !important;
    background: #ffffff !important;
    color: #111827 !important;
    text-decoration: none !important;
    font-size: 15px !important;
    font-weight: 900 !important;
    text-align: center !important;
    letter-spacing: .02em !important;
    box-shadow: 0 6px 18px rgba(15,23,42,.06) !important;
  }

  .pps-moon-top-title {
    font-size: 26px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    color: #0b0f19 !important;
    text-align: center !important;
  }

  .pps-moon-finalise {
    justify-self: end !important;
    width: auto !important;
    min-width: 170px !important;
    height: 52px !important;
    padding: 0 24px !important;
    border-radius: 12px !important;
    background: #075fd6 !important;
    color: #ffffff !important;
    font-size: 15px !important;
    font-weight: 900 !important;
    letter-spacing: .03em !important;
    box-shadow: 0 9px 22px rgba(7,95,214,.22) !important;
  }

  .pps-moon-workspace {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    width: min(calc(100vw - 72px), 1460px) !important;
    max-width: 1460px !important;
    margin: 32px auto 34px !important;
    display: grid !important;
    grid-template-columns: 330px 92px minmax(560px, 760px) !important;
    justify-content: center !important;
    gap: 0 !important;
    background: #ffffff !important;
    border: 1px solid #dde4ee !important;
    border-radius: 14px !important;
    box-shadow: 0 18px 54px rgba(15,23,42,.10) !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }

  .pps-moon-drawer {
    grid-column: 1 !important;
    grid-row: 1 !important;
    background: #ffffff !important;
    border-right: 1px solid #e2e8f0 !important;
    padding: 28px 24px !important;
    overflow: auto !important;
    box-shadow: none !important;
  }

  .pps-moon-rail {
    grid-column: 2 !important;
    grid-row: 1 !important;
    background: #ffffff !important;
    border-right: 1px solid #e2e8f0 !important;
    padding: 24px 10px !important;
    gap: 14px !important;
    overflow: auto !important;
    box-shadow: 6px 0 18px rgba(15,23,42,.035) !important;
  }

  .pps-moon-stage-area {
    grid-column: 3 !important;
    grid-row: 1 !important;
    min-width: 0 !important;
    padding: 30px 36px 34px !important;
    background: #ffffff !important;
    overflow: auto !important;
    align-items: flex-start !important;
  }

  .pps-moon-stage-head {
    width: min(720px, 100%) !important;
    margin: 0 auto 16px !important;
    text-align: left !important;
  }

  .pps-moon-stage-head h1 {
    font-size: 32px !important;
    margin: 0 0 10px !important;
    line-height: 1 !important;
    color: #0b0f19 !important;
    font-weight: 900 !important;
  }

  .pps-moon-stage-head p {
    margin: 0 !important;
    color: #667085 !important;
    font-size: 15px !important;
  }

  .pps-moon-canvas-wrap {
    width: 100% !important;
    display: flex !important;
    align-items: flex-start !important;
    justify-content: center !important;
  }

  .pps-moonpig-designer .pps-editor-canvas-shell {
    width: min(720px, 100%) !important;
    max-width: 720px !important;
    padding: 22px !important;
    border-radius: 22px !important;
    background: #dfeaf8 !important;
    box-shadow: inset 0 0 0 1px #c4d3e7, 0 18px 44px rgba(15,23,42,.12) !important;
  }

  .pps-moonpig-designer .pps-editor-paper {
    border: 3px solid #111827 !important;
    border-radius: 10px !important;
    background: #fffaf6 !important;
  }

  .pps-moon-drawer-head h2 {
    font-size: 22px !important;
    line-height: 1.05 !important;
    margin: 0 0 8px !important;
    color: #0b0f19 !important;
    font-weight: 900 !important;
  }

  .pps-moon-drawer-head p {
    color: #667085 !important;
    font-size: 14px !important;
    line-height: 1.45 !important;
    margin: 0 0 24px !important;
  }

  .pps-moon-edit-card {
    display: grid !important;
    gap: 16px !important;
  }

  .pps-toggle-lock {
    min-height: 70px !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 14px !important;
    background: #f6f8fb !important;
    color: #0b0f19 !important;
    font-weight: 900 !important;
    font-size: 15px !important;
    cursor: pointer !important;
  }

  .pps-moon-secondary-action {
    min-height: 70px !important;
    border: 0 !important;
    border-radius: 14px !important;
    background: #101828 !important;
    color: #ffffff !important;
    font-size: 15px !important;
    font-weight: 900 !important;
    letter-spacing: .01em !important;
    box-shadow: 0 10px 22px rgba(15,23,42,.15) !important;
  }

  .pps-moon-field {
    display: grid !important;
    gap: 10px !important;
    font-size: 14px !important;
    font-weight: 900 !important;
    color: #0b0f19 !important;
    margin-top: 8px !important;
  }

  .pps-moon-field input[type='range'] {
    width: 100% !important;
    height: 32px !important;
    accent-color: #075fd6 !important;
  }

  .pps-moon-field textarea,
  .pps-moon-field select {
    width: 100% !important;
    border: 1px solid #d8e0ea !important;
    border-radius: 12px !important;
    background: #ffffff !important;
    box-sizing: border-box !important;
  }

  .pps-moon-layer-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr 1fr !important;
    gap: 10px !important;
    padding-top: 12px !important;
    border-top: 1px solid #e2e8f0 !important;
  }

  .pps-moon-layer-actions button,
  .pps-moon-layer-actions .pps-delete-layer {
    min-height: 56px !important;
    border: 0 !important;
    border-radius: 12px !important;
    background: #111827 !important;
    color: #ffffff !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: .02em !important;
    padding: 9px 8px !important;
    margin: 0 !important;
    cursor: pointer !important;
  }

  .pps-moon-layer-actions .pps-delete-layer {
    background: #ffffff !important;
    color: #ef233c !important;
    border: 1px solid #e2e8f0 !important;
  }

  .pps-moon-tool,
  .pps-moon-done {
    width: 68px !important;
    min-height: 78px !important;
    padding: 8px 5px !important;
    border-radius: 12px !important;
    background: #ffffff !important;
    color: #4b5563 !important;
    gap: 6px !important;
  }

  .pps-moon-tool span,
  .pps-moon-done span {
    width: 30px !important;
    height: 30px !important;
    font-size: 19px !important;
    color: inherit !important;
  }

  .pps-moon-tool em,
  .pps-moon-done em {
    font-size: 12px !important;
    line-height: 1.05 !important;
    max-width: 66px !important;
    color: inherit !important;
  }

  .pps-moon-tool.is-active {
    background: #eef5ff !important;
    color: #075fd6 !important;
    box-shadow: inset 0 0 0 2px #075fd6 !important;
  }

  .pps-moon-done {
    margin-top: auto !important;
    color: #087a2a !important;
  }

  .pps-moon-sticker-library {
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
  }

  .pps-moon-empty,
  .pps-moon-note {
    border-radius: 14px !important;
    background: #f8fafc !important;
    border-color: #e2e8f0 !important;
    color: #667085 !important;
  }

  .pps-moonpig-designer .pps-design-el.is-selected {
    outline: 2px dashed #075fd6 !important;
    outline-offset: 7px !important;
  }

  .pps-resize-handle {
    width: 34px !important;
    height: 34px !important;
    right: -28px !important;
    bottom: -28px !important;
    border: 3px solid #075fd6 !important;
    border-radius: 999px !important;
    background: #ffffff !important;
    color: #075fd6 !important;
    box-shadow: 0 4px 14px rgba(15,23,42,.2) !important;
    font-size: 15px !important;
    line-height: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .pps-layer-quick {
    width: 42px !important;
    height: 42px !important;
    border: 3px solid #075fd6 !important;
    background: #ffffff !important;
    color: #075fd6 !important;
    border-radius: 999px !important;
    box-shadow: 0 4px 14px rgba(15,23,42,.2) !important;
  }
}

@media (min-width: 768px) and (max-width: 1180px) {
  .pps-moon-workspace {
    width: calc(100vw - 32px) !important;
    grid-template-columns: 300px 84px minmax(430px, 1fr) !important;
    margin: 20px auto !important;
  }
  .pps-moon-stage-area { padding: 24px 22px !important; }
  .pps-moonpig-designer .pps-editor-canvas-shell { padding: 16px !important; }
}

/* v1.3.13 designer toolbar polish, undo/redo, photo cleanup and safer text editing */
.pps-moon-tool span,
.pps-history-btn span {
  background: linear-gradient(135deg,#fff7d6,#e8f3ff) !important;
  border: 1px solid rgba(15,23,42,.08) !important;
  box-shadow: inset 0 -2px 0 rgba(15,23,42,.06), 0 4px 10px rgba(15,23,42,.08) !important;
}
.pps-moon-tool[data-panel="pages"] span { background: linear-gradient(135deg,#dbeafe,#fef3c7) !important; }
.pps-moon-tool[data-panel="stickers"] span { background: linear-gradient(135deg,#fde68a,#fce7f3) !important; }
.pps-moon-tool[data-panel="text"] span { background: linear-gradient(135deg,#dcfce7,#dbeafe) !important; font-family: Georgia,serif !important; font-size: 16px !important; }
.pps-moon-tool[data-panel="photo"] span { background: linear-gradient(135deg,#e0e7ff,#fbcfe8) !important; }
.pps-moon-tool[data-panel="edit"] span { background: linear-gradient(135deg,#ede9fe,#cffafe) !important; }
.pps-moon-tool.is-active span {
  background: #ffffff !important;
  box-shadow: inset 0 0 0 2px currentColor, 0 5px 14px rgba(7,95,214,.14) !important;
}
.pps-moon-history-desktop {
  display: none;
}
.pps-history-btn {
  border: 0 !important;
  background: #ffffff !important;
  color: #334155 !important;
  border-radius: 12px !important;
  display: inline-flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
  font-weight: 900 !important;
  cursor: pointer !important;
}
.pps-history-btn span {
  width: 30px !important;
  height: 30px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 20px !important;
  line-height: 1 !important;
}
.pps-history-btn em {
  font-style: normal !important;
  font-size: 11px !important;
  line-height: 1 !important;
}
.pps-history-btn:disabled {
  opacity: .35 !important;
  cursor: default !important;
}
.pps-moon-page-title-row {
  display: block;
}
.pps-moon-page-title-row > .pps-history-btn {
  display: none !important;
}
.pps-selection-text {
  pointer-events: none !important;
}
.pps-selection-text .pps-layer-quick,
.pps-selection-text .pps-resize-handle {
  pointer-events: auto !important;
}
.pps-text-editor-field textarea.pps-control-text,
.pps-moon-field textarea.pps-control-text {
  color: #111827 !important;
  caret-color: #075fd6 !important;
  -webkit-user-select: text !important;
  user-select: text !important;
  touch-action: manipulation !important;
}
.pps-moon-layer-actions .pps-delete-layer,
.pps-delete-layer,
.pps-cover-delete-selected {
  background: #e11d48 !important;
  border-color: #e11d48 !important;
  color: #ffffff !important;
}
.pps-moon-layer-actions button,
.pps-moon-layer-actions .pps-delete-layer {
  min-height: 56px !important;
  height: 56px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

@media (min-width: 768px) {
  .pps-moon-history-desktop {
    display: grid !important;
    gap: 10px !important;
    width: 68px !important;
    margin-top: 4px !important;
  }
  .pps-moon-history-desktop .pps-history-btn {
    width: 68px !important;
    min-height: 68px !important;
    padding: 7px 5px !important;
    border: 1px solid #e2e8f0 !important;
  }
  .pps-moon-layer-actions .pps-delete-layer {
    background: #e11d48 !important;
    color: #ffffff !important;
    border: 0 !important;
  }
}

@media (max-width: 767px) {
  .pps-no-active-panel .pps-moon-drawer {
    display: none !important;
  }
  .pps-no-active-panel .pps-moon-stage-area {
    bottom: 0 !important;
  }
  .pps-moon-rail {
    justify-content: space-evenly !important;
    gap: 0 !important;
    overflow-x: hidden !important;
    padding-left: 6px !important;
    padding-right: 6px !important;
  }
  .pps-moon-tool {
    flex: 1 1 0 !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 74px !important;
  }
  .pps-moon-tool span {
    width: 30px !important;
    height: 30px !important;
    font-size: 18px !important;
  }
  .pps-moon-tool[data-panel="text"] span {
    font-size: 15px !important;
  }
  .pps-moon-tool em {
    font-size: 10.5px !important;
  }
  .pps-moon-page-title-row {
    display: grid !important;
    grid-template-columns: 44px minmax(0,1fr) 44px !important;
    align-items: center !important;
    gap: 8px !important;
    width: min(100%, 430px) !important;
    margin: 0 auto !important;
  }
  .pps-moon-page-title-row h1 {
    margin: 0 !important;
    text-align: center !important;
  }
  .pps-moon-page-title-row > .pps-history-btn {
    display: inline-flex !important;
    width: 44px !important;
    height: 38px !important;
    min-height: 38px !important;
    padding: 0 !important;
    border: 1px solid #d7dde6 !important;
    box-shadow: 0 3px 10px rgba(15,23,42,.09) !important;
  }
  .pps-moon-page-title-row > .pps-history-btn span {
    width: 28px !important;
    height: 28px !important;
    font-size: 20px !important;
    background: #ffffff !important;
    box-shadow: none !important;
    border: 0 !important;
  }
  .pps-moon-page-title-row > .pps-history-btn em {
    display: none !important;
  }
  .pps-moon-history-desktop {
    display: none !important;
  }
  .pps-moon-layer-actions {
    grid-template-columns: repeat(3, minmax(0,1fr)) !important;
    align-items: stretch !important;
  }
  .pps-moon-layer-actions button,
  .pps-moon-layer-actions .pps-delete-layer {
    min-height: 50px !important;
    height: 50px !important;
    padding: 10px 6px !important;
    border-radius: 14px !important;
    font-size: 12px !important;
  }
  .pps-moon-layer-actions .pps-delete-layer,
  .pps-delete-layer {
    background: #e11d48 !important;
    border-color: #e11d48 !important;
    color: #ffffff !important;
  }
}

/* v1.3.14 photo face party hat product line */
.pps-photo-hat-live{margin:0 0 22px;padding:18px;border:1px solid rgba(0,0,0,.08);border-radius:18px;background:#fff;box-shadow:0 10px 30px rgba(0,0,0,.06)}
.pps-photo-hat-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:14px}.pps-photo-hat-head strong{font-size:18px}.pps-photo-hat-head p{margin:4px 0 0;color:#666;font-size:14px;line-height:1.45}.pps-photo-hat-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:14px}.pps-photo-hat-card{min-height:260px;border-radius:16px;background:linear-gradient(180deg,#fafafa,#fff);border:1px solid rgba(0,0,0,.07);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.pps-photo-hat-card span{position:absolute;left:12px;bottom:10px;font-size:12px;font-weight:800;color:#555;background:rgba(255,255,255,.8);border-radius:999px;padding:5px 9px}.pps-hat-scene{position:relative;width:100%;height:360px}.pps-hat-shadow{position:absolute;left:22%;right:18%;bottom:25px;height:50px;background:rgba(0,0,0,.16);filter:blur(20px);border-radius:50%}.pps-hat-cone{position:absolute;left:27%;top:25px;width:46%;height:74%;clip-path:polygon(50% 0,100% 92%,48% 100%,0 92%);background:#f4f4f0;overflow:hidden;box-shadow:inset -20px -10px 30px rgba(0,0,0,.16)}.pps-hat-pattern,.pps-hat-flat-pattern{width:100%;height:100%;background-size:100px 100px;background-repeat:repeat;background-position:center;transform:rotate(-12deg) scale(1.35);opacity:.95}.pps-photo-hat-live.is-empty .pps-hat-pattern,.pps-photo-hat-live.is-empty .pps-hat-flat-pattern{background-image:linear-gradient(45deg,#eee 25%,transparent 25%,transparent 75%,#eee 75%),linear-gradient(45deg,#eee 25%,transparent 25%,transparent 75%,#eee 75%);background-size:32px 32px;background-position:0 0,16px 16px;transform:none}.pps-hat-rim{position:absolute;left:24%;right:22%;bottom:76px;height:54px;background:linear-gradient(180deg,#fff,#dcdcd7);border-radius:50%;box-shadow:0 2px 8px rgba(0,0,0,.18)}.pps-hat-string{position:absolute;bottom:18px;width:28%;height:90px;border-bottom:3px solid #253343}.pps-hat-string.left{left:10%;border-left:3px solid #253343;border-radius:0 0 0 70%}.pps-hat-string.right{right:10%;border-right:3px solid #253343;border-radius:0 0 70% 0}.pps-hat-flat{position:relative;width:82%;height:72%;clip-path:polygon(4.5% 9.5%,40.5% 11.2%,61% 18.5%,79.5% 16%,84.5% 27.5%,90.5% 32.5%,90% 53.2%,96.5% 61%,84% 78.5%,50.5% 90%,20% 77%,3% 59%,3.5% 32%);background:#f8f8f8;overflow:hidden;border-radius:8px;box-shadow:0 14px 28px rgba(0,0,0,.18)}.pps-hat-flat:after{content:'';position:absolute;inset:0;border:2px dashed rgba(0,0,0,.42);clip-path:polygon(4.5% 9.5%,40.5% 11.2%,61% 18.5%,79.5% 16%,84.5% 27.5%,90.5% 32.5%,90% 53.2%,96.5% 61%,84% 78.5%,50.5% 90%,20% 77%,3% 59%,3.5% 32%);pointer-events:none}.pps-photo-hat-mode .pps-generate-btn:before{content:'Create hat preview';font-size:0}.pps-photo-hat-mode .pps-generate-btn{font-size:0}.pps-photo-hat-mode .pps-generate-btn:after{content:'Create hat preview';font-size:16px}
@media(max-width:760px){.pps-photo-hat-grid{grid-template-columns:1fr}.pps-hat-scene{height:300px}.pps-photo-hat-card{min-height:230px}}

/* v1.3.15 reusable template product controls */
.pps-template-live .pps-template-scene{position:relative;width:100%;height:360px;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.pps-template-live .pps-template-base,.pps-template-live .pps-template-mask,.pps-template-live .pps-template-overlay{position:absolute;inset:0;background-repeat:no-repeat;background-position:center;background-size:contain;pointer-events:none;}
.pps-template-live .pps-template-mask{overflow:hidden;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain;}
.pps-template-live .pps-template-mask .pps-template-pattern{position:absolute;inset:-38%;width:auto!important;height:auto!important;background-repeat:repeat;opacity:.96;}
.pps-template-live .pps-template-overlay{z-index:4;}
.pps-template-live .pps-template-base{z-index:1;}
.pps-template-live .pps-template-mask{z-index:2;}
.pps-template-live .pps-template-scene.has-custom-template .pps-template-base,.pps-template-live .pps-template-scene.has-custom-template .pps-template-mask,.pps-template-live .pps-template-scene.has-custom-template .pps-template-overlay{display:block;}
.pps-template-live .pps-template-scene:not(.has-custom-template) .pps-template-base,.pps-template-live .pps-template-scene:not(.has-custom-template) .pps-template-mask,.pps-template-live .pps-template-scene:not(.has-custom-template) .pps-template-overlay{display:none;}
.pps-template-controls{display:grid;grid-template-columns:repeat(4,minmax(0,1fr)) auto;gap:10px;align-items:end;margin-top:14px;padding:12px;border-radius:16px;background:#f7f7f7;border:1px solid rgba(0,0,0,.06)}
.pps-template-controls label{display:grid;gap:5px;font-size:12px;font-weight:800;color:#444}.pps-template-controls input[type=range]{width:100%}.pps-template-reset{border:0;border-radius:999px;background:#111!important;color:#fff!important;padding:10px 14px;font-weight:900;cursor:pointer}.pps-template-product-mode .pps-generate-btn:after{content:'Create template preview';font-size:16px}.pps-template-product-mode .pps-generate-btn{font-size:0!important}.pps-template-live.is-empty .pps-template-mask .pps-template-pattern{background-image:linear-gradient(45deg,#eee 25%,transparent 25%,transparent 75%,#eee 75%),linear-gradient(45deg,#eee 25%,transparent 25%,transparent 75%,#eee 75%)!important;background-size:32px 32px!important;background-position:0 0,16px 16px!important;transform:none!important;}
@media(max-width:760px){.pps-template-controls{grid-template-columns:1fr 1fr}.pps-template-reset{grid-column:1/-1}.pps-template-live .pps-template-scene{height:300px}}

/* v1.3.16 template editor modal refinements */
.pps-template-action-row{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:14px;padding:14px;border-radius:16px;background:#f7f7f7;border:1px solid rgba(0,0,0,.06)}
.pps-template-upload-summary strong{font-size:14px;font-weight:900;color:#222}.pps-template-upload-summary p{margin:3px 0 0;color:#666;font-size:13px;line-height:1.35}.pps-template-open-editor{border:1px solid #1d5bd8!important;background:#fff!important;color:#1d5bd8!important;border-radius:12px!important;padding:13px 18px!important;font-weight:900!important;min-width:210px;box-shadow:0 4px 12px rgba(29,91,216,.08);cursor:pointer}.pps-template-open-editor:before{content:'✎';margin-right:8px}.pps-template-open-editor:hover{background:#f3f7ff!important}
body.pps-template-modal-open{overflow:hidden}.pps-template-editor-modal{position:fixed;inset:0;z-index:999999;display:none;align-items:center;justify-content:center;padding:28px}.pps-template-editor-modal.is-open{display:flex}.pps-template-modal-shade{position:absolute;inset:0;background:rgba(12,14,18,.68);backdrop-filter:blur(2px)}.pps-template-modal-card{position:relative;z-index:1;width:min(1040px,calc(100vw - 44px));max-height:calc(100vh - 44px);overflow:auto;background:#fff;border-radius:18px;box-shadow:0 28px 90px rgba(0,0,0,.35);padding:26px}.pps-template-modal-close{position:absolute;top:16px;right:18px;width:38px;height:38px;border:0!important;background:transparent!important;color:#111!important;font-size:34px;line-height:1;cursor:pointer}.pps-template-modal-head{padding-right:48px;margin-bottom:16px}.pps-template-modal-head strong{font-size:22px;font-weight:950;color:#171717}.pps-template-modal-head p{margin:4px 0 0;color:#555;font-size:14px;line-height:1.4}.pps-template-modal-body{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:22px;align-items:stretch}.pps-template-modal-stage{min-height:520px;border:1px solid rgba(0,0,0,.08);border-radius:16px;background:linear-gradient(135deg,#ead3ad,#f7eddc 44%,#d5b07a);overflow:hidden;display:flex;align-items:center;justify-content:center}.pps-template-modal-stage .pps-template-scene{position:relative;width:100%;height:100%;min-height:520px;overflow:hidden;display:flex;align-items:center;justify-content:center}.pps-template-modal-stage .pps-hat-flat{width:88%;height:72%;box-shadow:0 18px 36px rgba(0,0,0,.22)}.pps-template-modal-stage .pps-template-base,.pps-template-modal-stage .pps-template-mask,.pps-template-modal-stage .pps-template-overlay{position:absolute;inset:0;background-repeat:no-repeat;background-position:center;background-size:contain;pointer-events:none}.pps-template-modal-stage .pps-template-mask{overflow:hidden;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain}.pps-template-modal-stage .pps-template-mask .pps-template-pattern{position:absolute;inset:-42%;background-repeat:repeat;opacity:.96}.pps-template-modal-stage .pps-template-overlay{z-index:4}.pps-template-modal-stage .pps-template-base{z-index:1}.pps-template-modal-stage .pps-template-mask{z-index:2}.pps-template-modal-stage .pps-template-scene.has-custom-template .pps-template-base,.pps-template-modal-stage .pps-template-scene.has-custom-template .pps-template-mask,.pps-template-modal-stage .pps-template-scene.has-custom-template .pps-template-overlay{display:block}.pps-template-modal-stage .pps-template-scene:not(.has-custom-template) .pps-template-base,.pps-template-modal-stage .pps-template-scene:not(.has-custom-template) .pps-template-mask,.pps-template-modal-stage .pps-template-scene:not(.has-custom-template) .pps-template-overlay{display:none}.pps-template-modal-controls{border:1px solid rgba(0,0,0,.08);border-radius:16px;background:#fafafa;padding:14px;display:flex;flex-direction:column;gap:14px}.pps-template-quick-controls{display:grid;grid-template-columns:repeat(5,1fr);border:1px solid rgba(0,0,0,.08);border-radius:14px;overflow:hidden;background:#fff}.pps-template-quick-controls button{border:0!important;border-right:1px solid rgba(0,0,0,.08)!important;background:#fff!important;color:#222!important;padding:12px 6px!important;font-size:24px!important;font-weight:900!important;cursor:pointer}.pps-template-quick-controls button:last-child{border-right:0!important}.pps-template-quick-controls span{display:block;margin-top:2px;font-size:10px;font-weight:800;color:#555;line-height:1.1}.pps-template-modal-controls label{display:grid;grid-template-columns:72px 1fr 58px;gap:10px;align-items:center;font-size:14px;font-weight:900;color:#242424}.pps-template-modal-controls label input[type=range]{width:100%;accent-color:#1769e8}.pps-template-modal-controls label em{font-style:normal;text-align:center;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:8px;padding:7px 5px;font-size:13px;color:#333}.pps-template-nudge{display:grid;grid-template-columns:72px 72px 72px;grid-template-rows:52px 52px 52px;gap:8px;justify-content:center;align-items:center;margin:2px auto}.pps-template-nudge button{width:72px;height:52px;border:1px solid rgba(0,0,0,.1)!important;background:#fff!important;color:#111!important;border-radius:12px!important;font-size:28px!important;font-weight:900!important;cursor:pointer}.pps-template-nudge button[data-template-action="up"]{grid-column:2;grid-row:1}.pps-template-nudge button[data-template-action="left"]{grid-column:1;grid-row:2}.pps-template-nudge button[data-template-action="right"]{grid-column:3;grid-row:2}.pps-template-nudge button[data-template-action="down"]{grid-column:2;grid-row:3}.pps-template-modal-footer{margin-top:auto;display:grid;grid-template-columns:1fr 1.4fr;gap:12px}.pps-template-modal-cancel,.pps-template-modal-save{border-radius:12px!important;padding:14px 16px!important;font-weight:950!important;cursor:pointer}.pps-template-modal-cancel{background:#fff!important;color:#222!important;border:1px solid rgba(0,0,0,.12)!important}.pps-template-modal-save{background:#1157d8!important;color:#fff!important;border:1px solid #1157d8!important}
@media(max-width:900px){.pps-template-modal-card{padding:18px;width:min(720px,calc(100vw - 24px));max-height:calc(100vh - 24px)}.pps-template-modal-body{grid-template-columns:1fr}.pps-template-modal-stage,.pps-template-modal-stage .pps-template-scene{min-height:430px}.pps-template-modal-controls{gap:12px}.pps-template-quick-controls{grid-template-columns:repeat(5,1fr)}}
@media(max-width:620px){.pps-template-editor-modal{padding:8px;align-items:center}.pps-template-modal-card{width:calc(100vw - 16px);max-height:calc(100vh - 16px);border-radius:14px;padding:14px}.pps-template-modal-stage,.pps-template-modal-stage .pps-template-scene{min-height:320px}.pps-template-modal-controls label{grid-template-columns:62px 1fr 50px;font-size:12px}.pps-template-quick-controls button{font-size:20px!important;padding:10px 4px!important}.pps-template-quick-controls span{font-size:9px}.pps-template-action-row{display:grid;grid-template-columns:1fr}.pps-template-open-editor{width:100%;min-width:0}.pps-template-nudge{grid-template-columns:62px 62px 62px;grid-template-rows:48px 48px 48px}.pps-template-nudge button{width:62px;height:48px}}


/* v1.3.17: cleaner photo-template editor flow */
.pps-template-live[hidden]{display:none!important;}
.pps-template-open-editor{white-space:nowrap;min-width:170px!important;font-size:15px!important;letter-spacing:.01em;}
.pps-template-open-editor:before{content:'✎';margin-right:8px;}
.pps-template-editor-help{border:1px solid rgba(29,91,216,.12);background:#f4f8ff;border-radius:14px;padding:14px;}
.pps-template-editor-help strong{display:block;font-size:15px;font-weight:950;color:#14233d;margin-bottom:4px;}
.pps-template-editor-help p{margin:0;color:#4b5d78;font-size:13px;line-height:1.45;}
.pps-template-modal-body{grid-template-columns:minmax(0,1fr) 330px!important;}
.pps-template-modal-stage .pps-template-scene{cursor:default;}
.pps-template-pattern{position:relative;overflow:hidden;}
.pps-template-tile{position:absolute;display:block;background-position:center;background-size:cover;background-repeat:no-repeat;border-radius:14%;transform-origin:center center;will-change:transform;}
.pps-hat-pattern.pps-template-pattern,.pps-hat-flat-pattern.pps-template-pattern{background-image:none!important;background-repeat:initial!important;background-size:auto!important;background-position:initial!important;transform:none!important;position:relative;overflow:visible;opacity:.96;}
.pps-template-live.is-empty .pps-hat-pattern,.pps-template-live.is-empty .pps-hat-flat-pattern{background-image:none!important;}
.pps-template-modal-stage .pps-template-pattern{position:absolute;inset:-42%;width:auto!important;height:auto!important;background-image:none!important;transform:none!important;}
.pps-template-live .pps-template-mask .pps-template-pattern{position:absolute;inset:-38%;background-image:none!important;transform:none!important;}
.pps-template-transform-box{position:absolute;left:50%;top:50%;z-index:12;border:3px solid #09b8c8;border-radius:6px;box-sizing:border-box;cursor:move;touch-action:none;box-shadow:0 0 0 9999px rgba(0,0,0,0);}
.pps-template-transform-box:before{content:'';position:absolute;inset:-2px;border:1px solid rgba(255,255,255,.85);border-radius:7px;pointer-events:none;}
.pps-template-resize-handle{position:absolute;width:22px;height:22px;border-radius:999px;background:#fff;border:2px solid #d7d7d7;box-shadow:0 2px 8px rgba(0,0,0,.18);touch-action:none;}
.pps-template-handle-nw{left:-12px;top:-12px;cursor:nwse-resize;}
.pps-template-handle-ne{right:-12px;top:-12px;cursor:nesw-resize;}
.pps-template-handle-sw{left:-12px;bottom:-12px;cursor:nesw-resize;}
.pps-template-handle-se{right:-12px;bottom:-12px;cursor:nwse-resize;}
.pps-template-rotate-handle{position:absolute;left:50%;top:-48px;transform:translateX(-50%);width:34px;height:34px;border-radius:999px;background:#fff;color:#111;border:2px solid #e8e8e8;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:950;box-shadow:0 2px 10px rgba(0,0,0,.2);cursor:grab;touch-action:none;}
.pps-template-rotate-handle:after{content:'';position:absolute;left:50%;top:100%;width:2px;height:16px;background:#09b8c8;transform:translateX(-50%);}
.pps-template-modal-controls label,.pps-template-scale,.pps-template-rotation,.pps-template-offset-x,.pps-template-offset-y,.pps-template-scale-val,.pps-template-rotation-val,.pps-template-offset-x-val,.pps-template-offset-y-val{display:none!important;}
.pps-template-quick-controls{grid-template-columns:repeat(5,1fr)!important;}
.pps-template-nudge{margin-top:8px!important;}
@media(max-width:900px){.pps-template-modal-body{grid-template-columns:1fr!important}.pps-template-modal-controls{order:2}.pps-template-modal-stage{order:1}.pps-template-transform-box{border-width:2px}.pps-template-resize-handle{width:20px;height:20px}}
@media(max-width:620px){.pps-template-open-editor{font-size:14px!important;padding:12px 14px!important}.pps-template-modal-card{max-height:calc(100vh - 14px)!important}.pps-template-modal-stage,.pps-template-modal-stage .pps-template-scene{min-height:360px!important}.pps-template-modal-body{gap:12px!important}.pps-template-editor-help{display:none}.pps-template-quick-controls button{font-size:18px!important}.pps-template-quick-controls span{font-size:8px!important}.pps-template-transform-box{border-width:2px}.pps-template-resize-handle{width:18px;height:18px}.pps-template-rotate-handle{top:-42px;width:30px;height:30px;font-size:18px}}

/* v1.3.18 - cleaner centred placement editor controls */
.pps-template-modal-card{
  width:min(980px,calc(100vw - 44px))!important;
  padding:24px!important;
  overflow:auto!important;
}
.pps-template-modal-head{margin-bottom:14px!important;}
.pps-template-modal-body-simple,
.pps-template-modal-body{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:14px!important;
}
.pps-template-modal-stage{
  min-height:560px!important;
  background:#fff!important;
  border:0!important;
  border-radius:10px!important;
  overflow:hidden!important;
}
.pps-template-modal-stage .pps-template-scene{
  min-height:560px!important;
  background:#fff!important;
}
.pps-template-modal-stage .pps-hat-flat{
  width:90%!important;
  height:78%!important;
  box-shadow:none!important;
}
.pps-template-modal-controls-simple,
.pps-template-modal-controls{
  border:0!important;
  background:transparent!important;
  border-radius:0!important;
  padding:0!important;
  display:grid!important;
  grid-template-columns:1fr auto!important;
  gap:16px!important;
  align-items:center!important;
}
.pps-template-editor-help,.pps-template-nudge{
  display:none!important;
}
.pps-template-icon-controls,
.pps-template-quick-controls{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:10px!important;
  align-items:center!important;
  justify-content:center!important;
  border:0!important;
  background:transparent!important;
  overflow:visible!important;
}
.pps-template-icon-controls button,
.pps-template-quick-controls button{
  width:48px!important;
  height:48px!important;
  min-width:48px!important;
  border-radius:999px!important;
  border:0!important;
  background:#3f3f3f!important;
  color:#fff!important;
  box-shadow:0 3px 8px rgba(0,0,0,.18)!important;
  font-size:24px!important;
  line-height:1!important;
  padding:0!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
.pps-template-icon-controls button:hover,
.pps-template-quick-controls button:hover{
  background:#222!important;
  transform:translateY(-1px);
}
.pps-template-icon-controls button span,
.pps-template-quick-controls button span{
  position:absolute!important;
  width:1px!important;
  height:1px!important;
  overflow:hidden!important;
  clip:rect(0,0,0,0)!important;
  white-space:nowrap!important;
}
.pps-template-modal-footer{
  margin:0!important;
  display:flex!important;
  justify-content:flex-end!important;
  gap:10px!important;
  min-width:230px!important;
}
.pps-template-modal-cancel,.pps-template-modal-save{
  min-width:105px!important;
  height:52px!important;
  border-radius:8px!important;
  padding:12px 18px!important;
  font-size:15px!important;
  letter-spacing:0!important;
}
.pps-template-transform-box{
  will-change:transform,width,height!important;
  touch-action:none!important;
}
.pps-template-tile{
  will-change:transform!important;
  transform-origin:center center!important;
  backface-visibility:hidden!important;
}
@media(max-width:900px){
  .pps-template-modal-card{width:calc(100vw - 24px)!important;max-height:calc(100vh - 24px)!important;padding:16px!important;}
  .pps-template-modal-stage,.pps-template-modal-stage .pps-template-scene{min-height:460px!important;}
  .pps-template-modal-controls{grid-template-columns:1fr!important;}
  .pps-template-modal-footer{justify-content:center!important;min-width:0!important;}
}
@media(max-width:620px){
  .pps-template-modal-card{width:calc(100vw - 12px)!important;max-height:calc(100vh - 12px)!important;padding:12px!important;}
  .pps-template-modal-head strong{font-size:19px!important;}
  .pps-template-modal-head p{font-size:13px!important;}
  .pps-template-modal-stage,.pps-template-modal-stage .pps-template-scene{min-height:360px!important;}
  .pps-template-icon-controls button,.pps-template-quick-controls button{width:42px!important;height:42px!important;min-width:42px!important;font-size:20px!important;}
  .pps-template-modal-footer{display:grid!important;grid-template-columns:1fr 1fr!important;width:100%!important;}
  .pps-template-modal-cancel,.pps-template-modal-save{width:100%!important;min-width:0!important;}
}


/* v1.3.29 targeted fixes */
.pps-template-product-mode .pps-generate-btn{display:none!important;}
.pps-template-pattern{will-change:transform!important;transform-origin:center center!important;backface-visibility:hidden!important;}
.pps-template-tile{will-change:transform!important;backface-visibility:hidden!important;contain:layout paint style!important;}
.pps-template-modal-cancel,.pps-template-modal-save{display:inline-flex!important;align-items:center!important;justify-content:center!important;text-align:center!important;line-height:1!important;}
.pps-template-open-editor{display:flex!important;align-items:center!important;justify-content:center!important;text-align:center!important;white-space:normal!important;}


/* v1.3.30 centre-out visible pattern fix */
.pps-template-modal-stage .pps-template-pattern,
.pps-template-live .pps-template-pattern{
  z-index:3!important;
}
.pps-template-transform-box{
  z-index:20!important;
}
.pps-template-overlay{
  z-index:6!important;
}


/* v1.3.32 canvas popup editor: fast editor surface only inside modal */
.pps-template-scene-editor .pps-template-editor-canvas{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  z-index:8!important;
  display:block!important;
  pointer-events:none!important;
}
.pps-template-scene-editor > :not(.pps-template-editor-canvas):not(.pps-template-transform-box){
  display:none!important;
}
.pps-template-scene-editor .pps-template-transform-box{
  z-index:24!important;
}


/* v1.3.34 mobile toolbar fix: keep preview visible and put toolbar below it */
.pps-template-editor-modal{
  overscroll-behavior:contain!important;
}
.pps-template-modal-stage,
.pps-template-modal-stage .pps-template-scene,
.pps-template-scene-editor .pps-template-editor-canvas,
.pps-template-transform-box{
  touch-action:none!important;
}
.pps-template-scene-editor .pps-template-editor-canvas{
  image-rendering:auto;
}

@media(max-width:760px){
  body.pps-template-modal-open{
    overflow:hidden!important;
  }

  .pps-template-editor-modal{
    padding:8px!important;
    align-items:center!important;
    justify-content:center!important;
  }

  .pps-template-modal-card{
    width:calc(100vw - 16px)!important;
    max-height:calc(100dvh - 18px)!important;
    padding:12px!important;
    border-radius:16px!important;
    overflow:hidden!important;
    display:flex!important;
    flex-direction:column!important;
    box-sizing:border-box!important;
  }

  .pps-template-modal-close{
    top:8px!important;
    right:9px!important;
    width:34px!important;
    height:34px!important;
    font-size:30px!important;
    z-index:50!important;
  }

  .pps-template-modal-head{
    flex:0 0 auto!important;
    margin:0 38px 8px 0!important;
    padding:0!important;
  }

  .pps-template-modal-head strong{
    font-size:18px!important;
    line-height:1.15!important;
  }

  .pps-template-modal-head p{
    font-size:12px!important;
    line-height:1.25!important;
    margin:5px 0 0!important;
  }

  .pps-template-modal-body,
  .pps-template-modal-body-simple{
    flex:1 1 auto!important;
    min-height:0!important;
    display:flex!important;
    flex-direction:column!important;
    gap:10px!important;
    grid-template-columns:none!important;
    overflow:hidden!important;
  }

  /* Force the preview to stay above the controls instead of collapsing/disappearing. */
  .pps-template-modal-stage{
    order:1!important;
    flex:0 0 auto!important;
    height:clamp(300px, 47dvh, 430px)!important;
    min-height:300px!important;
    max-height:430px!important;
    width:100%!important;
    margin:0!important;
    border-radius:12px!important;
    background:#f7f7f7!important;
    overflow:hidden!important;
  }

  .pps-template-modal-stage .pps-template-scene{
    height:100%!important;
    min-height:0!important;
    width:100%!important;
  }

  .pps-template-modal-controls,
  .pps-template-modal-controls-simple{
    order:2!important;
    flex:0 0 auto!important;
    width:100%!important;
    display:flex!important;
    flex-direction:column!important;
    gap:10px!important;
    padding:0!important;
    margin:0!important;
    border:0!important;
    background:transparent!important;
    overflow:visible!important;
  }

  /* One compact toolbar row, closer to the Printed Little Things style. */
  .pps-template-icon-controls,
  .pps-template-quick-controls{
    display:grid!important;
    grid-template-columns:repeat(9, minmax(0, 1fr))!important;
    gap:5px!important;
    width:100%!important;
    align-items:center!important;
    justify-items:center!important;
    border:0!important;
    background:transparent!important;
    overflow:visible!important;
  }

  .pps-template-icon-controls button,
  .pps-template-quick-controls button{
    width:36px!important;
    height:36px!important;
    min-width:36px!important;
    border-radius:999px!important;
    border:0!important;
    background:#3f3f3f!important;
    color:#fff!important;
    box-shadow:0 2px 7px rgba(0,0,0,.20)!important;
    font-size:17px!important;
    line-height:1!important;
    padding:0!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
  }

  .pps-template-icon-controls button span,
  .pps-template-quick-controls button span{
    position:absolute!important;
    width:1px!important;
    height:1px!important;
    overflow:hidden!important;
    clip:rect(0,0,0,0)!important;
    white-space:nowrap!important;
  }

  .pps-template-modal-footer{
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
    gap:8px!important;
    width:100%!important;
    min-width:0!important;
    margin:0!important;
  }

  .pps-template-modal-cancel,
  .pps-template-modal-save{
    width:100%!important;
    height:46px!important;
    min-height:46px!important;
    min-width:0!important;
    padding:0 12px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    text-align:center!important;
    font-size:14px!important;
    line-height:1!important;
    border-radius:8px!important;
  }

  .pps-template-transform-box{
    border-width:2px!important;
  }

  .pps-template-resize-handle{
    width:20px!important;
    height:20px!important;
  }

  .pps-template-rotate-handle{
    top:-42px!important;
    width:32px!important;
    height:32px!important;
    font-size:19px!important;
  }
}

@media(max-width:390px){
  .pps-template-modal-stage{
    height:clamp(270px, 43dvh, 390px)!important;
    min-height:270px!important;
  }
  .pps-template-icon-controls,
  .pps-template-quick-controls{
    gap:4px!important;
  }
  .pps-template-icon-controls button,
  .pps-template-quick-controls button{
    width:33px!important;
    height:33px!important;
    min-width:33px!important;
    font-size:15px!important;
  }
}

.pps-template-anchor-tile{will-change:transform;}


/* v1.3.55 template generated output panel */
.pps-template-generated-output{margin:0 0 14px;padding:14px;border:1px solid rgba(0,0,0,.09);border-radius:16px;background:#fff;box-shadow:0 8px 22px rgba(0,0,0,.06);display:grid;gap:10px;}
.pps-template-generated-output strong{font-size:16px;line-height:1.2;}
.pps-template-generated-output p{margin:0;color:#666;font-size:14px;}
.pps-template-generated-output img{width:100%;max-height:520px;object-fit:contain;border-radius:12px;background:#f7f6f3;display:block;}
.pps-template-live.is-generating-template-preview .pps-template-generated-output{background:linear-gradient(90deg,#fff,#f6f2ee,#fff);background-size:200% 100%;animation:ppsTemplateBusy 1.2s linear infinite;}
@keyframes ppsTemplateBusy{0%{background-position:0 0}100%{background-position:200% 0}}
@media(max-width:767px){
  .pps-template-generated-output{margin-top:10px;padding:10px;border-radius:14px;}
  .pps-template-generated-output img{max-height:360px;}
  .pps-photo-hat-grid.pps-template-grid{grid-template-columns:1fr!important;}
}


/* v1.3.57 custom template cover-mask mode */
.pps-template-scene.uses-cover-mask-template .pps-template-mask{
  -webkit-mask-image:none!important;
  mask-image:none!important;
}
.pps-template-scene.uses-cover-mask-template .pps-template-overlay{
  z-index:9!important;
}
.pps-template-scene.uses-cover-mask-template .pps-template-mask .pps-template-pattern{
  opacity:1!important;
}

.pps-template-export-scene{overflow:hidden;background:#fff;}

/* v1.4.12 exact save snapshot: export uses open editor canvas before modal close. */

/* v1.4.13 state replay highres: uploads full internal editor canvas, not CSS-downscaled screenshot. */

/* v1.4.14 transform replay no screenshot: frontend logs x/y/scale/rotation only. */

/* v1.4.16-state-replay-mask-subject-fix: Python state replay uses contained mask and trimmed subject. */

/* v1.4.17-preserve-open-editor-state: preserve open editor geometry captured on Save. */

/* v1.4.18-save-visible-tile-list: Save exact visible tile list for Python high-res replay. */

/* v1.4.19-use-actual-flat-template-source: Python uses actual flat template asset as source canvas. */

/* v1.4.20-preserve-head-aspect-ratio: preserve uploaded head/cutout aspect ratio when drawing tiles. */

/* v1.4.21-use-source-canvas-aspect: Python replay uses full source/cutout canvas aspect, not alpha-trimmed bounds. */

/* v1.4.22: trim transparent subject padding so uploaded heads match placeholder sizing. */

/* v1.4.23-bigger-default-head-scale: default placement scale 260%, max placement scale 520%. */

/* v1.4.24-builder-select-all-transform: builder can select all heads and transform selected group. */

/* v1.4.26-layer-buttons-after-duplicate-fix: fixed builder layer up/down after duplicate/multi-select. */


/* v1.4.31: keep template cover visible in the editor while the canvas redraws. */
.pps-template-scene-editor > :not(.pps-template-editor-canvas):not(.pps-template-transform-box){
  display:block!important;
}
.pps-template-scene-editor .pps-template-editor-canvas{
  background:transparent!important;
}
.pps-template-scene-editor.uses-cover-mask-template .pps-template-overlay,
.pps-template-scene-editor.uses-cover-mask-template .pps-template-mask{
  z-index:9!important;
}

/* v1.4.64 cleaner cropper + async template photo flow */
.pps-template-product-mode .pps-crop-controls{display:none!important;}
.pps-crop-stage.pps-crop-has-head-mask::after{content:'';position:absolute;left:50%;top:50%;width:42%;height:52%;transform:translate(-50%,-50%);border:3px dashed rgba(0,0,0,.35);border-radius:48% 48% 44% 44%;pointer-events:none;box-shadow:0 0 0 9999px rgba(255,255,255,.08);}
.pps-crop-transform-box{position:absolute;left:50%;top:50%;width:200px;height:200px;border:2px solid rgba(17,17,17,.85);box-shadow:0 0 0 1px rgba(255,255,255,.9);transform-origin:center center;cursor:move;z-index:5;touch-action:none;box-sizing:border-box;}
.pps-crop-transform-box [data-crop-handle="scale"]{position:absolute;right:-10px;bottom:-10px;width:22px;height:22px;border-radius:50%;background:#111;border:2px solid #fff;cursor:nwse-resize;}
.pps-crop-transform-box [data-crop-handle="rotate"]{position:absolute;right:-13px;top:-34px;width:26px;height:26px;border-radius:50%;background:#111;color:#fff;border:2px solid #fff;display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1;cursor:grab;}
.pps-template-modal-controls-simple .pps-template-quick-controls{display:none!important;}
.pps-template-modal-body-simple{grid-template-columns:1fr!important;}
.pps-template-modal-controls-simple{padding-top:0!important;}
.pps-template-image-tile{overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.16);}

/* v1.4.65 multi-upload polish + per-image AI builder controls */
.pps-template-upload-thumbs{display:flex;flex-wrap:wrap;gap:10px;margin:10px 0 0;}
.pps-template-upload-thumb{width:76px;border:1px solid rgba(0,0,0,.10);border-radius:12px;background:#fff;padding:6px;box-shadow:0 3px 10px rgba(0,0,0,.06);display:grid;gap:5px;text-align:center;}
.pps-template-upload-thumb img{width:64px;height:64px;object-fit:cover;border-radius:9px;background:#f3f3f3;display:block;}
.pps-template-upload-thumb span{font-size:11px;font-weight:800;color:#333;line-height:1.1;}
.pps-crop-stage img{z-index:2;}
.pps-crop-transform-box{z-index:8!important;background:rgba(255,255,255,.04);}
.pps-crop-stage.pps-crop-has-head-mask::after{z-index:7;}
.pps-tlb-link-panel{display:grid;gap:8px;padding:10px;border:1px solid #dcdcde;border-radius:8px;background:#fff;}
.pps-tlb-link-panel label{display:grid;gap:4px;font-weight:700;}
.pps-tlb-link-panel select,.pps-tlb-link-panel textarea{width:100%;}
.pps-tlb-ai-toggle{display:flex!important;grid-template-columns:none!important;flex-direction:row!important;align-items:center;gap:8px;}
.pps-tlb-ai-badge{position:absolute;right:-8px;top:-8px;background:#111;color:#fff;border-radius:999px;padding:3px 6px;font-size:10px;line-height:1;font-weight:900;box-shadow:0 1px 4px rgba(0,0,0,.25);}
.pps-crop-transform-box{display:none;}
.pps-template-product-mode .pps-crop-transform-box{display:block;}


/* v1.4.66 upload/crop/persistent-preview polish */
.pps-global-toast{z-index:1000001!important;}
.pps-template-product-mode .pps-photo-hat-head{display:none!important;}
.pps-template-open-editor{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  width:auto!important;
  min-width:0!important;
  max-width:none!important;
  white-space:nowrap!important;
  text-transform:none!important;
  letter-spacing:0!important;
  line-height:1.1!important;
  padding:12px 16px!important;
  border-radius:999px!important;
}
.pps-template-open-editor:before{margin-right:0!important;}
.pps-template-action-row{align-items:center!important;}
.pps-template-product-mode .pps-crop-stage{overflow:hidden!important;}
.pps-template-product-mode .pps-crop-transform-box{
  position:absolute!important;
  left:50%!important;
  top:50%!important;
  z-index:20!important;
  pointer-events:auto!important;
  background:rgba(255,255,255,.03)!important;
}
.pps-template-product-mode .pps-crop-transform-box [data-crop-handle="scale"]{
  width:28px!important;
  height:28px!important;
  right:-14px!important;
  bottom:-14px!important;
}
.pps-template-product-mode .pps-crop-transform-box [data-crop-handle="rotate"]{
  width:34px!important;
  height:34px!important;
  right:-17px!important;
  top:-46px!important;
  font-size:20px!important;
}
.pps-template-product-mode .pps-crop-stage.pps-crop-has-head-mask::after{z-index:12!important;}
.pps-template-product-mode .pps-crop-stage img{z-index:2!important;}
.pps-template-upload-thumbs:not([hidden]){display:flex!important;}
@media(max-width:620px){
  .pps-template-action-row{display:grid!important;grid-template-columns:1fr!important;}
  .pps-template-open-editor{width:100%!important;}
}


/* v1.4.67 template upload UI cleanup + persistent toast support */
.pps-template-product-mode .pps-template-live:empty,
.pps-template-product-mode .pps-template-live:not(.is-generating-template-preview):not(.has-template-output){
  display:none!important;
}
.pps-template-product-mode .pps-template-live .pps-photo-hat-grid,
.pps-template-product-mode .pps-template-live .pps-template-action-row{
  display:none!important;
}
.pps-template-product-mode .pps-template-live{
  margin:0 0 16px!important;
  padding:0!important;
  border:0!important;
  box-shadow:none!important;
  background:transparent!important;
}
.pps-template-product-mode .pps-change-photo-btn{
  text-transform:uppercase;
  letter-spacing:.04em;
}

/* v1.4.68: force global generating preview toast above site navigation/page transitions */
.pps-global-toast{z-index:2147483000!important;}

/* v1.4.71: isolated hat/template preview toast, separate from sticker/global toasts. */

/* v1.4.78 final preview handoff */
.pps-template-editor-modal.is-open{display:flex!important;visibility:visible!important;opacity:1!important;}
.pps-template-editor-modal.is-open .pps-template-modal-card{display:block!important;visibility:visible!important;opacity:1!important;}


/* v1.4.90: one customer-facing result only. The final mockup replaces the
   first gallery image; the old duplicate result card is never displayed. */
.pps-template-product-mode .pps-template-generated-output{display:none!important;}
.pps-template-product-mode .pps-template-live.has-template-output{display:none!important;}
.pps-generated-product-mockup{display:block;width:100%;height:100%;object-fit:contain;}
