/* ─── Reset + base ──────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --red:       #DB1D25;
  --red-dk:    #a5161b;
  --black:     #080808;
  --surface:   #111111;
  --card:      #181818;
  --lift:      #222222;
  --border:    #2c2c2c;
  --border-hi: #444444;
  --text:      #efefef;
  --muted:     #777777;
  --dim:       #444444;

  --gold:    #d4a017;
  --green:   #27c05a;
  --orange:  #e07430;
  --yellow:  #d4a017;
  --blue:    #3b90e0;
  --purple:  #9966cc;
  --accent:  #3b90e0;

  --r: 6px;
  --r-lg: 10px;

  font-family: 'Barlow', system-ui, sans-serif;
  font-size: 14px;
}

body { background: var(--black); color: var(--text); min-height: 100vh; }

/* ─── Header ────────────────────────────────────────────────── */
.header {
  background: var(--surface);
  border-bottom: 2px solid var(--red);
  position: sticky;
  top: 0;
  z-index: 200;
  backdrop-filter: blur(8px);
}
.header-inner {
  max-width: 1440px;
  margin: 0 auto;
  padding: 10px 20px;
  display: flex;
  align-items: center;
  gap: 20px;
}
.logo-area { display: flex; align-items: center; gap: 10px; cursor: pointer; user-select: none; }
.logo-img {
  width: 36px;
  height: 36px;
  border-radius: 4px;
  object-fit: contain;
}
.logo-mark {
  background: var(--red);
  color: #fff;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 900;
  font-size: 17px;
  letter-spacing: 1px;
  padding: 6px 10px;
  border-radius: 4px;
  line-height: 1;
  user-select: none;
}
.logo-title { font-weight: 700; font-size: 15px; line-height: 1.2; }
.logo-sub   { font-size: 11px; color: var(--muted); line-height: 1.2; }

.header-stats {
  display: flex;
  align-items: center;
  gap: 0;
  margin-left: auto;
  margin-right: 12px;
}
.stat-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 16px;
}
.stat-val  { font-family: 'Barlow Condensed', sans-serif; font-size: 20px; font-weight: 900; line-height: 1; }
.stat-val.red    { color: var(--red); }
.stat-val.green  { color: var(--green); }
.stat-lbl  { font-size: 10px; font-weight: 500; color: var(--muted); text-transform: uppercase; letter-spacing: .5px; margin-top: 2px; }
.stat-divider { width: 1px; background: var(--border); height: 28px; }

.last-updated {
  font-size: 10px;
  color: var(--muted);
  text-align: center;
  margin-top: 2px;
}
.user-area { display: flex; align-items: center; gap: 8px; margin-left: 8px; }
.user-avatar { width: 28px; height: 28px; border-radius: 50%; border: 2px solid var(--border); cursor: default; }
.user-name { font-size: 11px; color: var(--muted); max-width: 80px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.logout-btn { background: none; border: 1px solid var(--border); color: var(--muted); font-size: 10px; padding: 3px 8px; border-radius: 4px; cursor: pointer; font-family: inherit; transition: color .15s, border-color .15s; }
.logout-btn:hover { color: var(--red); border-color: var(--red); }
.sync-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--lift);
  border: 1px solid var(--border-hi);
  color: var(--text);
  padding: 7px 14px;
  border-radius: var(--r);
  cursor: pointer;
  font-family: 'Barlow', sans-serif;
  font-size: 13px;
  font-weight: 600;
  transition: all .15s;
  white-space: nowrap;
}
.sync-btn:hover   { border-color: var(--red); color: var(--red); }
.sync-btn.spinning .sync-icon { animation: spin 1s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.sync-icon { width: 14px; height: 14px; }

/* ─── Store tabs ─────────────────────────────────────────────── */
.store-tabs {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  display: flex;
  overflow-x: auto;
  padding: 0 20px;
  scrollbar-width: none;
  position: sticky;
  top: 52px;
  z-index: 199;
}
.store-tabs::-webkit-scrollbar { display: none; }

.tab {
  background: none;
  border: none;
  border-bottom: 3px solid transparent;
  color: var(--muted);
  padding: 10px 16px;
  cursor: pointer;
  font-family: 'Barlow', sans-serif;
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
  transition: all .15s;
  letter-spacing: .2px;
}
.tab:hover  { color: var(--text); }
.tab.active { color: var(--red); border-bottom-color: var(--red); }
.tab-count  {
  background: var(--lift);
  border-radius: 10px;
  padding: 1px 6px;
  font-size: 10px;
  margin-left: 4px;
  font-weight: 700;
}

/* ─── Toolbar ────────────────────────────────────────────────── */
.toolbar {
  max-width: 1440px;
  margin: 12px auto;
  padding: 0 20px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.search-wrap {
  flex: 1;
  min-width: 220px;
  position: relative;
}
.search-ico {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 15px;
  color: var(--muted);
  pointer-events: none;
}
#searchInput {
  width: 100%;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r);
  color: var(--text);
  padding: 8px 12px 8px 32px;
  font-family: 'Barlow', sans-serif;
  font-size: 13px;
  outline: none;
  transition: border-color .15s;
}
#searchInput:focus { border-color: var(--red); }
#searchInput::placeholder { color: var(--dim); }

.filter-group { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.filter-group select {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r);
  color: var(--text);
  padding: 7px 10px;
  font-family: 'Barlow', sans-serif;
  font-size: 13px;
  outline: none;
  cursor: pointer;
}
.filter-group select:focus { border-color: var(--red); }

.toggle-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  color: var(--muted);
  user-select: none;
}
.toggle-label input { display: none; }
.toggle-track {
  width: 32px;
  height: 17px;
  background: var(--lift);
  border: 1px solid var(--border-hi);
  border-radius: 10px;
  position: relative;
  transition: background .2s;
}
.toggle-track::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 11px;
  height: 11px;
  background: var(--muted);
  border-radius: 50%;
  transition: transform .2s, background .2s;
}
.toggle-label input:checked ~ .toggle-track { background: var(--red); border-color: var(--red); }
.toggle-label input:checked ~ .toggle-track::after { transform: translateX(15px); background: #fff; }

/* ─── Table ──────────────────────────────────────────────────── */
.main { max-width: 100%; margin: 0 auto; padding: 0 16px 60px; }
.table-wrap { display: flex; flex-direction: column; border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.table-top-scroll { overflow-x: auto; overflow-y: hidden; height: 14px; scrollbar-width: thin; border-bottom: 1px solid var(--border); }
.table-top-scroll::-webkit-scrollbar { height: 7px; }
.table-top-scroll::-webkit-scrollbar-track { background: var(--surface); }
.table-top-scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
.table-top-scroll-inner { height: 1px; }
.table-scroll { overflow-x: auto; flex: 1; }

.orders-table { width: 100%; border-collapse: collapse; min-width: 900px; }
.orders-table thead tr { background: var(--card); }
.orders-table th {
  padding: 9px 12px;
  text-align: left;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.orders-table td { padding: 9px 12px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.orders-table tbody tr { background: var(--surface); cursor: pointer; transition: background .1s; }
.orders-table tbody tr:hover { background: var(--card); }
.orders-table tbody tr:last-child td { border-bottom: none; }

/* urgency left border */
.orders-table tbody tr.urg-1 td:first-child { border-left: 3px solid var(--yellow); }
.orders-table tbody tr.urg-2 td:first-child { border-left: 3px solid var(--orange); }
.orders-table tbody tr.urg-3 td:first-child { border-left: 3px solid var(--red); }

/* col widths */
.col-urg    { width: 28px; }
.col-num    { width: 90px; }
.col-cust   { width: 160px; }
.col-tier   { width: 160px; }
.col-persona{ width: 160px; }
.col-store  { width: 120px; }
.col-type   { width: 120px; }
.col-deliv  { width: 130px; }
.col-val    { width: 90px; text-align: right; }
.col-shippaid { width: 80px; text-align: right; }
.col-days   { width: 70px; text-align: center; }
.days-caution { color: var(--yellow); }
.days-warn    { color: var(--red); }
.tag-strip {
  display: inline-block;
  margin-left: 6px;
  font-size: 10px;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 3px;
  border-left: 3px solid;
  background: rgba(255,255,255,.04);
  vertical-align: middle;
}
.noncore-flag  { border-left-color: var(--muted); color: var(--muted); }
.highval-flag  { border-left-color: var(--blue);  color: var(--blue); }
.overnight-flag { border-left-color: var(--blue); color: var(--blue); }
.rush-flag     { border-left-color: var(--red);   color: var(--red); }
.missing-flag  { border-left-color: var(--red);   color: var(--red); }
.late-flag     { border-left-color: var(--orange); color: var(--orange); }
.mnb-flag { display: inline-block; margin-left: 6px; vertical-align: middle; }
.mnb-flag-img { width: 14px; height: 14px; border-radius: 2px; vertical-align: middle; }
.grill-flag { border-left-color: var(--orange); color: var(--orange); }
.col-cs { width: 80px; text-align: center; }
.col-help { width: 40px; text-align: center; }
.col-order-status { width: 165px; }
.th-sortable { cursor: pointer; user-select: none; white-space: nowrap; }
.th-sortable:hover { color: var(--fg); }
.sort-arrow { margin-left: 4px; opacity: 0.5; font-style: normal; }
.sort-arrow.active { opacity: 1; color: var(--blue); }
.val-range-wrap { display: flex; align-items: center; gap: 4px; white-space: nowrap; }
.val-range-wrap label { font-size: 11px; color: var(--muted); font-weight: 600; }
.val-range-input {
  width: 72px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  color: var(--fg);
  font-size: 12px;
  padding: 5px 7px;
  outline: none;
}
.val-range-input:focus { border-color: var(--blue); }
.help-btn {
  background: none;
  border: 1px solid var(--border);
  border-radius: 6px;
  cursor: pointer;
  font-size: 14px;
  padding: 4px 8px;
  vertical-align: middle;
  opacity: 0.4;
  transition: opacity .15s, border-color .15s, background .15s;
  white-space: nowrap;
}
.help-btn:hover { opacity: 0.8; }
.help-btn.help-on {
  opacity: 1;
  border-color: #f97316;
  background: rgba(249,115,22,0.22);
}
.cs-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: none;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  cursor: pointer;
  font-size: 14px;
  padding: 5px 10px;
  vertical-align: middle;
  opacity: 0.5;
  font-weight: 600;
  color: var(--muted);
  transition: opacity .15s, border-color .2s, background .2s, color .2s, box-shadow .2s;
  white-space: nowrap;
  letter-spacing: .3px;
}
.cs-btn:hover { opacity: 0.85; border-color: var(--red); color: var(--red); }
.cs-btn.cs-on {
  opacity: 1;
  border-color: var(--red);
  background: var(--red);
  color: #fff;
  box-shadow: 0 0 8px rgba(219,29,37,.45);
  font-weight: 700;
}
.col-status { width: 160px; }
.status-sel {
  width: 100%;
  padding: 4px 6px;
  border-radius: 4px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
}
.status-sel option { background: var(--surface); color: #fff; }
.st-new        { border-color: var(--green);  color: var(--green); background: rgba(39,192,90,.08); }
.st-pending    { border-color: var(--yellow); color: var(--yellow); }
.st-missing    { border-color: var(--red);    color: var(--red); background: rgba(219,29,37,.1); font-weight: 800; }
.st-under30    { border-color: var(--yellow); color: var(--yellow); }
.st-partial    { border-color: var(--blue);   color: var(--blue); background: rgba(59,130,246,.08); }
.st-prepped    { border-color: var(--green);  color: var(--green); background: rgba(39,192,90,.08); }
.st-driver     { border-color: var(--blue);   color: var(--blue); }
.st-scheduled  { border-color: var(--muted);  color: var(--muted); }
.st-shipline   { border-color: var(--green);  color: var(--green); background: rgba(39,192,90,.08); }
.st-highrisk   { border-color: #f97316; color: #f97316; background: rgba(249,115,22,.1); font-weight: 700; }
.st-none       { border-color: var(--border); color: var(--muted); background: transparent; opacity: 0.6; }

.status-dot {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  margin-right: 4px;
  vertical-align: middle;
}
.st-new .status-dot        { background: var(--green); }
.st-pending .status-dot    { background: var(--yellow); }
.st-missing .status-dot    { background: var(--red); animation: pulse .9s infinite; }
.st-under30 .status-dot    { background: var(--yellow); }
.st-partial .status-dot    { background: var(--blue); }
.col-note   { width: 40px; text-align: center; }
.note-ico   { cursor: help; font-size: 14px; }
.st-prepped .status-dot    { background: var(--green); }
.st-driver .status-dot     { background: var(--blue); }
.st-scheduled .status-dot  { background: var(--muted); }
.st-shipline .status-dot   { background: var(--green); }

/* ─── Home view ─────────────────────────────────────────────── */
.home-view { padding: 20px 24px 40px; }
.home-grid { max-width: 1200px; margin: 0 auto; }
.home-section { margin-bottom: 28px; }
.home-section h3 {
  font-size: 15px; font-weight: 700; color: #fff;
  margin: 0 0 12px; padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}
.summary-row {
  display: flex; flex-wrap: wrap; gap: 10px;
}
.summary-card {
  background: var(--lift); border: 1px solid var(--border);
  border-radius: 8px; padding: 14px 16px; min-width: 130px;
  flex: 1 1 130px; text-align: center;
}
.summary-card.sm { min-width: 100px; flex: 0 1 120px; padding: 10px 12px; }
.sc-val { font-size: 28px; font-weight: 900; color: #fff; line-height: 1.1; }
.sc-label { font-size: 11px; font-weight: 600; color: var(--muted); margin-top: 4px; text-transform: uppercase; letter-spacing: .3px; }
.sc-sub { font-size: 10px; color: var(--muted); margin-top: 2px; }
.summary-card.highlight { border-color: var(--green); }
.summary-card.highlight .sc-val { color: var(--green); }
.summary-card.sc-red { border-color: var(--red); }
.summary-card.sc-red .sc-val { color: var(--red); }
.summary-card.sc-yellow { border-color: var(--yellow); }
.summary-card.sc-yellow .sc-val { color: var(--yellow); }
.summary-card.sc-green { border-color: var(--green); }
.summary-card.sc-green .sc-val { color: var(--green); }
.summary-card.sc-blue { border-color: var(--blue); }
.summary-card.sc-blue .sc-val { color: var(--blue); }
.summary-card.sc-purple { border-color: #7c3aed; }
.summary-card.sc-purple .sc-val { color: #a78bfa; }
.summary-card.sc-gray { border-color: var(--muted); }
.summary-card.sc-gray .sc-val { color: var(--muted); }
.summary-card.sc-orange { border-color: var(--orange); }
.summary-card.sc-orange .sc-val { color: var(--orange); }
.sc-muted { opacity: .5; }
.summary-card.clickable { cursor: pointer; transition: transform .12s, border-color .12s; }
.summary-card.clickable:hover { transform: translateY(-2px); border-color: #fff; }

/* Legend */
.legend-section { margin-top: 10px; }
.legend-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 20px;
}
.legend-group { background: var(--lift); border: 1px solid var(--border); border-radius: 8px; padding: 16px; }
.legend-group h4 { font-size: 13px; font-weight: 700; color: #fff; margin: 0 0 12px; }
.legend-item {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 6px 0; border-bottom: 1px solid rgba(255,255,255,.05);
}
.legend-item:last-child { border-bottom: none; }
.legend-icon { font-size: 16px; min-width: 22px; text-align: center; flex-shrink: 0; padding-top: 1px; }
.legend-item strong { font-size: 12px; color: #fff; }
.legend-item p { font-size: 11px; color: var(--muted); margin: 2px 0 0; line-height: 1.4; }
.legend-dot {
  width: 12px; height: 12px; border-radius: 50%; border: 2px solid;
  flex-shrink: 0; margin-top: 3px;
}
.legend-dot.st-new     { border-color: var(--green); background: var(--green); }
.legend-dot.st-pending { border-color: var(--yellow); background: var(--yellow); }
.legend-dot.st-missing { border-color: var(--red); background: var(--red); }
.legend-dot.st-under30 { border-color: var(--yellow); background: var(--yellow); }
.legend-dot.st-partial { border-color: var(--blue); background: var(--blue); }
.legend-dot.st-prepped { border-color: var(--green); background: var(--green); }
.legend-dot.st-driver  { border-color: var(--blue); background: var(--blue); }
.legend-dot.st-scheduled { border-color: var(--muted); background: var(--muted); }
.color-swatch {
  display: inline-block;
  width: 14px; height: 14px;
  border-radius: 3px;
  vertical-align: middle;
}

/* Urgency dropdown */
.col-urgent { width: 96px; text-align: center; }
.urg-sel {
  appearance: none; -webkit-appearance: none;
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 3px 6px;
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  background: var(--surface);
  color: var(--text-muted);
  width: 86px;
  text-align: center;
  transition: border-color .15s, color .15s;
}
.urg-sel:focus { outline: none; }
.urg-sel.urg-sel-0 { color: var(--text-muted); border-color: var(--border); }
.urg-sel.urg-sel-1 { color: var(--yellow); border-color: var(--yellow); font-weight: 600; }
.urg-sel.urg-sel-2 { color: var(--orange); border-color: var(--orange); font-weight: 600; }
.urg-sel.urg-sel-3 { color: var(--red);    border-color: var(--red);    font-weight: 600; animation: urgPulse 1s infinite; }
@keyframes urgPulse { 0%,100%{opacity:1}50%{opacity:.55} }
.urg-ro { font-size: 11px; font-weight: 500; color: var(--text-muted); }
.urg-ro.urg-ro-1 { color: var(--yellow); }
.urg-ro.urg-ro-2 { color: var(--orange); }
.urg-ro.urg-ro-3 { color: var(--red); }

/* HubSpot flags */
.hs-contact-flag {
  display: inline-block; font-size: 11px; margin-left: 4px;
  cursor: help; animation: hsPulse 2s ease-in-out infinite;
}
.hs-negative-flag {
  display: inline-block; font-size: 12px; margin-left: 4px;
  cursor: help; animation: hsPulse 1.5s ease-in-out infinite;
  filter: drop-shadow(0 0 4px rgba(239,68,68,.6));
}
@keyframes hsPulse { 0%,100% { opacity: 1; } 50% { opacity: .6; } }

/* HubSpot orders list in Home tab */
.hs-orders-list { display: flex; flex-direction: column; gap: 8px; }
.hs-order-card {
  background: var(--lift); border: 1px solid var(--border); border-radius: 8px;
  padding: 12px 16px; cursor: pointer; transition: border-color .15s, transform .12s;
}
.hs-order-card:hover { border-color: var(--blue); transform: translateY(-1px); }
.hs-order-card.hs-neg { border-color: rgba(239,68,68,.4); background: rgba(239,68,68,.05); }
.hs-order-top {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.hs-order-top strong { font-size: 13px; color: #fff; }
.hs-cust { font-size: 12px; color: var(--muted); }
.hs-neg-badge { font-size: 10px; background: rgba(239,68,68,.2); color: #ef4444; padding: 1px 6px; border-radius: 4px; font-weight: 700; }
.hs-date { font-size: 11px; color: var(--muted); margin-left: auto; }
.hs-order-mid {
  display: flex; align-items: center; gap: 12px; margin-top: 4px; flex-wrap: wrap;
}
.hs-snippet { font-size: 11px; color: #a78bfa; flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hs-store { font-size: 10px; color: var(--muted); background: rgba(255,255,255,.05); padding: 1px 6px; border-radius: 3px; }
.hs-val { font-size: 11px; color: var(--green); font-weight: 600; }
.hs-channels { font-size: 10px; color: var(--purple); background: rgba(153,102,204,.1); padding: 1px 6px; border-radius: 3px; font-weight: 600; }
.hs-order-actions { margin-top: 6px; }
.card-ai-summary { margin-top: 8px; cursor: default; }
.hs-link {
  font-size: 11px; color: var(--blue); text-decoration: none; font-weight: 500;
  padding: 2px 8px; border: 1px solid var(--blue); border-radius: 4px;
  transition: background .12s;
}
.hs-link:hover { background: rgba(59,130,246,.15); }

.hs-drawer-actions {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 6px;
}
.hs-ai-btn {
  font-size: 11px; font-weight: 600; padding: 2px 10px;
  border: 1px solid var(--purple); border-radius: 4px; cursor: pointer;
  color: var(--purple); background: transparent; transition: background .12s, opacity .12s;
}
.hs-ai-btn:hover:not(:disabled) { background: rgba(139,92,246,.12); }
.hs-ai-btn:disabled { opacity: .55; cursor: default; }
.hs-ai-result {
  margin-top: 8px; padding: 10px 12px;
  background: rgba(139,92,246,.08); border-left: 3px solid var(--purple);
  border-radius: 0 6px 6px 0; font-size: 12px; line-height: 1.6; color: var(--text);
  white-space: pre-wrap;
}
.hs-ai-result.hs-ai-loading {
  color: var(--muted); font-style: italic;
  animation: aiFade 1.2s ease-in-out infinite alternate;
}
.hs-ai-result.hs-ai-error {
  background: rgba(239,68,68,.07); border-left-color: var(--red); color: var(--red);
}
@keyframes aiFade { from { opacity: .5; } to { opacity: 1; } }

/* (legacy card classes removed — using sc-red/sc-yellow/etc now) */

/* Table row HubSpot snippet */
.hs-row-snippet {
  font-size: 10px;
  color: #a78bfa;
  margin-top: 3px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 220px;
  font-style: italic;
}

/* Mobile card HubSpot summary block */
.mc-hs-summary {
  border-left: 3px solid #a78bfa;
  padding: 6px 10px;
  margin: 6px 0;
  background: rgba(167,139,250,.06);
  border-radius: 0 6px 6px 0;
}
.mc-hs-summary.mc-hs-neg {
  border-left-color: var(--red);
  background: rgba(239,68,68,.06);
}
.mc-hs-snippet {
  font-size: 11px;
  color: #a78bfa;
  font-style: italic;
  margin-bottom: 4px;
}
.mc-hs-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 10px;
  flex-wrap: wrap;
}

/* Drawer HubSpot section */
.hs-drawer-section {
  border-left: 3px solid #a78bfa;
  padding-left: 12px;
}
.hs-drawer-section.hs-neg { border-left-color: var(--red); }
.hs-drawer-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}
.hs-drawer-title { font-weight: 700; font-size: 13px; }
.hs-drawer-snippet {
  font-size: 12px;
  color: #a78bfa;
  font-style: italic;
  margin-bottom: 6px;
}
.hs-drawer-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

/* State cells */
.state-cell { text-align: center; padding: 40px !important; color: var(--muted); font-size: 14px; }
.loading-cell { display: table-cell; }
.spinner {
  display: inline-block;
  width: 18px; height: 18px;
  border: 2px solid var(--border);
  border-top-color: var(--red);
  border-radius: 50%;
  animation: spin .7s linear infinite;
  vertical-align: middle;
  margin-right: 8px;
}

/* Urgency dot (row-level indicator only) */
.u-dot {
  width: 9px; height: 9px;
  border-radius: 50%;
  display: inline-block;
}
.u-dot.ud-0        { background: var(--border); }
.u-dot.ud-1        { background: var(--yellow); }
.u-dot.ud-2        { background: var(--orange); }
.u-dot.ud-3        { background: var(--red); animation: pulse .9s infinite; }
@keyframes pulse   { 0%,100%{opacity:1}50%{opacity:.3} }

/* Tier badges — purple saturation hierarchy */
.tier-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
  letter-spacing: .2px;
}
.t-vvip   { background: #7c3aed; color: #fff; border: 1px solid #a78bfa; }
.t-vip    { background: #3b1f7a; color: #c4b5fd; border: 1px solid #6d48c4; }
.t-gold   { background: #2a1854; color: #a78bfa; border: 1px solid #5b38a0; }
.t-member { background: #1e1040; color: #8b7fbd; border: 1px solid #3d2d6b; }
.t-review { background: #171024; color: #6b6183; border: 1px solid #2d2545; }

/* Type badges — shape: rounded pill, color by meaning */
.type-badge {
  display: inline-block;
  padding: 3px 7px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 600;
  border: 1px solid transparent;
}
.tt-sched  { background: rgba(119,119,119,.15); color: var(--muted); border-color: var(--border); }
.tt-pick   { background: rgba(39,192,90,.1);    color: var(--green); border-color: rgba(39,192,90,.3); }
.tt-same   { background: rgba(212,160,23,.1);   color: var(--yellow); border-color: rgba(212,160,23,.3); }
.tt-local  { background: rgba(59,144,224,.1);   color: var(--blue);  border-color: rgba(59,144,224,.3); }
.tt-ship   { background: rgba(59,144,224,.1);   color: var(--blue);  border-color: rgba(59,144,224,.3); }
.tt-other  { background: var(--lift); color: var(--muted); border-color: var(--border); }

/* Customer cell */
.cust-name  { font-weight: 600; font-size: 13px; }
.cust-badge {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .3px;
  margin-top: 1px;
  display: block;
}
.cust-new  { color: var(--green); }
.cust-ret  { color: var(--muted); }

/* Partial fulfillment flag — yellow/warning */
.partial-flag {
  display: inline-block;
  margin-top: 2px;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 10px;
  font-weight: 600;
  border-left: 3px solid var(--yellow);
  background: rgba(255,255,255,.04);
  color: var(--yellow);
  white-space: nowrap;
}

/* Open balance flag — red/problem */
.balance-flag {
  display: inline-block;
  margin-top: 2px;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 10px;
  font-weight: 600;
  border-left: 3px solid var(--red);
  background: rgba(255,255,255,.04);
  color: var(--red);
  white-space: nowrap;
}

/* Note icons */
.note-ico { font-size: 14px; cursor: default; }

/* Value cell */
.val-cell { font-weight: 700; font-size: 13px; text-align: right; }

/* Delivery cell */
.deliv-date { font-size: 13px; }
.deliv-win  { font-size: 11px; color: var(--muted); display: block; }

/* ─── Drawer ─────────────────────────────────────────────────── */
.drawer-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 299;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s;
}
.drawer-backdrop.open { opacity: 1; pointer-events: all; }

.drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: 440px;
  max-width: 100vw;
  height: 100vh;
  background: var(--card);
  border-left: 1px solid var(--border);
  z-index: 300;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform .28s cubic-bezier(.4,0,.2,1);
  overflow: hidden;
}
.drawer.open { transform: translateX(0); }

.drawer-header {
  padding: 16px 18px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  background: var(--surface);
  flex-shrink: 0;
}
.drawer-order-num { font-family: 'Barlow Condensed', sans-serif; font-size: 22px; font-weight: 900; line-height: 1; }
.drawer-close {
  background: none;
  border: 1px solid var(--border);
  color: var(--muted);
  cursor: pointer;
  width: 28px; height: 28px;
  border-radius: 4px;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.drawer-close:hover { color: var(--text); background: var(--lift); }

.drawer-body { flex: 1; overflow-y: auto; padding: 16px 18px; display: flex; flex-direction: column; gap: 18px; }
.drawer-body::-webkit-scrollbar { width: 5px; }
.drawer-body::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

/* Drawer sections */
.d-section h4 {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: var(--muted);
  margin-bottom: 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}
.d-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.d-field label { font-size: 10px; font-weight: 700; text-transform: uppercase; color: var(--muted); display: block; margin-bottom: 2px; }
.d-field span  { font-size: 13px; }

/* Urgency buttons */
.urg-btns { display: flex; gap: 6px; flex-wrap: wrap; }
.urg-btn {
  background: var(--lift);
  border: 1px solid var(--border);
  color: var(--muted);
  padding: 5px 12px;
  border-radius: var(--r);
  cursor: pointer;
  font-family: 'Barlow', sans-serif;
  font-size: 12px;
  font-weight: 600;
  transition: all .15s;
}
.urg-btn:hover         { border-color: var(--text); color: var(--text); }
.urg-btn.active-0      { border-color: var(--border-hi); color: var(--text); background: var(--lift); }
.urg-btn.active-1      { border-color: var(--yellow); color: var(--yellow); background: #2a2000; }
.urg-btn.active-2      { border-color: var(--orange); color: var(--orange); background: #2a1000; }
.urg-btn.active-3      { border-color: var(--red);    color: var(--red);    background: #2a0000; }

/* Note box */
.note-box {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 10px;
  font-size: 13px;
  line-height: 1.5;
  min-height: 38px;
  color: var(--text);
  white-space: pre-wrap;
}
.note-box.empty { color: var(--dim); font-style: italic; }

/* Textarea / inputs */
textarea, .d-input {
  width: 100%;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  color: var(--text);
  padding: 8px 10px;
  font-family: 'Barlow', sans-serif;
  font-size: 13px;
  resize: none;
  outline: none;
}
textarea:focus, .d-input:focus { border-color: var(--red); }

.btn-save {
  background: var(--red);
  border: none;
  color: #fff;
  padding: 7px 16px;
  border-radius: var(--r);
  cursor: pointer;
  font-family: 'Barlow', sans-serif;
  font-size: 13px;
  font-weight: 700;
  margin-top: 6px;
  transition: background .15s;
}
.btn-save:hover { background: var(--red-dk); }
.btn-save.saved { background: #27c05a; }

/* Comment thread */
.comment-thread { display: flex; flex-direction: column; gap: 8px; }
.comment-item {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 8px 10px;
}
.comment-meta { font-size: 10px; color: var(--muted); margin-bottom: 4px; }
.comment-meta strong { color: var(--text); font-weight: 700; }
.comment-body { font-size: 13px; line-height: 1.5; }
.comment-input-row { display: flex; flex-direction: column; gap: 6px; margin-top: 8px; }
.comment-name-row { display: flex; gap: 6px; }
.comment-name-row input {
  flex: 1;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  color: var(--text);
  padding: 7px 10px;
  font-family: 'Barlow', sans-serif;
  font-size: 13px;
  outline: none;
}
.comment-name-row input:focus { border-color: var(--red); }
.no-comments { font-size: 12px; color: var(--dim); font-style: italic; }

/* Tags */
.tags-list { display: flex; flex-wrap: wrap; gap: 4px; }
.tag-chip {
  background: var(--lift);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 2px 8px;
  font-size: 11px;
  color: var(--muted);
}

/* Scrollbar */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--surface); }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--border-hi); }

.first-order-badge {
  display: inline-block;
  background: #1a472a;
  color: #4ade80;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 4px;
  letter-spacing: 0.5px;
}
.col-ords, .col-lastord { text-align: center; min-width: 50px; }
.sentiment-icon { font-size: 14px; vertical-align: middle; margin-left: 2px; }

.filter-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  margin: 8px 0 4px 0;
  background: var(--accent);
  color: #fff;
  border-radius: 6px;
  font-size: 13px;
}
.filter-clear {
  background: rgba(255,255,255,0.2);
  border: none;
  color: #fff;
  font-size: 16px;
  cursor: pointer;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  padding: 0;
}
.filter-clear:hover { background: rgba(255,255,255,0.4); }

.summary-card.clickable { cursor: pointer; transition: transform 0.15s, box-shadow 0.15s; }
.summary-card.clickable:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.3); }

.hs-sentiment-badge { font-size: 14px; margin-left: 4px; }
.hs-order-bottom {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 4px;
  font-size: 12px;
}
.hs-interactions {
  color: var(--accent);
  font-weight: 600;
}

/* Notification bell */
.notif-bell {
  position: relative;
  background: var(--lift);
  border: 1px solid var(--border-hi);
  color: var(--text);
  width: 36px; height: 36px;
  border-radius: var(--r);
  cursor: pointer;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .15s;
  flex-shrink: 0;
}
.notif-bell:hover { border-color: var(--accent); }
.notif-badge {
  position: absolute;
  top: -4px; right: -4px;
  background: var(--red);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  min-width: 16px; height: 16px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  line-height: 1;
  pointer-events: none;
}
.notif-panel {
  position: absolute;
  top: 52px;
  right: 0;
  width: 360px;
  max-height: 420px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: 0 8px 32px rgba(0,0,0,.5);
  z-index: 250;
  display: none;
  flex-direction: column;
  overflow: hidden;
}
.notif-panel.open { display: flex; }
.notif-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
}
.notif-mark-all {
  background: none;
  border: none;
  color: var(--accent);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
}
.notif-mark-all:hover { text-decoration: underline; }
.notif-panel-body {
  overflow-y: auto;
  flex: 1;
  max-height: 360px;
}
.notif-empty { padding: 20px; text-align: center; color: var(--muted); font-size: 12px; }
.notif-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background .1s;
}
.notif-item:hover { background: var(--lift); }
.notif-item:last-child { border-bottom: none; }
.notif-item.unread { background: rgba(59,144,224,.06); border-left: 3px solid var(--accent); }
.notif-item-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.notif-sender { font-size: 12px; font-weight: 700; color: var(--text); }
.notif-time { font-size: 10px; color: var(--muted); white-space: nowrap; }
.notif-order { font-size: 11px; color: var(--accent); font-weight: 600; }
.notif-body { font-size: 11px; color: var(--muted); line-height: 1.4; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 320px; }
.notif-mark-btn {
  background: none;
  border: none;
  color: var(--muted);
  font-size: 10px;
  cursor: pointer;
  padding: 2px 4px;
  font-family: inherit;
  align-self: flex-end;
}
.notif-mark-btn:hover { color: var(--accent); }

/* @mention dropdown */
.mention-dropdown {
  position: absolute;
  bottom: 100%;
  left: 0;
  width: 100%;
  max-height: 160px;
  overflow-y: auto;
  background: var(--card);
  border: 1px solid var(--border-hi);
  border-radius: var(--r);
  box-shadow: 0 -4px 16px rgba(0,0,0,.4);
  z-index: 10;
  display: none;
}
.mention-dropdown.open { display: block; }
.mention-item {
  padding: 7px 12px;
  font-size: 13px;
  cursor: pointer;
  color: var(--text);
  transition: background .1s;
}
.mention-item:hover, .mention-item.active { background: var(--lift); color: var(--accent); }

/* Styled @mention in comment body */
.mention-tag {
  color: var(--accent);
  font-weight: 700;
  background: rgba(59,144,224,.1);
  padding: 0 3px;
  border-radius: 3px;
}

/* Comment input wrapper for mention dropdown positioning */
.comment-input-wrap { position: relative; }

[data-theme="light"] .notif-bell { background: #fff; border-color: #ccc; color: #333; }
[data-theme="light"] .notif-panel { background: #fff; border-color: #ddd; box-shadow: 0 8px 32px rgba(0,0,0,.15); }
[data-theme="light"] .notif-item.unread { background: rgba(42,109,181,.06); }
[data-theme="light"] .mention-dropdown { background: #fff; border-color: #ccc; box-shadow: 0 -4px 16px rgba(0,0,0,.1); }
[data-theme="light"] .mention-item:hover, [data-theme="light"] .mention-item.active { background: #f3f4f6; }

/* Theme toggle button */
.theme-btn {
  background: var(--lift);
  border: 1px solid var(--border-hi);
  color: var(--text);
  width: 36px; height: 36px;
  border-radius: var(--r);
  cursor: pointer;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .15s;
  flex-shrink: 0;
}
.theme-btn:hover { border-color: var(--accent); }

/* ─── LIGHT THEME ────────────────────────────────────────────── */
:root[data-theme="light"] {
  --red:       #c41922;
  --red-dk:    #a5161b;
  --black:     #f5f5f5;
  --surface:   #ffffff;
  --card:      #fafafa;
  --lift:      #f0f0f0;
  --border:    #dcdcdc;
  --border-hi: #bbb;
  --text:      #1a1a1a;
  --muted:     #666;
  --dim:       #999;

  --gold:    #b8860b;
  --green:   #1a8a3e;
  --orange:  #c85d1e;
  --yellow:  #b38b00;
  --blue:    #2a6db5;
  --purple:  #7a4db5;
  --accent:  #2a6db5;
}

[data-theme="light"] body { background: #f5f5f5; color: #1a1a1a; }

[data-theme="light"] .header { background: #fff; border-bottom: 2px solid var(--red); }
[data-theme="light"] .store-tabs { background: #fff; }
[data-theme="light"] .tab.active { color: var(--red); border-bottom-color: var(--red); }
[data-theme="light"] .tab-count { background: #eee; }

[data-theme="light"] .orders-table thead tr { background: #f4f4f4; }
[data-theme="light"] .orders-table th { color: #555; border-bottom: 1px solid #ddd; }
[data-theme="light"] .orders-table td { border-bottom: 1px solid #eee; }
[data-theme="light"] .orders-table tbody tr { background: #fff; }
[data-theme="light"] .orders-table tbody tr:hover { background: #f7f7f7; }

[data-theme="light"] .status-sel { background: #fff; color: #1a1a1a; border: 1px solid #ccc; }
[data-theme="light"] .status-sel option { background: #fff; color: #1a1a1a; }

[data-theme="light"] .st-new     { border-color: var(--green); color: var(--green); background: rgba(26,138,62,.06); }
[data-theme="light"] .st-pending { border-color: var(--yellow); color: var(--yellow); }
[data-theme="light"] .st-missing { border-color: var(--red); color: var(--red); background: rgba(196,25,34,.06); }
[data-theme="light"] .st-prepped { border-color: var(--green); color: var(--green); background: rgba(26,138,62,.06); }
[data-theme="light"] .st-shipline { border-color: var(--green); color: var(--green); background: rgba(26,138,62,.06); }

[data-theme="light"] .t-vvip   { background: #7c3aed; color: #fff; }
[data-theme="light"] .t-vip    { background: #ede9fe; color: #5b21b6; border-color: #c4b5fd; }
[data-theme="light"] .t-gold   { background: #f3e8ff; color: #6d28d9; border-color: #d8b4fe; }
[data-theme="light"] .t-member { background: #f5f3ff; color: #7c3aed; border-color: #e9d5ff; }
[data-theme="light"] .t-review { background: #f9f5ff; color: #9ca3af; border-color: #e5e7eb; }

[data-theme="light"] .type-badge { border: 1px solid; }
[data-theme="light"] .tt-sched { background: #f3f4f6; color: #666; border-color: #d1d5db; }
[data-theme="light"] .tt-pick  { background: #ecfdf5; color: var(--green); border-color: #a7f3d0; }
[data-theme="light"] .tt-same  { background: #fefce8; color: var(--yellow); border-color: #fde68a; }
[data-theme="light"] .tt-local { background: #eff6ff; color: var(--blue); border-color: #bfdbfe; }
[data-theme="light"] .tt-ship  { background: #eff6ff; color: var(--blue); border-color: #bfdbfe; }
[data-theme="light"] .tt-other { background: #f3f4f6; color: #888; border-color: #e5e7eb; }

[data-theme="light"] .summary-card { background: #fff; border: 1px solid #ddd; }
[data-theme="light"] .sc-val { color: #1a1a1a; }
[data-theme="light"] .summary-card.highlight .sc-val { color: var(--green); }
[data-theme="light"] .summary-card.sc-red .sc-val { color: var(--red); }
[data-theme="light"] .summary-card.sc-yellow .sc-val { color: var(--yellow); }
[data-theme="light"] .summary-card.sc-blue .sc-val { color: var(--blue); }
[data-theme="light"] .summary-card.sc-purple .sc-val { color: var(--purple); }
[data-theme="light"] .summary-card.sc-gray .sc-val { color: #666; }
[data-theme="light"] .summary-card.sc-orange .sc-val { color: var(--orange); }
[data-theme="light"] .summary-card.clickable:hover { border-color: var(--accent); box-shadow: 0 2px 8px rgba(0,0,0,.08); }

[data-theme="light"] .tag-strip { background: rgba(0,0,0,.04); }
[data-theme="light"] .partial-flag { background: rgba(0,0,0,.04); }
[data-theme="light"] .balance-flag { background: rgba(0,0,0,.04); }

[data-theme="light"] .drawer { background: #fff; border-left: 1px solid #ddd; }
[data-theme="light"] .drawer-header { background: #f9f9f9; }
[data-theme="light"] .drawer-close { border-color: #ddd; color: #888; }
[data-theme="light"] .drawer-close:hover { background: #eee; color: #333; }
[data-theme="light"] .d-section h4 { color: #888; border-bottom-color: #eee; }

[data-theme="light"] .home-section h3 { color: #1a1a1a; border-bottom-color: #ddd; }
[data-theme="light"] .legend-group { background: #fff; border-color: #ddd; }
[data-theme="light"] .legend-group h4 { color: #333; }
[data-theme="light"] .legend-item strong { color: #1a1a1a; }
[data-theme="light"] .legend-item { border-bottom-color: #f0f0f0; }

[data-theme="light"] .hs-order-card { background: #fff; border-color: #ddd; }
[data-theme="light"] .hs-order-card:hover { border-color: var(--accent); }
[data-theme="light"] .hs-order-card.hs-neg { background: #fef2f2; border-color: #fca5a5; }
[data-theme="light"] .hs-order-top strong { color: #1a1a1a; }
[data-theme="light"] .hs-snippet { color: var(--purple); }
[data-theme="light"] .hs-row-snippet { color: var(--purple); }
[data-theme="light"] .mc-hs-snippet { color: var(--purple); }
[data-theme="light"] .hs-drawer-snippet { color: var(--purple); }
[data-theme="light"] .mc-hs-summary { background: rgba(153,102,204,.06); }
[data-theme="light"] .hs-drawer-section { border-left-color: var(--purple); }

[data-theme="light"] #searchInput { background: #fff; border-color: #ccc; color: #1a1a1a; }
[data-theme="light"] #searchInput::placeholder { color: #aaa; }
[data-theme="light"] .filter-group select { background: #fff; border-color: #ccc; color: #1a1a1a; }

[data-theme="light"] .sync-btn { background: #fff; border-color: #ccc; color: #333; }
[data-theme="light"] .sync-btn:hover { border-color: var(--red); color: var(--red); }
[data-theme="light"] .theme-btn { background: #fff; border-color: #ccc; color: #333; }

[data-theme="light"] .filter-badge { background: var(--accent); color: #fff; }

[data-theme="light"] .cs-btn { border-color: #ddd; color: #666; }
[data-theme="light"] .cs-btn.cs-on { background: var(--red); border-color: var(--red); color: #fff; box-shadow: 0 0 8px rgba(219,29,37,.35); }
[data-theme="light"] .help-btn { border-color: #ddd; }
[data-theme="light"] .help-btn.help-on { background: rgba(249,115,22,.1); border-color: var(--orange); }

[data-theme="light"] .urg-btn { background: #f3f4f6; border-color: #d1d5db; }
[data-theme="light"] .urg-btn.active-0 { background: #f3f4f6; }
[data-theme="light"] .urg-btn.active-1 { background: rgba(179,139,0,.08); border-color: var(--yellow); }
[data-theme="light"] .urg-btn.active-2 { background: rgba(200,93,30,.08); border-color: var(--orange); }
[data-theme="light"] .urg-btn.active-3 { background: rgba(196,25,34,.08); border-color: var(--red); }

[data-theme="light"] .cust-name { color: #1a1a1a; }
[data-theme="light"] .val-cell { color: #1a1a1a; }
[data-theme="light"] .deliv-date { color: #1a1a1a; }

[data-theme="light"] .first-order-badge { background: #ecfdf5; color: var(--green); }

[data-theme="light"] .stat-divider { background: #ddd; }
[data-theme="light"] .logo-img { background: #1a1a1a; padding: 3px; border-radius: 6px; }

[data-theme="light"] .toggle-track { background: #ddd; border-color: #bbb; }
[data-theme="light"] .toggle-track::after { background: #999; }

[data-theme="light"] .table-scroll { border-color: #ddd; }

[data-theme="light"] .drawer-backdrop.open { background: rgba(0,0,0,.25); }

[data-theme="light"] .hs-drawer-section { border-left-color: var(--purple); }

/* ─── Mobile cards (hidden by default, shown at ≤768px) ───── */
.mobile-cards { display: none; flex-direction: column; gap: 10px; }
.m-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 14px 16px;
  cursor: pointer;
  transition: border-color .15s;
}
.m-card:active { border-color: var(--accent); }
.m-card.mc-urg-1 { border-left: 3px solid var(--yellow); }
.m-card.mc-urg-2 { border-left: 3px solid var(--orange); }
.m-card.mc-urg-3 { border-left: 3px solid var(--red); }
.mc-top {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.mc-order { font-size: 15px; color: var(--text); }
.mc-val { margin-left: auto; font-weight: 700; font-size: 15px; color: var(--text); }
.mc-customer { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; min-width: 0; }
.mc-customer .cust-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
.mc-meta {
  display: flex; align-items: center; gap: 6px;
  flex-wrap: wrap; font-size: 12px; margin-bottom: 6px;
}
.mc-store { color: var(--muted); }
.mc-date  { color: var(--muted); }
.mc-days  { font-weight: 700; font-size: 12px; }
.mc-flags { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 6px; }
.mc-actions {
  display: flex; align-items: center; gap: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--border);
}
.mc-actions .status-sel { flex: 1; font-size: 13px; }
.mc-btns { display: flex; gap: 4px; }

[data-theme="light"] .m-card { background: #fff; }
[data-theme="light"] .mc-order { color: #1a1a1a; }
[data-theme="light"] .mc-val { color: #1a1a1a; }
[data-theme="light"] .mc-actions { border-top-color: #eee; }

/* ─── Responsive ─────────────────────────────────────────────── */
@media (max-width: 768px) {
  .header-stats { display: none; }
  .drawer { width: 100vw; }

  .header-inner {
    padding: 8px 12px;
    gap: 10px;
  }
  .logo-title { font-size: 13px; }
  .sync-btn { padding: 6px 10px; font-size: 12px; }
  .sync-btn svg { width: 14px; height: 14px; }
  .last-updated { font-size: 9px; }

  .store-tabs {
    padding: 0 10px;
    top: 44px;
  }
  .tab { padding: 8px 12px; font-size: 12px; }

  .toolbar {
    padding: 0 12px;
    margin: 8px auto;
    gap: 8px;
  }
  .search-wrap { min-width: 0; width: 100%; flex: none; }
  #searchInput { font-size: 14px; padding: 10px 12px 10px 32px; }
  .filter-group { width: 100%; }
  .filter-group select { flex: 1; font-size: 13px; }

  .main { padding: 0 12px 40px; }

  .table-scroll { display: none !important; }
  .mobile-cards.mc-active { display: flex !important; }

  .home-view { padding: 12px 0 30px; }
  .summary-card { min-width: 0; flex: 1 1 calc(50% - 6px); padding: 10px 10px; }
  .summary-card.sm { min-width: 0; flex: 1 1 calc(50% - 6px); }
  .sc-val { font-size: 22px; }
  .sc-label { font-size: 10px; }
  .legend-grid { grid-template-columns: 1fr; gap: 12px; }

  .hs-order-card { padding: 10px 12px; }
  .hs-order-top { gap: 6px; }
  .hs-date { margin-left: 0; font-size: 10px; }
  .hs-order-mid { gap: 6px; }

  .d-grid { grid-template-columns: 1fr; }
  .drawer-header { padding: 12px 14px; }
  .drawer-body { padding: 12px 14px; }
  .drawer-order-num { font-size: 18px; }

  .m-card .cs-btn,
  .m-card .help-btn {
    min-width: 40px;
    min-height: 40px;
    font-size: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .m-card .urg-sel {
    min-height: 38px;
    font-size: 12px;
    width: 96px;
  }
  .mc-actions .status-sel {
    min-height: 40px;
    font-size: 14px;
  }

  .mc-top { overflow: hidden; }
  .mc-top .tier-badge { flex-shrink: 0; font-size: 10px; }
  .mc-order { white-space: nowrap; }
}

@media (max-width: 400px) {
  .header-inner { gap: 6px; padding: 6px 8px; }
  .logo-img { width: 28px; height: 28px; }
  .logo-title { font-size: 12px; }
  .theme-btn { width: 30px; height: 30px; font-size: 14px; }
  .sync-btn { padding: 5px 8px; font-size: 11px; gap: 4px; }
  .store-tabs { top: 38px; }
  .tab { padding: 6px 10px; font-size: 11px; }
  .summary-card { flex: 1 1 100%; }
  .summary-card.sm { flex: 1 1 100%; }
  .m-card { padding: 12px; }
}

/* ─── Admin Nav ──────────────────────────────────────────────── */
.admin-nav {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: 0 20px;
  display: flex;
  gap: 4px;
  align-items: center;
}
.admin-nav-btn {
  background: none;
  border: none;
  border-bottom: 3px solid transparent;
  color: var(--muted);
  padding: 10px 16px;
  cursor: pointer;
  font-family: 'Barlow', sans-serif;
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
  transition: all .15s;
}
.admin-nav-btn:hover { color: var(--text); }
.admin-nav-btn.active { color: var(--accent); border-bottom-color: var(--accent); }
[data-theme="light"] .admin-nav { background: #fff; }

/* ─── Admin Panel ────────────────────────────────────────────── */
.admin-panel { padding: 20px; }
.admin-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.admin-panel-header h2 {
  font-size: 18px;
  font-weight: 700;
}
.admin-panel-note {
  font-size: 12px;
  color: #888;
  margin-bottom: 14px;
  line-height: 1.5;
}
.admin-panel-note strong { color: #ccc; }
.admin-table { min-width: 600px; }
.admin-table th { font-size: 11px; }
.admin-table td { font-size: 13px; }

.role-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 700;
}
.role-admin { background: rgba(219,29,37,.15); color: var(--red); }
.role-cs { background: rgba(59,144,224,.15); color: var(--blue); }
.role-user { background: rgba(39,192,90,.15); color: var(--green); }
.role-viewer { background: rgba(119,119,119,.15); color: var(--muted); }

.status-active { color: var(--green); font-weight: 600; }
.status-deactivated { color: var(--red); font-weight: 600; }

.edit-user-btn {
  background: var(--lift);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 4px 10px;
  border-radius: var(--r);
  cursor: pointer;
  font-family: 'Barlow', sans-serif;
  font-size: 12px;
  font-weight: 600;
  transition: border-color .15s;
}
.edit-user-btn:hover { border-color: var(--accent); color: var(--accent); }

/* ─── Activity log filters ───────────────────────────────────── */
.activity-filters {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 12px;
}
.activity-filters .d-input {
  flex: 1;
  min-width: 120px;
  max-width: 200px;
}
.activity-filters .btn-save {
  margin-top: 0;
}

.pagination {
  display: flex;
  gap: 6px;
  align-items: center;
  justify-content: center;
  padding: 12px 0;
}
.page-btn {
  background: var(--lift);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 6px 12px;
  border-radius: var(--r);
  cursor: pointer;
  font-family: 'Barlow', sans-serif;
  font-size: 12px;
  font-weight: 600;
  transition: border-color .15s;
}
.page-btn:hover { border-color: var(--accent); }
.page-btn:disabled { opacity: .4; cursor: default; }
.page-info {
  font-size: 12px;
  color: var(--muted);
  padding: 0 8px;
}

/* ─── Modal ──────────────────────────────────────────────────── */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 400;
  display: flex;
  align-items: center;
  justify-content: center;
}
.modal {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  width: 400px;
  max-width: 90vw;
  max-height: 90vh;
  overflow-y: auto;
}
.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
}
.modal-header h3 {
  font-size: 16px;
  font-weight: 700;
}
.modal-body {
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.modal-field label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 4px;
}
.modal-error {
  color: var(--red);
  font-size: 12px;
  font-weight: 600;
  min-height: 16px;
}
[data-theme="light"] .modal { background: #fff; border-color: #ddd; }
[data-theme="light"] .modal-header { border-bottom-color: #eee; }

/* ─── User role badge in header ──────────────────────────────── */
.user-role-badge {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  padding: 2px 6px;
  border-radius: 4px;
  background: rgba(59,144,224,.15);
  color: var(--accent);
}

/* ─── Viewer disabled state ──────────────────────────────────── */
.viewer-disabled {
  opacity: .4 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}
.viewer-disabled-select {
  opacity: .5;
  pointer-events: none;
  cursor: not-allowed;
}

.site-footer {
  text-align: center;
  padding: 18px 16px 22px;
  border-top: 1px solid var(--border);
  margin-top: 32px;
}
.footer-inner {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 13px;
}
.footer-inner a {
  color: var(--muted);
  text-decoration: none;
  transition: color .15s;
}
.footer-inner a:hover {
  color: var(--red);
}
.footer-sep {
  color: var(--border);
}

/* ── PWA Install Banner ──────────────────────────────────────── */
.pwa-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: #1a1a1e;
  border-top: 1px solid #c8a96e55;
  box-shadow: 0 -4px 24px rgba(0,0,0,.45);
  animation: pwa-slide-up .35s ease;
}
@keyframes pwa-slide-up {
  from { transform: translateY(100%); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}
.pwa-banner-icon {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  object-fit: contain;
  background: #111;
  flex-shrink: 0;
}
.pwa-banner-text {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.pwa-banner-text strong {
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
}
.pwa-banner-text span {
  font-size: 12px;
  color: #999;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pwa-banner-btn {
  flex-shrink: 0;
  background: #c8a96e;
  color: #0e0e10;
  border: none;
  border-radius: 8px;
  padding: 8px 18px;
  font-family: 'Barlow', sans-serif;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: background .15s;
}
.pwa-banner-btn:hover { background: #d4b97e; }
.pwa-banner-dismiss {
  flex-shrink: 0;
  background: none;
  border: none;
  color: #555;
  font-size: 18px;
  cursor: pointer;
  padding: 4px 6px;
  line-height: 1;
  transition: color .15s;
}
.pwa-banner-dismiss:hover { color: #aaa; }
@media (max-width: 480px) {
  .pwa-banner-text span { display: none; }
}
