/* Canvas Print Designer — Editor Styles (Glassmorphism, #8074f9 palette) */
:root {
  --cpd-primary:      #8074f9;
  --cpd-primary-dark: #6558e8;
  --cpd-primary-light:#a599fb;
  --cpd-primary-glow: rgba(128,116,249,.35);
  --cpd-bg:           #f0eeff;
  --cpd-bg-grad:      linear-gradient(135deg,#ece8ff 0%,#f3f0ff 50%,#e8e3ff 100%);
  --cpd-glass:        rgba(255,255,255,.70);
  --cpd-glass-border: rgba(128,116,249,.22);
  --cpd-glass-blur:   20px;
  --cpd-surface:      rgba(255,255,255,.92);
  --cpd-text:         #1a1730;
  --cpd-text-muted:   #7b7594;
  --cpd-radius:       14px;
  --cpd-radius-sm:    8px;
  --cpd-shadow:       0 8px 32px rgba(128,116,249,.12), 0 2px 8px rgba(0,0,0,.06);
  --cpd-shadow-lg:    0 20px 60px rgba(128,116,249,.18), 0 4px 16px rgba(0,0,0,.08);
  --cpd-success:      #22c55e;
  --cpd-warning:      #f59e0b;
  --cpd-danger:       #ef4444;
  --cpd-transition:   .2s cubic-bezier(.4,0,.2,1);
}

/* ── Wrap ─────────────────────────────────────── */
.cpd-wrap {
  position: relative;
  background: var(--cpd-bg-grad);
  border-radius: var(--cpd-radius);
  padding: 20px;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--cpd-text);
  min-height: 500px;
}

.cpd-hidden { display: none !important; }

/* ── SVG Icon ─────────────────────────────────── */
/* width/height attrs on the SVG tag beat theme CSS; these are a secondary override */
.cpd-svg-icon {
  width: 20px !important;
  height: 20px !important;
  flex-shrink: 0;
  display: inline-block;
  vertical-align: middle;
  overflow: visible;
}

/* ── Top Bar ──────────────────────────────────── */
.cpd-topbar {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

/* Selects sit in center via flex justify-content: center */
.cpd-topbar__selects {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}

/* Price / DPI pinned to right */
.cpd-topbar__info {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  gap: 12px;
}

.cpd-select-wrap {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cpd-select-label {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--cpd-text-muted);
}

.cpd-wrap .cpd-select {
  appearance: none !important;
  -webkit-appearance: none !important;
  background: var(--cpd-glass) !important;
  backdrop-filter: blur(var(--cpd-glass-blur));
  -webkit-backdrop-filter: blur(var(--cpd-glass-blur));
  border: 1.5px solid var(--cpd-glass-border) !important;
  border-radius: var(--cpd-radius-sm) !important;
  padding: 8px 36px 8px 14px !important;
  margin: 0 !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--cpd-text) !important;
  cursor: pointer;
  min-width: 190px;
  width: auto !important;
  height: auto !important;
  line-height: 1.4 !important;
  box-sizing: border-box !important;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%238074f9' stroke-width='2' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 8px center !important;
  background-size: 16px !important;
  transition: border-color var(--cpd-transition), box-shadow var(--cpd-transition);
  box-shadow: none !important;
}
.cpd-wrap .cpd-select:focus {
  outline: none !important;
  border-color: var(--cpd-primary) !important;
  box-shadow: 0 0 0 3px var(--cpd-primary-glow) !important;
}

.cpd-price {
  font-size: 22px;
  font-weight: 700;
  color: var(--cpd-primary);
  letter-spacing: -.02em;
}

.cpd-dpi-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 20px;
  background: rgba(255,255,255,.8);
  border: 1px solid rgba(0,0,0,.08);
  font-size: 12px;
  font-weight: 600;
}
.cpd-dpi-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--cpd-success);
  flex-shrink: 0;
  transition: background var(--cpd-transition);
}
.cpd-dpi-badge.dpi-warning .cpd-dpi-dot { background: var(--cpd-warning); }
.cpd-dpi-badge.dpi-poor    .cpd-dpi-dot { background: var(--cpd-danger); }

/* ── Layout: Left Panel | Canvas | Right Panel ── */
.cpd-layout {
  display: flex;
  gap: 40px;
  align-items: flex-start;
  justify-content: center;
}

/* ── Shared Panel Styles ──────────────────────── */
.cpd-panel {
  background: var(--cpd-glass);
  backdrop-filter: blur(var(--cpd-glass-blur));
  -webkit-backdrop-filter: blur(var(--cpd-glass-blur));
  border: 1.5px solid var(--cpd-glass-border);
  border-radius: var(--cpd-radius);
  box-shadow: var(--cpd-shadow);
  overflow: hidden;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 32px;
  flex-shrink: 0;
}

.cpd-panel--left  { width: 350px; }
.cpd-panel--right { width: 350px; }

.cpd-panel__header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--cpd-glass-border);
  font-weight: 700;
  font-size: 15px;
  background: rgba(128,116,249,.07);
  user-select: none;
}
.cpd-panel__header span { flex: 1; }
.cpd-panel__header-actions { display: flex; gap: 4px; margin-left: auto; }

.cpd-panel__body {
  overflow-y: auto;
  flex: 1;
  padding: 4px 0 12px;
  scrollbar-width: thin;
  scrollbar-color: var(--cpd-glass-border) transparent;
}

/* ── Canvas Area ──────────────────────────────── */
.cpd-canvas-area {
  flex: 1 1 0;
  min-width: 0;
  max-width: 760px;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Upload Placeholder */
.cpd-upload-placeholder {
  align-self: stretch;
  border: 2px dashed var(--cpd-glass-border);
  border-radius: var(--cpd-radius);
  background: var(--cpd-glass);
  backdrop-filter: blur(var(--cpd-glass-blur));
  -webkit-backdrop-filter: blur(var(--cpd-glass-blur));
  transition: border-color var(--cpd-transition), background var(--cpd-transition);
  min-height: 420px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cpd-upload-placeholder.drag-over {
  border-color: var(--cpd-primary);
  background: rgba(128,116,249,.08);
}
.cpd-upload-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 40px 24px;
  cursor: pointer;
  text-align: center;
}
.cpd-upload-icon {
  width: 72px; height: 72px;
  color: var(--cpd-primary-light);
  transition: transform var(--cpd-transition), color var(--cpd-transition);
}
.cpd-upload-inner:hover .cpd-upload-icon {
  transform: translateY(-4px);
  color: var(--cpd-primary);
}
.cpd-upload-icon svg { width: 100%; height: 100%; }
.cpd-upload-text  { font-size: 15px; font-weight: 600; color: var(--cpd-text); }
.cpd-upload-hint  { font-size: 12px; color: var(--cpd-text-muted); margin-top: -8px; }

/* Canvas Container */
.cpd-canvas-container {
  border-radius: var(--cpd-radius);
  overflow: hidden;
  box-shadow: var(--cpd-shadow-lg);
  background: repeating-conic-gradient(#e8e3ff 0% 25%, white 0% 50%) 0 0 / 20px 20px;
  flex-shrink: 0;
  /* center within the flex-column canvas area */
  margin: 0 auto;
  display: block;
  width: fit-content;
}
/* Fabric.js wraps canvas in .canvas-container div — also center it */
.cpd-canvas-area .canvas-container { margin: 0 auto; }
.cpd-canvas-container canvas { display: block; }

/* Image Upload Loader */
.cpd-loader-overlay {
  position: absolute;
  inset: 0;
  border-radius: var(--cpd-radius);
  background: rgba(240,238,255,.85);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  z-index: 10;
  font-weight: 600;
  color: var(--cpd-primary);
}

/* ── Sections ─────────────────────────────────── */
.cpd-section {
  padding: 12px 16px;
  border-bottom: 1px solid rgba(128,116,249,.08);
}
.cpd-section:last-child { border-bottom: none; }
.cpd-section--actions { display: flex; flex-direction: column; gap: 8px; }

.cpd-section__title {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--cpd-primary);
  margin: 0 0 10px;
}

.cpd-color-hint p {
  font-size: 12px;
  color: var(--cpd-text-muted);
  line-height: 1.5;
  margin: 0;
}

/* ── Controls ─────────────────────────────────── */
.cpd-control-row { margin-bottom: 10px; }
.cpd-control-row label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--cpd-text-muted);
  margin-bottom: 5px;
}
.cpd-slider-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.cpd-range {
  flex: 1;
  appearance: none;
  height: 4px;
  border-radius: 4px;
  background: linear-gradient(to right, var(--cpd-primary) 0%, var(--cpd-primary) var(--progress, 50%), rgba(128,116,249,.2) var(--progress, 50%));
  outline: none;
  cursor: pointer;
}
.cpd-range::-webkit-slider-thumb {
  appearance: none;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--cpd-primary);
  box-shadow: 0 0 0 3px white, 0 0 0 5px var(--cpd-primary-glow);
  cursor: pointer;
  transition: transform var(--cpd-transition);
}
.cpd-range::-webkit-slider-thumb:hover { transform: scale(1.2); }
.cpd-range::-moz-range-thumb {
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--cpd-primary);
  border: none;
  cursor: pointer;
}

.cpd-num-input {
  width: 44px;
  padding: 4px 4px;
  border: 1.5px solid var(--cpd-glass-border);
  border-radius: var(--cpd-radius-sm);
  font-size: 12px;
  text-align: center;
  background: var(--cpd-surface);
  color: var(--cpd-text);
  transition: border-color var(--cpd-transition);
}
.cpd-num-input:focus { outline: none; border-color: var(--cpd-primary); }

/* Quick rotate */
.cpd-quick-rotate { display: flex; gap: 4px; margin-bottom: 6px; }

/* Flip buttons */
.cpd-flip-btns { display: flex; gap: 8px; margin-top: 4px; }
.cpd-flip-btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 7px 10px;
  border: 1.5px solid var(--cpd-glass-border);
  border-radius: var(--cpd-radius-sm);
  background: transparent;
  font-size: 12px;
  font-weight: 600;
  color: var(--cpd-text);
  cursor: pointer;
  transition: all var(--cpd-transition);
}
.cpd-flip-btn .cpd-svg-icon { width: 18px; height: 18px; }
.cpd-flip-btn:hover, .cpd-flip-btn.active {
  background: var(--cpd-primary);
  border-color: var(--cpd-primary);
  color: white;
}

/* 3×3 Align Grid (cross pattern — corners are spacers) */
.cpd-align-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
}
.cpd-align-spacer {
  display: block;
  background: transparent;
}
.cpd-align-btn {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  border: 1.5px solid var(--cpd-glass-border);
  border-radius: var(--cpd-radius-sm);
  background: transparent;
  cursor: pointer;
  transition: all var(--cpd-transition);
  color: var(--cpd-text-muted);
}
.cpd-align-btn .cpd-svg-icon { width: 18px; height: 18px; }
.cpd-align-btn:hover { background: rgba(128,116,249,.12); border-color: var(--cpd-primary); color: var(--cpd-primary); }
.cpd-align-btn--center { background: rgba(128,116,249,.1); }

/* ── Buttons ──────────────────────────────────── */
.cpd-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 20px;
  border-radius: var(--cpd-radius-sm);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  transition: all var(--cpd-transition);
  text-decoration: none;
  line-height: 1;
  white-space: nowrap;
}
.cpd-btn svg, .cpd-btn .cpd-svg-icon { width: 16px; height: 16px; flex-shrink: 0; }
.cpd-btn--full { width: 100%; }
.cpd-btn--sm { padding: 6px 12px; font-size: 12px; }
.cpd-btn--large { padding: 14px 28px; font-size: 16px; }

.cpd-btn--primary {
  background: linear-gradient(135deg, var(--cpd-primary) 0%, var(--cpd-primary-dark) 100%);
  color: white;
  box-shadow: 0 4px 14px var(--cpd-primary-glow);
}
.cpd-btn--primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px var(--cpd-primary-glow);
}
.cpd-btn--primary:active { transform: translateY(0); }
.cpd-btn--primary:disabled { opacity: .5; cursor: not-allowed; transform: none; }

.cpd-btn--accent {
  background: linear-gradient(135deg, #a599fb 0%, var(--cpd-primary) 100%);
  color: white;
}
.cpd-btn--accent:hover { filter: brightness(1.05); }

.cpd-btn--ghost {
  background: transparent;
  color: var(--cpd-text-muted);
  border: 1.5px solid var(--cpd-glass-border);
}
.cpd-btn--ghost:hover { background: rgba(128,116,249,.08); color: var(--cpd-primary); border-color: var(--cpd-primary); }

.cpd-icon-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 8px;
  border: 1.5px solid var(--cpd-glass-border);
  border-radius: var(--cpd-radius-sm);
  background: transparent;
  cursor: pointer;
  font-size: 11px;
  font-weight: 600;
  color: var(--cpd-text-muted);
  transition: all var(--cpd-transition);
}
.cpd-icon-btn svg { width: 14px; height: 14px; }
.cpd-icon-btn:hover:not(:disabled) { background: rgba(128,116,249,.1); color: var(--cpd-primary); border-color: var(--cpd-primary); }
.cpd-icon-btn:disabled { opacity: .35; cursor: not-allowed; }

/* ── Canvas Actions Bar (desktop: below canvas) ── */
.cpd-canvas-actions {
  display: flex;
  gap: 8px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 12px;
  width: 100%;
}

/* ── Bottom Bar ───────────────────────────────── */
.cpd-bottombar {
  display: flex;
  justify-content: center;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--cpd-glass-border);
}
#cpdAddToCart { min-width: 240px; }
#cpdAddToCart strong { font-size: 18px; }

/* ── Spinner ──────────────────────────────────── */
.cpd-spinner {
  width: 32px; height: 32px;
  border: 3px solid rgba(128,116,249,.2);
  border-top-color: var(--cpd-primary);
  border-radius: 50%;
  animation: cpd-spin .7s linear infinite;
}
.cpd-spinner--large { width: 48px; height: 48px; }
@keyframes cpd-spin { to { transform: rotate(360deg); } }

/* ── Order Overlay ────────────────────────────── */
.cpd-order-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(240,238,255,.88);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  display: flex;
  align-items: center;
  justify-content: center;
}
.cpd-order-overlay__inner {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.cpd-order-overlay__sub { font-size: 13px; color: var(--cpd-text-muted); }

/* ── Mobile Tabs ──────────────────────────────── */
.cpd-mobile-tabs { display: none; }

.cpd-tab-bar {
  display: flex;
  gap: 4px;
  border-bottom: 2px solid rgba(128,116,249,.15);
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.cpd-tab-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  border: none;
  background: transparent;
  font-size: 13px;
  font-weight: 600;
  color: var(--cpd-text-muted);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: all var(--cpd-transition);
}
.cpd-tab-btn svg { width: 16px; height: 16px; }
.cpd-tab-btn.active { color: var(--cpd-primary); border-bottom-color: var(--cpd-primary); }

.cpd-tab-content { display: none; padding: 8px 0; }
.cpd-tab-content.active { display: block; }

.cpd-mobile-undo-row {
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

/* ── Onboarding Modal ─────────────────────────── */
.cpd-onboarding {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.cpd-onboarding[hidden] { display: none; }

.cpd-onboarding__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(26,23,48,.65);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.cpd-onboarding__panel {
  position: relative;
  z-index: 1;
  background: white;
  border-radius: 20px;
  box-shadow: var(--cpd-shadow-lg);
  width: 100%;
  max-width: 460px;
  overflow: hidden;
  animation: cpd-modal-in .3s cubic-bezier(.34,1.56,.64,1);
}
@keyframes cpd-modal-in {
  from { opacity: 0; transform: scale(.92) translateY(10px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

.cpd-onboarding__steps { min-height: 260px; }

.cpd-onboarding__step {
  display: none;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 40px 36px 24px;
  gap: 14px;
}
.cpd-onboarding__step.active { display: flex; }

.cpd-onboarding__step-icon {
  width: 72px; height: 72px;
  border-radius: 18px;
  background: linear-gradient(135deg, #ece8ff 0%, #ddd6fe 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
}
.cpd-onboarding__step h3 { font-size: 20px; font-weight: 700; color: var(--cpd-text); margin: 0; }
.cpd-onboarding__step p  { font-size: 14px; color: var(--cpd-text-muted); margin: 0; line-height: 1.6; }

.cpd-onboarding__dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  padding: 8px;
}
.cpd-onboarding__dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(128,116,249,.25);
  transition: all var(--cpd-transition);
  cursor: pointer;
}
.cpd-onboarding__dot.active { background: var(--cpd-primary); width: 20px; border-radius: 4px; }

.cpd-onboarding__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 24px;
  border-top: 1px solid rgba(128,116,249,.1);
  gap: 8px;
}

/* ── Account Page ─────────────────────────────── */
.cpd-account-wrap { max-width: 800px; }
.cpd-account-wrap h2 { margin-bottom: 20px; }

.cpd-account-empty {
  text-align: center;
  padding: 40px 20px;
  color: #666;
}
.cpd-account-empty svg { display: block; margin: 0 auto 16px; color: #ccc; }
.cpd-account-empty p { margin-bottom: 16px; }

.cpd-account-orders { display: flex; flex-direction: column; gap: 12px; }

.cpd-account-card {
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 16px;
  background: #fff;
}
.cpd-account-card__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}
.cpd-account-card__id { font-weight: 700; font-size: 15px; }

.cpd-account-card__details {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 13px;
  color: #555;
  margin-bottom: 10px;
}
.cpd-account-card__details span {
  display: flex;
  align-items: center;
  gap: 5px;
}
.cpd-account-card__details svg { flex-shrink: 0; }

.cpd-account-card__rejection {
  font-size: 13px;
  color: #991b1b;
  background: #fee2e2;
  border-radius: 6px;
  padding: 8px 12px;
  margin-bottom: 10px;
}
.cpd-account-card__actions { display: flex; gap: 8px; flex-wrap: wrap; }

.cpd-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
}
.cpd-status--pending_review { background: #fef3c7; color: #92400e; }
.cpd-status--approved       { background: #dcfce7; color: #166534; }
.cpd-status--rejected       { background: #fee2e2; color: #991b1b; }
.cpd-status--other          { background: #f3f4f6; color: #374151; }

/* ── Responsive ───────────────────────────────── */
@media (max-width: 1300px) {
  .cpd-panel--left  { width: 290px; }
  .cpd-panel--right { width: 290px; }
  .cpd-layout { gap: 28px; }
}
@media (max-width: 1100px) {
  .cpd-panel--left  { width: 240px; }
  .cpd-panel--right { width: 240px; }
  .cpd-layout { gap: 20px; }
}

@media (max-width: 900px) {
  .cpd-layout { flex-direction: column; gap: 0; }
  .cpd-panel--left, .cpd-panel--right { display: none; }
  .cpd-canvas-area { align-self: stretch; max-width: none; }
  .cpd-canvas-actions { display: none; } /* replaced by mobile persistent actions */
  .cpd-mobile-tabs {
    display: block;
    background: var(--cpd-glass);
    backdrop-filter: blur(var(--cpd-glass-blur));
    -webkit-backdrop-filter: blur(var(--cpd-glass-blur));
    border: 1.5px solid var(--cpd-glass-border);
    border-radius: var(--cpd-radius);
    padding: 12px 16px;
    margin-top: 16px;
  }
  /* Active tab: white text on primary background */
  .cpd-tab-btn.active {
    background: var(--cpd-primary);
    color: white !important;
    border-bottom-color: var(--cpd-primary);
    border-radius: var(--cpd-radius-sm) var(--cpd-radius-sm) 0 0;
  }
  /* Persistent actions below all tabs */
  .cpd-mobile-persistent-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding-top: 12px;
    border-top: 1px solid var(--cpd-glass-border);
    margin-top: 8px;
  }
  /* Sliders bigger, number inputs smaller on mobile */
  .cpd-num-input { width: 36px !important; font-size: 11px; padding: 3px 2px !important; }
  .cpd-range { height: 6px; }
  .cpd-range::-webkit-slider-thumb { width: 22px; height: 22px; }
  .cpd-range::-moz-range-thumb { width: 22px; height: 22px; }
  /* Topbar: flow normally */
  .cpd-topbar { justify-content: center; }
  .cpd-topbar__info { position: static; transform: none; display: none; }
}

@media (max-width: 480px) {
  .cpd-wrap { padding: 12px; }
  .cpd-topbar { gap: 8px; justify-content: center; }
  .cpd-topbar__info { display: none; }
  .cpd-upload-inner { padding: 24px 16px; }
  .cpd-upload-icon { width: 52px; height: 52px; }
  .cpd-bottombar {
    position: sticky;
    bottom: 0;
    background: rgba(240,238,255,.9);
    backdrop-filter: blur(12px);
    padding: 12px;
    margin: 0 -12px -12px;
    border-radius: 0 0 var(--cpd-radius) var(--cpd-radius);
  }
  .cpd-btn--large { width: 100%; }
}
