/* ============================================================
   SHOPICKS — screens: cart, messages, dashboard, admin
   ============================================================ */

/* shared bits */
.seg{ display:inline-flex; background:var(--cream-2); border:1px solid var(--line); border-radius:var(--r-pill); padding:3px; gap:2px; }
.seg button{ font-size:13px; font-weight:600; color:var(--muted); padding:7px 16px; border-radius:var(--r-pill); transition:.18s; }
.seg button.on{ background:#fff; color:var(--ink); box-shadow:var(--sh-1); }
.seg.big button{ font-size:14.5px; padding:10px 22px; }
.card.pad{ padding:18px 20px; }
.back-link{ display:inline-flex; align-items:center; gap:6px; color:var(--muted); font-size:14px; font-weight:600; margin-bottom:12px; transition:.15s; }
.back-link:hover{ color:var(--gold-deep); }
.empty-state{ text-align:center; padding:80px 26px; }
.empty-bag{ font-size:54px; }
.empty-state h2{ font-family:var(--serif); font-size:30px; margin:10px 0 6px; }
.empty-state p{ color:var(--muted); margin-bottom:22px; }

.mini-thumb{ border-radius:var(--r-sm); background:radial-gradient(120% 90% at 50% 20%,#fff,var(--cream-2));
  border:1px solid var(--line); display:grid; place-items:center; flex-shrink:0; overflow:hidden; }

/* ---------- CART ---------- */
.cartview{ padding-bottom:30px; }
.cart-grid{ display:grid; grid-template-columns:1fr 340px; gap:26px; align-items:start; }
.cart-items{ display:flex; flex-direction:column; gap:12px; }
.cart-row{ display:flex; gap:15px; align-items:center; background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:14px; }
.cart-row-info{ flex:1; display:flex; flex-direction:column; gap:3px; }
.cart-row-info .chip{ align-self:flex-start; font-size:10.5px; padding:2px 8px; }
.cart-row-info b{ font-size:15.5px; } .cart-row-info span{ font-size:12.5px; color:var(--muted); }
.cart-seller{ display:flex; align-items:center; gap:6px; font-size:12px; color:var(--ink-2); margin-top:3px; }
.cart-row-end{ text-align:end; display:flex; flex-direction:column; align-items:flex-end; gap:6px; }
.cart-row-end b{ font-size:17px; }
.link-del{ font-size:12.5px; color:var(--muted); text-decoration:underline; }
.link-del:hover{ color:var(--danger); }
.cart-sum{ padding:22px; position:sticky; top:96px; }
.cart-sum h3{ margin:0 0 16px; font-family:var(--serif); font-size:21px; }
.sum-row{ display:flex; justify-content:space-between; padding:9px 0; font-size:14px; color:var(--ink-2); }
.sum-row.total{ border-top:1px solid var(--line); margin-top:6px; padding-top:14px; font-size:18px; font-weight:700; color:var(--ink); }
.cart-trust{ margin-top:14px; text-align:center; font-size:11.5px; color:var(--muted); }

/* ---------- MESSAGES ---------- */
.msgs-wrap{ padding-top:18px; padding-bottom:24px; }
.msgs{ display:grid; grid-template-columns:340px 1fr; gap:0; height:calc(100vh - 200px); min-height:560px;
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--sh-1); }
.msg-list{ border-inline-end:1px solid var(--line); display:flex; flex-direction:column; min-height:0; }
.msg-list-head{ padding:18px 18px 14px; border-bottom:1px solid var(--line); }
.msg-list-head h2{ font-family:var(--serif); font-size:24px; margin:0 0 12px; }
.msg-rows{ overflow-y:auto; flex:1; min-height:0; }
.msg-group-head{ display:flex; align-items:center; justify-content:space-between; gap:8px; padding:11px 16px 6px;
  font-size:11.5px; font-weight:700; letter-spacing:.04em; color:var(--muted); background:var(--cream); position:sticky; top:0; z-index:1; }
.msg-group-head i{ font-style:normal; font-weight:600; color:var(--muted-2); background:var(--cream-2); border-radius:99px; padding:1px 8px; font-size:11px; }
.msg-empty-filter{ padding:26px 16px; text-align:center; color:var(--muted); font-size:13px; }
.msg-row{ display:flex; gap:12px; align-items:center; width:100%; padding:14px 16px; border-bottom:1px solid var(--line); text-align:start; transition:.15s; }
.msg-row:hover{ background:var(--cream); }
.msg-row.on{ background:var(--cream-2); box-shadow:inset 3px 0 0 var(--gold); }
.mr-av{ position:relative; flex-shrink:0; }
.mr-av .dot{ position:absolute; bottom:1px; left:1px; width:11px; height:11px; border-radius:50%; background:var(--pos); border:2px solid #fff; }
.mr-mid{ flex:1; min-width:0; }
.mr-top{ display:flex; align-items:center; gap:7px; }
.mr-top b{ font-size:14.5px; }
.role{ font-size:10px; font-weight:700; padding:2px 7px; border-radius:99px; }
.role.buying{ background:#EAF0E6; color:#5C7A52; }
.role.selling{ background:var(--gold-pale); color:var(--gold-deep); }
.mr-item{ font-size:12px; color:var(--gold-deep); font-weight:600; margin:2px 0; }
.mr-last{ font-size:13px; color:var(--muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mr-end{ text-align:end; display:flex; flex-direction:column; align-items:flex-end; gap:5px; flex-shrink:0; }
.mr-end span{ font-size:11px; color:var(--muted-2); }
.unread{ background:var(--gold-grad); color:#2A2008; font-size:11px; font-weight:700; min-width:18px; height:18px; border-radius:99px; display:grid; place-items:center; font-style:normal; padding:0 5px; }

.msg-thread{ display:flex; flex-direction:column; min-height:0; background:
  linear-gradient(0deg, var(--paper-warm), var(--paper-warm)),
  radial-gradient(60% 50% at 50% 0%, rgba(233,223,207,.4), transparent); }
.thread-head{ display:flex; align-items:center; gap:12px; padding:14px 20px; border-bottom:1px solid var(--line); background:#fff; }
.back-btn{ display:none; font-size:26px; color:var(--muted); width:32px; }
.th-id{ flex:1; } .th-id b{ font-size:15px; display:block; } .th-id span{ font-size:11.5px; color:var(--pos); }
.thread-item{ display:flex; align-items:center; gap:12px; margin:14px 20px 0; padding:10px 12px; background:#fff; border:1px solid var(--line); border-radius:var(--r-md); }
.ti-info{ flex:1; } .ti-info b{ font-size:14px; display:block; } .ti-info span{ font-size:12px; color:var(--muted); }
.thread-body{ flex:1; overflow-y:auto; min-height:0; padding:18px 20px; display:flex; flex-direction:column; gap:8px; }
.day-sep{ text-align:center; margin:4px 0 10px; }
.day-sep span{ font-size:11px; color:var(--muted); background:var(--cream-3); padding:3px 12px; border-radius:99px; }
.bub{ max-width:74%; padding:10px 14px; border-radius:18px; font-size:14px; line-height:1.5; position:relative; align-self:flex-start; }
.bub.them{ background:#fff; border:1px solid var(--line); border-bottom-right-radius:5px; color:var(--ink); }
.bub.me{ align-self:flex-end; background:var(--ink); color:#F4ECDC; border-bottom-left-radius:5px; }
.bub-time{ display:block; font-style:normal; font-size:10px; opacity:.6; margin-top:4px; text-align:end; }
.bub-img{ border-radius:12px; overflow:hidden; }
.composer{ display:flex; align-items:center; gap:10px; padding:14px 18px; border-top:1px solid var(--line); background:#fff; }
.comp-ic{ color:var(--muted); width:38px; height:38px; border-radius:50%; display:grid; place-items:center; }
.comp-ic:hover{ background:var(--cream-2); color:var(--ink); }
.composer input{ flex:1; border:1px solid var(--line); background:var(--cream); border-radius:var(--r-pill); padding:11px 18px; font-size:14px; outline:none; }
.composer input:focus{ border-color:var(--gold-soft); background:#fff; }
.comp-send{ width:42px; height:42px; border-radius:50%; background:var(--gold-grad); color:#2A2008; display:grid; place-items:center; flex-shrink:0; transition:.18s; }
.comp-send:hover{ transform:scale(1.06); }

/* ---------- DASHBOARD ---------- */
.dash{ padding-top:22px; padding-bottom:30px; }
.dash-band{ display:flex; align-items:center; gap:26px; padding:22px 26px; flex-wrap:wrap; }
.db-id{ display:flex; align-items:center; gap:16px; }
.db-name{ font-size:21px; font-weight:700; display:flex; align-items:center; gap:8px; font-family:var(--serif); }
.name-edit{ display:inline-flex; align-items:center; gap:6px; flex-wrap:wrap; }
.name-edit input{ font-family:var(--font); font-size:16px; padding:6px 10px; border:1px solid var(--line); border-radius:var(--r-sm); background:var(--cream); outline:none; min-width:150px; }
.name-edit input:focus{ border-color:var(--gold-soft); background:#fff; }
.name-edit-btn{ font-size:13px; color:var(--muted); width:26px; height:26px; border-radius:50%; display:inline-grid; place-items:center; transition:.15s; }
.name-edit-btn:hover{ background:var(--cream-2); color:var(--gold-deep); }
.db-rate{ display:flex; align-items:center; gap:8px; font-size:13px; color:var(--muted); margin-top:3px; }
.db-stats{ display:flex; gap:28px; margin-inline-start:auto; }
.db-stats div{ text-align:center; } .db-stats b{ font-size:22px; display:block; font-family:var(--serif); } .db-stats span{ font-size:11.5px; color:var(--muted); }
.dash-toggle{ margin:22px 0; }

.kpi-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:22px; }
.statcard{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:16px 18px; display:flex; flex-direction:column; gap:5px; position:relative; overflow:hidden; }
.sc-label{ font-size:12.5px; color:var(--muted); }
.sc-value{ font-size:27px; font-family:var(--serif); font-weight:600; line-height:1; }
.sc-sub{ font-size:11.5px; color:var(--muted-2); }
.sc-delta{ font-size:12px; font-weight:700; } .sc-delta.up{ color:var(--pos); } .sc-delta.down{ color:var(--danger); }
.spark{ display:flex; align-items:flex-end; gap:3px; height:30px; margin-top:6px; }
.spark span{ flex:1; border-radius:2px 2px 0 0; opacity:.85; min-height:3px; }

.dash-cols{ display:grid; grid-template-columns:1fr 320px; gap:22px; align-items:start; }
.listing-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(170px,1fr)); gap:16px; }
.listing{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; cursor:pointer; transition:.22s var(--ease); }
.listing:hover{ transform:translateY(-3px); box-shadow:var(--sh-2); }
.listing.sold{ opacity:.7; }
.listing-img{ aspect-ratio:1/1; background:radial-gradient(120% 90% at 50% 18%,#fff,var(--cream-2)); display:grid; place-items:center; position:relative; }
.listing-status{ position:absolute; top:10px; right:10px; font-size:10.5px; font-weight:700; padding:3px 9px; border-radius:99px; }
.s-live{ background:#EAF0E6; color:#5C7A52; } .s-sold{ background:var(--ink); color:#F4ECDC; }
.listing-body{ padding:12px 14px; } .listing-body b{ font-size:14.5px; }
.listing-meta{ display:flex; gap:12px; font-size:12px; color:var(--muted); margin:5px 0; }
.listing-price{ font-weight:700; font-size:16px; }
.side-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; }
.orders{ display:flex; flex-direction:column; gap:12px; margin-bottom:8px; }
.order-row{ display:flex; align-items:center; gap:14px; padding:14px; }
.order-info{ flex:1; } .order-info b{ font-size:14.5px; display:block; } .order-info span{ font-size:12px; color:var(--muted); }
.order-status{ font-size:11.5px; font-weight:700; padding:4px 11px; border-radius:99px; }
.order-status.done{ background:#EAF0E6; color:#5C7A52; } .order-status.shipping{ background:var(--gold-pale); color:var(--gold-deep); }
.order-price{ font-size:16px; }
.mini-stats{ display:flex; gap:18px; margin-top:14px; }
.mini-stats div{ text-align:center; } .mini-stats b{ font-size:22px; font-family:var(--serif); display:block; } .mini-stats span{ font-size:11.5px; color:var(--muted); }

/* ---------- ADMIN ---------- */
.admin{ padding-top:22px; padding-bottom:40px; }
.admin-head{ display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:20px; }
.admin-head h1{ font-size:32px; margin:6px 0 0; }
.admin-head-side{ display:flex; align-items:center; gap:12px; }
.live-dot{ width:8px; height:8px; border-radius:50%; background:var(--pos); display:inline-block; box-shadow:0 0 0 0 rgba(92,122,82,.5); animation:pulse 2s infinite; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(92,122,82,.5);} 70%{box-shadow:0 0 0 7px rgba(92,122,82,0);} 100%{box-shadow:0 0 0 0 rgba(92,122,82,0);} }
.admin-cols{ display:grid; grid-template-columns:1fr 340px; gap:18px; margin-bottom:18px; align-items:start; }
.chart-head{ display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:10px; }
.chart-head b{ font-size:16px; } .chart-head span{ display:block; font-size:12px; color:var(--muted); }
.legend{ display:flex; gap:14px; font-size:12px; color:var(--muted); }
.legend span{ display:flex; align-items:center; gap:6px; }
.lg{ width:14px; height:3px; border-radius:2px; display:inline-block; } .lg.gold{ background:var(--gold); } .lg.ink{ background:var(--ink); }
.linechart{ width:100%; height:200px; display:block; }
.chart-x{ display:flex; justify-content:space-between; padding:0 14px; margin-top:4px; }
.chart-x span{ font-size:10.5px; color:var(--muted-2); }
.cat-card b{ font-size:16px; }
.cat-bars{ display:flex; flex-direction:column; gap:14px; margin-top:16px; }
.cb-top{ display:flex; justify-content:space-between; font-size:13px; margin-bottom:5px; } .cb-top b{ font-size:13px; }
.cb-track{ height:8px; background:var(--cream-2); border-radius:99px; overflow:hidden; }
.cb-track i{ display:block; height:100%; border-radius:99px; }

.mod-card{ padding:20px 22px; }
.mod-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:16px; }
.mod-head b{ font-size:17px; } .mod-count{ display:block; font-size:12.5px; color:var(--warn); font-weight:600; margin-top:2px; }
.mod-table{ font-size:13.5px; overflow-x:auto; max-width:100%; }
.mod-th,.mod-tr{ display:grid; grid-template-columns:64px 1.4fr 1.6fr 90px 96px 150px; gap:14px; align-items:center; }
.mod-th{ font-size:11.5px; color:var(--muted); font-weight:600; padding:0 4px 10px; border-bottom:1px solid var(--line); }
.mod-tr{ padding:14px 4px; border-bottom:1px solid var(--line); }
.mod-tr:last-child{ border-bottom:none; }
.mod-kind{ font-size:11.5px; font-weight:700; color:var(--ink-2); background:var(--cream-2); border:1px solid var(--line); padding:4px 0; border-radius:8px; text-align:center; }
.mod-target b{ display:block; font-size:13.5px; } .mod-target i{ font-style:normal; font-size:11.5px; color:var(--muted); }
.mod-reason{ color:var(--ink-2); } .mod-reason i{ display:block; font-style:normal; font-size:11px; color:var(--muted-2); margin-top:2px; }
.sev{ font-style:normal; font-size:11.5px; font-weight:700; padding:4px 10px; border-radius:99px; }
.sev-high{ background:var(--danger-bg); color:var(--danger); } .sev-med{ background:var(--warn-bg); color:var(--warn); } .sev-low{ background:var(--cream-2); color:var(--muted); }
.mod-status{ font-size:12px; font-weight:700; }
.st-open{ color:var(--warn); } .st-review{ color:var(--gold-deep); } .st-resolved{ color:var(--pos); } .st-removed{ color:var(--danger); }
.mod-actions{ display:flex; gap:7px; }
.ma{ font-size:12px; font-weight:700; padding:7px 12px; border-radius:99px; border:1.4px solid; transition:.15s; }
.ma-ok{ border-color:#cfe0c4; color:var(--pos); } .ma-ok:hover{ background:var(--pos); color:#fff; border-color:var(--pos); }
.ma-rm{ border-color:#e8c8c2; color:var(--danger); } .ma-rm:hover{ background:var(--danger); color:#fff; border-color:var(--danger); }
.ma-done{ font-size:12px; color:var(--muted); font-weight:600; }
.mod-empty{ text-align:center; padding:30px; color:var(--muted); }
/* admin overhaul: nav + shops/items/activity panels */
.admin-nav{ margin-bottom:20px; }
.adm-panel{ padding:18px 20px; }
.adm-table{ display:flex; flex-direction:column; }
.adm-th,.adm-tr{ display:grid; grid-template-columns:1.6fr 1.8fr .7fr .9fr .9fr; gap:10px; align-items:center; padding:11px 6px; }
.adm-th{ font-size:11.5px; font-weight:700; color:var(--muted); border-bottom:1px solid var(--line); text-align:start; }
.adm-tr{ border-bottom:1px solid var(--line); font-size:13.5px; }
.adm-tr.is-blocked{ opacity:.6; }
.adm-owner{ display:flex; flex-direction:column; min-width:0; } .adm-owner i{ font-style:normal; font-size:11.5px; color:var(--muted); overflow:hidden; text-overflow:ellipsis; }
.adm-st{ font-style:normal; font-size:11.5px; font-weight:700; padding:2px 9px; border-radius:99px; }
.adm-st.ok{ background:#EAF0E6; color:#5C7A52; } .adm-st.bad{ background:#F6E2DE; color:var(--danger); }
.adm-items{ display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:12px; }
.adm-item{ display:flex; gap:12px; align-items:center; border:1px solid var(--line); border-radius:var(--r-md); padding:10px; background:#fff; }
.adm-item.st-hidden{ opacity:.55; }
.ai-thumb{ width:56px; height:56px; border-radius:var(--r-sm); overflow:hidden; flex:none; background:var(--cream-2); }
.ai-thumb img,.ai-thumb .sv{ width:100%; height:100%; object-fit:cover; }
.ai-info{ flex:1; min-width:0; display:flex; flex-direction:column; gap:2px; }
.ai-info b{ font-size:14px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.ai-info span{ font-size:12px; color:var(--muted); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.ai-price{ color:var(--ink-2)!important; font-weight:600; }
.act-head{ display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.act-feed{ display:flex; flex-direction:column; }
.act-row{ display:flex; align-items:center; gap:11px; padding:10px 4px; border-bottom:1px solid var(--line); font-size:13.5px; }
.act-ic{ font-size:17px; flex:none; }
.act-label{ flex:1; min-width:0; } .act-label b{ font-weight:700; }
.act-time{ font-size:11.5px; color:var(--muted); white-space:nowrap; }
@media(max-width:680px){ .adm-th{ display:none; } .adm-tr{ grid-template-columns:1fr 1fr; row-gap:4px; } }

/* ---------- SELL ---------- */
.sell{ padding-top:22px; padding-bottom:34px; }
.sell-head{ display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:20px; }
.sell-head h1{ font-size:30px; margin:6px 0 0; }
.sell-grid{ display:grid; grid-template-columns:380px 1fr; gap:22px; align-items:start; }
.dropzone{ width:100%; aspect-ratio:4/3; border:2px dashed var(--line-2); border-radius:var(--r-md);
  background:var(--paper-warm); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px;
  color:var(--muted); transition:.2s; padding:14px; }
.dropzone:hover{ border-color:var(--gold-soft); background:#fff; }
.dropzone.has{ aspect-ratio:auto; min-height:200px; align-items:stretch; justify-content:flex-start; }
.dropzone b{ color:var(--ink); font-size:15px; } .dropzone span{ font-size:12.5px; }
.dz-ic{ width:60px; height:60px; border-radius:50%; background:var(--gold-pale); display:grid; place-items:center; }
.dz-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:8px; width:100%; }
.dz-shot{ aspect-ratio:3/4; border-radius:9px; background-color:var(--cream-2); background-repeat:no-repeat; border:1px solid var(--line); }
.dz-add{ aspect-ratio:3/4; border-radius:9px; border:1.6px dashed var(--line-2); display:grid; place-items:center; font-size:24px; color:var(--gold); }
.sell-tips{ margin-top:14px; } .sell-tips b{ font-size:14px; } .sell-tips ul{ margin:8px 0 0; padding-inline-start:18px; }
.sell-tips li{ font-size:12.5px; color:var(--muted); margin:4px 0; }
/* sectioned upload form — each step is its own calm card */
.sell-form{ display:flex; flex-direction:column; gap:16px; }
.sell-section{ padding:20px 22px; }
.ss-head{ display:flex; align-items:flex-start; gap:13px; padding-bottom:15px; margin-bottom:16px; border-bottom:1px solid var(--line); }
.ss-num{ flex:none; width:28px; height:28px; border-radius:50%; background:var(--gold-pale); color:var(--gold-2); font-weight:700; font-size:14px; display:grid; place-items:center; margin-top:1px; }
.ss-titles h4{ margin:0; font-size:16px; font-weight:700; color:var(--ink); }
.ss-titles p{ margin:2px 0 0; font-size:12.5px; color:var(--muted); }
.sell-section .field{ margin-top:13px; }
.sell-section .field:first-of-type, .sell-section .frow:first-of-type{ margin-top:0; }
.sell-section .frow{ margin-top:13px; }
.field{ display:flex; flex-direction:column; gap:6px; flex:1; min-width:0; }
.field span{ font-size:13px; font-weight:600; color:var(--ink-2); } .field i{ color:var(--danger); font-style:normal; margin-inline-start:3px; }
.field em{ font-style:normal; font-weight:400; font-size:11.5px; color:var(--muted); }
.field input,.field select,.field textarea{ border:1px solid var(--line); border-radius:var(--r-sm); padding:11px 13px; font-size:14px; background:var(--cream); outline:none; transition:.18s; resize:vertical; }
.field input:focus,.field select:focus,.field textarea:focus{ border-color:var(--gold-soft); background:#fff; box-shadow:0 0 0 3px var(--gold-pale); }
.frow{ display:flex; gap:14px; }
/* primary-photo badge on first preview */
.up-thumb{ position:relative; }
.up-thumb img{ width:84px; height:84px; object-fit:cover; border-radius:var(--r-sm); border:1px solid var(--line); display:block; }
.up-thumb.is-cover img{ border:2px solid var(--gold); }
.up-cover-tag{ position:absolute; inset-inline-start:4px; inset-block-end:4px; background:var(--gold); color:#fff; font-size:10px; font-weight:700; padding:1px 6px; border-radius:6px; }
.up-del{ position:absolute; inset-block-start:4px; inset-inline-end:4px; width:20px; height:20px; border:none; border-radius:50%;
  background:rgba(20,14,8,.74); color:#fff; font-size:11px; line-height:1; cursor:pointer; display:grid; place-items:center; padding:0; }
.up-del:hover{ background:var(--danger,#c0392b); }
.sell-done{ text-align:center; font-size:13px; color:var(--pos); margin:2px 0 0; }

@media(max-width:980px){
  .cart-grid,.dash-cols,.admin-cols,.sell-grid{ grid-template-columns:1fr; }
  .cart-sum{ position:static; }
  .kpi-row{ grid-template-columns:repeat(2,1fr); }
  .db-stats{ width:100%; justify-content:space-between; gap:12px; margin-inline-start:0; }
  .mod-table{ overflow-x:auto; } .mod-th,.mod-tr{ grid-template-columns:60px 1.3fr 1.5fr 84px 90px 140px; min-width:720px; }
}
@media(max-width:760px){
  .msgs{ grid-template-columns:1fr; }
  .msg-thread{ display:none; }
  .msgs.show-thread .msg-list{ display:none; }
  .msgs.show-thread .msg-thread{ display:flex; }
  .back-btn{ display:block; }
}

/* ============ auth screen (dark, gold on noir) ============ */
.auth-screen{
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  padding:40px 20px;
  background:
    radial-gradient(120% 80% at 50% 0%, #2A2014 0%, var(--noir) 60%),
    var(--noir);
}
.auth-card{
  width:100%; max-width:420px; text-align:center;
  background:linear-gradient(180deg, rgba(46,38,28,.65), rgba(21,17,12,.85));
  border:1px solid rgba(201,162,75,.28);
  border-radius:var(--r-xl);
  box-shadow:0 40px 90px -30px rgba(0,0,0,.7);
  padding:38px 30px 28px;
}
.auth-emblem{ height:54px; width:auto; margin:0 auto 10px; display:block; }
.auth-word{
  color:var(--gold-soft); font-size:30px; margin:0;
  background:var(--gold-grad); -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
}
.auth-tag{ display:block; color:var(--muted-2); letter-spacing:.18em; font-size:12px; margin-top:4px; }
.auth-tabs{
  display:flex; gap:6px; background:rgba(0,0,0,.25); border-radius:var(--r-pill);
  padding:5px; margin:24px 0 18px;
}
.auth-tabs button{
  flex:1; padding:9px 0; border-radius:var(--r-pill); color:var(--muted-2);
  font-weight:600; font-size:14px; transition:.2s var(--ease);
}
.auth-tabs button.on{ background:var(--gold-grad); color:#241a08; }
.auth-form{ display:flex; flex-direction:column; gap:13px; text-align:start; }
.auth-form label{ display:flex; flex-direction:column; gap:6px; color:var(--gold-pale); font-size:13px; font-weight:600; }
.auth-form input{
  background:rgba(0,0,0,.32); border:1px solid rgba(201,162,75,.25);
  border-radius:var(--r-sm); padding:12px 14px; color:#F3E9D4; font-size:15px;
  transition:.18s var(--ease);
}
.auth-form input:focus{ outline:none; border-color:var(--gold-2); background:rgba(0,0,0,.45); }
.auth-form input::placeholder{ color:#7c715c; }
.auth-submit{ margin-top:6px; width:100%; justify-content:center; }
.auth-err{
  background:rgba(176,70,60,.16); border:1px solid rgba(176,70,60,.4);
  color:#F1C9C2; border-radius:var(--r-sm); padding:9px 12px; font-size:13px;
}
.auth-or{ display:flex; align-items:center; gap:12px; margin:16px 0 14px; color:var(--gold-soft); font-size:12px; letter-spacing:.04em; }
.auth-or::before,.auth-or::after{ content:''; flex:1; height:1px; background:rgba(228,197,142,.22); }
.google-btn{ display:flex; justify-content:center; min-height:44px; }
.auth-demo{ color:var(--muted-2); font-size:12.5px; margin:18px 0 4px; }
.auth-demo b{ color:var(--gold-soft); font-weight:600; }
.auth-back{ color:var(--muted-2); font-size:13px; margin-top:6px; }
.auth-back:hover{ color:var(--gold-soft); }

/* ============ boot splash / empty / shop view ============ */
.boot-splash{ min-height:64vh; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; color:var(--muted); font-family:var(--font); }
.boot-emblem{ width:46px; height:46px; border-radius:50%; background:var(--gold-grad); animation:bootpulse 1.1s ease-in-out infinite; }
@keyframes bootpulse{ 0%,100%{ transform:scale(.9); opacity:.6 } 50%{ transform:scale(1.05); opacity:1 } }

.empty-state{ text-align:center; padding:54px 24px; color:var(--muted); display:flex; flex-direction:column; align-items:center; gap:12px; background:var(--paper-warm); border:1px dashed var(--line-2); border-radius:var(--r-lg); }
.empty-state h3{ margin:0; font-size:22px; color:var(--ink); }
.empty-state p{ margin:0; max-width:380px; }

.shop-hero{ display:flex; gap:18px; align-items:center; padding:8px 0 14px; }
.shop-hero-info{ flex:1; min-width:0; }
.shop-hero-info h2{ margin:0 0 4px; font-size:26px; }
.shop-hero-meta{ color:var(--muted); font-size:14px; }
.shop-hero-info p{ margin:8px 0 0; color:var(--ink-2); max-width:560px; }
.follow-wrap{ display:flex; flex-direction:column; align-items:flex-end; gap:7px; flex:none; }
.notify-toggle{ display:flex; align-items:center; gap:6px; font-size:12.5px; color:var(--muted); cursor:pointer; white-space:nowrap; }
.notify-toggle input{ accent-color:var(--gold-deep); }
@media(max-width:600px){ .shop-hero{ flex-wrap:wrap; } .follow-wrap{ align-items:flex-start; } }
.reviews-list{ display:grid; gap:12px; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); }
.review{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md); padding:14px 16px; }
.review-top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.review p{ margin:0; color:var(--ink-2); font-size:14px; }
.review-item{ color:var(--muted); font-size:12px; }

.search-go{ display:flex; align-items:center; }

/* upload zone (sell form) */
.upload-zone{ margin-bottom:8px; }
.upload-empty{ display:flex; flex-direction:column; align-items:center; gap:6px; padding:30px; border:1.5px dashed var(--line-2); border-radius:var(--r-md); background:var(--paper-warm); cursor:pointer; color:var(--muted); text-align:center; }
.upload-empty b{ color:var(--ink); }
.upload-empty:hover{ border-color:var(--gold); }
.upload-previews{ display:flex; flex-wrap:wrap; gap:8px; }
.upload-previews img{ width:84px; height:84px; object-fit:cover; border-radius:var(--r-sm); border:1px solid var(--line); }
.upload-more{ width:84px; height:84px; border:1.5px dashed var(--line-2); border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; font-size:26px; color:var(--gold); cursor:pointer; background:var(--paper-warm); }
.upload-more:hover{ border-color:var(--gold); }

/* listing actions + review modal */
.listing-actions{ display:flex; gap:8px; margin-top:8px; }
.listing-actions button{ font-size:12px; color:var(--muted); padding:4px 9px; border:1px solid var(--line); border-radius:var(--r-pill); background:var(--paper); }
.listing-actions button:hover{ border-color:var(--gold); color:var(--ink); }
.listing-actions button.del:hover{ border-color:var(--danger); color:var(--danger); }
.modal-scrim{ position:fixed; inset:0; background:rgba(20,15,8,.55); display:flex; align-items:center; justify-content:center; z-index:200; padding:20px; }
.modal{ width:100%; max-width:420px; padding:24px; }
.modal h3{ margin:0 0 14px; }
.modal textarea{ width:100%; border:1px solid var(--line); border-radius:var(--r-sm); padding:10px 12px; font-family:inherit; resize:vertical; margin-top:6px; }
.star-pick{ display:flex; gap:4px; direction:ltr; justify-content:flex-end; }
.star-pick button{ font-size:26px; color:var(--line-2); line-height:1; }
.star-pick button.on{ color:var(--gold-2); }
.modal-actions{ display:flex; gap:10px; justify-content:flex-end; margin-top:14px; }

/* logo placeholder for items without a photo */
.img-ph{ width:100%; height:100%; display:flex; align-items:center; justify-content:center; background:var(--paper-warm); }
.img-ph img{ width:46%; max-width:96px; opacity:.45; }

/* clean (static) product stage — no tilt / parallax / zoom tricks */
.pstage.clean{
  aspect-ratio:4/5; width:100%;
  background:linear-gradient(160deg, var(--paper-warm), var(--cream-2));
  border:1px solid var(--line); border-radius:var(--r-lg);
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; padding:18px;
}
.pstage.clean .pstage-photo{ width:100%; height:100%; object-fit:contain; border-radius:var(--r-md); }
.pstage.clean .pstage-cut{ width:100%; height:100%; display:flex; align-items:center; justify-content:center; }
.pstage.clean .pstage-cut img{ max-width:86%; max-height:96%; object-fit:contain; filter:drop-shadow(0 24px 40px rgba(40,30,15,.26)); }
.pstage.clean .pstage-scenebox{ width:100%; height:100%; border-radius:var(--r-md); overflow:hidden; position:relative; }
.pstage.clean .pstage-scenebox > *{ width:100%; height:100%; }
.pstage.clean .img-ph{ background:transparent; }
.pstage.clean .img-ph img{ width:34%; max-width:120px; }
/* hover-to-zoom (magnifier toward the cursor); returns to normal on leave */
.pstage.clean{ cursor:zoom-in; }
.pstage.clean .zoomable{ transition:transform .28s var(--ease); will-change:transform; }

/* real-photo thumbnails on the product page */
.pview-thumbs .thumb{ width:64px; height:64px; padding:0; border-radius:var(--r-sm); overflow:hidden; border:1px solid var(--line); }
.pview-thumbs .thumb.on{ border-color:var(--gold-2); }
.pview-thumbs .thumb img{ width:100%; height:100%; object-fit:cover; }

.chart-empty{ padding:54px 16px; text-align:center; color:var(--muted); }

/* 404 */
.notfound{ min-height:60vh; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; text-align:center; padding:40px 20px; }
.notfound h2{ margin:0; font-size:28px; }
.notfound p{ color:var(--muted); margin:0; }

/* shop card cover fallback */
.shopcard-ph{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background:linear-gradient(160deg,var(--cream-2),var(--cream-3)); }
.shopcard-ph img{ width:42%; max-width:80px; opacity:.4; }

/* open/edit shop form */
.shopform-head{ display:flex; align-items:center; gap:14px; margin-bottom:14px; }
.shopform-head h3{ margin:0; font-size:20px; }
.shopform-head span{ color:var(--muted); font-size:13px; }
/* shop cover picker */
.cover-pick{ position:relative; display:block; border:1.5px dashed var(--line-2); border-radius:var(--r-md); overflow:hidden; cursor:pointer;
  background:var(--paper-warm); aspect-ratio:16/6; min-height:96px; transition:.18s; }
.cover-pick:hover{ border-color:var(--gold); }
.cover-img{ width:100%; height:100%; object-fit:cover; }
.cover-ph{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px; color:var(--muted); font-size:13px; }
.cover-edit{ position:absolute; inset-block-start:8px; inset-inline-end:8px; width:28px; height:28px; border-radius:50%; background:rgba(20,14,8,.7); color:#fff; display:grid; place-items:center; font-size:14px; }
/* delete-shop modal options */
.del-opt{ display:flex; align-items:center; gap:10px; width:100%; text-align:start; padding:12px 14px; border:1px solid var(--line); border-radius:var(--r-md); margin-bottom:8px; transition:.15s; background:#fff; }
.del-opt:hover{ border-color:var(--gold-soft); }
.del-opt.on{ border-color:var(--gold); background:var(--gold-pale); }
.del-opt.danger.on{ border-color:var(--danger); background:rgba(192,57,43,.06); }
.do-radio{ font-size:15px; color:var(--gold-deep); flex:none; }
.del-opt.danger .do-radio{ color:var(--danger); }
.do-body{ display:flex; flex-direction:column; gap:6px; flex:1; min-width:0; }
.do-body select{ border:1px solid var(--line); border-radius:var(--r-sm); padding:7px 10px; font-size:13px; background:var(--cream); }
.btn-danger{ background:var(--danger,#c0392b); color:#fff; }
.btn-danger:hover{ filter:brightness(1.06); }
.shop-del-link{ display:block; width:100%; text-align:center; margin-top:12px; color:var(--danger,#c0392b); font-size:13.5px; font-weight:600; }
.shop-del-link:hover{ text-decoration:underline; }

/* collections manager */
.collections2{ display:grid; grid-template-columns:1fr 1fr; gap:16px; align-items:start; }
.hint-note{ color:var(--muted); font-size:12.5px; margin:10px 0 0; }
.col-list{ display:flex; flex-direction:column; gap:10px; margin-top:10px; }
.col-row{ display:flex; justify-content:space-between; align-items:flex-start; gap:10px; padding:12px 14px; border:1px solid var(--line); border-radius:var(--r-md); background:var(--paper-warm); }
.col-info b{ display:block; }
.col-info span{ color:var(--muted); font-size:12px; }
.col-info p{ margin:4px 0 0; font-size:13px; color:var(--ink-2); }

/* collection filter chips on shop page */
.shop-collections{ display:flex; flex-wrap:wrap; gap:8px; margin:6px 0 4px; }
.shop-collections button{ padding:7px 14px; border-radius:var(--r-pill); border:1px solid var(--line-2); background:var(--paper); font-size:13px; font-weight:600; color:var(--ink-2); }
.shop-collections button.on{ background:var(--ink); color:var(--gold-soft); border-color:var(--ink); }

@media(max-width:760px){
  .collections2{ grid-template-columns:1fr; }
}

/* ============ v2: collections / shops / sales / explore ============ */
.col-tag{ display:inline-block; font-size:11px; color:var(--gold-deep); background:var(--gold-pale); padding:2px 9px; border-radius:var(--r-pill); font-weight:600; }
.sold-chip{ background:#E6DCCD; color:var(--muted); }
.owner-note{ background:var(--paper-warm); border:1px solid var(--line); border-radius:var(--r-md); padding:13px 16px; color:var(--ink-2); font-weight:600; text-align:center; flex:1; }

.db-actions{ display:flex; gap:8px; flex-wrap:wrap; }
.shop-switch{ display:flex; gap:2px; border-bottom:1px solid var(--line); margin:4px 0 16px; overflow-x:auto; -webkit-overflow-scrolling:touch; }
.shop-switch::-webkit-scrollbar{ display:none; }
.shop-chip{ padding:11px 18px; border:none; border-radius:0; background:none; border-bottom:2px solid transparent; color:var(--muted); font-weight:600; font-size:14px; white-space:nowrap; transition:color .15s var(--ease); }
.shop-chip:hover{ color:var(--ink-2); }
.shop-chip.on{ color:var(--ink); border-bottom-color:var(--gold-2); }
.shop-chip.add{ color:var(--gold-deep); }
.shop-head-row{ display:flex; justify-content:space-between; align-items:center; gap:10px; margin-bottom:12px; flex-wrap:wrap; }

.col-cards{ display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:12px; }
.col-card{ display:flex; flex-direction:column; gap:4px; align-items:flex-start; padding:16px; border:1px solid var(--line); border-radius:var(--r-md); background:var(--paper-warm); text-align:start; }
.col-card:hover{ border-color:var(--gold); }
.col-card-ic{ color:var(--gold-2); font-size:18px; }
.col-card b{ font-size:15px; } .col-card span{ color:var(--muted); font-size:12px; }
.listing .col-tag{ display:inline-block; margin:3px 0; }

.buyer-list{ display:flex; flex-direction:column; gap:8px; max-height:240px; overflow-y:auto; margin:6px 0; }
.buyer-opt{ display:flex; align-items:center; gap:10px; padding:8px 12px; border:1px solid var(--line); border-radius:var(--r-md); background:var(--paper); }
.buyer-opt.on{ border-color:var(--gold-2); background:var(--gold-pale); }
.buyer-opt i{ margin-inline-start:auto; color:var(--gold-deep); font-style:normal; }

.bulk-contact{ padding:16px; margin-bottom:16px; display:flex; flex-direction:column; gap:8px; }
.bulk-contact textarea, .cart-composer textarea{ width:100%; border:1px solid var(--line); border-radius:var(--r-sm); padding:8px 10px; font-family:inherit; resize:vertical; }
.bulk-row{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.bulk-done{ color:var(--pos); font-size:13px; } .bulk-done a{ color:var(--gold-deep); text-decoration:underline; cursor:pointer; }
.cart-composer{ margin-top:8px; }
.contacted{ color:var(--pos); font-weight:700; font-size:13px; }

.col-hero{ padding:6px 0 16px; }
.col-hero h2{ margin:4px 0; font-size:28px; }
.col-hero p{ color:var(--ink-2); max-width:560px; margin:0; }
.col-open{ background:none; color:var(--gold-deep); font-weight:600; font-size:13px; }

.explore-search{ display:flex; gap:10px; margin:14px 0 20px; }
.explore-search input{ flex:1; border:1px solid var(--line); border-radius:var(--r-pill); padding:12px 18px; font-size:15px; background:var(--paper); font-family:inherit; }
.explore-cols{ display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:12px; }
.explore-col{ display:flex; flex-direction:column; gap:3px; align-items:flex-start; padding:14px 16px; border:1px solid var(--line); border-radius:var(--r-md); background:var(--paper-warm); }
.explore-col:hover{ border-color:var(--gold); }
.explore-users{ display:flex; flex-wrap:wrap; gap:10px; }
.explore-user{ display:flex; align-items:center; gap:10px; padding:7px 14px 7px 8px; border:1px solid var(--line); border-radius:var(--r-pill); background:var(--paper); }
.explore-user:hover{ border-color:var(--gold); }

.col-new{ display:flex; gap:6px; align-items:center; }
.col-new input{ flex:1; min-width:0; }

/* ============ personalized home: preferences + filters ============ */
.rack-placeholder{ min-height:340px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; text-align:center; padding:40px 24px;
  background:linear-gradient(160deg,var(--paper-warm),var(--cream-2)); border:1px dashed var(--line-2); border-radius:var(--r-xl); }
.rack-placeholder h3{ margin:0; font-size:24px; }
.rack-placeholder p{ color:var(--muted); max-width:430px; margin:0; }

.prefs-modal{ max-width:460px; }
.pref-cats{ display:flex; flex-direction:column; gap:4px; max-height:52vh; overflow-y:auto; margin:6px 0; }
.pref-cat{ border-bottom:1px solid var(--line); padding:9px 2px; }
.pref-catrow{ display:flex; align-items:center; gap:8px; font-weight:600; cursor:pointer; }
.pref-sizes{ display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; padding-inline-start:24px; }
.pref-sizes button{ padding:5px 12px; border:1px solid var(--line-2); border-radius:var(--r-pill); font-size:12.5px; background:var(--paper); }
.pref-sizes button.on{ background:var(--ink); color:var(--gold-soft); border-color:var(--ink); }

.filter-bar{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:16px; }
.filter-bar select{ border:1px solid var(--line); border-radius:var(--r-pill); padding:9px 16px; background:var(--paper); font-family:inherit; font-size:13.5px; color:var(--ink); }

.pcard-sold{ position:absolute; top:10px; left:10px; z-index:3; background:rgba(24,18,12,.9); color:#F4ECDC; font-size:11px; font-weight:700; padding:3px 10px; border-radius:var(--r-pill); }

/* collection item management (collection page) */
.col-manage{ display:flex; flex-direction:column; gap:8px; }
.col-manage-row{ display:flex; align-items:center; gap:12px; justify-content:space-between; padding:10px 14px; border:1px solid var(--line); border-radius:var(--r-md); background:var(--paper); }
.cm-name{ font-weight:600; }
.col-manage-row select{ border:1px solid var(--line); border-radius:var(--r-sm); padding:6px 10px; font-family:inherit; }

/* dashboard collection cards with edit/delete tools */
.col-card-wrap{ display:flex; flex-direction:column; gap:6px; }
.col-card-tools{ display:flex; gap:8px; }
.col-card-tools button{ font-size:12px; color:var(--muted); padding:3px 9px; border:1px solid var(--line); border-radius:var(--r-pill); background:var(--paper); }
.col-card-tools button:hover{ border-color:var(--gold); color:var(--ink); }
.col-card-tools button.del:hover{ border-color:var(--danger); color:var(--danger); }
.col-card.editing{ display:flex; flex-direction:column; gap:6px; padding:14px; border:1px solid var(--gold-2); border-radius:var(--r-md); background:var(--paper-warm); }
.col-card.editing input{ border:1px solid var(--line); border-radius:var(--r-sm); padding:6px 10px; font-family:inherit; }
.col-card-acts{ display:flex; gap:6px; }
.col-card-acts button{ font-size:12px; padding:4px 10px; border-radius:var(--r-pill); border:1px solid var(--line); background:var(--paper); }

/* edit item modal grid */
.edit-grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:8px; }
.edit-grid .field span{ font-size:12px; }
@media(max-width:520px){ .edit-grid{ grid-template-columns:1fr; } }
/* edit-item photo manager */
.edit-photos{ margin-bottom:14px; }
.ep-label{ display:block; font-size:13px; font-weight:600; color:var(--ink-2); margin-bottom:8px; }
.ep-label em{ font-style:normal; font-weight:400; color:var(--muted); }
.ep-grid{ display:flex; flex-wrap:wrap; gap:8px; }
.ep-thumb{ position:relative; width:72px; height:72px; border-radius:var(--r-sm); overflow:hidden; border:1px solid var(--line); }
.ep-thumb.is-cover{ border:2px solid var(--gold); }
.ep-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.ep-cover{ position:absolute; inset-inline-start:0; inset-block-end:0; background:var(--gold); color:#fff; font-size:9px; font-weight:700; padding:1px 5px; border-start-end-radius:6px; }
.ep-del{ position:absolute; inset-block-start:3px; inset-inline-end:3px; width:20px; height:20px; border:none; border-radius:50%;
  background:rgba(20,14,8,.72); color:#fff; font-size:11px; line-height:1; cursor:pointer; display:grid; place-items:center; padding:0; }
.ep-del:hover{ background:var(--danger,#c0392b); }
.ep-add{ width:72px; height:72px; border-radius:var(--r-sm); border:1.5px dashed var(--line-2); display:grid; place-items:center;
  font-size:24px; color:var(--gold); cursor:pointer; background:var(--paper-warm); }
.ep-add:hover{ border-color:var(--gold); }
.ep-add.busy{ cursor:default; color:var(--muted); }

/* ============ filter/sort bar + buyer search ============ */
.filterbar{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-bottom:16px; }
.fb-search{ display:flex; align-items:center; gap:8px; flex:1; min-width:200px; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-pill); padding:9px 16px; color:var(--muted); }
.fb-search input{ border:none; background:none; outline:none; width:100%; font-size:14px; color:var(--ink); font-family:inherit; }
.fb-ctl{ position:relative; }
.fb-btn{ display:flex; align-items:center; gap:7px; padding:10px 16px; border:1px solid var(--line); border-radius:var(--r-pill); background:var(--paper); font-weight:600; font-size:13.5px; color:var(--ink-2); white-space:nowrap; }
.fb-btn:hover{ border-color:var(--line-2); }
.fb-btn.on{ background:var(--ink); color:var(--gold-soft); border-color:var(--ink); }
.fb-scrim{ position:fixed; inset:0; z-index:40; }
.fb-pop{ position:absolute; top:calc(100% + 8px); inset-inline-start:0; z-index:50; min-width:230px; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md); box-shadow:var(--sh-2); padding:14px; display:flex; flex-direction:column; gap:10px; }
.fb-pop.sort{ min-width:200px; gap:2px; padding:8px; }
.fb-pop.sort button{ text-align:start; padding:9px 12px; border-radius:var(--r-sm); font-size:14px; color:var(--ink-2); }
.fb-pop.sort button:hover{ background:var(--cream-2); }
.fb-pop.sort button.on{ background:var(--gold-pale); color:var(--gold-deep); font-weight:600; }
.fb-clear{ color:var(--danger); font-size:13px; font-weight:600; text-align:start; padding:2px 0; }

.shops-row.all{ grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); }

.sold-modal{ max-width:440px; }
.buyer-opt.offsite{ width:100%; margin:4px 0 8px; border-style:dashed; }
.buyer-opt.offsite .off-ic{ font-size:18px; }
.buyer-opt.offsite .off-sub{ display:block; color:var(--muted); font-size:11.5px; font-weight:400; }
.bl-head{ font-size:12px; color:var(--muted); font-weight:600; padding:6px 2px 2px; }
.bl-empty{ color:var(--muted); font-size:13px; padding:8px 2px; }
@media(max-width:560px){ .filterbar{ flex-direction:column; align-items:stretch; } .fb-pop{ inset-inline-start:auto; inset-inline-end:0; } }
