/* ─────────────────────────────────────────────────────────────────────────────
   RC Decal Sheet Builder — Styles
   Aesthetic: Industrial precision — dark panels, sharp edges, vivid accent,
   monospaced slot numbers, crisp micro-animations.
   Font: Barlow Condensed (display) + DM Mono (labels)
───────────────────────────────────────────────────────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700;900&family=DM+Mono:wght@400;500&display=swap');

/* ── Variables ─────────────────────────────────────────────────────────────── */
.dbb-wrap {
  --dbb-bg:         #0f1117;
  --dbb-surface:    #181c27;
  --dbb-surface-2:  #1f2436;
  --dbb-border:     #2a3048;
  --dbb-accent:     #e8ff00;       /* electric chartreuse — unforgettable */
  --dbb-accent-dim: #b8cc00;
  --dbb-text:       #e8eaf0;
  --dbb-text-dim:   #7a8299;
  --dbb-success:    #00e07a;
  --dbb-error:      #ff4c60;
  --dbb-font-head:  'Barlow Condensed', sans-serif;
  --dbb-font-mono:  'DM Mono', monospace;
  --dbb-radius:     4px;
  --dbb-transition: 180ms ease;

  font-family:      var(--dbb-font-mono);
  background:       var(--dbb-bg);
  color:            var(--dbb-text);
  border-radius:    8px;
  overflow:         visible;
  max-width:        100%;
  width:            100%;
  border:           1px solid var(--dbb-border);
  box-shadow:       0 20px 60px rgba(0,0,0,.55);
}

/* ── Header ────────────────────────────────────────────────────────────────── */
.dbb-header {
  position:   relative;
  padding:    36px 40px 28px;
  background: var(--dbb-surface);
  border-bottom: 1px solid var(--dbb-border);
  overflow:   hidden;
}

.dbb-header-accent {
  position:   absolute;
  top: -40px; right: -40px;
  width:  200px;
  height: 200px;
  background: var(--dbb-accent);
  border-radius: 50%;
  opacity: .06;
  pointer-events: none;
}

.dbb-title {
  font-family:    var(--dbb-font-head) !important;
  font-size:      clamp(1.8rem, 4vw, 2.6rem) !important;
  font-weight:    900 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  color:          var(--dbb-text) !important;
  margin:         0 0 6px !important;
  line-height:    1 !important;
}

.dbb-title::after {
  content:          '';
  display:          block;
  width:            40px;
  height:           3px;
  background:       var(--dbb-accent);
  margin-top:       10px;
}

.dbb-subtitle {
  font-size:   .78rem;
  color:       var(--dbb-text-dim);
  margin:      14px 0 0;
  letter-spacing: .06em;
  text-transform: uppercase;
}

/* ── Slots container ───────────────────────────────────────────────────────── */
.dbb-slots {
  padding: 8px 0;
  overflow: visible;
}

/* ── Single slot row ───────────────────────────────────────────────────────── */
.dbb-slot {
  display:         grid;
  grid-template-columns: 52px 1fr 28px;
  align-items:     center;
  gap:             0 16px;
  padding:         18px 24px 18px 20px;
  border-bottom:   1px solid var(--dbb-border);
  background:      var(--dbb-bg);
  transition:      background var(--dbb-transition);
  animation:       dbb-slide-in 300ms ease both;
  animation-delay: var(--delay, 0ms);
  position:        relative;
  z-index:         1;
  overflow:        visible;
}

/* Elevate slot above siblings when its virtual picker or size picker is open */
.dbb-slot:has(.dbb-vp.is-open),
.dbb-slot:has(.dbb-size-picker.is-open) {
  z-index: 100;
}

.dbb-slot:last-child { border-bottom: none; }
.dbb-slot:hover      { background: var(--dbb-surface); }

@keyframes dbb-slide-in {
  from { opacity: 0; transform: translateX(-12px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* Slot number badge */
.dbb-slot-number {
  font-family:    var(--dbb-font-head);
  font-size:      2rem;
  font-weight:    900;
  color:          var(--dbb-border);
  line-height:    1;
  user-select:    none;
  transition:     color var(--dbb-transition);
}

.dbb-slot:hover .dbb-slot-number,
.dbb-slot:focus-within .dbb-slot-number {
  color: var(--dbb-accent);
}

/* Slot body */
.dbb-slot-body {
  display:    flex;
  flex-direction: column;
  gap:        8px;
  min-width:  0;
}

.dbb-slot-label {
  font-size:      .7rem;
  font-weight:    500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color:          var(--dbb-text-dim);
  display:        block;
}

.dbb-slot-selects {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* ── Custom Select ─────────────────────────────────────────────────────────── */
.dbb-select-wrap {
  position:   relative;
  display:    flex;
  align-items: center;
}

.dbb-select {
  appearance:    none;
  -webkit-appearance: none;
  width:         100%;
  background:    var(--dbb-surface-2);
  border:        1px solid var(--dbb-border);
  border-radius: var(--dbb-radius);
  color:         var(--dbb-text);
  font-family:   var(--dbb-font-mono);
  font-size:     .82rem;
  line-height:   1.5;
  min-height:    52px;
  box-sizing:    border-box;
  padding:       15px 36px 15px 12px;
  cursor:        pointer;
  outline:       none;
  transition:    border-color var(--dbb-transition), box-shadow var(--dbb-transition);
  min-width:     0;
}

.dbb-select:focus {
  border-color: var(--dbb-accent);
  box-shadow:   0 0 0 2px rgba(232,255,0,.15);
}

.dbb-select:disabled {
  opacity: .4;
  cursor:  not-allowed;
}

.dbb-select option {
  background: var(--dbb-surface-2);
  color:      var(--dbb-text);
}

.dbb-select-arrow {
  position:       absolute;
  right:          12px;
  color:          var(--dbb-text-dim);
  pointer-events: none;
  font-size:      .85rem;
  transition:     color var(--dbb-transition);
}

.dbb-select-wrap:focus-within .dbb-select-arrow {
  color: var(--dbb-accent);
}

/* Secondary select — slightly indented */
.dbb-select-wrap--secondary .dbb-select {
  border-left:   3px solid var(--dbb-accent);
  padding-left:  10px;
  background:    #161a26;
}

/* preview box removed — scale preview is in the sidebar */

/* ── Checkmark ─────────────────────────────────────────────────────────────── */
.dbb-slot-check {
  width:       26px;
  height:      26px;
  background:  var(--dbb-success);
  color:       #000;
  border-radius: 50%;
  display:     flex;
  align-items: center;
  justify-content: center;
  font-size:   .75rem;
  font-weight: 700;
  flex-shrink: 0;
}

.dbb-check--pop {
  animation: dbb-pop .35s ease;
}

@keyframes dbb-pop {
  0%   { transform: scale(.6); opacity: 0; }
  60%  { transform: scale(1.2); }
  100% { transform: scale(1);  opacity: 1; }
}

/* ── Summary ───────────────────────────────────────────────────────────────── */
.dbb-summary {
  background:    var(--dbb-surface);
  border-top:    1px solid var(--dbb-border);
  padding:       24px 40px;
}

.dbb-summary-title {
  font-family:    var(--dbb-font-head);
  font-size:      1rem;
  font-weight:    700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color:          var(--dbb-text-dim);
  margin:         0 0 14px;
}

.dbb-summary-list {
  list-style:  none;
  margin:      0;
  padding:     0;
  display:     flex;
  flex-direction: column;
  gap:         6px;
}

.dbb-summary-item {
  display:     flex;
  align-items: baseline;
  gap:         12px;
  font-size:   .8rem;
}

.dbb-summary-slot {
  color:          var(--dbb-text-dim);
  font-size:      .7rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  width:          72px;
  flex-shrink:    0;
}

.dbb-summary-value {
  color: var(--dbb-text);
}

.dbb-summary-value em {
  font-style:  normal;
  color:       var(--dbb-accent);
  margin-left: 6px;
}

/* ── Actions ───────────────────────────────────────────────────────────────── */
.dbb-actions {
  padding:     20px 40px 28px;
  background:  var(--dbb-bg);
  display:     flex;
  align-items: center;
  gap:         12px;
  flex-wrap:   wrap;
}

/* ── Quantity control ───────────────────────────────────────────────────────── */
.dbb-qty-wrap {
  display:     flex;
  align-items: center;
  border:      1px solid var(--dbb-border);
  border-radius: var(--dbb-radius);
  overflow:    hidden;
  background:  var(--dbb-surface-2);
  flex-shrink: 0;
}

.dbb-qty-btn {
  background:  transparent;
  border:      none;
  color:       var(--dbb-text);
  font-size:   1.2rem;
  width:       36px;
  height:      48px;
  cursor:      pointer;
  display:     flex;
  align-items: center;
  justify-content: center;
  transition:  background var(--dbb-transition), color var(--dbb-transition);
  flex-shrink: 0;
  line-height: 1;
}

.dbb-qty-btn:hover {
  background: rgba(255,255,255,.08);
  color:      var(--dbb-accent);
}

.dbb-qty-input {
  width:       48px;
  height:      48px;
  border:      none;
  border-left: 1px solid var(--dbb-border);
  border-right: 1px solid var(--dbb-border);
  background:  transparent;
  color:       var(--dbb-text);
  font-family: var(--dbb-font-mono);
  font-size:   1rem;
  text-align:  center;
  padding:     0;
  -moz-appearance: textfield;
  outline:     none;
}

.dbb-qty-input::-webkit-outer-spin-button,
.dbb-qty-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.dbb-qty-input:focus { color: var(--dbb-accent); }

.dbb-qty-label {
  font-family:    var(--dbb-font-head);
  font-size:      1.05rem;
  font-weight:    700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color:          var(--dbb-text-dim);
  padding:        0 10px 0 14px;
  white-space:    nowrap;
}

.dbb-btn {
  display:        inline-flex;
  align-items:    center;
  gap:            8px;
  padding:        14px 32px;
  font-family:    var(--dbb-font-head);
  font-size:      1.05rem;
  font-weight:    700;
  letter-spacing: .1em;
  text-transform: uppercase;
  border:         2px solid var(--dbb-border);
  border-radius:  var(--dbb-radius);
  background:     transparent;
  color:          var(--dbb-text-dim);
  cursor:         not-allowed;
  transition:     all var(--dbb-transition);
  position:       relative;
  overflow:       hidden;
}

.dbb-btn--primary.dbb-btn--ready {
  background:    var(--dbb-accent);
  border-color:  var(--dbb-accent);
  color:         #000;
  cursor:        pointer;
  box-shadow:    0 4px 24px rgba(232,255,0,.3);
}

.dbb-btn--primary.dbb-btn--ready:hover {
  background:    var(--dbb-accent-dim);
  border-color:  var(--dbb-accent-dim);
  box-shadow:    0 6px 32px rgba(232,255,0,.45);
  transform:     translateY(-1px);
}

.dbb-btn--primary.dbb-btn--ready:active {
  transform: translateY(0);
}

/* ── Message ───────────────────────────────────────────────────────────────── */
.dbb-message {
  margin:      0 40px 24px;
  padding:     12px 16px;
  border-radius: var(--dbb-radius);
  font-size:   .82rem;
}

.dbb-message--success {
  background: rgba(0,224,122,.12);
  border:     1px solid rgba(0,224,122,.35);
  color:      var(--dbb-success);
}

.dbb-message--error {
  background: rgba(255,76,96,.12);
  border:     1px solid rgba(255,76,96,.35);
  color:      var(--dbb-error);
}

.dbb-message a {
  color:           inherit;
  font-weight:     700;
  text-decoration: underline;
}

/* ── Responsive ────────────────────────────────────────────────────────────── */
@media (max-width: 560px) {
  .dbb-slot {
    grid-template-columns: 40px 1fr auto 24px;
    padding: 14px 14px 14px 12px;
    gap: 0 10px;
  }

  .dbb-slot-number { font-size: 1.5rem; }

  .dbb-header,
  .dbb-actions,
  .dbb-summary,
  .dbb-message { padding-left: 18px; padding-right: 18px; }

  .dbb-select { font-size: .76rem; }
}

/* ── Prevent right-click / drag on all SVGs in the widget ─────────────────── */
#dbb-wrap img {
  -webkit-user-drag: none;
  user-drag:         none;
  pointer-events:    none;
}

/* ── Sub-option required warning ───────────────────────────────────────────── */
.dbb-sub-warning {
  margin:      6px 0 0;
  font-size:   .72rem;
  font-family: var(--dbb-font-mono);
  color:       var(--dbb-error);
  letter-spacing: .04em;
  display:     flex;
  align-items: center;
  gap:         5px;
}

.dbb-sub-warning::before {
  content:     '⚠';
  font-size:   .8rem;
  flex-shrink: 0;
}

/* Highlight the sub-select border red when warning is visible */

/* ── Clear buttons ─────────────────────────────────────────────────────────── */
.dbb-clear-btn {
  position:        absolute;
  right:           8px;
  top:             50%;
  transform:       translateY(-50%);
  background:      transparent;
  border:          none;
  color:           var(--dbb-text-dim);
  font-size:       1.1rem;
  line-height:     1;
  cursor:          pointer;
  padding:         4px 6px;
  border-radius:   var(--dbb-radius);
  transition:      color var(--dbb-transition), background var(--dbb-transition);
  z-index:         10;
}

.dbb-clear-btn:hover {
  color:       var(--dbb-error);
  background:  rgba(255,76,96,.12);
}

/* Nudge the Choices arrow out of the way when clear btn is visible */
.dbb-select-wrap--primary,
.dbb-select-wrap--secondary {
  position: relative;
}

/* ── Summary SVG thumbnail ─────────────────────────────────────────────────── */
.dbb-summary-item {
  display:     flex;
  align-items: center;
  gap:         12px;
}

.dbb-summary-value {
  display:     flex;
  align-items: center;
  gap:         8px;
}

.dbb-summary-thumb {
  width:          36px;
  height:         36px;
  object-fit:     contain;
  background:     #ffffff;
  border-radius:  3px;
  padding:        3px;
  flex-shrink:    0;
  pointer-events: none;
  -webkit-user-drag: none;
}

/* ── Two-column body layout ────────────────────────────────────────────────── */
.dbb-body {
  display:        flex;
  flex-direction: row;
  align-items:    stretch;
  min-height:     0;
}

/* Sidebar is now on the LEFT */
.dbb-left {
  flex:     1 1 0;
  min-width: 0;
  display:  flex;
  flex-direction: column;
  border-left: 1px solid var(--dbb-border);
  order: 2;
}

/* ── Scale Preview Sidebar (left side) ────────────────────────────────────── */
.dbb-sidebar {
  width:            480px;
  flex-shrink:      0;
  background:       transparent;
  display:          flex;
  flex-direction:   column;
  position:         sticky;
  top:              20px;
  align-self:       flex-start;
  padding:          16px 12px 0;
  box-sizing:       border-box;
  order: 1;
}

.dbb-preview-header {
  margin-bottom: 10px;
}

.dbb-preview-label {
  font-family:    var(--dbb-font-head);
  font-size:      .72rem;
  font-weight:    700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color:          #999;
  display:        block;
}

.dbb-preview-hint {
  font-size:   .62rem;
  color:       #bbb;
  font-family: var(--dbb-font-mono);
  display:     block;
  margin-top:  2px;
}

/* Canvas stage — white, stacked rows, auto height */
.dbb-canvas-stage {
  width:           100%;
  background:      transparent;
  display:         flex;
  flex-direction:  column;
  gap:             20px;
  padding:         12px 12px 12px 0;
  box-sizing:      border-box;
  min-height:      40px;
  overflow:        visible;
}

.dbb-canvas-empty {
  font-family:    var(--dbb-font-mono);
  font-size:      .65rem;
  color:          #bbb;
  letter-spacing: .04em;
  text-transform: uppercase;
  pointer-events: none;
  user-select:    none;
  text-align:     left;
  padding:        8px 0;
}

/* Each row: [size label] [svg] */
.dbb-canvas-decal {
  display:        flex;
  flex-direction: row;
  align-items:    center;
  gap:            8px;
  overflow:       visible;
}

/* Only animate rows that are genuinely new */
.dbb-canvas-decal--new {
  animation: dbb-pop .3s ease;
}

/* Center the SVG within the full stage width (after label) */
.dbb-canvas-decal--center {
  justify-content: flex-start;
}

.dbb-canvas-decal--center .dbb-canvas-svg-wrap {
  margin-left: auto;
  margin-right: auto;
}

.dbb-canvas-svg-wrap {
  overflow:  visible;
  flex-shrink: 0;
}

.dbb-canvas-svg-wrap svg {
  overflow: visible;
  display:  block;
}

/* Size label — fixed width, right-aligned */
.dbb-canvas-decal-label {
  font-family:  var(--dbb-font-mono);
  font-size:    1.3rem;
  color:        #999;
  white-space:  nowrap;
  text-align:   right;
  width:        52px;
  flex-shrink:  0;
}

.dbb-canvas-decal img {
  display:           block;
  pointer-events:    none;
  user-select:       none;
  -webkit-user-drag: none;
}

/* Ruler — sits ABOVE the logo rows, ticks point downward */
.dbb-ruler {
  position:    relative;
  width:       100%;
  height:      28px;
  background:  transparent;
  overflow:    visible;
  flex-shrink: 0;
  margin-bottom: 6px;
}

.dbb-ruler-tick {
  position:       absolute;
  top:            0;
  display:        flex;
  flex-direction: column;
  align-items:    center;
  transform:      translateX(-50%);
}

/* Number above the tick line */
.dbb-ruler-tick-num {
  font-family:  var(--dbb-font-mono);
  font-size:    .55rem;
  color:        #999;
  margin-bottom: 2px;
  white-space:  nowrap;
}

.dbb-ruler-tick-line { width: 1px; background: #ccc; }
.dbb-ruler-tick-line--major { height: 8px; background: #999; }
.dbb-ruler-tick-line--minor { height: 5px; background: #bbb; }
.dbb-ruler-tick-spacer { height: 12px; } /* keeps minor ticks bottom-aligned with major ticks */

/* 1-inch accent bar at the bottom of the ruler */
.dbb-ruler-inch-bar {
  position:   absolute;
  bottom:     0;
  height:     2px;
  background: var(--dbb-accent);
  opacity:    .7;
}

/* ── Responsive: stack on narrow screens ───────────────────────────────────── */
@media (max-width: 860px) {
  .dbb-body {
    flex-direction: column;
  }
  .dbb-left {
    border-right: none;
    border-bottom: 1px solid var(--dbb-border);
  }
  .dbb-sidebar {
    width:    100%;
    position: static;
    padding:  16px;
    background: transparent;
    border-top: 1px solid var(--dbb-border);
  }
}

/* ── Custom size picker ────────────────────────────────────────────────────── */
.dbb-size-picker {
  position:  relative;
  width:     100%;
}

.dbb-size-display {
  display:        flex;
  align-items:    center;
  justify-content: space-between;
  background:     var(--dbb-surface-2);
  border:         1px solid var(--dbb-border);
  border-radius:  var(--dbb-radius);
  padding:        11px 12px;
  min-height:     52px;
  cursor:         pointer;
  box-sizing:     border-box;
  transition:     border-color var(--dbb-transition), box-shadow var(--dbb-transition);
  user-select:    none;
}

.dbb-size-display:hover,
.dbb-size-picker.is-open .dbb-size-display {
  border-color: var(--dbb-accent);
  box-shadow:   0 0 0 2px rgba(232,255,0,.15);
}

.dbb-size-display-text {
  font-family: var(--dbb-font-mono);
  font-size:   .82rem;
  color:       var(--dbb-text-dim);
}

.dbb-size-picker.has-value .dbb-size-display-text {
  color: var(--dbb-text);
}

.dbb-size-arrow {
  color:     var(--dbb-text-dim);
  font-size: .85rem;
  transition: transform var(--dbb-transition), color var(--dbb-transition);
}

.dbb-size-picker.is-open .dbb-size-arrow {
  transform: rotate(180deg);
  color:     var(--dbb-accent);
}

.dbb-size-dropdown {
  position:   absolute;
  top:        calc(100% + 4px);
  left:       0;
  right:      0;
  background: var(--dbb-surface-2);
  border:     1px solid var(--dbb-accent);
  border-radius: var(--dbb-radius);
  z-index:    9999;
  list-style: none;
  margin:     0;
  padding:    4px 0;
  max-height: 240px;
  overflow-y: auto;
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
}

.dbb-size-option {
  font-family: var(--dbb-font-mono);
  font-size:   .82rem;
  color:       var(--dbb-text);
  padding:     9px 14px;
  cursor:      pointer;
  transition:  background var(--dbb-transition), color var(--dbb-transition);
}

.dbb-size-option:hover {
  background: var(--dbb-accent);
  color:      #000;
}

.dbb-size-option.is-selected {
  color: var(--dbb-accent);
  font-weight: 500;
}

/* ── Background-image SVG thumbnails (hides transparent viewBox padding) ───── */
.dbb-option-thumb--bg {
  background-size:     contain;
  background-repeat:   no-repeat;
  background-position: center;
  background-color:    #ffffff;
}

/* Override img-specific rules that don't apply to divs */
.dbb-option-thumb.dbb-option-thumb--bg,
.dbb-option-thumb--selected.dbb-option-thumb--bg {
  display:    block;
  flex-shrink: 0;
}

.dbb-summary-thumb.dbb-option-thumb--bg {
  width:  36px;
  height: 36px;
}

/* ── Color Customizer ────────────────────────────────────────────────────────── */
.dbb-color-wrap {
  background:    var(--dbb-surface);
  border-bottom: 1px solid var(--dbb-border);
  padding:       24px 28px;
}

.dbb-color-header {
  display:        flex;
  align-items:    baseline;
  gap:            16px;
  margin-bottom:  20px;
}

.dbb-color-title {
  font-family:    var(--dbb-font-head);
  font-size:      .8rem;
  font-weight:    700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color:          var(--dbb-text-dim);
}

.dbb-color-price {
  font-family: var(--dbb-font-head);
  font-size:   1.4rem;
  font-weight: 900;
  color:       var(--dbb-accent);
}

.dbb-price-breakdown {
  font-size:   .7rem;
  font-weight: 400;
  color:       var(--dbb-text-dim);
  font-family: var(--dbb-font-mono);
  margin-left: 6px;
}

.dbb-color-body {
  display:     flex;
  align-items: center;
  gap:         32px;
}

/* ── Sample SVG preview ───────────────────────────────────────────────────── */
.dbb-color-preview-wrap {
  flex-shrink: 0;
}

.dbb-sample-label {
  font-family:    var(--dbb-font-mono);
  font-size:      .65rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color:          var(--dbb-text-dim);
  margin-bottom:  8px;
}

/* Stacked SVG layers — all positioned on top of each other */
#dbb-sample-svg-wrap {
  position: relative;
  width:    495px;
  display:  block;
}

#dbb-sample-svg-wrap svg {
  display: block;
  width:   100%;
  height:  auto;
}

/* All layers share the same space — outline2 at back, main on top */
#dbb-sample-svg-wrap svg.dbb-layer-outline2 { position: relative; }
#dbb-sample-svg-wrap svg.dbb-layer-outline1 { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
#dbb-sample-svg-wrap svg.dbb-layer-main     { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

#dbb-sample-svg-wrap svg path {
  transition: fill .25s ease;
}

/* ── Color select rows ─────────────────────────────────────────────────────── */
.dbb-color-selects {
  flex:       1;
  display:    flex;
  flex-direction: column;
  gap:        14px;
}

.dbb-color-row {
  display:     flex;
  align-items: center;
  gap:         16px;
}

/* Match slot label style exactly */
.dbb-color-row-label {
  font-size:      .7rem;
  font-weight:    500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color:          var(--dbb-text-dim);
  display:        block;
  flex-shrink:    0;
  width:          120px;
}

.dbb-color-req {
  color:          var(--dbb-accent);
  font-size:      .9em;
  letter-spacing: .04em;
  text-transform: none;
}

.dbb-color-select-wrap {
  flex: 1;
  min-width: 0;
}

/* ── Custom color picker dropdown ─────────────────────────────────────────── */
.dbb-cpicker {
  position: relative;
}

.dbb-cpicker-display {
  display:        flex;
  align-items:    center;
  gap:            10px;
  padding:        10px 12px;
  background:     var(--dbb-surface-2);
  border:         1px solid var(--dbb-border);
  border-radius:  var(--dbb-radius);
  cursor:         pointer;
  user-select:    none;
  transition:     border-color var(--dbb-transition), box-shadow var(--dbb-transition);
  min-height:     48px;
}

.dbb-cpicker-display:hover,
.dbb-cpicker.is-open .dbb-cpicker-display {
  border-color: var(--dbb-accent);
  box-shadow:   0 0 0 2px rgba(232,255,0,.15);
}

.dbb-cpicker-swatch {
  width:        24px;
  height:       24px;
  border-radius: 4px;
  border:       1px solid rgba(255,255,255,.15);
  flex-shrink:  0;
  display:      block;
  transition:   background .2s ease;
}

.dbb-cpicker-text {
  flex:        1;
  font-size:   .82rem;
  color:       var(--dbb-text-dim);
  font-family: var(--dbb-font-mono);
}

.dbb-cpicker.has-value .dbb-cpicker-text {
  color: var(--dbb-text);
}

.dbb-cpicker-arrow {
  font-size:  .85rem;
  color:      var(--dbb-text-dim);
  transition: transform var(--dbb-transition);
}

.dbb-cpicker.is-open .dbb-cpicker-arrow {
  transform: rotate(180deg);
  color:     var(--dbb-accent);
}

.dbb-cpicker-list {
  position:      absolute;
  top:           calc(100% + 4px);
  left:          0;
  right:         0;
  background:    var(--dbb-surface-2);
  border:        1px solid var(--dbb-accent);
  border-radius: var(--dbb-radius);
  z-index:       9999;
  list-style:    none;
  margin:        0;
  padding:       4px 0;
  max-height:    260px;
  overflow-y:    auto;
  box-shadow:    0 8px 24px rgba(0,0,0,.35);
}

.dbb-cpicker-option {
  display:     flex;
  align-items: center;
  gap:         10px;
  padding:     9px 14px;
  cursor:      pointer;
  transition:  background var(--dbb-transition);
}

.dbb-cpicker-option:hover:not(.is-disabled) {
  background: rgba(255,255,255,.06);
}

.dbb-cpicker-option.is-disabled {
  opacity: .35;
  cursor:  not-allowed;
}

.dbb-cpicker-opt-swatch {
  width:         20px;
  height:        20px;
  border-radius: 3px;
  flex-shrink:   0;
  display:       block;
  border:        1px solid rgba(255,255,255,.1);
}

.dbb-cpicker-opt-name {
  font-size:   .82rem;
  color:       var(--dbb-text);
  font-family: var(--dbb-font-mono);
}

.dbb-cpicker-upcharge {
  font-size:  .7rem;
  color:      var(--dbb-accent);
  margin-left: 6px;
}

/* ── Responsive ────────────────────────────────────────────────────────────── */
@media (max-width: 620px) {
  .dbb-color-body {
    flex-direction: column;
  }
  #dbb-sample-svg {
    width: 100%;
  }
  .dbb-color-row {
    flex-direction: column;
    align-items:    flex-start;
    gap:            6px;
  }
  .dbb-color-row-label {
    width: auto;
  }
}


/* ── Virtual Scrolling Logo Picker ──────────────────────────────────────────── */
.dbb-vp {
  position: relative;
  width:    100%;
}

.dbb-vp-display {
  display:        flex;
  align-items:    center;
  justify-content: space-between;
  padding:        10px 14px;
  background:     var(--dbb-surface-2);
  border:         1px solid var(--dbb-border);
  border-radius:  var(--dbb-radius);
  cursor:         pointer;
  user-select:    none;
  min-height:     72px;
  padding:        0px 14px 0px 6px;
  transition:     border-color var(--dbb-transition), box-shadow var(--dbb-transition);
  outline:        none;
}

.dbb-vp-display:hover,
.dbb-vp.is-open .dbb-vp-display {
  border-color: var(--dbb-accent);
  box-shadow:   0 0 0 2px rgba(232,255,0,.12);
}

.dbb-vp-text {
  font-size:   .85rem;
  color:       var(--dbb-text-dim);
  font-family: var(--dbb-font-mono);
  flex:        1;
  overflow:    hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dbb-vp-display.has-value .dbb-vp-text,
.dbb-vp-display.has-value + * .dbb-vp-text {
  color: var(--dbb-text);
}

.dbb-vp .dbb-vp-display.has-value .dbb-vp-text { color: var(--dbb-text); }

.dbb-vp-arrow {
  color:      var(--dbb-text-dim);
  font-size:  .85rem;
  flex-shrink: 0;
  transition: transform var(--dbb-transition);
  margin-left: 8px;
}
.dbb-vp.is-open .dbb-vp-arrow { transform: rotate(180deg); color: var(--dbb-accent); }

/* Panel — appended to body and absolutely positioned via JS page coords */
.dbb-vp-panel {
  position:      absolute;
  background:    #1e1e2e;
  border:        1px solid var(--dbb-accent);
  border-radius: var(--dbb-radius);
  z-index:       99999;
  box-shadow:    0 8px 28px rgba(0,0,0,.75);
  overflow:      hidden;
}

/* Ensure child elements also have solid backgrounds */
.dbb-vp-search {
  background: #16161f !important;
}

.dbb-vp-scroller {
  background: #1e1e2e;
}

.dbb-vp-row {
  background: #1e1e2e;
}

.dbb-vp-row:hover    { background: #2a2a3e; }
.dbb-vp-row.is-selected { background: rgba(232,255,0,.08); }

/* Search */
.dbb-vp-search {
  display:    block;
  width:      100%;
  padding:    10px 14px;
  background: var(--dbb-surface);
  border:     none;
  border-bottom: 1px solid var(--dbb-border);
  color:      var(--dbb-text);
  font-size:  .85rem;
  font-family: var(--dbb-font-mono);
  outline:    none;
  box-sizing: border-box;
}
.dbb-vp-search::placeholder { color: var(--dbb-text-dim); }
.dbb-vp-search:focus { border-bottom-color: var(--dbb-accent); }

/* Scroller */
.dbb-vp-scroller {
  position:   relative;
  overflow-y: auto;
  overflow-x: hidden;
}

.dbb-vp-spacer { width: 1px; }

/* Rows container — absolutely positioned for virtual scroll */
.dbb-vp-rows {
  position: absolute;
  left:     0;
  right:    0;
  top:      0;
}

.dbb-vp-row {
  height:      40px;
  line-height: 40px;
  padding:     0 14px;
  font-size:   .85rem;
  font-family: var(--dbb-font-mono);
  color:       var(--dbb-text);
  cursor:      pointer;
  white-space: nowrap;
  overflow:    hidden;
  text-overflow: ellipsis;
  transition:  background .1s;
}
.dbb-vp-row:hover    { background: rgba(255,255,255,.07); }
.dbb-vp-row.is-selected { color: var(--dbb-accent); background: rgba(232,255,0,.06); }

.dbb-vp-noresults {
  padding:    16px 14px;
  font-size:  .8rem;
  color:      var(--dbb-text-dim);
  font-family: var(--dbb-font-mono);
  text-align: center;
}


/* ── Virtual picker thumbnails ──────────────────────────────────────────────── */
.dbb-vp-row {
  display:     flex;
  align-items: center;
  gap:         10px;
}

.dbb-vp-thumb {
  width:          72px;
  height:         72px;
  object-fit:     contain;
  flex-shrink:    0;
  border-radius:  3px;
  background:     none;
  padding:        6px;
  pointer-events: none;
}

.dbb-vp-thumb--selected {
  width:        72px !important;
  height:       72px !important;
  margin-right: 8px;
  padding:      4px;
  flex-shrink:  0;
}

.dbb-vp-thumb-placeholder {
  width:        72px;
  height:       72px;
  flex-shrink:  0;
  border-radius: 3px;
  background:   none;
}

.dbb-vp-name {
  flex:          1;
  overflow:      hidden;
  text-overflow: ellipsis;
  white-space:   nowrap;
}

/* Display bar with thumbnail */
.dbb-vp-text {
  display:     flex;
  align-items: center;
  gap:         8px;
  flex:        1;
  overflow:    hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dbb-cpicker-incompat {
  font-size:   .7rem;
  color:       #888;
  font-style:  italic;
  margin-left: 4px;
}

.dbb-cpicker-option.is-disabled .dbb-cpicker-incompat {
  color: #666;
}

/* ── Canvas loading placeholder ─────────────────────────────────────────────── */
@keyframes dbb-pulse {
  0%, 100% { opacity: .35; }
  50%       { opacity: .7; }
}

.dbb-canvas-loading {
  border-radius:    4px;
  background:       linear-gradient(90deg, rgba(255,255,255,.08) 0%, rgba(255,255,255,.18) 50%, rgba(255,255,255,.08) 100%);
  background-size:  200% 100%;
  animation:        dbb-shimmer 1.4s ease infinite;
}

@keyframes dbb-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ── 4-Step Layout ──────────────────────────────────────────────────────────── */
.dbb-step {
  border:        1px solid var(--dbb-border);
  border-radius: var(--dbb-radius);
  margin-bottom: 16px;
  background:    var(--dbb-surface);
  transition:    opacity .3s ease, filter .3s ease;
  overflow:      visible;
}

.dbb-step--locked {
  opacity:        .45;
  pointer-events: none;
  user-select:    none;
  filter:         grayscale(30%);
}

.dbb-step-header {
  display:     flex;
  align-items: center;
  gap:         16px;
  padding:     16px 24px;
  border-bottom: 1px solid var(--dbb-border);
}

.dbb-step--locked .dbb-step-header { border-bottom-color: transparent; }

.dbb-step-number {
  width:           36px;
  height:          36px;
  border-radius:   50%;
  background:      var(--dbb-accent);
  color:           #000;
  font-family:     var(--dbb-font-head);
  font-size:       1.1rem;
  font-weight:     800;
  display:         flex;
  align-items:     center;
  justify-content: center;
  flex-shrink:     0;
}

.dbb-step--locked .dbb-step-number {
  background: var(--dbb-border);
  color:      var(--dbb-text-dim);
}

.dbb-step-title-wrap { flex: 1; }

.dbb-step-title {
  font-family:    var(--dbb-font-head) !important;
  font-size:      1.35rem !important;
  font-weight:    800 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  color:          var(--dbb-text) !important;
  margin:         0 0 2px !important;
}

.dbb-step-subtitle {
  font-size:  .8rem;
  color:      var(--dbb-text-dim);
  margin:     0;
}

.dbb-step-body {
  padding: 20px 24px;
}

/* Step 1 — color set select */
.dbb-set-select-wrap { max-width: 480px; }

.dbb-set-select {
  width:        100%;
  padding:      12px 16px;
  background:   var(--dbb-surface-2);
  border:       1px solid var(--dbb-border);
  border-radius: var(--dbb-radius);
  color:        #e0e0e0;
  font-family:  var(--dbb-font-head);
  font-size:    .95rem;
  cursor:       pointer;
  outline:      none;
  transition:   border-color var(--dbb-transition);
  appearance:   none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23999' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 40px;
}

.dbb-set-select option {
  background: #1e1e2e;
  color:      #e0e0e0;
}

.dbb-set-select option[value=""] {
  color: #888;
}

.dbb-set-select:focus { border-color: var(--dbb-accent); }

/* Step 4 price display */
.dbb-step4-price {
  margin-bottom: 16px;
  font-family:   var(--dbb-font-head);
}

.dbb-step4-total {
  font-size:    1.3rem;
  font-weight:  700;
  color:        var(--dbb-accent);
  letter-spacing: .05em;
}

/* Remove old dbb-color-wrap border since it's now inside step */
#dbb-step-2 .dbb-color-body {
  padding-top: 0;
}

/* ── Step 1 Custom Set Picker ───────────────────────────────────────────────── */
.dbb-set-picker {
  position:   relative;
  max-width:  480px;
}

.dbb-set-display {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  padding:         10px 14px;
  background:      var(--dbb-surface-2);
  border:          1px solid var(--dbb-border);
  border-radius:   var(--dbb-radius);
  cursor:          pointer;
  user-select:     none;
  min-height:      48px;
  transition:      border-color var(--dbb-transition), box-shadow var(--dbb-transition);
  outline:         none;
}

.dbb-set-display:hover,
.dbb-set-picker.is-open .dbb-set-display {
  border-color: var(--dbb-accent);
  box-shadow:   0 0 0 2px rgba(232,255,0,.12);
}

.dbb-set-text {
  font-size:   .85rem;
  color:       var(--dbb-text-dim);
  font-family: var(--dbb-font-mono);
  flex:        1;
  overflow:    hidden;
  text-overflow: ellipsis;
  white-space:   nowrap;
}

.dbb-set-display.has-value .dbb-set-text { color: var(--dbb-text); }

.dbb-set-arrow {
  color:       var(--dbb-text-dim);
  font-size:   .85rem;
  flex-shrink: 0;
  transition:  transform var(--dbb-transition);
  margin-left: 8px;
}
.dbb-set-picker.is-open .dbb-set-arrow { transform: rotate(180deg); color: var(--dbb-accent); }

.dbb-set-panel {
  position:      absolute;
  top:           calc(100% + 4px);
  left:          0;
  right:         0;
  background:    #1e1e2e;
  border:        1px solid var(--dbb-accent);
  border-radius: var(--dbb-radius);
  z-index:       99999;
  box-shadow:    0 8px 28px rgba(0,0,0,.6);
  overflow:      hidden;
}

.dbb-set-option {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  padding:         14px 16px;
  cursor:          pointer;
  color:           #e0e0e0;
  font-family:     var(--dbb-font-mono);
  font-size:       .85rem;
  transition:      background .15s;
  border-bottom:   1px solid rgba(255,255,255,.06);
}

.dbb-set-option:last-child { border-bottom: none; }
.dbb-set-option:hover      { background: rgba(255,255,255,.07); }
.dbb-set-option.is-selected { color: var(--dbb-accent); background: rgba(232,255,0,.06); }

.dbb-set-option-price {
  font-size:   .9rem;
  font-weight: 700;
  color:       var(--dbb-accent);
  flex-shrink: 0;
  margin-left: 12px;
}

.dbb-set-option.is-selected .dbb-set-option-price { color: var(--dbb-accent); }




/* ── Order Summary ── */
.dbb-order-summary {
  border:        1px solid var(--dbb-border);
  border-radius: var(--dbb-radius);
  background:    var(--dbb-surface);
  margin-top:    16px;
}
.dbb-sum--empty { opacity: .5; }
.dbb-sum-header {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  padding:         12px 20px;
  background:      var(--dbb-surface-2);
  border-bottom:   1px solid var(--dbb-border);
}
.dbb-sum-title {
  font-family:    var(--dbb-font-head);
  font-size:      .8rem;
  font-weight:    800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color:          var(--dbb-accent);
}
.dbb-sum-status {
  font-size:   .75rem;
  color:       var(--dbb-text-dim);
  font-family: var(--dbb-font-mono);
}
.dbb-sum-section {
  padding:       12px 20px;
  border-bottom: 1px solid var(--dbb-border);
}
.dbb-sum-section-label {
  font-size:      .65rem;
  font-weight:    700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color:          var(--dbb-text-dim);
  margin-bottom:  8px;
}
.dbb-sum-footer {
  display:         flex;
  justify-content: space-between;
  align-items:     center;
  padding:         14px 20px;
  background:      #0e0e1a;
}
.dbb-sum-total-label {
  font-family:    var(--dbb-font-head);
  font-size:      .75rem;
  font-weight:    700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color:          var(--dbb-text-dim);
}
.dbb-sum-total-val {
  font-family: var(--dbb-font-mono);
  font-size:   1.2rem;
  font-weight: 800;
  color:       var(--dbb-accent);
}
.dbb-sum-empty { font-size:.8rem; color:#3a3a4e; font-style:italic; }
.dbb-sum-set-badge { display:inline-flex; align-items:center; gap:8px; background:var(--dbb-surface-2); border:1px solid var(--dbb-border); border-radius:var(--dbb-radius); padding:6px 12px; }
.dbb-sum-set-dot { width:8px; height:8px; border-radius:50%; background:var(--dbb-accent); flex-shrink:0; }
.dbb-sum-set-name { font-size:.82rem; color:var(--dbb-text); }
.dbb-sum-set-price { font-size:.82rem; font-weight:700; color:var(--dbb-accent); margin-left:4px; }
.dbb-sum-color-row { display:flex; align-items:center; gap:10px; margin-bottom:7px; }
.dbb-sum-color-row:last-child { margin-bottom:0; }
.dbb-sum-swatch { width:18px; height:18px; border-radius:3px; flex-shrink:0; border:1px solid rgba(255,255,255,.1); }
.dbb-sum-color-label { font-size:.75rem; color:var(--dbb-text-dim); width:90px; flex-shrink:0; }
.dbb-sum-color-name { flex:1; font-size:.82rem; color:var(--dbb-text); font-family:var(--dbb-font-mono); }
.dbb-sum-logo-row { display:flex; align-items:center; gap:10px; margin-bottom:7px; }
.dbb-sum-logo-row:last-child { margin-bottom:0; }
.dbb-sum-logo-empty { opacity:.35; }
.dbb-sum-logo-num { font-size:.72rem; color:var(--dbb-text-dim); width:14px; flex-shrink:0; font-weight:700; }
.dbb-sum-logo-thumb { width:88px; height:56px; background:var(--dbb-surface-2); border:1px solid var(--dbb-border); border-radius:3px; flex-shrink:0; overflow:hidden; }
.dbb-sum-logo-thumb.filled { border-color:rgba(232,255,0,.3); background:rgba(232,255,0,.06); }
.dbb-sum-logo-info { flex:1; min-width:0; }
.dbb-sum-logo-name { display:block; font-size:.82rem; color:var(--dbb-text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; font-family:var(--dbb-font-mono); }
.dbb-sum-logo-size { font-size:.72rem; color:var(--dbb-text-dim); }
.dbb-sum-check { width:16px; height:16px; border-radius:50%; background:var(--dbb-accent); color:#000; font-size:.6rem; font-weight:700; display:flex; align-items:center; justify-content:center; flex-shrink:0; }

.dbb-sum-logo-partial { opacity: .7; }

/* ── Start Over button + Modal ──────────────────────────────────────────────── */
.dbb-sum-footer {
  padding:    12px 20px;
  background: var(--dbb-surface-2);
  border-top: 1px solid var(--dbb-border);
  display:    flex;
  justify-content: flex-end;
}

.dbb-start-over-btn {
  background:     transparent;
  border:         1px solid var(--dbb-border);
  border-radius:  var(--dbb-radius);
  color:          var(--dbb-text-dim);
  font-family:    var(--dbb-font-head);
  font-size:      1rem;
  font-weight:    700;
  letter-spacing: .06em;
  padding:        10px 24px;
  cursor:         pointer;
  transition:     all var(--dbb-transition);
}
.dbb-start-over-btn:hover { border-color: #e00; color: #e00; }

.dbb-modal-backdrop {
  position:        fixed;
  inset:           0;
  background:      rgba(0,0,0,.65);
  z-index:         999999;
  display:         flex;
  align-items:     center;
  justify-content: center;
  padding:         20px;
  visibility:      hidden;
  pointer-events:  none;
}
.dbb-modal-backdrop.is-open { visibility: visible; pointer-events: all; }

.dbb-modal {
  background:    #1a1a2e;
  border:        1px solid var(--dbb-border);
  border-radius: var(--dbb-radius);
  padding:       28px 32px;
  max-width:     380px;
  width:         100%;
  box-shadow:    0 20px 60px rgba(0,0,0,.6);
}
.dbb-modal-title {
  font-family:    var(--dbb-font-head);
  font-size:      1.15rem;
  font-weight:    800;
  letter-spacing: .06em;
  text-transform: uppercase;
  color:          var(--dbb-text);
  margin-bottom:  12px;
}
.dbb-modal-body { font-size:.88rem; color:var(--dbb-text-dim); line-height:1.6; margin-bottom:24px; }
.dbb-modal-actions { display:flex; gap:10px; justify-content:flex-end; }
.dbb-modal-cancel {
  background: transparent; border: 1px solid var(--dbb-border);
  border-radius: var(--dbb-radius); color: var(--dbb-text-dim);
  font-family: var(--dbb-font-head); font-size:.82rem; font-weight:700;
  padding: 8px 18px; cursor: pointer; transition: all var(--dbb-transition);
}
.dbb-modal-cancel:hover { border-color: var(--dbb-text-dim); color: var(--dbb-text); }
.dbb-modal-confirm {
  background: #cc0033; border: 1px solid #cc0033;
  border-radius: var(--dbb-radius); color: #fff;
  font-family: var(--dbb-font-head); font-size:.82rem; font-weight:700;
  padding: 8px 18px; cursor: pointer; transition: all var(--dbb-transition);
}
.dbb-modal-confirm:hover { background: #e00039; border-color: #e00039; }

@media (max-width: 600px) {
  #dbb-sample-svg-wrap { width: 100%; }
}

/* ── Qty controls disabled state during cart submission ─────────────────────── */
#dbb-qty:disabled,
#dbb-qty-down:disabled,
#dbb-qty-up:disabled {
  opacity:        0.4;
  pointer-events: none;
  cursor:         not-allowed;
}

/* ── Mobile: hide selected thumbnail in closed bar ─────────────────────────── */
@media (max-width: 600px) {
  #dbb-sample-svg-wrap { width: 100%; }
  .dbb-vp-thumb--selected {
    display: none !important;
  }
  .dbb-vp-display {
    min-height: 48px;
    padding:    10px 14px;
  }
}

/* ── Mobile landscape: constrain color preview and stack color body ─────────── */
@media (max-width: 860px) and (orientation: landscape) {
  #dbb-sample-svg-wrap {
    width: 240px;
  }
  .dbb-color-body {
    flex-wrap: wrap;
  }
  .dbb-color-preview-wrap {
    width: 100%;
  }
  #dbb-sample-svg-wrap {
    width: 100%;
    max-width: 300px;
  }
}
