.photo-gallery { padding: 1rem 1.25rem; }
.logo-widget { padding: 0; }
.logo-widget .gallery-grid { grid-template-columns: minmax(220px, 280px); gap: 0; margin: .25rem 0; }
.logo-widget .slot-preview { aspect-ratio: 4/3; background: #fafbfc; }
.logo-widget .slot-preview img { object-fit: contain; padding: .35rem; }
.logo-widget .gallery-slot[data-slot="logo"] { border-color: var(--c-border); box-shadow: none; }
.logo-widget .gallery-slot .slot-badge { display: none; }
.gallery-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: .85rem; margin-top: .5rem;
}
.gallery-slot {
  position: relative; background: var(--c-surface);
  border: 1px solid var(--c-border); border-radius: 8px;
  padding: .55rem; display: flex; flex-direction: column; gap: .4rem;
  transition: border-color .12s, transform .12s;
}
.gallery-slot[data-slot="1"] { border-color: var(--c-accent); box-shadow: 0 0 0 2px rgba(30,64,175,.12); }
.gallery-slot.drag-over { border-color: var(--c-accent); background: #f1f5ff; }
.gallery-slot.dragging { opacity: .4; }
.slot-badge {
  position: absolute; top: -8px; left: -8px; z-index: 2;
  background: var(--c-accent); color: white; font-size: .7rem;
  padding: .15rem .5rem; border-radius: 10px; font-weight: 600;
}
.gallery-slot:not([data-slot="1"]) .slot-badge { background: #64748b; }
.slot-preview {
  aspect-ratio: 4/3; background: #f1f5f9; border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; cursor: pointer;
}
.slot-preview img { width: 100%; height: 100%; object-fit: cover; }
.slot-empty { font-size: 2rem; color: #94a3b8; }
.slot-upload-btn {
  border: 0; background: var(--c-accent); color: white;
  padding: .35rem .6rem; border-radius: 5px; font-size: .8rem;
  cursor: pointer; font-family: inherit;
}
.slot-upload-btn:hover { background: var(--c-accent-hover); }
.slot-upload-btn:disabled { opacity: .5; cursor: progress; }
.slot-remove-btn {
  position: absolute; top: .35rem; right: .35rem; z-index: 2;
  border: 0; background: rgba(15,23,42,.55); color: white;
  width: 22px; height: 22px; border-radius: 50%; cursor: pointer;
  line-height: 1; font-size: 1rem; padding: 0;
}
.slot-remove-btn:hover { background: var(--c-error); }
.slot-caption {
  padding: .3rem .5rem; border: 1px solid var(--c-border);
  border-radius: 4px; font-size: .8rem; width: 100%;
}
.gallery-slot.is-removed { opacity: .4; }
.gallery-slot.is-removed .slot-preview img { filter: grayscale(1); }

/* ── Cropper modal ────────────────────────────────────────────────── */
.cropper-overlay[hidden] { display: none; }
.cropper-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(15,23,42,.78);
  display: flex; align-items: center; justify-content: center; padding: 1rem;
}
.cropper-panel {
  background: white; border-radius: 10px; padding: 1.25rem;
  max-width: min(96vw, 960px); width: 100%;
  display: flex; flex-direction: column; gap: .75rem;
}
.cropper-panel h3 { margin: 0; }
.cropper-panel .meta { margin: 0; font-size: .85rem; }
.cropper-frame {
  position: relative; max-height: 70vh; background: #0f172a;
  border-radius: 6px; overflow: hidden; align-self: center;
  user-select: none; touch-action: none;
}
.cropper-img { display: block; max-width: 100%; max-height: 70vh; pointer-events: none; }
.cropper-mask { position: absolute; inset: 0; pointer-events: none; }
.cropper-box {
  position: absolute; left: 15%; top: 15%; width: 70%; height: 70%;
  border: 2px solid white; box-shadow: 0 0 0 9999px rgba(15,23,42,.55);
  cursor: move; pointer-events: auto; box-sizing: border-box;
}
.handle {
  position: absolute; width: 14px; height: 14px; background: white;
  border: 1px solid #1e40af; border-radius: 2px;
}
.handle.nw { top: -7px; left: -7px; cursor: nwse-resize; }
.handle.ne { top: -7px; right: -7px; cursor: nesw-resize; }
.handle.sw { bottom: -7px; left: -7px; cursor: nesw-resize; }
.handle.se { bottom: -7px; right: -7px; cursor: nwse-resize; }
.cropper-actions { display: flex; gap: .5rem; justify-content: flex-end; flex-wrap: wrap; }
.cropper-status { padding: .5rem .75rem; border-radius: 4px; background: var(--c-error-bg); color: var(--c-error); font-size: .85rem; }
.cropper-status.ok { background: var(--c-ok-bg); color: #166534; }

/* Live crop metadata + DPI/resolution controls. */
.cropper-info {
  display: flex; flex-direction: column; gap: .35rem;
  padding: .65rem .8rem; border: 1px solid var(--c-border);
  border-radius: 6px; background: #f8fafc; font-size: .85rem;
}
.cropper-info-row { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.cropper-info-label { color: var(--c-muted); min-width: 4rem; font-weight: 500; }
.cropper-info-value { font-variant-numeric: tabular-nums; font-weight: 600; color: var(--c-fg); }
.cropper-info-sep { color: var(--c-muted); opacity: .5; }
.cropper-dpi-input { width: 80px; padding: .25rem .4rem; border: 1px solid var(--c-border); border-radius: 4px; font-size: .85rem; }
.cropper-scale-slider { flex: 1; min-width: 180px; max-width: 320px; accent-color: var(--c-accent); }
.cropper-scale-value { min-width: 3rem; text-align: right; }
