/* ============================================================
   BikeBid — Wholesalers page
   Builds on app.css (sidebar, .card, .btn, .badge, colours)
   ============================================================ */

.main.wholesalers{ max-width:1760px; }

/* page header */
.wpage-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:24px; margin-bottom:24px; }
.wpage-head h1{ font-size:34px; font-weight:800; letter-spacing:-.025em; margin:0 0 7px; }
.wpage-head p{ margin:0; color:var(--ink-3); font-size:15px; }
.wpage-head .acts{ display:flex; gap:12px; flex:none; }
.btn.compact{ padding:12px 18px; font-size:14px; }
.btn.compact i[data-lucide]{ width:18px; height:18px; }

/* outer grid: main + side */
.wgrid{ display:grid; grid-template-columns:minmax(0,1fr) 306px; gap:24px; align-items:start; }
.wmain{ display:flex; flex-direction:column; gap:22px; min-width:0; }
.wside{ display:flex; flex-direction:column; gap:22px; position:sticky; top:24px; min-width:0; }

/* stat tiles */
.wstats{ display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:18px; }
.wstat{ padding:18px 20px; }
.wstat .wtop{ display:flex; align-items:center; gap:12px; }
.wstat .wico{ width:40px; height:40px; border-radius:11px; background:var(--blue-50); color:var(--blue);
  display:flex; align-items:center; justify-content:center; flex:none; }
.wstat .wico i[data-lucide]{ width:20px; height:20px; }
.wstat .wlbl{ font-size:13px; color:var(--ink-3); font-weight:600; }
.wstat .wbig{ font-size:30px; font-weight:800; letter-spacing:-.02em; margin:12px 0 4px; line-height:1; }
.wstat .wsub{ font-size:12.5px; color:var(--ink-4); font-weight:600; display:flex; align-items:center; gap:4px; }
.wstat .wsub.up{ color:var(--green); }
.wstat .wsub.up i[data-lucide]{ width:14px; height:14px; }

/* toolbar */
.wtoolbar{ display:flex; align-items:center; gap:14px; flex-wrap:nowrap; }
.wtabs{ display:flex; gap:6px; flex:none; }
.wtab{ font-family:inherit; padding:9px 16px; border-radius:10px; font-weight:600; font-size:13.5px;
  color:var(--ink-3); cursor:pointer; border:none; background:transparent; }
.wtab:hover{ background:var(--bg); color:var(--ink); }
.wtab.active{ background:var(--blue); color:#fff; }
.wsearch{ position:relative; margin-left:auto; min-width:0; flex:1 1 auto; max-width:300px; }
.wsearch input{ font-family:inherit; width:100%; font-size:14px; color:var(--ink); background:var(--card);
  border:1px solid var(--line); border-radius:11px; padding:11px 14px 11px 40px; }
.wsearch input::placeholder{ color:var(--ink-4); }
.wsearch input:focus{ outline:none; border-color:var(--blue); box-shadow:0 0 0 3px color-mix(in oklab,var(--blue) 14%,transparent); }
.wsearch i[data-lucide], .wsearch > svg{ position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--ink-4); width:17px; height:17px; pointer-events:none; }
.filter-btn{ display:flex; align-items:center; gap:8px; padding:11px 17px; border:1px solid var(--line);
  border-radius:11px; background:var(--card); font-family:inherit; font-weight:600; font-size:14px; color:var(--ink-2); cursor:pointer; flex:none; }
.filter-btn:hover{ background:var(--bg); }
.filter-btn i[data-lucide]{ width:16px; height:16px; color:var(--ink-3); }

/* table */
.wtable-card{ padding:0; overflow:visible; }
.wt-head, .wt-row{ display:grid;
  grid-template-columns:1.45fr 1.7fr .9fr 2.3fr 1fr .68fr .8fr 38px; gap:12px; align-items:center; }
.wt-head > span, .wt-row > div{ min-width:0; }
.wt-head{ padding:15px 24px; border-bottom:1px solid var(--line); font-size:11px; font-weight:700;
  letter-spacing:.045em; text-transform:uppercase; color:var(--ink-4); }
.wt-row{ padding:16px 24px; border-bottom:1px solid var(--line-2); cursor:pointer; transition:background .1s; }
.wt-row:hover{ background:#fafbfc; }
.wt-row:last-child{ border-bottom:none; }

.wt-row .biz{ font-weight:700; font-size:14.5px; line-height:1.2; }
.pill-pref{ display:inline-block; margin-top:6px; font-size:11px; font-weight:700; color:var(--blue);
  background:var(--blue-50); padding:2px 9px; border-radius:7px; }
.pill-new-tag{ display:inline-block; margin-top:6px; font-size:11px; font-weight:700; color:#b4690e;
  background:#fdf2dc; padding:2px 9px; border-radius:7px; }
.pill-pending-tag{ display:inline-block; margin-top:6px; font-size:11px; font-weight:700; color:#9a6700;
  background:#fef3c7; padding:2px 9px; border-radius:7px; }
.badge.amber{ background:#fef3c7; color:#92600a; }

/* approval request note */
.reqnote{ display:flex; gap:11px; align-items:flex-start; background:#fef9ec; border:1px solid #f5e2b3;
  border-radius:12px; padding:13px 15px; margin-bottom:18px; font-size:13px; color:#7a5a12; line-height:1.45; }
.reqnote i[data-lucide]{ width:19px; height:19px; color:#b4860b; flex:none; margin-top:1px; }
.reqnote b{ color:#5c4408; }

.cc-name{ font-weight:600; font-size:13.5px; color:var(--ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cc-line{ font-size:12.5px; color:var(--ink-3); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cc-line.mono{ font-variant-numeric:tabular-nums; }

.loc-city{ font-weight:600; font-size:13.5px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.loc-country{ font-size:12.5px; color:var(--ink-4); }

/* brand badges */
.brands{ display:flex; flex-wrap:wrap; gap:5px; align-items:center; }
.bchip{ display:inline-flex; align-items:center; gap:5px; background:#f1f5f9; border-radius:7px;
  padding:3px 8px 3px 3px; font-size:11.5px; font-weight:600; color:var(--ink-2); white-space:nowrap; }
.bbadge{ width:16px; height:16px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center;
  color:#fff; font-size:8px; font-weight:800; letter-spacing:-.02em; flex:none; }
.bmore{ font-size:12px; font-weight:700; color:var(--ink-4); padding:0 2px; }

.lastoffer .amt2{ font-weight:800; font-size:15px; }
.lastoffer .ago{ font-size:12px; color:var(--ink-4); margin-top:2px; }

.winrate{ font-weight:800; font-size:14px; }
.winrate.good{ color:var(--green); }
.winrate.mid{ color:#d9920b; }
.winrate.low{ color:#e0612f; }
.winrate.none{ color:var(--ink-4); }

.row-menu-btn{ width:32px; height:32px; border-radius:8px; border:none; background:transparent; color:var(--ink-3);
  display:flex; align-items:center; justify-content:center; cursor:pointer; }
.row-menu-btn:hover{ background:var(--bg); color:var(--ink); }

/* pagination */
.wpage-foot{ display:flex; align-items:center; justify-content:space-between; padding:16px 24px; border-top:1px solid var(--line); }
.wpage-foot .showing{ font-size:13px; color:var(--ink-3); }
.pager{ display:flex; gap:6px; align-items:center; }
.pager button{ min-width:34px; height:34px; padding:0 9px; border-radius:9px; border:1px solid var(--line);
  background:var(--card); font-family:inherit; font-weight:600; font-size:13.5px; color:var(--ink-2); cursor:pointer; }
.pager button:hover{ background:var(--bg); }
.pager button.active{ background:var(--blue); border-color:var(--blue); color:#fff; }
.pager button.dots{ border:none; background:none; cursor:default; }

/* ---- side cards ---- */
.wside .card{ padding:20px 22px; }
.wside .card-h{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.wside .card-h h3{ font-size:16px; font-weight:700; margin:0; }
.wside .card-h .va{ color:var(--blue); font-weight:700; font-size:13px; cursor:pointer; }

.tp-row{ display:flex; align-items:center; gap:12px; padding:10px 0; border-bottom:1px solid var(--line-2); }
.tp-row:last-of-type{ border-bottom:none; }
.tp-rank{ width:22px; height:22px; border-radius:7px; background:var(--bg); color:var(--ink-3); font-weight:700;
  font-size:12px; display:flex; align-items:center; justify-content:center; flex:none; }
.tp-row:first-of-type .tp-rank{ background:var(--blue-50); color:var(--blue); }
.tp-name{ font-weight:600; font-size:13.5px; }
.tp-pct{ margin-left:auto; font-weight:800; font-size:13.5px; color:var(--green); }
.tp-foot{ font-size:11.5px; color:var(--ink-4); margin-top:12px; }
.empty-state{ padding:28px 10px; text-align:center; color:var(--ink-4); font-size:13px; font-weight:600; }

.ra-item{ display:flex; gap:12px; padding:12px 0; border-bottom:1px solid var(--line-2); }
.ra-item:last-of-type{ border-bottom:none; }
.ra-ico{ width:34px; height:34px; border-radius:9px; flex:none; display:flex; align-items:center; justify-content:center;
  background:var(--blue-50); color:var(--blue); }
.ra-ico.green{ background:var(--green-50); color:var(--green); }
.ra-ico i[data-lucide]{ width:16px; height:16px; }
.ra-t{ font-size:13.5px; font-weight:700; line-height:1.25; }
.ra-s{ font-size:12.5px; color:var(--ink-3); }
.ra-s b{ color:var(--blue); font-weight:700; }
.ra-time{ font-size:11.5px; color:var(--ink-4); margin-top:2px; }
.ra-foot{ display:flex; align-items:center; gap:8px; color:var(--blue); font-weight:700; font-size:14px;
  padding-top:14px; cursor:pointer; }
.ra-foot i[data-lucide]{ width:16px; height:16px; }

/* ---- row action menu (popover) ---- */
.rowmenu{ position:fixed; z-index:1100; min-width:180px; background:var(--card); border:1px solid var(--line);
  border-radius:12px; box-shadow:0 16px 40px rgba(16,24,40,.18); padding:6px; display:none; }
.rowmenu.open{ display:block; }
.rowmenu button{ width:100%; display:flex; align-items:center; gap:10px; padding:9px 11px; border:none;
  background:transparent; font-family:inherit; font-size:13.5px; font-weight:600; color:var(--ink-2);
  border-radius:8px; cursor:pointer; text-align:left; }
.rowmenu button:hover{ background:var(--bg); }
.rowmenu button i[data-lucide]{ width:16px; height:16px; color:var(--ink-3); }
.rowmenu button.danger{ color:var(--red); }
.rowmenu button.danger i[data-lucide]{ color:var(--red); }
.rowmenu .sep{ height:1px; background:var(--line-2); margin:5px 4px; }

/* =================== MODALS =================== */
.overlay{ position:fixed; inset:0; background:rgba(15,23,42,.45); backdrop-filter:blur(2px);
  display:none; align-items:flex-start; justify-content:center; padding:44px 20px; z-index:1000; overflow:auto; }
.overlay.open{ display:flex; }
.modal{ background:var(--card); border-radius:20px; width:100%; max-width:620px; box-shadow:0 24px 60px rgba(16,24,40,.28); overflow:hidden; }
.modal-head{ display:flex; align-items:flex-start; justify-content:space-between; padding:22px 26px; border-bottom:1px solid var(--line); }
.modal-head h2{ font-size:20px; font-weight:800; margin:0; }
.modal-head p{ margin:4px 0 0; color:var(--ink-3); font-size:13px; }
.modal-head .x{ width:34px; height:34px; border-radius:9px; border:1px solid var(--line); background:var(--card);
  color:var(--ink-3); cursor:pointer; display:flex; align-items:center; justify-content:center; flex:none; }
.modal-head .x:hover{ background:var(--bg); }
.modal-body{ padding:22px 26px; max-height:64vh; overflow:auto; }
.modal-foot{ display:flex; align-items:center; justify-content:flex-end; gap:12px; padding:18px 26px; border-top:1px solid var(--line); background:#fcfcfd; }

/* add form */
.fgrid{ display:grid; grid-template-columns:1fr 1fr; gap:15px 18px; }
.fgrid .full{ grid-column:1 / -1; }
.fld{ display:flex; flex-direction:column; gap:6px; }
.fld label{ font-size:12.5px; font-weight:600; color:var(--ink-2); }
.fld input, .fld select{ font-family:inherit; font-size:14px; color:var(--ink); background:var(--card);
  border:1px solid var(--line); border-radius:10px; padding:10px 12px; width:100%; }
.fld input:focus, .fld select:focus{ outline:none; border-color:var(--blue); box-shadow:0 0 0 3px color-mix(in oklab,var(--blue) 14%,transparent); }
.brand-pick{ display:flex; flex-wrap:wrap; gap:8px; }
.brand-head{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.brand-search{ position:relative; display:inline-flex; align-items:center; }
.brand-search > i[data-lucide]{ position:absolute; left:9px; width:14px; height:14px; color:var(--ink-4); pointer-events:none; }
.brand-search input{ font-family:inherit; font-size:12.5px; color:var(--ink); background:var(--card);
  border:1px solid var(--line); border-radius:8px; padding:6px 10px 6px 29px; width:160px; }
.brand-search input:focus{ outline:none; border-color:var(--blue); box-shadow:0 0 0 3px color-mix(in oklab,var(--blue) 14%,transparent); }
.brand-pick label.hide{ display:none; }
.brand-pick .bsw{ width:16px; height:16px; border-radius:4px; flex:none; border:1px solid color-mix(in oklab,var(--ink) 14%,transparent); }
.brand-pick .bsw.split{ border:none; }
.brand-pick label{ display:inline-flex; align-items:center; gap:7px; border:1px solid var(--line); border-radius:9px;
  padding:6px 11px; font-size:12.5px; font-weight:600; cursor:pointer; user-select:none; }
.brand-pick label:hover{ border-color:var(--blue); }
.brand-pick input{ accent-color:var(--blue); width:14px; height:14px; }
.brand-pick label.on{ border-color:var(--blue); background:var(--blue-50); color:var(--blue); }

/* view detail */
.vd-top{ display:flex; align-items:center; gap:14px; margin-bottom:18px; }
.vd-ava{ width:54px; height:54px; border-radius:14px; background:var(--blue-50); color:var(--blue); font-weight:800;
  font-size:20px; display:flex; align-items:center; justify-content:center; flex:none; }
.vd-name{ font-size:18px; font-weight:800; }
.vd-sub{ color:var(--ink-3); font-size:13px; }
.vd-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin:6px 0 20px; }
.vd-stat{ background:var(--bg); border-radius:12px; padding:13px; text-align:center; }
.vd-stat .n{ font-size:20px; font-weight:800; }
.vd-stat .l{ font-size:11.5px; color:var(--ink-3); font-weight:600; margin-top:2px; }
.vd-rows{ display:grid; grid-template-columns:1fr; gap:0; }
.vd-r{ display:flex; justify-content:space-between; gap:12px; padding:10px 0; border-bottom:1px solid var(--line-2); font-size:13.5px; }
.vd-r:last-child{ border-bottom:none; }
.vd-r .k{ color:var(--ink-3); }
.vd-r .v{ font-weight:700; text-align:right; }

/* toast */
.toast{ position:fixed; bottom:26px; left:50%; transform:translateX(-50%) translateY(20px); opacity:0;
  background:var(--ink); color:#fff; padding:13px 20px; border-radius:12px; font-size:13.5px; font-weight:600;
  display:flex; align-items:center; gap:10px; box-shadow:0 12px 30px rgba(0,0,0,.25); z-index:1200; pointer-events:none;
  transition:opacity .2s, transform .2s; }
.toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }
.toast i[data-lucide]{ width:18px; height:18px; color:#4ade80; }

@media (max-width:1300px){
  .wgrid{ grid-template-columns:1fr; }
  .wside{ position:static; flex-direction:row; flex-wrap:wrap; }
  .wside .card{ flex:1 1 300px; min-width:0; }
}
@media (max-width:1024px){
  .wstats{ grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width:760px){
  .wstats{ grid-template-columns:1fr; }
  .wside{ flex-direction:column; }
  .wt-head{ display:none; }
  .wt-row{ grid-template-columns:1fr; gap:8px; }
  .wtoolbar{ flex-wrap:wrap; }
  .wsearch{ order:3; max-width:none; flex-basis:100%; }
}
