/* =========================================================
   vendors.css — Everjoy Vendors Page (clean, scoped)
   - Filters + results grid
   - Polished cards + heart (white → red when saved)
   - Mobile-only “Popular near you” strip (copied style, trimmed)
   - Minimal globals; everything else scoped to vendor page
========================================================= */

/* ---------- Theme tokens (scoped to Vendors page) ---------- */
body[data-page-kind="vendor"]{
  --ej-line:#e5e7eb;
  --ej-sub:#475569;
  --ej-card:#ffffff;
  --ej-brand:#025fbc;
  --ej-brand2:#06a2dd;
  --ej-ink:#0f172a;
  --ej-shadow:0 8px 22px rgba(15,23,42,.08);
  --ej-shadow-soft:0 4px 12px rgba(15,23,42,.06);
  background:#F6F8FB; color:var(--ej-ink);
}

/* Options / selects / range */
body[data-page-kind="vendor"] .filter-options{ display:flex; flex-direction:column; gap:12px; }
body[data-page-kind="vendor"] .check-option{ display:flex; align-items:center; gap:8px; font-size:14px; color:#334155; cursor:pointer; }
body[data-page-kind="vendor"] .check-option input{ accent-color:#2563eb; }
body[data-page-kind="vendor"] .filter-select{
  width:100%; padding:10px 12px; border:1px solid #e2e8f0; border-radius:8px;
  background:#f8fafc; font:500 14px/1.2 Poppins,system-ui; outline:0; box-sizing:border-box;
}
body[data-page-kind="vendor"] .range-labels{ display:flex; justify-content:space-between; font-size:12px; color:#64748b; margin-bottom:8px; }
body[data-page-kind="vendor"] .range-slider{ width:100%; accent-color:#2563eb; }

/* Apply filters */
body[data-page-kind="vendor"] .apply-filters-btn{
  width:100%; padding:12px; font-weight:700; font-size:15px; border-radius:10px; border:none;
  background:#0f172a; color:#fff; cursor:pointer; margin-top:24px;
}

/* =========================================================
   RESULTS HEADER
   (match other collection pages)
========================================================= */
body[data-page-kind="vendor"] .results-toolbar{
  display:flex;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
}

body[data-page-kind="vendor"] .results-head .results-title{
  margin:0;
  font-weight:800;
  line-height:1.2;
  font-size:clamp(22px,2.4vw,28px);
}

/* Match Rentals/Caterers title stack */
body[data-page-kind="vendor"] .results-title-main{
  display:block;
  font-weight:700;
  font-size:24px;
  letter-spacing:-.015em;
  line-height:1.15;
}

body[data-page-kind="vendor"] .results-subtitle{
  display:block;
  margin-top:4px;
  font-weight:500;
  font-size:13px;
  color:#64748b;
  line-height:1.2;
}

@media (min-width: 961px){
  body[data-page-kind="vendor"] .results-title-main{
    font-size:28px;
  }
  body[data-page-kind="vendor"] .results-subtitle{
    font-size:14px;
  }
}


/* Let "Showing N vendors in Manitoba" look like the other pages:
   regular weight, default color, on its own line. */
body[data-page-kind="vendor"] #resultsCount,
body[data-page-kind="vendor"] .results-head #resultsKind{
  color:inherit;
  font-weight:inherit;
}

body[data-page-kind="vendor"] .results-controls select{
  padding:10px 12px;
  border:1px solid var(--ej-line);
  border-radius:10px;
  background:#fff;
  font:500 .92rem/1 Poppins,system-ui;
  color:var(--ej-ink);
}

/* Small count/meta */
body[data-page-kind="vendor"] .results-header{
  display:block;
  margin-bottom:24px;
}

body[data-page-kind="vendor"] .results-meta{
  margin-top:4px;
}

body[data-page-kind="vendor"] .results-count{
  font-size:14px;
  color:#64748b;
  text-align:left;
}

body[data-page-kind="vendor"] .results-count strong{
  font-weight:500;
}


body[data-page-kind="vendor"] .vendors-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:24px;
}

/* Card container */
/* Legacy standalone vendor cards can still use this */
body[data-page-kind="vendor"] .vendor-card{
  position:relative; background:#fff; border:1px solid var(--ej-line); border-radius:16px;
  box-shadow:var(--ej-shadow); overflow:hidden;
  transition:transform .18s ease, box-shadow .18s ease;
  padding:0;
}
body[data-page-kind="vendor"] .vendor-card:hover{
  transform:translateY(-2px); box-shadow:0 10px 26px rgba(15,23,42,.12);
}

/* Pagination */
body[data-page-kind="vendor"] .pager{
  display:flex; justify-content:center; gap:8px; margin:28px 0 8px;
}
body[data-page-kind="vendor"] .pager a{
  text-decoration:none; border:1px solid var(--ej-line); background:#fff; color:var(--ej-ink);
  padding:8px 12px; border-radius:10px; font-weight:600; box-shadow:0 1px 0 rgba(255,255,255,.6) inset;
}
body[data-page-kind="vendor"] .pager a[aria-current="page"]{
  background:var(--ej-brand); border-color:var(--ej-brand); color:#fff;
}
body[data-page-kind="vendor"] .pager a[aria-disabled="true"]{
  opacity:.55; pointer-events:none;
}

/* =========================================================
   CTA (optional section block)
========================================================= */
body[data-page-kind="vendor"] .cta-section{ background:#eef2ff; padding:64px 0; }
body[data-page-kind="vendor"] .cta-wrap{ text-align:center; max-width:600px; margin:0 auto; }
body[data-page-kind="vendor"] .cta-wrap h2{ font-size:28px; font-weight:800; color:#1e293b; margin-bottom:12px; }
body[data-page-kind="vendor"] .cta-wrap p{ font-size:16px; color:#475569; line-height:1.6; margin-bottom:24px; }
body[data-page-kind="vendor"] .cta-btn{
  display:inline-block; background:#2563eb; color:#fff; font-weight:700; padding:14px 28px;
  border-radius:12px; text-decoration:none; box-shadow:0 4px 12px rgba(37,99,235,.2);
  transition:background-color .2s, transform .2s;
}
body[data-page-kind="vendor"] .cta-btn:hover{ background:#1d4ed8; transform:translateY(-2px); }

/* =========================================================
   RESPONSIVE
========================================================= */
@media (max-width:1024px){
  body[data-page-kind="vendor"] .vendors-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:900px){
  body[data-page-kind="vendor"] .filters-sidebar{ position:static; }
}
@media (max-width:640px){
  body[data-page-kind="vendor"] .vendors-grid{ grid-template-columns:1fr; }
  body[data-page-kind="vendor"] .results-toolbar{ flex-direction:column; align-items:stretch; gap:8px; }
  body[data-page-kind="vendor"] .results-controls select{ width:100%; height:44px; border-radius:12px; }
}

/* Filter pills visibility rules */
@media (max-width: 599px){
  #filterPills{ display:none !important; }   /* phones use mobile chips row */
}
@media (min-width: 600px){
  #activeChips{ display:none !important; }   /* tablets/desktop use filterPills */
}


/* =========================================================
   MOBILE-ONLY FEATURED STRIP — "Popular near you"
   (Copied from index.css, trimmed to essentials, scoped)
   Markup expectation:
   <section id="popularNearYou">
     <div class="venues-grid h-scroll">
       ... .venue-card ...
     </div>
   </section>
========================================================= */

/* Mobile only */
#popularNearYou{ padding:8px 0 16px; }
@media (min-width:601px){ #popularNearYou{ display:none !important; } }

/* Horizontal scroller (scoped) */
#popularNearYou .h-scroll{
  display:grid; grid-auto-flow:column;
  grid-auto-columns:clamp(220px,70vw,280px);
  gap:10px; overflow-x:auto; overflow-y:hidden;
  padding:0; margin:0;
  scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch;
}
#popularNearYou .h-scroll > *{ scroll-snap-align:start; }

/* Card (minimal home-style look) */
#popularNearYou .venue-card{
  background:#fff; border-radius:12px; overflow:hidden;
  border:1px solid rgba(0,0,0,.08); box-shadow:0 1px 2px rgba(0,0,0,.04);
}

#popularNearYou .rating{ display:flex; align-items:center; gap:4px; font-weight:600; font-size:13px; }
#popularNearYou .star-icon{ width:16px; height:16px; color:#F59E0B; }
#popularNearYou .price{ font-size:13px; color:#6b7280; }

/* Gutters to match mobile rhythm */
@media (max-width:600px){
  :root{ --mb-gutter:15px; }
  #popularNearYou{ padding-left:var(--mb-gutter); padding-right:var(--mb-gutter); }
}

body[data-page-kind="vendor"] .deals-ribbon{
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; padding:10px 12px; margin: 0 0 12px;
  border:1px solid #dbeafe; border-radius:12px;
  background:#eff6ff; color:#1e3a8a;
  box-shadow:0 2px 8px rgba(2,95,188,.06);
}
body[data-page-kind="vendor"] .deals-ribbon[hidden]{ display:none !important; }
body[data-page-kind="vendor"] .deals-ribbon .count{ font-weight:800; }
body[data-page-kind="vendor"] .deals-ribbon .action{
  border:1px solid #93c5fd; background:#fff; color:#0f172a;
  border-radius:999px; padding:6px 10px; font:700 12px/1 Poppins,system-ui;
}
body[data-page-kind="vendor"] .deals-ribbon .action[aria-pressed="true"]{
  border-color:#0ea5e9; box-shadow:0 0 0 2px rgba(14,165,233,.15) inset;
}

/* Hide non-deal cards when toggled */
body[data-page-kind="vendor"] #gridResults[data-deals-only="1"] > *:not(.has-deal){
  display:none !important;
}

/* Vendor Type dropdown: one checkbox per row, same look/spacing as Location */
#vtypeMenu { padding: 6px 0; }

#vtypeMenu .multisel-opt{
  display: flex;
  align-items: center;
  gap: 10px;
  width: 90%;
  padding: 10px 14px;
  margin: 0;
  cursor: pointer;
  white-space: normal;              /* allow multi-word labels */
}

#vtypeMenu .multisel-opt + .multisel-opt{
  border-top: 1px solid #f1f5f9;   /* subtle separators like list items */
}

#vtypeMenu .multisel-opt input{
  flex: 0 0 auto;
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: #025fbc;
}

/* Utility: visually hide without affecting layout (prevents horizontal scroll) */
.sr-only-keep{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip: rect(0 0 0 0) !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  border:0 !important;
}

/* Guard: bottom-sheet never wider than viewport on mobile */
@media (max-width:600px){
  body[data-page-kind="vendor"] .filters-sidebar.is-open{
    max-width: calc(100vw - 24px);
  }
}

/* =======================
   Filters: dropdown polish
   (shared by Location + Vendor Type)
======================= */
body[data-page-kind="vendor"] .ej-dd{ position:relative; }
body[data-page-kind="vendor"] .ej-dd-toggle{
  display:flex; align-items:center; justify-content:space-between; width:100%;
  padding:12px 14px; border:1px solid #e2e8f0; border-radius:12px; background:#fff;
  font:600 15px/1.2 "Poppins",system-ui; color:#0f172a;
}
body[data-page-kind="vendor"] .ej-dd-menu{
  position:absolute; inset:auto 0  auto 0; top:calc(100% + 8px);
  background:#fff; border:1px solid #e2e8f0; border-radius:12px;
  box-shadow:0 10px 28px rgba(2,95,188,.08); padding:6px 0; max-height:260px; overflow:auto; z-index:30;
}

/* Vendor Type list — one per row */
#vtypeMenu{ padding:6px 0; }
#vtypeMenu .multisel-opt{
  display:block;
  padding:10px 14px;
  white-space:normal;
  font:500 14px/1.25 Poppins,system-ui;
}
#vtypeMenu .multisel-opt + .multisel-opt{ border-top:1px solid #f1f5f9; }
#vtypeMenu .multisel-opt input{ margin-right:10px; accent-color:#025fbc; }

/* Prevent any horizontal bleed on tiny screens */
@media (max-width:600px){
  body[data-page-kind="vendor"]{ overflow-x:hidden; }
  body[data-page-kind="vendor"] .filters-sidebar.is-open{ max-width:calc(100vw - 24px); }
}

/* Ultra-small hardening (legacy iPhone SE 320px) */
@media (max-width:330px){
  body[data-page-kind="vendor"] .ej-dd-toggle{ padding:10px 12px; font-size:14px; }
  #vtypeMenu .multisel-opt{ padding:8px 12px; font-size:13px; }
}

/* ================================
   Toolbar actions (search + filters + sort)
==================================*/
body[data-page-kind="vendor"] .toolbar-actions{
  display:flex; align-items:center; gap:10px; flex-wrap:nowrap;
}
body[data-page-kind="vendor"] .toolbar-actions .sort-wrap select{
  padding:10px 12px; border:1px solid var(--ej-line); border-radius:999px;
  background:#fff; font:500 .92rem/1 Poppins,system-ui; color:var(--ej-ink);
}

body[data-page-kind="vendor"] .searchbar{
  position:relative; display:flex; align-items:center;
}
body[data-page-kind="vendor"] .searchbar input{
  width:min(40vw, 340px); height:40px;
  padding:0 40px 0 12px; border:1px solid var(--ej-line); border-radius:999px;
  background:#fff; font:500 14px/1 Poppins,system-ui; color:var(--ej-ink);
}
body[data-page-kind="vendor"] .searchbar button{
  position:absolute; right:6px; width:30px; height:30px;
  display:grid; place-items:center; border:0; background:transparent; cursor:pointer;
  color:#64748b;
}

@media (max-width: 640px){
  body[data-page-kind="vendor"] .results-toolbar{ flex-direction:column; align-items:stretch; gap:10px; }
  body[data-page-kind="vendor"] .toolbar-actions{ gap:8px; }
  body[data-page-kind="vendor"] .searchbar{ flex:1; }
  body[data-page-kind="vendor"] .searchbar input{ width:100%; }
}

/* One-column wrapper (defensive override against any left-grid) */
body[data-page-kind="vendor"] .results-wrap{ display:block; }

/* Popup-only filters (defensive in case desktop “show” sneaks back) */
@media (min-width:960px){
  body[data-page-kind="vendor"] .filters-sidebar{ display:none !important; }
  body[data-page-kind="vendor"] .filters-sidebar.is-open{ display:block !important; }
}

/* Cards grid — make sure we’re a grid everywhere here too */
body[data-page-kind="vendor"] .results-main .cards-grid{
  display:grid !important;
}

/* Pager ellipsis spacing */
body[data-page-kind="vendor"] .pager span{
  display:inline-flex; align-items:center;
  padding:0 6px; color:#64748b;
}

/* Smooth page switch on the cards grid */
@media (prefers-reduced-motion: no-preference){
  body[data-page-kind="vendor"] .cards-grid{
    transition: opacity .22s ease, transform .22s ease;
  }
  body[data-page-kind="vendor"] .cards-grid.is-paging{
    opacity: 0;
    transform: translateY(6px);
    pointer-events: none; /* prevent double-clicks while animating */
  }
}

/* =========================
   Vendors page (scoped)
   - filter sheet (mobile/desktop overlay)
   - mini toolbar + chips
   - results tip
   - centered empty state
   - pager visuals
   - safe grid + helpers
   ========================= */

/* Hide browse-sb inline empties so our centered state handles it */
body[data-page-kind="vendor"] #gridResults > .empty,
body[data-page-kind="vendor"] #gridResults > .no-results,
body[data-page-kind="vendor"] #gridResults > .grid-empty { display:none !important; }

/* Results tip (small blue info) */
body[data-page-kind="vendor"] .results-main .results-tip{
  display:none; width:100%; margin:8px 0 12px; padding:10px 14px;
  border:1px solid #cfe1ff; background:#eaf3ff; color:#0f3d73;
  border-radius:10px; box-sizing:border-box; align-items:center; gap:10px;
}
body[data-page-kind="vendor"] .results-main .results-tip.is-visible{ display:flex; }
body[data-page-kind="vendor"] .results-tip .tip-icon{
  flex:0 0 22px; width:22px; height:22px; display:grid; place-items:center;
  border-radius:999px; background:#1d4ed8; color:#fff;
}
body[data-page-kind="vendor"] .results-tip .tip-icon svg{ width:14px; height:14px; }
body[data-page-kind="vendor"] .results-tip .tip-label{ font-weight:700; margin-right:4px; }
/* Tip dismiss button */
body[data-page-kind="vendor"] .results-tip{ position:relative; }
body[data-page-kind="vendor"] .results-tip .tip-dismiss{
  position:absolute; right:10px; top:50%; transform:translateY(-50%);
  width:28px; height:28px; border:0; background:transparent; cursor:pointer;
  border-radius:8px; font-size:18px; line-height:1; font-weight:800;
  color:#0f3d73; opacity:.8;
}
body[data-page-kind="vendor"] .results-tip .tip-dismiss:hover{
  opacity:1; background:rgba(29,78,216,.08);
}

/* Mini toolbar (Filters / Sort / Map) + chips — mobile only by default */
body[data-page-kind="vendor"] .mobile-only{ display:block; }
body[data-page-kind="vendor"] .mini-toolbar{
  display:grid; grid-template-columns: repeat(3,1fr); gap:8px; padding:0 12px 8px;
}
body[data-page-kind="vendor"] .mini-toolbar button{
  height:40px; border-radius:999px; border:1px solid #e5e7eb; background:#fff;
  font:700 13px/1 Poppins, system-ui; color:#0f172a;
}
body[data-page-kind="vendor"] #activeChips{
  display:flex; gap:8px; padding:0 12px 6px; overflow:auto; -webkit-overflow-scrolling:touch;
}
body[data-page-kind="vendor"] #activeChips .chip{
  flex:0 0 auto; padding:8px 10px; border-radius:999px; border:1px solid #e5e7eb; background:#fff;
  font:600 12px/1 Poppins,system-ui; color:#0f172a;
}
body[data-page-kind="vendor"] #activeChips .chip .x{ margin-left:6px; opacity:.6; }

/* Filter sheet (as a centered overlay panel) */
body[data-page-kind="vendor"] #filtersScrim.sheet-scrim{
  position: fixed; inset: 0; z-index: 998; background: rgba(2,15,31,.55); backdrop-filter: blur(2px);
}
body[data-page-kind="vendor"] #filtersScrim[hidden]{ display:none; }

@keyframes ejSheetIn { from { transform: translate(-50%, 14px); opacity:.0; } to { transform: translate(-50%, 0); opacity:1; } }

/* ==== FILTER SHEET (common) ====================================== */
.filters-sidebar{
  /* always in the tree; closed via opacity/pointer-events */
  position: fixed;
  z-index: 2147483600;
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:14px;
  box-shadow:0 12px 26px rgba(15,23,42,.18);
  opacity:0;
  pointer-events:none;
  will-change: transform, opacity;
  transition: transform .22s cubic-bezier(.22,.61,.36,1), opacity .16s ease-out;
}

/* ---- Mobile (≤960px): true bottom sheet ---- */
@media (max-width:960px){
  .filters-sidebar{
    left:12px; right:12px;
    bottom: calc(56px + env(safe-area-inset-bottom) + 10px); /* clears tab bar */
    transform: translate3d(0, 110%, 0); /* start fully below viewport */
    max-height: calc(100dvh - var(--header-h,88px) - 90px);
    padding:20px;
  }
  .filters-sidebar.is-open{
    opacity:1;
    pointer-events:auto;
    transform: translate3d(0, 0, 0);  /* slide up */
  }
}

/* ---- Desktop/Tablet (≥961px): centered modal ---- */
@media (min-width:961px){
  .filters-sidebar{
    top:50%; left:50%;
    width: clamp(320px, 40vw, 480px);
    max-height: min(84dvh, 720px);
    padding:20px;
    transform: translate3d(-50%, calc(-50% + 24px), 0) scale(.98); /* start slightly lower/smaller */
  }
  .filters-sidebar.is-open{
    opacity:1;
    pointer-events:auto;
    transform: translate3d(-50%, -50%, 0) scale(1);             /* fade + lift */
  }
}

/* Scrim stays behind the sheet but above everything else */
#filtersScrim{
  position:fixed; inset:0;
  z-index:2147483500;
  background:rgba(2,15,31,.55);
  backdrop-filter: blur(2px);
}

/* While sheet is open, keep bottom tab bar inert and visually behind */
html.sheet-open #mbTabbar{
  pointer-events:none;
  z-index:1 !important;
}

body[data-page-kind="vendor"] .filters-sidebar.is-open #filtersTitle{
  position:sticky; top:0; z-index:2; margin:0; padding:14px 36px 12px 2px; background:#fff;
  font:700 23px/1.1 Poppins,system-ui;
}
body[data-page-kind="vendor"] .filters-sidebar.is-open .sheet-close{
  position:absolute; top:10px; right:10px; width:32px; height:32px; border-radius:999px;
  display:grid; place-items:center; border:1px solid #e2e8f0; background:#fff;
}
body[data-page-kind="vendor"] .filters-sidebar.is-open .filter-section{ margin:12px 0; }
body[data-page-kind="vendor"] .filters-sidebar.is-open .divider{ margin:10px 0; }
body[data-page-kind="vendor"] .filters-sidebar.is-open .filter-actions{
  position:sticky; bottom:0; z-index:2; display:flex; gap:10px; align-items:center;
  margin:0 -14px; padding:12px 14px calc(12px + env(safe-area-inset-bottom));
  background:linear-gradient(180deg, rgba(255,255,255,.95), #fff);
  border-top:1px solid #eef2f7;
}
html.sheet-open #mbFilterToggle{ opacity:0; pointer-events:none; transform:translateY(6px); }
html.sheet-open{ overflow:hidden; }

/* Custom dropdown shell shared on Vendors page */
.ej-dd{ position:relative; }
.ej-dd-toggle{
  display:flex; align-items:center; justify-content:space-between; width:100%;
  padding:12px 14px; border:1px solid #e5e7eb; border-radius:12px; background:#fff;
  font:600 15px/1.2 "Poppins",system-ui; color:#0f172a;
}
.ej-dd-toggle svg{ margin-left:8px; }
.ej-dd-menu{
  position:absolute; left:0; right:0; top:calc(100% + 8px); background:#fff; border:1px solid #e5e7eb;
  border-radius:12px; box-shadow:0 10px 28px rgba(2,95,188,.08); padding:6px 0; max-height:260px; overflow:auto; z-index:30;
}
.ej-dd-item{
  display:flex; align-items:center; gap:10px; width:100%; text-align:left; background:none; border:0;
  padding:10px 14px; font:500 15px/1.2 "Poppins",system-ui; color:#0f172a; cursor:pointer;
}
.ej-dd-item[aria-selected="true"]{ background:#eff6ff; }
.ej-dd-item:hover{ background:#f8fafc; }

/* Cards grid (guarded in case base CSS differs) */
body[data-page-kind="vendor"] .cards-grid{
  display:grid !important; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:14px;
}
@media (min-width: 600px){
  body[data-page-kind="vendor"] .cards-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); gap:18px; }
}
@media (min-width: 960px){
  body[data-page-kind="vendor"] .cards-grid{ grid-template-columns: repeat(4, minmax(0, 1fr)); gap:20px; }
}

/* Centered empty state */
body[data-page-kind="vendor"] #resultsEmpty{
  display:none; align-items:center; justify-content:center; text-align:center;
  padding:100px 16px; gap:10px;
}
body[data-page-kind="vendor"] #resultsEmpty.is-visible{ display:flex !important; }
body[data-page-kind="vendor"] #resultsEmpty .empty-wrap{ max-width:640px; margin:0 auto; }
body[data-page-kind="vendor"] #resultsEmpty h3{ margin:0 0 6px; font:700 20px/1.2 Poppins,system-ui; color:#0f172a; }
body[data-page-kind="vendor"] #resultsEmpty p{ margin:0; color:#64748b; font:500 14px/1.55 Poppins,system-ui; }
body[data-page-kind="vendor"] #resultsEmpty .btn-reset{
  margin-top:14px; padding:10px 14px; border-radius:999px; border:1px solid #e5e7eb;
  background:#fff; font:700 13px/1 Poppins,system-ui;
}
body[data-page-kind="vendor"] .results-main.is-empty .results-tip{ display:none !important; }
/* Ensure empty-state text always renders */
body[data-page-kind="vendor"] #resultsEmpty{ color:var(--ej-ink); visibility:visible; }
body[data-page-kind="vendor"] #resultsEmpty .empty-wrap{ opacity:1; }

/* Pager visuals (safe even if pageSize=0) */
body[data-page-kind="vendor"] #pager{
  display:flex; gap:8px; align-items:center; flex-wrap:wrap;
}
body[data-page-kind="vendor"] #pager a,
body[data-page-kind="vendor"] #pager button{
  padding:6px 10px; border-radius:8px; border:1px solid #e5e7eb; text-decoration:none; background:#fff;
}
body[data-page-kind="vendor"] #pager a:hover,
body[data-page-kind="vendor"] #pager button:hover{ background:#f8fafc; }
body[data-page-kind="vendor"] #pager a[aria-disabled="true"],
body[data-page-kind="vendor"] #pager button[aria-disabled="true"],
body[data-page-kind="vendor"] #pager button[disabled]{ pointer-events:none; opacity:.45; }
body[data-page-kind="vendor"] #pager .page-current{
  padding:6px 10px; border-radius:8px; border:1px solid #e5e7eb;
  background:#f1f5f9; color:#334155; opacity:.7; cursor:default; pointer-events:none; font-weight:700;
}

/* Filters button icon */
body[data-page-kind="vendor"] .btn-with-icon{
  display:inline-flex; align-items:center; gap:8px;
}
body[data-page-kind="vendor"] .btn-with-icon svg{
  width:16px; height:16px; flex:0 0 auto;
}

/* ===== Filters sheet (mobile bottom sheet + desktop popover) ===== */
body[data-page-kind="vendor"] #filtersPanel{ display:none; }

/* Shown state (both breakpoints) */
body[data-page-kind="vendor"] #filtersPanel.is-open{
  display:block !important;
  z-index:1002;
  background:#fff;
  border:1px solid #e2e8f0;
  box-shadow:0 12px 26px rgba(15,23,42,.18);
}

/* --- Desktop/Tablet: centered popover (unchanged behavior) --- */
@media (min-width: 961px){
  body[data-page-kind="vendor"] #filtersPanel{
    position: fixed;
    left:50%;
    top:50%;
    transform: translate(-50%, -50%);
    width: clamp(360px, 44vw, 520px);
    max-height: min(80vh, calc(100dvh - 40px));
    overflow:auto;
    border-radius:14px;
    padding:16px 18px;
  }
}

/* --- Mobile: bottom sheet that slides up --- */
@media (max-width: 960px){
  body[data-page-kind="vendor"] #filtersPanel{
    position: fixed;
    left:0; right:0; bottom:0; top:auto;
    z-index:2147483600;                /* above bottom nav */
    width:100vw; max-width:none;
    max-height: calc(100dvh - 8px);
    overscroll-behavior: contain;
    overflow:auto;
    border-radius:16px 16px 0 0;
    padding:14px 16px calc(18px + env(safe-area-inset-bottom));
    transform: translateY(100%);
    opacity:0;
    transition:
      transform .24s cubic-bezier(.22,.61,.36,1),
      opacity   .18s ease-out;
  }
  body[data-page-kind="vendor"] #filtersPanel.is-open{
    transform: translateY(0);
    opacity:1;
  }
  body[data-page-kind="vendor"] #filtersPanel::before{
    content:"";
    position:absolute; left:50%; top:6px; transform:translateX(-50%);
    width:40px; height:4px; border-radius:999px; background:#e5e7eb;
  }

    /* little grab-handle */
  body[data-page-kind="vendor"] #filtersPanel::before{
    content:"";
    position:absolute; left:50%; top:6px; transform:translateX(-50%);
    width:40px; height:4px; border-radius:999px; background:#e5e7eb;
  }
}

/* Scrim shown only while sheet is open */
#filtersScrim[hidden]{ display:none !important; }
html.sheet-open #filtersScrim{
  position: fixed; inset:0;
  display:block !important;
  z-index:2147483500;             /* just under the sheet */
  background: rgba(2,15,31,.55);
  backdrop-filter: blur(2px);
}

html.sheet-open #mbTabbar{ pointer-events:none; }

/* When the filter sheet is open, keep the bottom tab bar from covering/catching taps */
html.sheet-open #mbTabbar{
  pointer-events: none;
  z-index: 1 !important;    /* push it below the sheet */
  /* optional visual soften: */
  /* opacity: .25; */
}

/* ===== Filter sheet polish: icon headings ===== */
body[data-page-kind="vendor"] .filter-heading{
  display:flex; align-items:center; gap:10px;
  margin:0 0 10px; font:700 15px/1.2 "Poppins",system-ui; color:#0f172a;
}
body[data-page-kind="vendor"] .filter-heading .icon{
  display:inline-grid; place-items:center;
  width:28px; height:28px; border-radius:999px;
  background:#eff6ff; color:#025fbc;
  border:1px solid #dbeafe;
  box-shadow: inset 0 0 0 1px rgba(2,95,188,.04);
}
body[data-page-kind="vendor"] .filter-heading .icon svg{
  width:16px; height:16px;
}

/* Optional: section body “card” feel */
body[data-page-kind="vendor"] .filter-section{
  background:#fafcff; border:1px solid #eef2f7; border-radius:12px;
  padding:12px; margin-bottom:14px;
}
body[data-page-kind="vendor"] .filter-section + .divider{ display:none; } /* dividers redundant with cards */

/* Inputs inside cards */
body[data-page-kind="vendor"] .filter-section .ej-dd-toggle,
body[data-page-kind="vendor"] .filter-section .budget-row input[type="range"]{
  background:#fff;
}

/* === Filters actions: unified button size & typography === */
body[data-page-kind="vendor"] .filters-sidebar .filter-actions .btn-primary,
body[data-page-kind="vendor"] .filters-sidebar .filter-actions .btn-ghost{
  display:inline-flex; align-items:center; justify-content:center;
  height:44px;
  padding:0 16px;
  border-radius:12px;
  font:700 14px/1 "Poppins",system-ui;
  letter-spacing:.01em;
}

body[data-page-kind="vendor"] .filters-sidebar .filter-actions .btn-primary{
  background:#0f172a; color:#fff;
  border:1px solid #0f172a;
}

body[data-page-kind="vendor"] .filters-sidebar .filter-actions .btn-ghost{
  background:#fff; color:#0f172a;
  border:1px solid #e5e7eb;
}

body[data-page-kind="vendor"] .filters-sidebar .filter-actions .btn-primary:focus-visible,
body[data-page-kind="vendor"] .filters-sidebar .filter-actions .btn-ghost:focus-visible{
  outline:2px solid #93c5fd; outline-offset:2px;
}

/* Compact on very small phones */
@media (max-width:360px){
  body[data-page-kind="vendor"] .filters-sidebar .filter-actions .btn-primary,
  body[data-page-kind="vendor"] .filters-sidebar .filter-actions .btn-ghost{
    height:40px;
    padding:0 14px;
    font-size:13px;
  }
}

/* === Filter pills (desktop) — sits under the toolbar === */
body[data-page-kind="vendor"] .filter-pills{
  display:flex; flex-wrap:wrap; gap:8px;
  margin:6px 0 12px;
  padding:0;
}
body[data-page-kind="vendor"] .filter-pills[hidden]{ display:none !important; }

/* Share the same chip look between mobile #activeChips and desktop .filter-pills */
body[data-page-kind="vendor"] #activeChips .chip,
body[data-page-kind="vendor"] .filter-pills .chip{
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 10px; border-radius:999px;
  border:1px solid #e5e7eb; background:#fff;
  font:600 12px/1 Poppins,system-ui; color:#0f172a;
  cursor:pointer;
}
body[data-page-kind="vendor"] #activeChips .chip .x,
body[data-page-kind="vendor"] .filter-pills .chip .x{
  margin-left:4px; opacity:.6; font-weight:800;
}

/* Hide desktop pills on small screens (mobile uses #activeChips already) */
@media (max-width: 600px){
  body[data-page-kind="vendor"] .filter-pills{ display:none !important; }
}

/* Make results column fill viewport even with zero cards */
body[data-page-kind="vendor"] .results-main{
  min-height: calc(100dvh - var(--header-h, 88px) - 220px);
}

/* Empty state icon tweak */
body[data-page-kind="vendor"] #resultsEmpty .empty-ico{
  font-size: 28px; margin-bottom: 6px;
}
