/**
 * UBS Driveshaft Builder v1.3 — Frontend Styles
 * Brand: #1246ab primary · #c0392b red accent · #0f172a dark
 * Font:  Poppins (inherits from theme)
 *
 * All rules use !important and .ubs-dsb-wrap prefix to defeat Woodmart theme
 * button resets and layout interference. Every button shares a 5px radius.
 */

/* ==================================================================== //
   0. Layout escape — break out of flex/grid parent (Woodmart, etc.)
   ==================================================================== */
.dsb-flex-break {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  flex: 0 0 100% !important;
  grid-column: 1 / -1 !important;
  -ms-grid-column-span: 99 !important;
  order: -1 !important;
  margin: 0 0 24px !important;
  box-sizing: border-box !important;
}

.dsb-flex-break::before,
.dsb-flex-break::after {
  content: '' !important;
  display: table !important;
  clear: both !important;
}

.dsb-standalone-form {
  display: block !important;
  width: 100% !important;
  max-width: 960px !important;
  margin: 0 auto !important;
}

/* ==================================================================== //
   1. Design tokens + container
   ==================================================================== */
.ubs-dsb-wrap {
  --dsb-primary:     #1246ab;
  --dsb-primary-2:   #1853c8;
  --dsb-primary-d:   #0d337d;
  --dsb-primary-50:  #eaf0fc;
  --dsb-primary-100: #cfdcf6;
  --dsb-red:         #c0392b;
  --dsb-red-d:       #992d22;
  --dsb-red-50:      #fdecea;
  --dsb-dark:        #0f172a;
  --dsb-dark-2:      #1e293b;
  --dsb-muted:       #64748b;
  --dsb-border:      #e2e8f0;
  --dsb-border-2:    #cbd5e1;
  --dsb-bg:          #f8fafc;
  --dsb-bg-2:        #f1f5f9;
  --dsb-white:       #ffffff;
  --dsb-success:     #16a34a;
  --dsb-r:           5px;
  --dsb-r-lg:        10px;
  --dsb-shadow-sm:   0 1px 2px rgba(15, 23, 42, 0.05);
  --dsb-shadow:      0 4px 16px rgba(15, 23, 42, 0.08);
  --dsb-shadow-lg:   0 12px 32px rgba(18, 70, 171, 0.18);
  --dsb-t:           180ms cubic-bezier(.4, 0, .2, 1);

  font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
  color: var(--dsb-dark) !important;
  box-sizing: border-box !important;
  display: block !important;
  width: 100% !important;
  max-width: 960px !important;
  margin: 0 auto 28px !important;
  background: var(--dsb-white) !important;
  border: 1px solid var(--dsb-border) !important;
  border-radius: var(--dsb-r-lg) !important;
  overflow: hidden !important;
  box-shadow: var(--dsb-shadow) !important;
  position: relative !important;
}

.ubs-dsb-wrap *,
.ubs-dsb-wrap *::before,
.ubs-dsb-wrap *::after {
  box-sizing: border-box !important;
}

.ubs-dsb-wrap [hidden] {
  display: none !important;
}

/* ==================================================================== //
   2. Hero
   ==================================================================== */
.ubs-dsb-wrap .dsb-hero {
  background: var(--dsb-primary) !important;
  background-image: none !important;
  color: #fff !important;
  padding: 0 !important;
  border-radius: 0 !important;
}

.ubs-dsb-wrap .dsb-hero-inner {
  display: flex !important;
  align-items: center !important;
  gap: 18px !important;
  padding: 26px 32px !important;
  flex-wrap: wrap !important;
}

.ubs-dsb-wrap .dsb-hero-logo {
  width: 44px !important;
  height: 44px !important;
  flex: 0 0 44px !important;
  border-radius: 50% !important;
  background: rgba(255, 255, 255, 0.15) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #fff !important;
}

.ubs-dsb-wrap .dsb-hero-logo svg {
  width: 22px !important;
  height: 22px !important;
  display: block !important;
}

.ubs-dsb-wrap .dsb-hero-text {
  flex: 1 1 260px !important;
  min-width: 0 !important;
}

.ubs-dsb-wrap .dsb-hero-title {
  margin: 0 0 4px !important;
  font-size: 24px !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
  color: #fff !important;
  letter-spacing: -0.01em !important;
}

.ubs-dsb-wrap .dsb-hero-sub {
  margin: 0 !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
  color: rgba(255, 255, 255, 0.82) !important;
}

.ubs-dsb-wrap .dsb-hero-price {
  background: rgba(255, 255, 255, 0.12) !important;
  border: 1px solid rgba(255, 255, 255, 0.25) !important;
  border-radius: var(--dsb-r) !important;
  padding: 10px 16px !important;
  min-width: 150px !important;
  text-align: right !important;
}

.ubs-dsb-wrap .dsb-hero-price-label {
  display: block !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: rgba(255, 255, 255, 0.72) !important;
  margin-bottom: 2px !important;
}

.ubs-dsb-wrap .dsb-hero-price-value {
  display: block !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  color: #fff !important;
  line-height: 1.1 !important;
}

/* ==================================================================== //
   3. Breadcrumb
   ==================================================================== */
.ubs-dsb-wrap .dsb-crumbs {
  display: flex !important;
  align-items: stretch !important;
  gap: 6px !important;
  padding: 16px 22px !important;
  background: var(--dsb-bg) !important;
  border-bottom: 1px solid var(--dsb-border) !important;
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch !important;
}

.ubs-dsb-wrap .dsb-crumb {
  flex: 1 1 0 !important;
  min-width: 120px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 10px 12px !important;
  background: var(--dsb-white) !important;
  border: 1px solid var(--dsb-border) !important;
  border-radius: var(--dsb-r) !important;
  color: var(--dsb-muted) !important;
  font-family: 'Poppins', inherit !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
  cursor: default !important;
  transition: all var(--dsb-t) !important;
  position: relative !important;
  white-space: nowrap !important;
  text-align: left !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  box-shadow: none !important;
  min-height: 0 !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}

.ubs-dsb-wrap .dsb-crumb[disabled] {
  opacity: 0.7 !important;
  cursor: not-allowed !important;
}

.ubs-dsb-wrap .dsb-crumb.active {
  background: var(--dsb-primary) !important;
  border-color: var(--dsb-primary) !important;
  color: #fff !important;
  box-shadow: 0 2px 6px rgba(18, 70, 171, 0.25) !important;
  opacity: 1 !important;
}

.ubs-dsb-wrap .dsb-crumb.completed {
  background: var(--dsb-primary-50) !important;
  border-color: var(--dsb-primary-100) !important;
  color: var(--dsb-primary-d) !important;
  cursor: pointer !important;
  opacity: 1 !important;
}

.ubs-dsb-wrap .dsb-crumb.completed:hover {
  background: var(--dsb-primary-100) !important;
}

.ubs-dsb-wrap .dsb-crumb-num {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 22px !important;
  height: 22px !important;
  border-radius: 50% !important;
  background: var(--dsb-bg-2) !important;
  color: var(--dsb-muted) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  flex: 0 0 22px !important;
}

.ubs-dsb-wrap .dsb-crumb.active .dsb-crumb-num {
  background: rgba(255, 255, 255, 0.22) !important;
  color: #fff !important;
}

.ubs-dsb-wrap .dsb-crumb.completed .dsb-crumb-num {
  background: var(--dsb-primary) !important;
  color: #fff !important;
}

.ubs-dsb-wrap .dsb-crumb-col {
  display: flex !important;
  flex-direction: column !important;
  min-width: 0 !important;
  flex: 1 1 auto !important;
  overflow: hidden !important;
}

.ubs-dsb-wrap .dsb-crumb-label {
  font-size: 12px !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.ubs-dsb-wrap .dsb-crumb-value {
  font-size: 10px !important;
  font-weight: 500 !important;
  line-height: 1.2 !important;
  margin-top: 1px !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  opacity: 0.9 !important;
}

.ubs-dsb-wrap .dsb-crumb-value.empty {
  font-style: italic !important;
  opacity: 0.55 !important;
}

.ubs-dsb-wrap .dsb-crumb-sep {
  display: none !important;
}

/* ==================================================================== //
   4. Stage / Steps
   ==================================================================== */
.ubs-dsb-wrap .dsb-stage {
  padding: 28px 32px !important;
  background: var(--dsb-white) !important;
  min-height: 320px !important;
}

.ubs-dsb-wrap .dsb-step {
  display: none !important;
  animation: dsb-fade 260ms ease !important;
}

.ubs-dsb-wrap .dsb-step.dsb-step--active {
  display: block !important;
}

@keyframes dsb-fade {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.ubs-dsb-wrap .dsb-step-head {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 14px !important;
  margin-bottom: 18px !important;
  flex-wrap: wrap !important;
}

.ubs-dsb-wrap .dsb-step-head > div {
  flex: 1 1 260px !important;
  min-width: 0 !important;
}

.ubs-dsb-wrap .dsb-step-title {
  margin: 0 0 4px !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--dsb-dark) !important;
  line-height: 1.2 !important;
}

.ubs-dsb-wrap .dsb-step-desc {
  margin: 0 !important;
  font-size: 13px !important;
  color: var(--dsb-muted) !important;
  line-height: 1.45 !important;
}

.ubs-dsb-wrap .dsb-step-foot {
  display: flex !important;
  justify-content: flex-end !important;
  gap: 10px !important;
  margin-top: 22px !important;
  padding-top: 18px !important;
  border-top: 1px solid var(--dsb-border) !important;
  flex-wrap: wrap !important;
}

/* ==================================================================== //
   5. Search + Filter
   ==================================================================== */
.ubs-dsb-wrap .dsb-search {
  position: relative !important;
  margin-bottom: 14px !important;
}

.ubs-dsb-wrap .dsb-search input[type="search"],
.ubs-dsb-wrap #dsb-series-search {
  width: 100% !important;
  height: 44px !important;
  padding: 0 42px 0 42px !important;
  font-size: 14px !important;
  font-family: 'Poppins', inherit !important;
  color: var(--dsb-dark) !important;
  background: var(--dsb-white) !important;
  border: 1px solid var(--dsb-border-2) !important;
  border-radius: var(--dsb-r) !important;
  outline: none !important;
  transition: border-color var(--dsb-t), box-shadow var(--dsb-t) !important;
  box-shadow: none !important;
  line-height: 44px !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  margin: 0 !important;
  max-width: 100% !important;
}

.ubs-dsb-wrap #dsb-series-search:focus {
  border-color: var(--dsb-primary) !important;
  box-shadow: 0 0 0 3px rgba(18, 70, 171, 0.12) !important;
}

.ubs-dsb-wrap #dsb-series-search::placeholder {
  color: #94a3b8 !important;
}

.ubs-dsb-wrap #dsb-series-search::-webkit-search-decoration,
.ubs-dsb-wrap #dsb-series-search::-webkit-search-cancel-button {
  -webkit-appearance: none !important;
  display: none !important;
}

.ubs-dsb-wrap .dsb-search-icon {
  position: absolute !important;
  left: 14px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 16px !important;
  height: 16px !important;
  pointer-events: none !important;
  color: var(--dsb-muted) !important;
  display: block !important;
}

.ubs-dsb-wrap .dsb-search-clear {
  position: absolute !important;
  right: 10px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 26px !important;
  height: 26px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  margin: 0 !important;
  background: var(--dsb-bg-2) !important;
  color: var(--dsb-muted) !important;
  border: none !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  font-family: 'Poppins', inherit !important;
  transition: all var(--dsb-t) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  box-shadow: none !important;
  min-width: 0 !important;
  min-height: 0 !important;
  line-height: 1 !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}

.ubs-dsb-wrap .dsb-search-clear svg {
  width: 12px !important;
  height: 12px !important;
  display: block !important;
}

.ubs-dsb-wrap .dsb-search-clear:hover {
  background: var(--dsb-dark) !important;
  color: #fff !important;
}

.ubs-dsb-wrap .dsb-filter-bar {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 14px !important;
  flex-wrap: wrap !important;
}

.ubs-dsb-wrap .dsb-filter-label {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--dsb-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
}

.ubs-dsb-wrap .dsb-filter-pills {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
}

.ubs-dsb-wrap .dsb-pill {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 7px 14px !important;
  background: var(--dsb-white) !important;
  border: 1px solid var(--dsb-border-2) !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--dsb-dark-2) !important;
  cursor: pointer !important;
  font-family: 'Poppins', inherit !important;
  transition: all var(--dsb-t) !important;
  line-height: 1.2 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  box-shadow: none !important;
  min-height: 0 !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}

.ubs-dsb-wrap .dsb-pill:hover {
  border-color: var(--dsb-primary) !important;
  color: var(--dsb-primary) !important;
}

.ubs-dsb-wrap .dsb-pill.active {
  background: var(--dsb-primary) !important;
  border-color: var(--dsb-primary) !important;
  color: #fff !important;
}

.ubs-dsb-wrap .dsb-result-count {
  font-size: 12px !important;
  color: var(--dsb-muted) !important;
  margin: 0 0 12px !important;
  font-weight: 500 !important;
}

.ubs-dsb-wrap .dsb-note {
  padding: 10px 14px !important;
  background: #fffbeb !important;
  border: 1px solid #fde68a !important;
  border-left-width: 3px !important;
  border-radius: var(--dsb-r) !important;
  font-size: 12px !important;
  color: #78350f !important;
  margin-bottom: 14px !important;
}

/* ==================================================================== //
   6. Cards (duty / series / combo)
   ==================================================================== */
.ubs-dsb-wrap .dsb-cards {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)) !important;
  gap: 14px !important;
}

.ubs-dsb-wrap .dsb-cards--duty {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
  gap: 16px !important;
}

.ubs-dsb-wrap .dsb-card {
  position: relative !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  padding: 18px !important;
  background: var(--dsb-white) !important;
  border: 1px solid var(--dsb-border) !important;
  border-radius: var(--dsb-r) !important;
  cursor: pointer !important;
  text-align: left !important;
  font-family: 'Poppins', inherit !important;
  color: var(--dsb-dark) !important;
  transition: all var(--dsb-t) !important;
  overflow: hidden !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  box-shadow: var(--dsb-shadow-sm) !important;
  min-height: 0 !important;
  width: 100% !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}

.ubs-dsb-wrap .dsb-card::before {
  content: '' !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 3px !important;
  background: transparent !important;
  transition: background var(--dsb-t) !important;
}

.ubs-dsb-wrap .dsb-card:hover {
  border-color: var(--dsb-primary) !important;
  transform: translateY(-2px) !important;
  box-shadow: var(--dsb-shadow) !important;
  color: var(--dsb-dark) !important;
}

.ubs-dsb-wrap .dsb-card:hover::before {
  background: var(--dsb-primary) !important;
}

.ubs-dsb-wrap .dsb-card.selected,
.ubs-dsb-wrap .dsb-card.is-selected {
  border-color: var(--dsb-primary) !important;
  background: var(--dsb-primary-50) !important;
  box-shadow: 0 0 0 2px var(--dsb-primary) inset, var(--dsb-shadow) !important;
}

.ubs-dsb-wrap .dsb-card-visual {
  width: 44px !important;
  height: 44px !important;
  flex: 0 0 44px !important;
  border-radius: var(--dsb-r) !important;
  background: var(--dsb-primary-50) !important;
  color: var(--dsb-primary) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.ubs-dsb-wrap .dsb-card-visual svg {
  width: 22px !important;
  height: 22px !important;
  display: block !important;
}

.ubs-dsb-wrap .dsb-card--heavy .dsb-card-visual {
  background: var(--dsb-red-50) !important;
  color: var(--dsb-red) !important;
}

.ubs-dsb-wrap .dsb-card-content {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}

.ubs-dsb-wrap .dsb-card-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
}

.ubs-dsb-wrap .dsb-card-title {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--dsb-dark) !important;
  line-height: 1.2 !important;
  margin: 0 !important;
  display: block !important;
}

.ubs-dsb-wrap .dsb-card-desc {
  font-size: 12px !important;
  color: var(--dsb-muted) !important;
  line-height: 1.4 !important;
  margin: 0 !important;
  display: block !important;
}

.ubs-dsb-wrap .dsb-card-meta {
  font-size: 11px !important;
  color: var(--dsb-muted) !important;
  display: block !important;
  margin-top: 4px !important;
  font-weight: 500 !important;
}

.ubs-dsb-wrap .dsb-card-price {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--dsb-primary) !important;
  display: inline-block !important;
  margin-top: 4px !important;
}

.ubs-dsb-wrap .dsb-card-arrow {
  width: 20px !important;
  height: 20px !important;
  flex: 0 0 20px !important;
  color: var(--dsb-muted) !important;
  align-self: center !important;
  transition: transform var(--dsb-t), color var(--dsb-t) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.ubs-dsb-wrap .dsb-card-arrow svg {
  width: 16px !important;
  height: 16px !important;
  display: block !important;
}

.ubs-dsb-wrap .dsb-card:hover .dsb-card-arrow {
  color: var(--dsb-primary) !important;
  transform: translateX(3px) !important;
}

.ubs-dsb-wrap .dsb-badge {
  display: inline-flex !important;
  align-items: center !important;
  padding: 3px 8px !important;
  background: var(--dsb-bg-2) !important;
  color: var(--dsb-muted) !important;
  border-radius: 999px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  line-height: 1 !important;
}

.ubs-dsb-wrap .dsb-badge--light  { background: #dbeafe !important; color: #1e40af !important; }
.ubs-dsb-wrap .dsb-badge--medium { background: #fef3c7 !important; color: #92400e !important; }
.ubs-dsb-wrap .dsb-badge--heavy  { background: #fee2e2 !important; color: #991b1b !important; }

.ubs-dsb-wrap .dsb-empty {
  text-align: center !important;
  padding: 40px 20px !important;
  color: var(--dsb-muted) !important;
  font-size: 14px !important;
  background: var(--dsb-bg) !important;
  border: 1px dashed var(--dsb-border-2) !important;
  border-radius: var(--dsb-r) !important;
  grid-column: 1 / -1 !important;
  margin: 0 !important;
}

/* ==================================================================== //
   7. Buttons — universal reset to defeat Woodmart
   ==================================================================== */
.ubs-dsb-wrap .dsb-btn,
.ubs-dsb-wrap button.dsb-btn,
.ubs-dsb-wrap a.dsb-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 11px 20px !important;
  min-height: 42px !important;
  min-width: 0 !important;
  font-family: 'Poppins', inherit !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
  letter-spacing: 0.01em !important;
  text-transform: none !important;
  text-decoration: none !important;
  cursor: pointer !important;
  border: 1px solid transparent !important;
  border-radius: var(--dsb-r) !important;
  background: var(--dsb-white) !important;
  color: var(--dsb-dark) !important;
  transition: all var(--dsb-t) !important;
  box-shadow: none !important;
  outline: none !important;
  white-space: nowrap !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  margin: 0 !important;
}

.ubs-dsb-wrap .dsb-btn:focus-visible {
  box-shadow: 0 0 0 3px rgba(18, 70, 171, 0.22) !important;
}

.ubs-dsb-wrap .dsb-btn[disabled],
.ubs-dsb-wrap .dsb-btn:disabled {
  opacity: 0.5 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}

.ubs-dsb-wrap .dsb-btn svg {
  width: 14px !important;
  height: 14px !important;
  display: block !important;
  flex: 0 0 auto !important;
}

/* Secondary (back / start over) */
.ubs-dsb-wrap .dsb-btn.dsb-btn-secondary,
.ubs-dsb-wrap button.dsb-btn.dsb-btn-secondary {
  background: var(--dsb-white) !important;
  color: var(--dsb-dark-2) !important;
  border-color: var(--dsb-border-2) !important;
}

.ubs-dsb-wrap .dsb-btn.dsb-btn-secondary:hover {
  background: var(--dsb-bg) !important;
  border-color: var(--dsb-primary) !important;
  color: var(--dsb-primary) !important;
}

/* Primary (continue / next) */
.ubs-dsb-wrap .dsb-btn.dsb-btn-primary,
.ubs-dsb-wrap button.dsb-btn.dsb-btn-primary {
  background: var(--dsb-primary) !important;
  color: #fff !important;
  border-color: var(--dsb-primary) !important;
  box-shadow: 0 2px 6px rgba(18, 70, 171, 0.22) !important;
}

.ubs-dsb-wrap .dsb-btn.dsb-btn-primary:hover {
  background: var(--dsb-primary-2) !important;
  border-color: var(--dsb-primary-2) !important;
  color: #fff !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 12px rgba(18, 70, 171, 0.3) !important;
}

/* ==================================================================== //
   8. Fields (inputs / selects / textareas)
   ==================================================================== */
.ubs-dsb-wrap .dsb-fields {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
  gap: 16px !important;
  margin-bottom: 8px !important;
}

.ubs-dsb-wrap .dsb-fields--grid3 {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)) !important;
}

.ubs-dsb-wrap .dsb-field {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  margin: 0 !important;
}

.ubs-dsb-wrap .dsb-field--notes {
  margin-top: 16px !important;
}

.ubs-dsb-wrap .dsb-field-label {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--dsb-dark-2) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}

.ubs-dsb-wrap .dsb-req {
  color: var(--dsb-red) !important;
  font-weight: 700 !important;
}

.ubs-dsb-wrap .dsb-field .dsb-input,
.ubs-dsb-wrap input.dsb-input,
.ubs-dsb-wrap select.dsb-input,
.ubs-dsb-wrap textarea.dsb-input {
  width: 100% !important;
  height: 42px !important;
  padding: 0 14px !important;
  font-size: 14px !important;
  font-family: 'Poppins', inherit !important;
  color: var(--dsb-dark) !important;
  background: var(--dsb-white) !important;
  border: 1px solid var(--dsb-border-2) !important;
  border-radius: var(--dsb-r) !important;
  outline: none !important;
  transition: border-color var(--dsb-t), box-shadow var(--dsb-t) !important;
  box-shadow: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  line-height: 42px !important;
  min-height: 42px !important;
  margin: 0 !important;
  max-width: 100% !important;
}

.ubs-dsb-wrap textarea.dsb-input {
  height: auto !important;
  min-height: 90px !important;
  padding: 12px 14px !important;
  line-height: 1.5 !important;
  resize: vertical !important;
}

.ubs-dsb-wrap select.dsb-input {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path fill='%2364748b' d='M5.5 7l4.5 4.5L14.5 7z'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: right 10px center !important;
  padding-right: 34px !important;
}

.ubs-dsb-wrap .dsb-input:focus {
  border-color: var(--dsb-primary) !important;
  box-shadow: 0 0 0 3px rgba(18, 70, 171, 0.12) !important;
}

.ubs-dsb-wrap .dsb-input::placeholder {
  color: #94a3b8 !important;
}

.ubs-dsb-wrap .dsb-field-hint {
  font-size: 11px !important;
  color: var(--dsb-muted) !important;
  line-height: 1.4 !important;
  display: block !important;
}

/* ==================================================================== //
   9. Review
   ==================================================================== */
.ubs-dsb-wrap .dsb-review {
  background: var(--dsb-bg) !important;
  border: 1px solid var(--dsb-border) !important;
  border-radius: var(--dsb-r-lg) !important;
  padding: 26px !important;
}

.ubs-dsb-wrap .dsb-review-badge {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 42px !important;
  height: 42px !important;
  border-radius: 50% !important;
  background: var(--dsb-success) !important;
  color: #fff !important;
  margin-bottom: 12px !important;
}

.ubs-dsb-wrap .dsb-review-badge svg {
  width: 20px !important;
  height: 20px !important;
  display: block !important;
}

.ubs-dsb-wrap .dsb-review-title {
  margin: 0 0 4px !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--dsb-dark) !important;
  line-height: 1.2 !important;
}

.ubs-dsb-wrap .dsb-review-sub {
  margin: 0 0 18px !important;
  font-size: 13px !important;
  color: var(--dsb-muted) !important;
  line-height: 1.5 !important;
}

.ubs-dsb-wrap .dsb-review-list {
  display: block !important;
  margin: 0 0 18px !important;
  padding: 0 !important;
  background: var(--dsb-white) !important;
  border: 1px solid var(--dsb-border) !important;
  border-radius: var(--dsb-r) !important;
  overflow: hidden !important;
}

.ubs-dsb-wrap .dsb-review-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 14px !important;
  padding: 12px 16px !important;
  border-bottom: 1px solid var(--dsb-border) !important;
  font-size: 13px !important;
  margin: 0 !important;
}

.ubs-dsb-wrap .dsb-review-row:last-child {
  border-bottom: none !important;
}

.ubs-dsb-wrap .dsb-review-row dt {
  font-weight: 600 !important;
  color: var(--dsb-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  font-size: 11px !important;
  flex: 0 0 auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

.ubs-dsb-wrap .dsb-review-row dd {
  font-weight: 600 !important;
  color: var(--dsb-dark) !important;
  text-align: right !important;
  word-break: break-word !important;
  flex: 1 1 auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

.ubs-dsb-wrap .dsb-review-row--price {
  background: var(--dsb-primary-50) !important;
  border-top: 2px solid var(--dsb-primary) !important;
}

.ubs-dsb-wrap .dsb-review-row--price dt {
  color: var(--dsb-primary-d) !important;
  font-size: 12px !important;
}

.ubs-dsb-wrap .dsb-review-row--price dd {
  color: var(--dsb-primary-d) !important;
  font-size: 18px !important;
  font-weight: 800 !important;
}

.ubs-dsb-wrap .dsb-review-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  justify-content: flex-end !important;
  margin-top: 6px !important;
}

/* ==================================================================== //
   10. Cart footer (standalone qty + add to cart)
   ==================================================================== */
.ubs-dsb-wrap .dsb-cart-footer {
  padding: 20px 32px !important;
  background: var(--dsb-bg) !important;
  border-top: 1px solid var(--dsb-border) !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}

.ubs-dsb-wrap .dsb-cart-status {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 10px 14px !important;
  background: #fff7ed !important;
  border: 1px solid #fed7aa !important;
  border-radius: var(--dsb-r) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  color: #9a3412 !important;
}

.ubs-dsb-wrap .dsb-cart-status svg {
  width: 16px !important;
  height: 16px !important;
  flex: 0 0 16px !important;
}

.ubs-dsb-wrap .dsb-cart-status.ready {
  background: #ecfdf5 !important;
  border-color: #a7f3d0 !important;
  color: #065f46 !important;
}

.ubs-dsb-wrap .dsb-cart-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  flex-wrap: wrap !important;
}

.ubs-dsb-wrap .dsb-qty-wrap {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
}

.ubs-dsb-wrap .dsb-qty-label {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--dsb-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  margin: 0 !important;
}

.ubs-dsb-wrap .dsb-qty-control {
  display: inline-flex !important;
  align-items: stretch !important;
  border: 1px solid var(--dsb-border-2) !important;
  border-radius: var(--dsb-r) !important;
  overflow: hidden !important;
  background: var(--dsb-white) !important;
}

.ubs-dsb-wrap .dsb-qty-btn {
  width: 36px !important;
  height: 42px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--dsb-white) !important;
  color: var(--dsb-dark) !important;
  border: none !important;
  cursor: pointer !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  font-family: 'Poppins', inherit !important;
  transition: background var(--dsb-t) !important;
  padding: 0 !important;
  min-width: 0 !important;
  min-height: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  line-height: 1 !important;
}

.ubs-dsb-wrap .dsb-qty-btn:hover {
  background: var(--dsb-bg-2) !important;
  color: var(--dsb-primary) !important;
}

.ubs-dsb-wrap .dsb-qty-input {
  width: 52px !important;
  height: 42px !important;
  border: none !important;
  border-left: 1px solid var(--dsb-border) !important;
  border-right: 1px solid var(--dsb-border) !important;
  background: var(--dsb-white) !important;
  text-align: center !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--dsb-dark) !important;
  font-family: 'Poppins', inherit !important;
  outline: none !important;
  padding: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  line-height: 42px !important;
  -moz-appearance: textfield !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  margin: 0 !important;
}

.ubs-dsb-wrap .dsb-qty-input::-webkit-outer-spin-button,
.ubs-dsb-wrap .dsb-qty-input::-webkit-inner-spin-button {
  -webkit-appearance: none !important;
  margin: 0 !important;
}

.ubs-dsb-wrap .dsb-btn.dsb-add-btn,
.ubs-dsb-wrap button.dsb-btn.dsb-add-btn,
.ubs-dsb-wrap button[name="add-to-cart"].dsb-add-btn {
  min-height: 48px !important;
  padding: 13px 26px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  background: var(--dsb-red) !important;
  color: #fff !important;
  border: 1px solid var(--dsb-red) !important;
  border-radius: var(--dsb-r) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  box-shadow: 0 4px 12px rgba(192, 57, 43, 0.25) !important;
  gap: 10px !important;
}

.ubs-dsb-wrap .dsb-btn.dsb-add-btn:hover {
  background: var(--dsb-red-d) !important;
  border-color: var(--dsb-red-d) !important;
  color: #fff !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 18px rgba(192, 57, 43, 0.35) !important;
}

.ubs-dsb-wrap .dsb-btn.dsb-add-btn svg {
  width: 16px !important;
  height: 16px !important;
}

.ubs-dsb-wrap .dsb-btn.dsb-add-btn[disabled],
.ubs-dsb-wrap .dsb-btn.dsb-add-btn:disabled {
  opacity: 0.55 !important;
  cursor: not-allowed !important;
  background: #94a3b8 !important;
  border-color: #94a3b8 !important;
  box-shadow: none !important;
  transform: none !important;
  pointer-events: none !important;
}

.ubs-dsb-wrap .dsb-add-price {
  display: inline-block !important;
  padding: 3px 9px !important;
  background: rgba(255, 255, 255, 0.2) !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
}

/* ---------- AJAX states: loading / success / error ---------- */
.ubs-dsb-wrap .dsb-btn.dsb-add-btn {
  position: relative !important;
  overflow: hidden !important;
  transition: background 0.25s ease, border-color 0.25s ease, transform 0.15s ease !important;
}
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-loading,
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-success,
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-error {
  pointer-events: none !important;
}
/* Override the default [disabled] gray — keep the brand color while loading. */
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-loading,
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-loading[disabled],
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-loading:disabled {
  background: var(--dsb-red) !important;
  border-color: var(--dsb-red) !important;
  opacity: 0.92 !important;
  color: #ffffff !important;
}
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-success[disabled],
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-success:disabled {
  background: #16a34a !important;
  border-color: #16a34a !important;
  opacity: 1 !important;
  color: #ffffff !important;
}
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-loading > svg,
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-loading > span,
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-success > svg,
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-success > span {
  opacity: 0 !important;
  transform: translateY(4px) !important;
  transition: opacity 0.2s ease, transform 0.2s ease !important;
}
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-loading::after {
  content: "" !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 22px !important;
  height: 22px !important;
  margin: -11px 0 0 -11px !important;
  border: 2.5px solid rgba(255, 255, 255, 0.35) !important;
  border-top-color: #ffffff !important;
  border-radius: 50% !important;
  animation: dsb-spin 0.7s linear infinite !important;
  box-sizing: border-box !important;
}
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-success {
  background: #16a34a !important;
  border-color: #16a34a !important;
  opacity: 1 !important;
}
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-success::after {
  content: "" !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 22px !important;
  height: 11px !important;
  margin: -9px 0 0 -11px !important;
  border-left: 3px solid #ffffff !important;
  border-bottom: 3px solid #ffffff !important;
  transform: rotate(-45deg) !important;
  animation: dsb-check-pop 0.35s ease-out !important;
  box-sizing: border-box !important;
}
.ubs-dsb-wrap .dsb-btn.dsb-add-btn.dsb-error {
  background: #dc2626 !important;
  border-color: #dc2626 !important;
  animation: dsb-shake 0.4s ease !important;
}
@keyframes dsb-spin {
  to { transform: rotate(360deg); }
}
@keyframes dsb-check-pop {
  0%   { opacity: 0; transform: rotate(-45deg) scale(0.4); }
  60%  { opacity: 1; transform: rotate(-45deg) scale(1.12); }
  100% { opacity: 1; transform: rotate(-45deg) scale(1); }
}
@keyframes dsb-shake {
  0%, 100% { transform: translateX(0); }
  20%      { transform: translateX(-6px); }
  40%      { transform: translateX(6px); }
  60%      { transform: translateX(-4px); }
  80%      { transform: translateX(4px); }
}

/* ==================================================================== //
   11. Toast
   ==================================================================== */
.ubs-dsb-wrap .dsb-toast {
  position: fixed !important;
  left: 50% !important;
  bottom: 32px !important;
  transform: translateX(-50%) translateY(80px) !important;
  padding: 12px 22px !important;
  background: var(--dsb-dark) !important;
  color: #fff !important;
  border-radius: var(--dsb-r) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  font-family: 'Poppins', inherit !important;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.3) !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: all 240ms cubic-bezier(.4, 0, .2, 1) !important;
  z-index: 99999 !important;
}

.ubs-dsb-wrap .dsb-toast.show {
  transform: translateX(-50%) translateY(0) !important;
  opacity: 1 !important;
}

/* ==================================================================== //
   12. Responsive
   ==================================================================== */
@media (max-width: 780px) {
  .ubs-dsb-wrap .dsb-hero-inner {
    padding: 22px 20px !important;
    gap: 14px !important;
  }
  .ubs-dsb-wrap .dsb-hero-title { font-size: 21px !important; }
  .ubs-dsb-wrap .dsb-hero-price { text-align: left !important; width: 100% !important; }
  .ubs-dsb-wrap .dsb-crumbs { padding: 14px !important; }
  .ubs-dsb-wrap .dsb-crumb { min-width: 110px !important; padding: 8px 10px !important; font-size: 11px !important; }
  .ubs-dsb-wrap .dsb-stage { padding: 22px 18px !important; }
  .ubs-dsb-wrap .dsb-cards { grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)) !important; gap: 10px !important; }
  .ubs-dsb-wrap .dsb-card { padding: 14px !important; }
  .ubs-dsb-wrap .dsb-cart-footer { padding: 16px 18px !important; }
  .ubs-dsb-wrap .dsb-cart-row { flex-direction: column !important; align-items: stretch !important; }
  .ubs-dsb-wrap .dsb-fields { grid-template-columns: 1fr !important; gap: 12px !important; }
  .ubs-dsb-wrap .dsb-step-head { flex-direction: column !important; align-items: stretch !important; gap: 10px !important; margin-bottom: 14px !important; }
  .ubs-dsb-wrap .dsb-step-head > div { flex: 0 0 auto !important; flex-basis: auto !important; }
  .ubs-dsb-wrap .dsb-step-head .dsb-btn { align-self: flex-start !important; flex: 0 0 auto !important; }
  .ubs-dsb-wrap .dsb-stage { min-height: 0 !important; }
  .ubs-dsb-wrap .dsb-review { padding: 20px !important; }
}

/* =================================================================
   v1.4 — Tube length lock + Yoke add-ons
   ================================================================= */
.ubs-dsb-wrap .dsb-tube-lock {
  display: block !important;
  margin-top: 8px !important;
  padding: 8px 12px !important;
  background: #fef3c7 !important;
  border: 1px solid #fbbf24 !important;
  border-left: 3px solid #f59e0b !important;
  border-radius: 5px !important;
  color: #78350f !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
}
.ubs-dsb-wrap .dsb-tube-lock[hidden] { display: none !important; }

.ubs-dsb-wrap .dsb-addons {
  margin-top: 24px !important;
  padding: 20px 22px !important;
  background: #f8fafc !important;
  border: 1px solid #e2e8f0 !important;
  border-left: 3px solid #1246ab !important;
  border-radius: 8px !important;
  flex: 0 0 100% !important;
  grid-column: 1 / -1 !important;
}
.ubs-dsb-wrap .dsb-addons-title {
  margin: 0 0 4px !important;
  font-family: "Poppins", system-ui, sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: #0f172a !important;
}
.ubs-dsb-wrap .dsb-addons-desc {
  margin: 0 0 16px !important;
  font-size: 13px !important;
  color: #64748b !important;
  line-height: 1.5 !important;
}

.ubs-dsb-wrap .dsb-addon-card {
  background: #fff !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 8px !important;
  padding: 14px 16px !important;
  margin-bottom: 12px !important;
}
.ubs-dsb-wrap .dsb-addon-card:last-child { margin-bottom: 0 !important; }

.ubs-dsb-wrap .dsb-addon-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}
.ubs-dsb-wrap .dsb-addon-header strong {
  font-family: "Poppins", system-ui, sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #0f172a !important;
}
.ubs-dsb-wrap .dsb-addon-toggle {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  cursor: pointer !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  color: #1246ab !important;
}
.ubs-dsb-wrap .dsb-addon-toggle input[type="checkbox"] {
  width: 16px !important;
  height: 16px !important;
  accent-color: #1246ab !important;
  cursor: pointer !important;
}
.ubs-dsb-wrap .dsb-addon-body {
  margin-top: 12px !important;
  padding-top: 12px !important;
  border-top: 1px dashed #e2e8f0 !important;
}
.ubs-dsb-wrap .dsb-addon-body[hidden] { display: none !important; }

.ubs-dsb-wrap .dsb-addon-options {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}
.ubs-dsb-wrap .dsb-addon-option {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  padding: 12px 14px !important;
  background: #f8fafc !important;
  border: 2px solid #e2e8f0 !important;
  border-radius: 5px !important;
  cursor: pointer !important;
  transition: all 160ms ease !important;
}
.ubs-dsb-wrap .dsb-addon-option:hover {
  border-color: #1246ab !important;
  background: #eaf0fc !important;
}
.ubs-dsb-wrap .dsb-addon-option input[type="radio"] {
  margin-top: 3px !important;
  width: 16px !important;
  height: 16px !important;
  accent-color: #1246ab !important;
  cursor: pointer !important;
  flex-shrink: 0 !important;
}
.ubs-dsb-wrap .dsb-addon-option input[type="radio"]:checked ~ .dsb-addon-label {
  color: #1246ab !important;
}
.ubs-dsb-wrap .dsb-addon-option:has(input[type="radio"]:checked) {
  border-color: #1246ab !important;
  background: #eaf0fc !important;
}
.ubs-dsb-wrap .dsb-addon-label {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  flex: 1 !important;
}
.ubs-dsb-wrap .dsb-addon-label strong {
  font-size: 13.5px !important;
  font-weight: 600 !important;
  color: #0f172a !important;
}
.ubs-dsb-wrap .dsb-addon-pricerow {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
  font-size: 13px !important;
}
.ubs-dsb-wrap .dsb-addon-old {
  color: #94a3b8 !important;
  text-decoration: line-through !important;
  font-size: 12px !important;
}
.ubs-dsb-wrap .dsb-addon-old .woocommerce-Price-amount,
.ubs-dsb-wrap .dsb-addon-old bdi { color: inherit !important; }
.ubs-dsb-wrap .dsb-addon-new {
  color: #0f172a !important;
  font-weight: 700 !important;
}
.ubs-dsb-wrap .dsb-addon-new .woocommerce-Price-amount,
.ubs-dsb-wrap .dsb-addon-new bdi { color: #0f172a !important; }
.ubs-dsb-wrap .dsb-addon-save {
  display: inline-block !important;
  padding: 2px 8px !important;
  background: #dcfce7 !important;
  color: #166534 !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .02em !important;
}

@media (max-width: 480px) {
  .ubs-dsb-wrap .dsb-hero-title { font-size: 19px !important; }
  .ubs-dsb-wrap .dsb-hero-sub { font-size: 12px !important; }
  .ubs-dsb-wrap .dsb-crumb-label { display: none !important; }
  .ubs-dsb-wrap .dsb-crumb-value { display: none !important; }
  .ubs-dsb-wrap .dsb-crumb {
    min-width: 0 !important;
    flex: 0 0 auto !important;
    padding: 8px !important;
    justify-content: center !important;
  }
  .ubs-dsb-wrap .dsb-review-row { flex-direction: column !important; gap: 4px !important; }
  .ubs-dsb-wrap .dsb-review-row dd { text-align: left !important; }
  .ubs-dsb-wrap .dsb-review-actions { justify-content: stretch !important; }
  .ubs-dsb-wrap .dsb-review-actions .dsb-btn { flex: 1 1 auto !important; }
  .ubs-dsb-wrap .dsb-btn.dsb-add-btn { width: 100% !important; }
}
