/*
 * WholesaleWP — Bulk Order Form v2
 * Two themes (Catalog, Quick order) + three colour modes (Light, Dark, Match WP).
 * Shared chrome: header, cart pill, tabs.
 */

.wwp-bof,
.wwp-bof * {
  box-sizing: border-box;
}

/* ---------- Tokens (Light is default) ---------- */
.wwp-bof {
  --bof-bg:           #faf8f3;
  --bof-card:         #ffffff;
  --bof-soft:         #f3f1ec;
  --bof-softer:       #ebe9e3;
  --bof-text-1:       #1a1a1a;
  --bof-text-2:       #6b6b6b;
  --bof-text-3:       #a0a0a0;
  --bof-border:       rgba(0, 0, 0, 0.10);
  --bof-border-strong:rgba(0, 0, 0, 0.18);
  --bof-accent:       #E8412A;
  --bof-success-bg:   #e7f5ec;
  --bof-success-text: #1d6b3a;
  --bof-warning-bg:   #fdf2dd;
  --bof-warning-text: #8b6914;
  --bof-danger-bg:    #fce8e8;
  --bof-danger-text:  #a32d2d;
  --bof-radius-md:    8px;
  --bof-radius-lg:    12px;
  --bof-font-sans:    -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --bof-font-mono:    ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace;

  background: var(--bof-card);
  border: 0.5px solid var(--bof-border);
  border-radius: var(--bof-radius-lg);
  padding: 24px 28px 28px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.02);
  font-family: var(--bof-font-sans);
  color: var(--bof-text-1);
  font-size: 14px;
  line-height: 1.5;
  max-width: 920px;
  margin: 0 auto;
}

/* Dark colour mode */
.wwp-bof[data-colour="dark"] {
  --bof-bg:           #131311;
  --bof-card:         #1c1c1a;
  --bof-soft:         #232320;
  --bof-softer:       #2c2c28;
  --bof-text-1:       #f5f1e6;
  --bof-text-2:       #a8a39a;
  --bof-text-3:       #6b6760;
  --bof-border:       rgba(255, 255, 255, 0.10);
  --bof-border-strong:rgba(255, 255, 255, 0.18);
  --bof-accent:       #E8412A;
  --bof-success-bg:   #1c3624;
  --bof-success-text: #6cd388;
  --bof-warning-bg:   #3a2e0e;
  --bof-warning-text: #e6c365;
  --bof-danger-bg:    #3a1c1c;
  --bof-danger-text:  #e88787;
  background: var(--bof-card);
}

/* Match-WP — inherits site CSS vars where possible (else stays Light). */
.wwp-bof[data-colour="match_wp"] {
  background: transparent;
  border: none;
  padding: 0;
  box-shadow: none;
}

/* ---------- Header ---------- */
.wwp-bof__head {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 12px;
  margin-bottom: 1.25rem;
}
.wwp-bof__title {
  font-family: var(--bof-font-sans);
  font-size: 22px; font-weight: 500; margin: 0;
  color: var(--bof-text-1);
}
.wwp-bof__subtitle {
  font-size: 11px; color: var(--bof-text-3); margin-top: 2px;
  font-weight: 400; letter-spacing: 0.04em; text-transform: uppercase;
}

/* Cart pill */
.wwp-bof__cart-pill {
  background: var(--bof-soft);
  border-radius: 999px; padding: 7px 14px;
  font-size: 13px; color: var(--bof-text-1);
  display: inline-flex; align-items: center; gap: 6px;
  text-decoration: none;
  transition: background 0.15s;
}
.wwp-bof__cart-pill:hover { background: var(--bof-softer); }
.wwp-bof__cart-pill.has-items {
  background: var(--bof-success-bg);
  color: var(--bof-success-text);
}
.wwp-bof__cart-pill--checkout {
  background: var(--bof-text-1); color: var(--bof-card);
}
.wwp-bof__cart-pill--checkout:hover { opacity: 0.88; background: var(--bof-text-1); }

/* ---------- Tabs ---------- */
.wwp-bof__tabs {
  display: flex; gap: 4px;
  border-bottom: 0.5px solid var(--bof-border);
  margin-bottom: 1.25rem;
}
.wwp-bof__tab {
  background: transparent; border: none;
  padding: 12px 16px; cursor: pointer;
  font-size: 13px; font-family: inherit; color: var(--bof-text-2);
  border-bottom: 2px solid transparent;
  margin-bottom: -0.5px;
  transition: color 0.15s, border-color 0.15s;
  display: inline-flex; align-items: center; gap: 6px;
}
.wwp-bof__tab:hover { color: var(--bof-text-1); }
.wwp-bof__tab.is-active {
  color: var(--bof-text-1);
  border-bottom-color: var(--bof-text-1);
  font-weight: 500;
}
.wwp-bof__tab-count {
  background: var(--bof-soft); color: var(--bof-text-2);
  border-radius: 999px; padding: 1px 7px;
  font-size: 11px; font-weight: 400;
}

/* ---------- Panels ---------- */
.wwp-bof__panel { display: none; }
.wwp-bof__panel.is-active { display: block; }
.wwp-bof__empty {
  text-align: center; padding: 40px 20px;
  color: var(--bof-text-2); font-size: 13px;
}

/* ---------- Inputs (shared) ---------- */
.wwp-bof input[type="text"],
.wwp-bof input[type="number"],
.wwp-bof select,
.wwp-bof textarea {
  font-family: inherit; font-size: 13px; padding: 9px 12px;
  border: 0.5px solid var(--bof-border-strong);
  border-radius: var(--bof-radius-md);
  background: var(--bof-card); color: var(--bof-text-1);
  transition: border-color 0.15s, box-shadow 0.15s;
}
.wwp-bof input[type="text"]:focus,
.wwp-bof input[type="number"]:focus,
.wwp-bof select:focus,
.wwp-bof textarea:focus {
  outline: none;
  border-color: var(--bof-accent);
  box-shadow: 0 0 0 3px rgba(232, 65, 42, 0.12);
}

/* ---------- Buttons ---------- */
.wwp-bof__btn {
  background: transparent;
  border: 0.5px solid var(--bof-border-strong);
  padding: 7px 12px; border-radius: var(--bof-radius-md);
  font-size: 12px; cursor: pointer; font-family: inherit;
  color: var(--bof-text-1);
  display: inline-flex; align-items: center; gap: 5px;
}
.wwp-bof__btn:hover { background: var(--bof-soft); }
.wwp-bof__btn--primary {
  background: var(--bof-text-1); color: var(--bof-card); border: none;
  padding: 8px 14px; font-weight: 500;
  transition: opacity 0.15s, transform 0.05s;
}
.wwp-bof__btn--primary:hover { opacity: 0.88; }
.wwp-bof__btn--primary:active { transform: scale(0.98); }
.wwp-bof__btn--primary:disabled { opacity: 0.4; cursor: not-allowed; }
.wwp-bof__btn--lg { padding: 10px 18px; font-size: 13px; }

/* ---------- Pills (status/stock/tier) ---------- */
.wwp-bof__pill {
  font-size: 10px; padding: 2px 7px; border-radius: 999px;
  white-space: nowrap; font-weight: 500;
  display: inline-flex; align-items: center; gap: 3px;
}
.wwp-bof__pill--ok    { background: var(--bof-success-bg); color: var(--bof-success-text); }
.wwp-bof__pill--warn  { background: var(--bof-warning-bg); color: var(--bof-warning-text); }
.wwp-bof__pill--err   { background: var(--bof-danger-bg);  color: var(--bof-danger-text); }

/* ============ QUICK ORDER theme ============ */

.wwp-bof__qo-search {
  display: flex; gap: 8px; margin-bottom: 14px; align-items: stretch;
}
.wwp-bof__qo-search > select { width: 110px; }
.wwp-bof__qo-search-input-wrap {
  flex: 1; position: relative;
}
.wwp-bof__qo-search-input-wrap > .wwp-bof__icon {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  color: var(--bof-text-2); pointer-events: none;
}
.wwp-bof__qo-search-input-wrap input[type="text"] {
  width: 100%; padding-left: 38px;
}
.wwp-bof__qo-suggest {
  position: absolute; top: 100%; left: 0; right: 0;
  background: var(--bof-card); border: 0.5px solid var(--bof-border);
  border-radius: var(--bof-radius-md); margin-top: 4px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
  z-index: 10; max-height: 320px; overflow-y: auto;
}
.wwp-bof__qo-suggest-item {
  padding: 10px 14px; cursor: pointer;
  display: flex; align-items: center; gap: 10px; font-size: 13px;
  border-bottom: 0.5px solid var(--bof-border);
}
.wwp-bof__qo-suggest-item:last-child { border-bottom: none; }
.wwp-bof__qo-suggest-item:hover,
.wwp-bof__qo-suggest-item.is-active { background: var(--bof-soft); }
.wwp-bof__qo-suggest-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.wwp-bof__qo-suggest-sku  { font-family: var(--bof-font-mono); font-size: 11px; color: var(--bof-text-2); }
.wwp-bof__qo-suggest-price{ font-weight: 500; }

.wwp-bof__rows {
  background: var(--bof-card);
  border: 0.5px solid var(--bof-border);
  border-radius: var(--bof-radius-lg);
  overflow: hidden;
}
.wwp-bof__rows:empty { display: none; }
.wwp-bof__row {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) 80px 64px 90px 24px;
  gap: 12px; align-items: center;
  padding: 12px 16px; border-bottom: 0.5px solid var(--bof-border);
}
.wwp-bof__row:last-child { border-bottom: none; }
.wwp-bof__thumb {
  width: 44px; height: 44px;
  background: var(--bof-soft); border-radius: var(--bof-radius-md);
  display: flex; align-items: center; justify-content: center;
  color: var(--bof-text-3); overflow: hidden;
}
.wwp-bof__thumb-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.wwp-bof__thumb-fallback { width: 18px; height: 18px; background: rgba(0, 0, 0, 0.08); border-radius: 4px; }
.wwp-bof__pname-cell { min-width: 0; }
.wwp-bof__pname { font-size: 13px; font-weight: 500; line-height: 1.3; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--bof-text-1); }
.wwp-bof__pmeta { font-size: 11px; color: var(--bof-text-2); margin-top: 3px; display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.wwp-bof__sku   { font-family: var(--bof-font-mono); }
.wwp-bof__unit  { text-align: center; font-size: 11px; color: var(--bof-text-2); }
.wwp-bof__unit-num { font-size: 13px; color: var(--bof-text-1); display: block; line-height: 1.2; }
.wwp-bof__unit-each { display: block; }
.wwp-bof__qty {
  width: 64px; text-align: center; font-variant-numeric: tabular-nums;
}
.wwp-bof__sub { text-align: right; }
.wwp-bof__subtotal { font-size: 14px; font-weight: 500; font-variant-numeric: tabular-nums; color: var(--bof-text-1); }
.wwp-bof__savings  { font-size: 10px; color: var(--bof-success-text); margin-top: 2px; }
.wwp-bof__del {
  background: transparent; border: none; cursor: pointer; padding: 4px;
  color: var(--bof-text-3); display: flex; align-items: center; justify-content: center;
  border-radius: 4px;
}
.wwp-bof__del:hover { color: var(--bof-danger-text); background: var(--bof-soft); }

.wwp-bof__empty-row {
  margin-top: 8px;
}
.wwp-bof__empty-row input {
  width: 100%; padding: 12px 14px 12px 38px;
  border-style: dashed;
  background: transparent;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23a0a0a0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' viewBox='0 0 24 24'><path d='M12 5v14M5 12h14'/></svg>");
  background-repeat: no-repeat;
  background-position: 12px center;
  font-size: 13px;
}

/* Sticky summary */
.wwp-bof__summary {
  background: var(--bof-soft);
  border-radius: var(--bof-radius-lg);
  padding: 16px 18px; margin-top: 14px;
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-areas:
    "stats actions"
    "total actions"
    "savings actions";
  align-items: center; gap: 0 18px;
  position: sticky; bottom: 16px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
}
.wwp-bof__summary-stats   { grid-area: stats;   font-size: 12px; color: var(--bof-text-2); }
.wwp-bof__summary-total   { grid-area: total;   font-size: 22px; font-weight: 500; line-height: 1.1; margin-top: 2px; font-variant-numeric: tabular-nums; }
.wwp-bof__summary-savings { grid-area: savings; font-size: 11px; color: var(--bof-success-text); margin-top: 3px; display: inline-flex; align-items: center; gap: 4px; }
.wwp-bof__summary-actions { grid-area: actions; display: flex; gap: 8px; align-items: center; }

/* ============ CATALOG theme ============ */

.wwp-bof__cat-search {
  display: flex; gap: 8px; align-items: stretch; margin-bottom: 14px; position: relative;
}
.wwp-bof__cat-search-input-wrap {
  flex: 1; position: relative;
}
.wwp-bof__cat-search-input-wrap > .wwp-bof__icon {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  color: var(--bof-text-2); pointer-events: none;
}
.wwp-bof__cat-search-input-wrap input[type="text"] { width: 100%; padding-left: 38px; }
.wwp-bof__cat-search select { width: 130px; }

/* Filters button + panel */
.wwp-bof__filters-btn {
  background: var(--bof-soft); color: var(--bof-text-1); border: 0.5px solid var(--bof-border-strong);
  padding: 0 14px; border-radius: var(--bof-radius-md);
  font-size: 12px; font-family: inherit; cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
  white-space: nowrap;
  transition: background 0.15s, border-color 0.15s;
}
.wwp-bof__filters-btn:hover { background: var(--bof-softer); }
.wwp-bof__filters-btn.is-open { background: var(--bof-text-1); color: var(--bof-card); border-color: var(--bof-text-1); }

.wwp-bof__filters-panel {
  position: absolute; top: calc(100% + 6px); left: 0; right: 0;
  background: var(--bof-card); border: 0.5px solid var(--bof-border);
  border-radius: var(--bof-radius-lg);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.10);
  padding: 16px 18px;
  z-index: 20;
  display: flex; flex-direction: column; gap: 14px;
  max-height: 60vh; overflow-y: auto;
}
/* The HTML [hidden] attribute uses `display: none` as a UA default, but the
   explicit `display: flex` above wins. Re-assert hiding when [hidden] is set. */
.wwp-bof__filters-panel[hidden] { display: none; }
.wwp-bof__filters-section h4 {
  font-size: 11px; color: var(--bof-text-2);
  font-weight: 500; letter-spacing: 0.04em; text-transform: uppercase;
  margin: 0 0 8px;
}
.wwp-bof__filters-options {
  display: flex; flex-direction: column;
}
.wwp-bof__filter-opt {
  background: transparent; border: 0;
  padding: 8px 10px; border-radius: 6px;
  font-size: 13px; color: var(--bof-text-1);
  font-family: inherit; cursor: pointer; text-align: left;
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  transition: background 0.12s, color 0.12s;
}
.wwp-bof__filter-opt:hover { background: var(--bof-soft); }
.wwp-bof__filter-opt.is-active {
  color: var(--bof-accent); font-weight: 500;
}
.wwp-bof__filter-opt.is-active::before {
  content: '✓ '; margin-right: 4px;
}
.wwp-bof__filter-opt-count {
  font-size: 11px; color: var(--bof-text-3); font-variant-numeric: tabular-nums;
}

.wwp-bof__cat-grid {
  background: var(--bof-card);
  border: 0.5px solid var(--bof-border);
  border-radius: var(--bof-radius-lg);
  overflow: hidden;
}
.wwp-bof__cat-row {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr) 100px 80px 110px 32px;
  gap: 14px; align-items: center;
  padding: 14px 18px; border-bottom: 0.5px solid var(--bof-border);
}
.wwp-bof__cat-row:last-child { border-bottom: none; }
.wwp-bof__cat-row .wwp-bof__thumb { width: 56px; height: 56px; }

.wwp-bof__cat-foot {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 18px; margin-top: 14px;
  background: var(--bof-soft); border-radius: var(--bof-radius-lg);
}
.wwp-bof__cat-foot-stats { font-size: 12px; color: var(--bof-text-2); flex: 1; }
.wwp-bof__cat-foot-num   { font-size: 18px; font-weight: 500; font-variant-numeric: tabular-nums; }
.wwp-bof__cat-foot-savings { font-size: 11px; color: var(--bof-success-text); margin-top: 2px; }

/* ---------- Filter row (used by Previous Orders) ---------- */
.wwp-bof__filterrow {
  display: flex; gap: 8px; margin-bottom: 14px;
}
.wwp-bof__filterrow input { flex: 1; }
.wwp-bof__filterrow select { width: 150px; }

/* ---------- Previous orders panel ---------- */
.wwp-bof__prev-list {
  background: var(--bof-card);
  border: 0.5px solid var(--bof-border);
  border-radius: var(--bof-radius-lg);
  overflow: hidden;
}
.wwp-bof__prev-head {
  display: grid;
  grid-template-columns: 90px 110px 1fr 90px 200px;
  gap: 14px; align-items: center;
  padding: 10px 18px;
  background: var(--bof-soft);
  font-size: 11px; color: var(--bof-text-2);
  text-transform: uppercase; letter-spacing: 0.04em; font-weight: 500;
}
.wwp-bof__prev-row {
  display: grid;
  grid-template-columns: 90px 110px 1fr 90px 200px;
  gap: 14px; align-items: center;
  padding: 14px 18px; border-bottom: 0.5px solid var(--bof-border);
  font-size: 13px;
}
.wwp-bof__prev-row:last-child { border-bottom: none; }
.wwp-bof__prev-row:has(.wwp-bof__prev-expand:not([hidden])) { border-bottom: none; }
.wwp-bof__prev-id    { font-family: var(--bof-font-mono); font-size: 12px; color: var(--bof-text-2); }
.wwp-bof__prev-date  { font-size: 12px; color: var(--bof-text-2); }
.wwp-bof__prev-items { font-size: 12px; }
.wwp-bof__prev-total { text-align: right; font-weight: 500; font-variant-numeric: tabular-nums; }
.wwp-bof__prev-actions {
  display: flex; gap: 6px; justify-content: flex-end;
}

.wwp-bof__prev-expand {
  grid-column: 1 / -1;
  background: var(--bof-soft);
  margin: 0 -18px -14px;
  padding: 14px 18px 16px;
  border-top: 0.5px solid var(--bof-border);
  border-bottom: 0.5px solid var(--bof-border);
}
.wwp-bof__prev-exp-label {
  font-size: 11px; color: var(--bof-text-2);
  text-transform: uppercase; letter-spacing: 0.04em; font-weight: 500;
  margin-bottom: 10px;
}
.wwp-bof__prev-line {
  display: grid;
  grid-template-columns: 18px 36px 1fr 70px 90px;
  gap: 10px; align-items: center;
  padding: 7px 0; font-size: 12px;
}
.wwp-bof__prev-line .wwp-bof__thumb { width: 36px; height: 36px; background: var(--bof-card); }
.wwp-bof__prev-line-check { margin: 0; cursor: pointer; }
.wwp-bof__prev-line-name { min-width: 0; }
.wwp-bof__prev-line-name .wwp-bof__pname { font-size: 12px; }
.wwp-bof__prev-line-name .wwp-bof__sku   { font-size: 11px; }
.wwp-bof__prev-line-qty   { text-align: center; }
.wwp-bof__prev-line-total { text-align: right; font-weight: 500; }

.wwp-bof__prev-exp-foot {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 14px; padding-top: 12px;
  border-top: 0.5px solid var(--bof-border);
  font-size: 12px; color: var(--bof-text-2);
}
.wwp-bof__prev-line-check:disabled { opacity: 0.4; cursor: not-allowed; }
.wwp-bof__prev-line:has(.wwp-bof__prev-line-check:disabled) { opacity: 0.55; }
@media (max-width: 720px) {
  .wwp-bof__prev-head, .wwp-bof__prev-row {
    grid-template-columns: 1fr 1fr; gap: 6px;
  }
  .wwp-bof__prev-head { display: none; }
  .wwp-bof__prev-actions { grid-column: 1 / -1; justify-content: flex-start; }
}

/* ---------- Uploader / paste (used by Upload tab) ---------- */
.wwp-bof__uploader {
  background: var(--bof-soft); border: 1.5px dashed var(--bof-border-strong);
  border-radius: var(--bof-radius-lg); padding: 28px 16px;
  text-align: center; cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.wwp-bof__uploader:hover, .wwp-bof__uploader.is-drag {
  background: var(--bof-softer); border-color: var(--bof-accent); border-style: solid;
}
.wwp-bof__uploader-title { font-size: 14px; font-weight: 500; margin: 8px 0 4px; }
.wwp-bof__uploader-meta  { font-size: 11px; color: var(--bof-text-2); }
.wwp-bof__uploader-meta a { color: var(--bof-accent); }

.wwp-bof__divider {
  display: flex; align-items: center; gap: 12px;
  margin: 1.25rem 0; color: var(--bof-text-3);
  font-size: 11px; letter-spacing: 0.04em; font-weight: 500;
}
.wwp-bof__divider::before, .wwp-bof__divider::after {
  content: ''; flex: 1; height: 0.5px; background: var(--bof-border);
}

.wwp-bof__paste {
  width: 100%; min-height: 110px;
  font-family: var(--bof-font-mono); font-size: 12px; resize: vertical;
}
.wwp-bof__paste-actions {
  display: flex; gap: 8px; margin-top: 10px;
}

/* ---------- Upload preview ---------- */
.wwp-bof__upload-preview {
  margin-top: 1.75rem;
}
.wwp-bof__upload-preview-h {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 8px;
}
.wwp-bof__upload-preview-label {
  font-size: 11px; color: var(--bof-text-2);
  text-transform: uppercase; letter-spacing: 0.04em; font-weight: 500;
}
.wwp-bof__upload-preview-status { font-size: 11px; }

.wwp-bof__preview-table {
  background: var(--bof-card);
  border: 0.5px solid var(--bof-border);
  border-radius: var(--bof-radius-lg);
  overflow: hidden;
}
.wwp-bof__preview-row {
  display: grid;
  grid-template-columns: 130px 1fr 60px 100px 120px;
  gap: 12px; align-items: center;
  padding: 10px 18px; font-size: 12px;
  border-bottom: 0.5px solid var(--bof-border);
}
.wwp-bof__preview-row:last-child { border-bottom: none; }
.wwp-bof__preview-row--head {
  background: var(--bof-soft);
  font-size: 11px; color: var(--bof-text-2);
  text-transform: uppercase; letter-spacing: 0.04em; font-weight: 500;
}
.wwp-bof__preview-row.is-muted { color: var(--bof-text-3); }
.wwp-bof__preview-row.is-muted .wwp-bof__sku { color: var(--bof-text-3); }

.wwp-bof__upload-actionbar {
  display: flex; justify-content: space-between; align-items: center;
  gap: 12px; padding: 14px 18px;
  background: var(--bof-soft); border-radius: var(--bof-radius-lg);
  margin-top: 14px;
}
.wwp-bof__upload-actionbar-total {
  font-size: 20px; font-weight: 500; line-height: 1.1;
  font-variant-numeric: tabular-nums;
}
.wwp-bof__upload-actionbar-sub {
  font-size: 11px; color: var(--bof-text-2); margin-top: 3px;
}

@media (max-width: 720px) {
  .wwp-bof__preview-row {
    grid-template-columns: 1fr; gap: 4px;
    padding: 12px 14px;
  }
  .wwp-bof__preview-row--head { display: none; }
}

/* ---------- Mobile ---------- */
@media (max-width: 720px) {
  .wwp-bof { padding: 18px 16px 20px; }
  .wwp-bof__row, .wwp-bof__cat-row { grid-template-columns: 44px 1fr; gap: 8px; row-gap: 4px; }
  .wwp-bof__row > .wwp-bof__unit,
  .wwp-bof__row > .wwp-bof__qty,
  .wwp-bof__row > .wwp-bof__sub,
  .wwp-bof__row > .wwp-bof__del,
  .wwp-bof__cat-row > .wwp-bof__unit,
  .wwp-bof__cat-row > .wwp-bof__qty,
  .wwp-bof__cat-row > .wwp-bof__sub,
  .wwp-bof__cat-row > .wwp-bof__del { grid-column: 2 / -1; justify-self: end; }
  .wwp-bof__qo-search { flex-direction: column; }
  .wwp-bof__qo-search > select { width: 100%; }
  .wwp-bof__cat-search { flex-direction: column; }
  .wwp-bof__cat-search select { width: 100%; }
  .wwp-bof__summary {
    grid-template-columns: 1fr;
    grid-template-areas: "stats" "total" "savings" "actions";
    bottom: 0; border-radius: 0; margin: 14px -16px 0;
  }
  .wwp-bof__summary-actions { justify-content: flex-end; }
  .wwp-bof__tab span:not(.wwp-bof__tab-count) { display: none; }
}
