*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#F2EFE9;
  --paper:#FFFFFF;
  --paper2:#FAF8F5;
  --border:#E2DDD6;
  --border2:#CBC5BC;
  --text:#1A1815;
  --text2:#4A4640;
  --muted:#8A8480;
  --navy:#1B2F4E;
  --navy2:#243B5E;
  --gold:#B8891A;
  --gold-light:#F5E9C8;
  --emerald:#1B6B3A;
  --emerald-light:#D4EDE0;
  --crimson:#952020;
  --crimson-light:#FADADD;
  --sapphire:#1B4F8A;
  --shadow:0 1px 3px rgba(0,0,0,.07),0 4px 16px rgba(0,0,0,.05);
  --shadow-md:0 2px 8px rgba(0,0,0,.08),0 8px 24px rgba(0,0,0,.06);
}

body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  font-size:13.5px;
  line-height:1.5;
}

/* ─── Upload ─────────────────────────────────────────────────── */
#upload-screen{
  display:flex;align-items:center;justify-content:center;
  min-height:100vh;padding:2rem;background:var(--bg);
}
.upload-card{
  background:var(--paper);border:1px solid var(--border);
  border-radius:16px;padding:3.5rem 3rem;text-align:center;
  max-width:460px;width:100%;box-shadow:var(--shadow-md);
}
.upload-card .brand-mark{
  width:56px;height:56px;border-radius:14px;
  background:var(--navy);color:#fff;
  font-family:'Inter',sans-serif;font-size:1.6rem;font-weight:700;
  display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:1.5rem;
}
.upload-card h1{
  font-family:'Inter',sans-serif;font-size:1.8rem;
  font-weight:600;color:var(--text);margin-bottom:.4rem;
}
.upload-card p{color:var(--muted);font-size:.85rem;line-height:1.6}
#xml-input{display:none}
.upload-btn{
  display:inline-flex;align-items:center;gap:.6rem;
  background:var(--navy);color:#fff;font-weight:500;
  padding:.8rem 1.8rem;border-radius:8px;cursor:pointer;
  font-size:.9rem;letter-spacing:.01em;margin-top:1.8rem;
  transition:background .2s;border:none;
}
.upload-btn:hover{background:var(--navy2)}
.upload-note{
  color:var(--muted);font-size:.75rem;margin-top:1.2rem;
  padding-top:1.2rem;border-top:1px solid var(--border);line-height:1.6;
}

/* ─── Loading ────────────────────────────────────────────────── */
#loading-screen{
  display:none;align-items:center;justify-content:center;
  min-height:100vh;flex-direction:column;gap:1rem;background:var(--bg);
}
.spinner{
  width:40px;height:40px;
  border:3px solid var(--border);border-top-color:var(--navy);
  border-radius:50%;animation:spin 1s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
#loading-text{color:var(--muted);font-size:.85rem;letter-spacing:.02em}

/* ─── Dashboard shell ────────────────────────────────────────── */
#dashboard{display:none;min-height:100vh}

/* ─── Topbar ─────────────────────────────────────────────────── */
.topbar{
  background:var(--navy);color:#fff;
  padding:0 2rem;
  display:flex;align-items:center;justify-content:space-between;
  height:56px;position:sticky;top:0;z-index:100;
}
.topbar-brand{display:flex;align-items:center;gap:.9rem}
.topbar-logo{
  width:32px;height:32px;border-radius:8px;
  background:rgba(255,255,255,.15);
  font-family:'Inter',sans-serif;font-size:1rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
.topbar-title{font-family:'Inter',sans-serif;font-size:1.05rem;font-weight:600;letter-spacing:.01em}
.topbar-right{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}
.topbar-info{font-size:.75rem;color:rgba(255,255,255,.55)}

.btn-reset{
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.85);padding:.35rem .85rem;border-radius:6px;
  cursor:pointer;font-size:.75rem;letter-spacing:.01em;transition:background .2s;
}
.btn-reset:hover{background:rgba(255,255,255,.2)}

/* ─── Tabs nav ───────────────────────────────────────────────── */
.tabs-nav{
  background:var(--paper);border-bottom:1px solid var(--border);
  padding:0 2rem;display:flex;gap:0;
}
.tab-btn{
  padding:.9rem 1.4rem;font-size:.82rem;font-weight:500;
  color:var(--muted);border:none;background:none;cursor:pointer;
  border-bottom:2px solid transparent;transition:color .15s,border-color .15s;
  letter-spacing:.02em;white-space:nowrap;
}
.tab-btn:hover{color:var(--text)}
.tab-btn.active{color:var(--navy);border-bottom-color:var(--navy);font-weight:600}

/* ─── Content area ───────────────────────────────────────────── */
.content{max-width:1380px;margin:0 auto;padding:1.75rem 2rem}

/* ─── Section title ──────────────────────────────────────────── */
.section-head{margin-bottom:1.25rem}
.section-head h2{
  font-family:'Inter',sans-serif;font-size:1.25rem;
  font-weight:600;color:var(--text);
}
.section-head p{color:var(--muted);font-size:.8rem;margin-top:.2rem}

/* ─── KPI Cards ──────────────────────────────────────────────── */
.kpi-grid{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:1rem;margin-bottom:1.5rem;
}
@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}

.kpi-card{
  background:var(--paper);border:1px solid var(--border);
  border-radius:12px;padding:1.2rem 1.3rem;
  box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.kpi-accent{
  position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--kpi-c,var(--navy));
}
.kpi-label{
  font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);margin-bottom:.55rem;font-weight:500;
}
.kpi-value{
  font-family:'Inter',sans-serif;font-size:1.6rem;
  font-weight:600;color:var(--text);line-height:1.15;
}
.kpi-sub{font-size:.72rem;color:var(--muted);margin-top:.3rem}
.kpi-badge{
  display:inline-block;padding:.12rem .45rem;border-radius:4px;
  font-size:.65rem;font-weight:600;margin-top:.35rem;
}
.kpi-badge.up{background:var(--emerald-light);color:var(--emerald)}
.kpi-badge.down{background:var(--crimson-light);color:var(--crimson)}
.kpi-badge.neutral{background:var(--gold-light);color:var(--gold)}

/* ─── Chart grid ─────────────────────────────────────────────── */
.chart-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}
.chart-grid.cols-1{grid-template-columns:1fr}
.chart-grid.cols-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:860px){.chart-grid,.chart-grid.cols-3{grid-template-columns:1fr}}

.card{
  background:var(--paper);border:1px solid var(--border);
  border-radius:12px;padding:1.3rem;box-shadow:var(--shadow);
}
.card-title{
  font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);font-weight:600;margin-bottom:1rem;
}
.card-h{height:320px;position:relative}
.card-h-sm{height:260px;position:relative}
.card-h-lg{height:400px;position:relative}
.card-h-xl{height:440px;position:relative}

/* ─── Store pills ────────────────────────────────────────────── */
.store-pills{
  display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.25rem;
  padding:.1rem 0;
}
.pill{
  padding:.42rem 1rem;border-radius:20px;border:1px solid var(--border);
  background:var(--paper);color:var(--text2);font-size:.78rem;font-weight:500;
  cursor:pointer;transition:all .15s;white-space:nowrap;
}
.pill:hover{border-color:var(--navy);color:var(--navy)}
.pill.active{background:var(--navy);border-color:var(--navy);color:#fff;font-weight:600}

/* ─── Ranking bar ────────────────────────────────────────────── */
.rank-card{
  background:var(--paper);border:1px solid var(--border);
  border-radius:12px;padding:1.3rem;box-shadow:var(--shadow);
  display:flex;align-items:center;gap:1.5rem;margin-bottom:1rem;
}
.rank-num{
  font-family:'Inter',sans-serif;font-size:3rem;font-weight:700;
  color:var(--navy);line-height:1;min-width:2.5rem;text-align:center;
}
.rank-meta{flex:1}
.rank-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:500;margin-bottom:.3rem}
.rank-store{font-family:'Inter',sans-serif;font-size:1.1rem;font-weight:600}
.rank-bar{flex:2}
.rank-bar-label{font-size:.72rem;color:var(--muted);margin-bottom:.4rem;display:flex;justify-content:space-between}
.rank-bar-track{height:8px;background:var(--border);border-radius:4px;overflow:hidden}
.rank-bar-fill{height:100%;background:var(--navy);border-radius:4px;transition:width .5s}

/* ─── Supplier selector ──────────────────────────────────────── */
.supplier-select-wrap{
  display:flex;gap:1rem;align-items:center;
  margin-bottom:1.25rem;flex-wrap:wrap;
}
.styled-select{
  background:var(--paper);border:1px solid var(--border);
  color:var(--text);padding:.55rem 1rem;border-radius:8px;
  font-size:.85rem;outline:none;min-width:260px;font-family:inherit;
  cursor:pointer;
}
.styled-select:focus{border-color:var(--navy)}
.styled-select option{background:var(--paper)}

/* ─── Quick filter chips ─────────────────────────────────────── */
.chip-row{display:flex;gap:.45rem;flex-wrap:wrap;margin-bottom:1rem}
.chip{
  padding:.35rem .85rem;border-radius:20px;
  border:1px solid var(--border);background:var(--paper);
  color:var(--text2);font-size:.75rem;font-weight:500;
  cursor:pointer;transition:all .15s;
}
.chip:hover{border-color:var(--navy);color:var(--navy)}
.chip.active{background:var(--navy);border-color:var(--navy);color:#fff;font-weight:600}
.chip.chip-gold.active{background:var(--gold);border-color:var(--gold);color:#fff}
.chip.chip-green.active{background:var(--emerald);border-color:var(--emerald);color:#fff}
.chip.chip-red.active{background:var(--crimson);border-color:var(--crimson);color:#fff}

/* ─── Table ──────────────────────────────────────────────────── */
.tbl-controls{
  display:flex;gap:.65rem;flex-wrap:wrap;margin-bottom:.85rem;align-items:center;
}
.tbl-controls input,.tbl-controls select{
  background:var(--paper);border:1px solid var(--border);
  color:var(--text);padding:.5rem .85rem;border-radius:7px;
  font-size:.8rem;outline:none;font-family:inherit;
}
.tbl-controls input:focus,.tbl-controls select:focus{border-color:var(--navy);box-shadow:0 0 0 2px rgba(27,47,78,.1)}
.tbl-controls input{min-width:220px}
.tbl-count{margin-left:auto;font-size:.75rem;color:var(--muted)}

.tbl-wrap{overflow-x:auto;border-radius:8px;border:1px solid var(--border)}

table{width:100%;border-collapse:collapse;font-size:.78rem}
thead th{
  background:var(--paper2);padding:.65rem .85rem;
  text-align:left;font-weight:600;color:var(--muted);font-size:.7rem;
  text-transform:uppercase;letter-spacing:.06em;
  cursor:pointer;white-space:nowrap;user-select:none;
  border-bottom:1px solid var(--border);
}
thead th:hover{color:var(--text)}
thead th.asc::after{content:' ↑';color:var(--navy)}
thead th.desc::after{content:' ↓';color:var(--navy)}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:#F7F5F0}
td{padding:.55rem .85rem;border-bottom:1px solid var(--border);white-space:nowrap}
td.nm{text-align:right;font-variant-numeric:tabular-nums;font-family:'Inter',sans-serif}
td.product-name{max-width:230px;overflow:hidden;text-overflow:ellipsis;font-weight:500}

/* ─── Explorar tab ───────────────────────────────────────────── */
.search-hero{
  text-align:center;padding:2.5rem 1rem 1.5rem;
}
.search-hero h2{
  font-family:'Inter',sans-serif;font-size:1.6rem;font-weight:600;
  color:var(--text);margin-bottom:.35rem;
}
.search-hero p{color:var(--muted);font-size:.85rem;margin-bottom:1.5rem}
.search-bar-wrap{
  position:relative;max-width:580px;margin:0 auto;
}
.search-bar-wrap input{
  width:100%;padding:.85rem 3.2rem .85rem 1.2rem;
  border:2px solid var(--border);border-radius:10px;
  font-size:1rem;font-family:inherit;color:var(--text);
  background:var(--paper);outline:none;transition:border-color .2s;
  box-shadow:var(--shadow);
}
.search-bar-wrap input:focus{border-color:var(--navy)}
.search-bar-wrap .search-icon{
  position:absolute;right:1rem;top:50%;transform:translateY(-50%);
  color:var(--muted);pointer-events:none;
}
.cat-chips{display:flex;gap:.45rem;flex-wrap:wrap;justify-content:center;margin-top:1rem}

.expl-results{margin-top:1.5rem}
.expl-kpi-row{
  display:grid;grid-template-columns:repeat(4,1fr);gap:.85rem;margin-bottom:1rem;
}
@media(max-width:760px){.expl-kpi-row{grid-template-columns:repeat(2,1fr)}}

.expl-kpi{
  background:var(--paper);border:1px solid var(--border);border-radius:10px;
  padding:1rem 1.1rem;box-shadow:var(--shadow);
}
.expl-kpi-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.35rem}
.expl-kpi-value{font-family:'Inter',sans-serif;font-size:1.35rem;font-weight:600}

.expl-toolbar{
  display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;
  margin-bottom:.85rem;
}
.expl-toolbar-label{font-size:.72rem;font-weight:600;color:var(--muted);
  text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}

.toggle-view{
  display:flex;background:var(--paper2);border:1px solid var(--border);
  border-radius:7px;overflow:hidden;margin-left:auto;flex-shrink:0;
}
.toggle-view button{
  padding:.38rem .9rem;font-size:.76rem;font-weight:500;
  border:none;background:none;cursor:pointer;color:var(--muted);
  transition:all .15s;
}
.toggle-view button.active{background:var(--navy);color:#fff;font-weight:600}

/* Pivot table stores */
td.store-qty{text-align:right;font-variant-numeric:tabular-nums;min-width:60px}
td.store-qty.zero{color:var(--border2)}
th.store-col{text-align:right;white-space:nowrap;font-size:.65rem}

/* ─── Modal ──────────────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;
  background:rgba(20,18,14,.6);
  backdrop-filter:blur(5px);
  z-index:2000;
  display:flex;align-items:center;justify-content:center;
  padding:1.25rem;
  opacity:0;pointer-events:none;
  transition:opacity .22s;
}
.modal-overlay.open{opacity:1;pointer-events:auto}
.modal{
  background:var(--paper);border-radius:16px;
  max-width:1040px;width:100%;max-height:92vh;
  overflow-y:auto;
  box-shadow:0 32px 96px rgba(0,0,0,.2),0 4px 16px rgba(0,0,0,.1);
  transform:translateY(16px);transition:transform .22s;
}
.modal-overlay.open .modal{transform:translateY(0)}
.modal-hdr{
  display:flex;align-items:flex-start;justify-content:space-between;
  padding:1.4rem 1.75rem 1rem;border-bottom:1px solid var(--border);
  position:sticky;top:0;background:var(--paper);z-index:10;
  border-radius:16px 16px 0 0;
}
.modal-tag{
  display:inline-block;background:var(--navy);color:#fff;
  font-size:.62rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  padding:.18rem .55rem;border-radius:4px;margin-bottom:.4rem;
}
.modal-title{
  font-family:'Inter',sans-serif;font-size:1.25rem;font-weight:600;
}
.modal-sub{font-size:.78rem;color:var(--muted);margin-top:.2rem}
.modal-close{
  background:var(--paper2);border:1px solid var(--border);
  width:34px;height:34px;border-radius:8px;cursor:pointer;
  font-size:1rem;color:var(--muted);display:flex;
  align-items:center;justify-content:center;flex-shrink:0;margin-left:1rem;
  transition:all .15s;
}
.modal-close:hover{background:var(--border);color:var(--text)}
.modal-body{padding:1.25rem 1.75rem 1.75rem}

/* ── Modal filter toolbar ───────────────────────────────────────── */
.modal-filters{
  background:var(--paper2);border:1px solid var(--border);
  border-radius:10px;padding:.85rem 1rem;margin-bottom:1.1rem;
}
.modal-filters-lbl{
  font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);font-weight:600;margin-bottom:.6rem;
}
.modal-filters-row{display:flex;gap:.55rem;flex-wrap:wrap;align-items:center}
.modal-filter-ctrl{
  background:var(--paper);border:1px solid var(--border);
  color:var(--text);padding:.45rem .7rem;border-radius:7px;
  font-size:.78rem;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s;
}
.modal-filter-ctrl:focus{border-color:var(--navy);box-shadow:0 0 0 2px rgba(27,47,78,.1)}
#modal-search{flex:1;min-width:180px}
.modal-filter-clear{
  background:var(--paper);border:1px solid var(--border);
  color:var(--text2);padding:.45rem .8rem;border-radius:7px;
  font-size:.76rem;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s;
}
.modal-filter-clear:hover{border-color:var(--navy);color:var(--navy)}
.modal-filter-count{margin-left:auto;font-size:.74rem;color:var(--muted);font-weight:500}
.modal-filter-count.filtered{color:var(--gold);font-weight:600}

.modal-kpis{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:.7rem;margin-bottom:1.25rem;
}
@media(max-width:700px){.modal-kpis{grid-template-columns:repeat(2,1fr)}}
.modal-kpi{
  position:relative;overflow:hidden;
  background:var(--paper2);border:1px solid var(--border);
  border-radius:9px;padding:.95rem 1rem .9rem;
}
.modal-kpi::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--kpi-accent,var(--navy));
}
.modal-kpi-lbl{font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.3rem}
.modal-kpi-val{font-family:'Inter',sans-serif;font-size:1.2rem;font-weight:700;line-height:1.1}
.modal-kpi-ctx{font-size:.7rem;color:var(--muted);margin-top:.2rem}
.modal-charts{display:grid;grid-template-columns:repeat(2,1fr);gap:.85rem;margin-bottom:1.25rem}
@media(max-width:640px){.modal-charts{grid-template-columns:1fr}}
.modal-chart-card{
  background:var(--paper2);border:1px solid var(--border);
  border-radius:9px;padding:1rem;
}
.modal-chart-lbl{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.7rem;font-weight:600}
.modal-section-lbl{
  font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);font-weight:600;margin-bottom:.65rem;
}
.btn-detail{
  background:transparent;border:1px solid var(--border);
  color:var(--navy);font-size:.73rem;font-weight:600;
  padding:.28rem .7rem;border-radius:5px;cursor:pointer;
  white-space:nowrap;transition:all .15s;letter-spacing:.01em;
}
.btn-detail:hover{background:var(--navy);color:#fff;border-color:var(--navy)}

.empty-search{
  text-align:center;padding:3rem;color:var(--muted);font-size:.85rem;
}
.no-results{
  text-align:center;padding:2.5rem;color:var(--muted);font-size:.85rem;
  background:var(--paper);border:1px solid var(--border);border-radius:10px;
}

.badge{display:inline-flex;align-items:center;padding:.14rem .5rem;border-radius:4px;font-size:.68rem;font-weight:600}
.badge-gold{background:var(--gold-light);color:var(--gold)}
.badge-green{background:var(--emerald-light);color:var(--emerald)}
.badge-navy{background:#E8EEF6;color:var(--navy)}
.badge-red{background:var(--crimson-light);color:var(--crimson)}
.badge-gray{background:#F0EDE8;color:var(--muted)}
.pos{color:var(--emerald);font-weight:600}
.neg{color:var(--crimson);font-weight:600}

/* ─── Pagination ─────────────────────────────────────────────── */
.pagination{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:1rem;flex-wrap:wrap;gap:.5rem;
}
.pag-info{font-size:.75rem;color:var(--muted)}
.page-btns{display:flex;gap:.3rem;flex-wrap:wrap}
.page-btn{
  background:var(--paper);border:1px solid var(--border);
  color:var(--text2);padding:.35rem .65rem;border-radius:5px;
  cursor:pointer;font-size:.75rem;min-width:32px;text-align:center;transition:all .15s;
}
.page-btn:hover:not(.active):not([disabled]){border-color:var(--navy);color:var(--navy)}
.page-btn.active{background:var(--navy);color:#fff;border-color:var(--navy);font-weight:600}
.page-btn[disabled]{opacity:.3;cursor:not-allowed}

/* ─── Divider ────────────────────────────────────────────────── */
.divider{border:none;border-top:1px solid var(--border);margin:1.25rem 0}

/* ─── Supplier header card ───────────────────────────────────── */
.supplier-hero{
  background:var(--navy);color:#fff;border-radius:12px;
  padding:1.3rem 1.6rem;margin-bottom:1rem;
  display:flex;align-items:center;gap:2rem;flex-wrap:wrap;
}
.supplier-hero-name{
  font-family:'Inter',sans-serif;font-size:1.4rem;font-weight:600;
}
.supplier-hero-meta{font-size:.78rem;color:rgba(255,255,255,.6);margin-top:.2rem}
.supplier-hero-stats{
  display:flex;gap:2.5rem;margin-left:auto;flex-wrap:wrap;
}
.shs{text-align:right}
.shs-v{font-family:'Inter',sans-serif;font-size:1.3rem;font-weight:600}
.shs-l{font-size:.68rem;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.07em;margin-top:.15rem}

/* ─── Alert list ─────────────────────────────────────────────── */
.alert-list{display:flex;flex-direction:column;gap:.5rem;max-height:260px;overflow-y:auto}
.alert-item{
  display:flex;align-items:center;gap:.75rem;padding:.55rem .75rem;
  background:var(--paper2);border-radius:7px;border:1px solid var(--border);
}
.alert-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.alert-dot.red{background:var(--crimson)}
.alert-dot.gold{background:var(--gold)}
.alert-name{font-size:.78rem;font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.alert-val{font-size:.75rem;color:var(--muted);white-space:nowrap}

/* ─── Category store popup ───────────────────────────────────── */
#cat-store-popup{
  position:fixed;z-index:2000;
  background:var(--paper);border:1px solid var(--border2);
  border-radius:10px;box-shadow:var(--shadow-md);
  min-width:230px;max-width:290px;overflow:hidden;
}
#cat-store-popup-hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:.55rem .85rem;background:var(--navy);color:#fff;
  font-size:.75rem;font-weight:600;
}
#cat-store-popup-hdr button{
  background:none;border:none;color:rgba(255,255,255,.65);
  cursor:pointer;font-size:.9rem;line-height:1;padding:0 .15rem;
}
#cat-store-popup-hdr button:hover{color:#fff}
#cat-store-popup-body{padding:.4rem .85rem .6rem}
.cat-store-row{
  display:flex;align-items:center;gap:.55rem;
  padding:.3rem 0;font-size:.77rem;
  border-bottom:1px solid var(--border);
}
.cat-store-row:last-child{border-bottom:none}
.cat-store-name{flex:1;color:var(--text2);white-space:nowrap}
.cat-store-qty{font-weight:600;color:var(--text);white-space:nowrap}
.cat-store-bar-wrap{width:52px;background:var(--paper2);border:1px solid var(--border);border-radius:3px;height:5px;flex-shrink:0}
.cat-store-bar{height:5px;background:var(--navy);border-radius:3px}
.cat-qty-cell{cursor:pointer;text-decoration:underline dotted;text-underline-offset:3px}
.cat-qty-cell:hover{color:var(--navy)}

/* ─── Misc ───────────────────────────────────────────────────── */
.hidden{display:none!important}
.ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
