.sj-bb{--pad:16px}
.sj-bb .sj-bb-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:24px}
@media(max-width:980px){.sj-bb .sj-bb-grid{grid-template-columns:1fr}}
.sj-bb-header h2{margin:0 0 4px;font-size:clamp(22px,2.6vw,34px)}
.sj-bb-header p{margin:0 0 14px;opacity:.8}
.sj-bb-step{display:flex;align-items:center;gap:12px;margin:45px 0 15px}
.sj-bb-step h3{margin:0;font-size:1.4rem}
.sj-bb-stepnum{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;background:var(--sjbb-accent);color:#111;font-weight:700}
.sj-bb-sep{border:0;border-top:1px solid #eee;margin:10px 0}
.sj-bb-header .sj-bb-sizepicker button{background:#fff!important;color:#111!important;border-color:var(--sjbb-primary)!important}
.sj-bb-header .sj-bb-sizepicker button[aria-pressed="true"],
.sj-bb-header .sj-bb-sizepicker button:hover{background:var(--sjbb-primary)!important;color:#fff!important}
.sj-bb-header--mobile{display:none}
@media(max-width:980px){.sj-bb-header--mobile{display:block;margin-bottom:8px}}
.sj-bb-header h2{margin:0 0 4px;font-size:clamp(22px,2.6vw,34px)}
.sj-bb-header p{margin:0 0 14px;opacity:.8}
.sj-bb-sizepicker{display:flex;gap:8px;margin:10px 0 18px}
.sj-bb-sizepicker button{border:2px solid var(--sjbb-primary);background:#fff;padding:8px 12px;border-radius:12px;cursor:pointer}
.sj-bb-sizepicker button[aria-pressed="true"], .sj-bb-sizepicker button:hover{background:var(--sjbb-primary);color:#fff}
.sj-bb-products{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
.sj-bb-card{border:1px solid #e5e7eb!important;border-radius:14px!important;padding:12px!important;background:#fff!important;display:flex!important;flex-direction:column!important;gap:10px!important}
.sj-bb-card img{aspect-ratio:1/1!important;object-fit:contain!important;width:100%!important;border-radius:10px!important}
.sj-bb-card-info{flex:1!important;min-width:0!important;cursor:pointer}
.sj-bb-card-name{font-weight:600!important;font-size:0.95rem!important;line-height:1.3!important;color:#111!important;margin-bottom:4px!important}
.sj-bb-card-variations{font-size:0.8rem!important;color:#555!important;line-height:1.35!important;margin-bottom:4px!important}
.sj-bb-card-price-wrap{display:flex!important;align-items:baseline!important;gap:8px!important;flex-wrap:wrap!important}
.sj-bb-card-price{font-weight:700!important;font-size:1rem!important;color:var(--sjbb-primary,#0c699b)!important}
.sj-bb-card-price-regular{font-size:0.8rem!important;color:#6b7280!important;text-decoration:line-through!important}
.sj-bb-qty{display:flex;align-items:center;justify-content:center;gap:6px;border:1px solid #e5e7eb;border-radius:999px;overflow:hidden}
.sj-bb-qty button{width:60px;justify-content:center;height:40px;border:0;background:#fff!important;color:#111;cursor:pointer;box-shadow:none}
.sj-bb-qty input{width:80px;text-align:center;border:0;background:transparent}
/* Hide inner number spinners */
.sj-bb-qty input::-webkit-outer-spin-button,
.sj-bb-qty input::-webkit-inner-spin-button{ -webkit-appearance: none; margin: 0; }
.sj-bb-qty input[type=number]{ -moz-appearance: textfield; appearance: textfield; }
.sj-bb-right .sj-bb-summary{position:sticky;top:124px;border:1px solid #e5e7eb;border-radius:16px;padding:0px 40px 40px;background:#fff}
.sj-bb-progress{margin:6px 0 10px;font-weight:600}
.sj-bb-chosen{display:flex;flex-direction:column;gap:10px;max-height:100%;overflow:auto;margin:8px 0}
.sj-bb-chip{display:flex;align-items:center;gap:8px;border:1px solid #eee;border-radius:12px;padding:8px;font-size: 14px;}
.sj-bb-chip img{width:80px;height:40px;border-radius:8px;object-fit:cover}
.sj-bb-totals{border-top:1px dashed #e5e7eb;padding-top:10px;margin-top:10px}
.sj-bb-totals .row{display:flex;justify-content:space-between;margin:6px 0}
.sj-bb-totals .grand{font-size:1.1rem;font-weight:700}
.sj-bb-savings{font-weight:700;color:var(--sjbb-primary,#0c699b)}
.sj-bb-lbl-savings{font-weight:600;color:#111}
.sj-bb .button.alt.sj-bb-complete{width:100%;background:var(--sjbb-primary);color:#fff;border-radius:999px;padding:12px;font-size:1.05rem}
.sj-bb .button.alt.sj-bb-complete:disabled{opacity:.5;cursor:not-allowed}
.sj-bb .button.alt.sj-bb-cases-add{width:100%;background:var(--sjbb-primary);color:#fff;border-radius:999px;padding:12px;font-size:1.05rem}
.sj-bb .button.alt.sj-bb-cases-add:disabled{opacity:.5;cursor:not-allowed}
/* Packaging selector */
.sj-bb-packaging{display:flex;gap:8px;margin:10px 0 14px}
.sj-bb-packaging .sj-bb-pack-option{display:inline-flex;align-items:center;gap:8px;border:2px solid var(--sjbb-primary);background:#fff;padding:8px 12px;border-radius:12px;cursor:pointer}
.sj-bb-packaging .sj-bb-pack-option[aria-pressed="true"], .sj-bb-packaging .sj-bb-pack-option:hover{background:var(--sjbb-primary);color:#fff}
.sj-bb-packaging .sj-bb-pack-icon{font-size:18px}
/* Mobile drawer */
.sj-bb-mobilebar{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid #e5e7eb;padding:10px;display:none;z-index:50}
.sj-bb-mobilebar .sj-bb-mobileinfo{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-weight:600}
.sj-bb-mobilebar .sj-bb-mobileactions{display:flex;gap:10px}
.sj-bb-mobilebar .sj-bb-mobileactions .sj-bb-mobileview{flex:1;border-radius:999px;padding:12px;background:#f4f4f5;color:#111;border:1px solid #e5e7eb}
.sj-bb-mobilebar .sj-bb-mobileactions .sj-bb-complete,
.sj-bb-mobilebar .sj-bb-mobileactions .sj-bb-cases-add{flex:1}
.sj-bb-cases-mobile-qty{font-weight:600}
.sj-bb-drawer-actions .sj-bb-cases-add{flex:1;width:auto;min-width:0}
.sj-bb-drawer{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top-left-radius:16px;border-top-right-radius:16px;box-shadow:0 -10px 30px rgba(0,0,0,.15)}
.sj-bb-drawer[hidden]{display:none}
.sj-bb-drawer .sj-bb-drawer-inner{padding:16px;max-height:70vh;overflow:auto}
.sj-bb-drawer-actions{display:flex;gap:10px;margin-top:10px}
.sj-bb-drawer-actions .sj-bb-hide{flex:1;border-radius:999px;padding:12px;background:#f4f4f5;color:#111;border:1px solid #e5e7eb}
@media(max-width:980px){.sj-bb-right{display:none}.sj-bb-mobilebar{display:block}}
/* Case-lot builder: keep the bottom bar and product detail layer above typical theme/WooCommerce fixed footers; stay below filter overlay/panel (99998/99999). */
.sj-bb--cases .sj-bb-mobilebar{z-index:9990}
.sj-bb--cases .sj-bb-overlay{z-index:9995}
.sj-bb--cases .sj-bb-panel{z-index:10000}
.sj-bb--cases .sj-bb-mobilebar .sj-bb-drawer:not([hidden]){z-index:2}
.sj-bb--cases .sj-bb-mobileinfo,
.sj-bb--cases .sj-bb-mobileactions{position:relative;z-index:1}
.sj-bb-note{margin-top: 20px;}

/* === Product details slide-out === */
.sj-bb-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:90}
.sj-bb-overlay[hidden]{display:none}
.sj-bb-panel{position:fixed;top:0;right:0;bottom:0;width:min(420px,100%);background:#fff;box-shadow:-10px 0 30px rgba(0,0,0,.15);transform:translateX(100%);transition:transform .25s ease;z-index:100;display:flex;flex-direction:column}
.sj-bb-panel.open{transform:translateX(0)}
.sj-bb-panel-header{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:14px 16px;border-bottom:1px solid #e5e7eb}
.sj-bb-panel-title{font-weight:700;flex:1}
.sj-bb-panel-price{font-weight:700;color:#111}
.sj-bb-panel-close{border:0;background:#f4f4f5!important;color:#111!important;width:36px;height:36px;border-radius:999px;line-height:1;font-size:20px;cursor:pointer}
.sj-bb-panel-body{padding:12px 16px 16px;overflow:auto}
.sj-bb-gallery{display:flex;gap:8px;overflow:auto;scroll-snap-type:x mandatory;margin-bottom:12px}
.sj-bb-gallery img{width:100%;height:auto;max-height:280px;object-fit:contain;border-radius:10px;flex:0 0 100%;scroll-snap-align:center;background:#fff}
@media(min-width:981px){ .sj-bb-gallery img{ max-height:340px } }
.sj-bb-desc{font-size:.95rem;line-height:1.5;color:#333;margin:8px 0 14px}
.sj-bb-desc-more{color:var(--sjbb-primary,#0c699b);font-weight:600;text-decoration:none;white-space:nowrap}
.sj-bb-desc-more:hover{text-decoration:underline}
.sj-bb-qty--panel{margin-top:8px;justify-content:space-between}

/* Desktop modal layout for product details */
@media(min-width:981px){
  .sj-bb-panel{
    top:50%; left:50%; right:auto; bottom:auto;
    width:min(900px, 92vw); max-height:82vh;
    transform:translate(-50%,-50%) scale(.98);
    transition:transform .18s ease, opacity .18s ease, visibility .18s ease;
    opacity:0; visibility:hidden; pointer-events:none;
    border-radius:14px; box-shadow:0 10px 50px rgba(0,0,0,.25);
  }
  .sj-bb-panel.open{ transform:translate(-50%,-50%) scale(1); opacity:1; visibility:visible; pointer-events:auto; }
  .sj-bb-panel-body{
    display:grid; grid-template-columns:1.1fr 1fr; grid-auto-rows:auto; gap:16px;
  }
  .sj-bb-gallery{ grid-column:1; grid-row:1 / span 2; overflow:hidden; }
  .sj-bb-gallery img{ flex:0 0 auto; max-height:none; height:auto; }
  .sj-bb-desc{ grid-column:2; grid-row:1; margin-top:0; }
  .sj-bb-panel-footer{
    grid-column:1 / -1; grid-row:auto;
    display:flex; align-items:center; justify-content:space-between; gap:12px;
    border-top:1px solid #e5e7eb; padding-top:10px; margin-top:4px;
  }
  .sj-bb-panel-meta{ display:flex; flex-direction:column; gap:4px; }
  .sj-bb-panel-title{ font-weight:700; }
  .sj-bb-panel-price{ font-weight:700; color:#111; }
  .sj-bb-qty--panel{ margin-top:0; }
}

/* === Product filters: button + slide-out (left) === */
/* Filter UI buttons use custom classes so you can override colours without affecting site buttons:
   .sj-bb-filters-trigger (open Filters), .sj-bb-filter-btn--close (×), .sj-bb-filter-btn--clear (Clear all) */
.sj-bb-toolbar{ display:flex; align-items:center; gap:10px; margin:8px 0 14px; flex-wrap:wrap; }
.sj-bb-search-input{ flex:1; min-width:140px; max-width:280px; padding:10px 14px; border:1px solid #e5e7eb; border-radius:10px; font-size:0.95rem; }
.sj-bb-search-input::placeholder{ color:#9ca3af; }
.sj-bb-search-input:focus{ outline:none; border-color:var(--sjbb-primary,#0c699b); }
.sj-bb-filter-btn,
.sj-bb-filters-trigger{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:10px 18px; border-radius:10px; border:1px solid #e5e7eb;
  background:#fff!important; color:#374151; font-size:0.9rem; font-weight:600; cursor:pointer;
  transition:background .2s, color .2s, border-color .2s;
}
.sj-bb-filter-btn:hover,
.sj-bb-filters-trigger:hover{ background:#f9fafb; border-color:var(--sjbb-primary,#0c699b); color:var(--sjbb-primary,#0c699b); }
.sj-bb-filter-overlay{
  position:fixed; inset:0; background:rgba(0,0,0,.35); z-index:99998;
  opacity:0; visibility:hidden; transition:opacity .25s ease, visibility .25s ease;
}
.sj-bb-filter-overlay[aria-hidden="false"]{ opacity:1; visibility:visible; }
.sj-bb-filter-overlay[hidden]{ display:none; }
.sj-bb-filter-panel{
  position:fixed; top:0; left:0; bottom:0; z-index:99999;
  width:min(320px, 92vw); max-width:100%;
  background:#fff; box-shadow:4px 0 24px rgba(0,0,0,.12);
  transform:translateX(-100%); transition:transform .28s ease;
  display:flex; flex-direction:column; overflow:hidden;
}
.sj-bb-filter-panel.open{ transform:translateX(0); }
.sj-bb-filter-panel-inner{ display:flex; flex-direction:column; height:100%; overflow:hidden; }
.sj-bb-filter-panel-header{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:16px 18px; border-bottom:1px solid #e5e7eb; flex-shrink:0;
}
.sj-bb-filter-panel-title{ margin:0; font-size:1.15rem; font-weight:700; color:#111; }
.sj-bb-filter-close,
.sj-bb-filter-btn--close{
  width:40px; height:40px; border:0; border-radius:10px; background:#f3f4f6!important;
  font-size:22px; line-height:1; color:#374151; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
  transition:background .2s, color .2s;
}
.sj-bb-filter-close:hover,
.sj-bb-filter-btn--close:hover{ background:#e5e7eb; color:#111; }
.sj-bb-filter-panel-body{
  flex:1; overflow:auto; padding:14px 18px; -webkit-overflow-scrolling:touch;
}
.sj-bb-filter-section{ margin-bottom:14px; border:1px solid #e5e7eb; border-radius:10px; overflow:hidden; }
.sj-bb-filter-section:last-child{ margin-bottom:0; }
.sj-bb-filter-section-header{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  width:100%; padding:12px 14px; border:0; border-radius:0;
  background:#f9fafb!important; color:#374151; font-size:0.8rem; font-weight:700; text-transform:uppercase; letter-spacing:0.04em;
  cursor:pointer; text-align:left; -webkit-tap-highlight-color:transparent;
  transition:background .2s, color .2s;
}
.sj-bb-filter-section-header:hover{ background:#f3f4f6!important; color:#111; }
.sj-bb-filter-section-chevron{
  flex-shrink:0; width:20px; height:20px; display:inline-flex; align-items:center; justify-content:center;
  transition:transform .2s ease;
}
.sj-bb-filter-section.sj-bb-filter-section--collapsed .sj-bb-filter-section-chevron{ transform:rotate(-90deg); } /* ▼ points right when collapsed */
.sj-bb-filter-section-body{ overflow:hidden; transition:height .2s ease; }
.sj-bb-filter-section.sj-bb-filter-section--collapsed .sj-bb-filter-section-body{ display:none; }
.sj-bb-filter-section-body-inner{ padding:10px 14px 14px; }
.sj-bb-filter-section-title{
  font-size:0.75rem; font-weight:700; text-transform:uppercase; letter-spacing:0.04em;
  color:#6b7280; margin:0 0 10px; padding:0;
}
.sj-bb-filter-options{ display:flex; flex-direction:column; gap:6px; }
.sj-bb-filter-option{
  display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:8px;
  border:1px solid transparent; background:#f9fafb; cursor:pointer;
  transition:background .2s, border-color .2s;
  -webkit-tap-highlight-color:transparent;
}
.sj-bb-filter-option:hover{ background:#f3f4f6; }
.sj-bb-filter-option input{ margin:0; width:18px; height:18px; accent-color:var(--sjbb-primary,#0c699b); cursor:pointer; }
.sj-bb-filter-option label{ margin:0; flex:1; font-size:0.9rem; color:#374151; cursor:pointer; }
.sj-bb-filter-option.active{ background:rgba(12,105,155,.08); border-color:var(--sjbb-primary,#0c699b); }
.sj-bb-filter-option.active label{ color:var(--sjbb-primary,#0c699b); font-weight:600; }
.sj-bb-filter-attr-group{ margin-bottom:14px; }
.sj-bb-filter-attr-group:last-child{ margin-bottom:0; }
.sj-bb-filter-panel-footer{
  padding:14px 18px; border-top:1px solid #e5e7eb; flex-shrink:0;
}
.sj-bb-filter-clear,
.sj-bb-filter-btn--clear{
  width:100%; padding:12px; border-radius:10px; border:1px solid #e5e7eb;
  background:#fff; color:#6b7280; font-size:0.9rem; font-weight:600; cursor:pointer;
  transition:background .2s, color .2s, border-color .2s;
}
.sj-bb-filter-clear:hover,
.sj-bb-filter-btn--clear:hover{ background:#f9fafb; color:#374151; border-color:#d1d5db; }

