/* ====== Vars and base ====== */
:root{
  --bg:#ffffff;--text:#1f2937;--muted:#6b7280;--line:#f3f4f6;
  --primary:#ff1f59;--primary-light:#ffe7ee;
  --chip:#f9fafb;--chip-b:#e5e7eb;
  --ok:#22c55e;
  --shadow:0 4px 12px rgba(0,0,0,.05);
  --radius:12px;--transition:all .2s ease;
  --s1:8px;--s2:12px;--s3:16px;--s4:20px;
  --sidebar-w:280px;
  --sticky-top:72px;   /* adjust if header height differs */
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:#fff;color:var(--text)}

/* ====== Layout ====== */
.page{
  display:grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  gap:18px;
  padding:10px;
}

/* ====== Sidebar (desktop: sticky + scrollable in grid) ====== */
.filter-sidebar{
  background:var(--bg);
  
  box-shadow:var(--shadow);
  padding:16px;
  container-type:inline-size;
  container-name:sidebar;
  position:sticky;
  top:var(--sticky-top);
  max-height:calc(100vh - var(--sticky-top) - 12px);
  overflow:auto;

  scrollbar-width:none;           /* Firefox */
  -ms-overflow-style:none;        /* IE/Edge legacy */
}

/* Mobile trigger */
.filter-toggle-button{
  display:none; position:fixed; bottom:100px; left:50%; transform:translateX(-50%);
  z-index:1000; background:var(--primary); color:#fff; border:0; border-radius:30px;
  padding:12px 24px; font-weight:600; box-shadow:0 4px 12px rgba(0,0,0,.15); cursor:pointer;
}
.filter-toggle-button i{margin-right:8px}

/* ====== Tabs / toolbar ====== */
/* Tabs / toolbar */
.tabs{
  display:flex;
  align-items:center;
  justify-content:flex-start;   /* was center */
  gap:10px;
  margin:10px 0px;              /* add px */
  padding-inline:12px;          /* keep first tab visible */
  overflow-x:auto;
  white-space:nowrap;
  flex-wrap:nowrap;
  scrollbar-width:none;
  -webkit-overflow-scrolling: touch;
  scroll-padding-left:12px;
}
.tabs::-webkit-scrollbar{display:none}

.tab{
  flex:0 0 auto;                /* prevent shrinking to 10% */
  padding:8px 14px;
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
  cursor:pointer;
  font-size:14px;
}
.tab.active{
  background:#000;color:#fff;border-color:#000;
}

.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:10px 0}
.count{font-weight:600}
.segmented{display:flex;gap:8px}
.segmented .btn{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--line);border-radius:10px;background:#fff}
.segmented .btn[aria-selected="true"]{background:#f3f4f6}
@media (min-width:1025px){ .segmented{display:none} }
@media (max-width:1024px){ .segmented{display:flex} }

/* ====== Grid columns ====== */
.grid{display:grid;gap:14px;min-height:120px}
.view-grid .grid{grid-template-columns: repeat(2,1fr)}                 /* phone: 2 */
@media (min-width:600px){ .view-grid .grid{grid-template-columns: repeat(3,minmax(0,1fr))} }
@media (min-width:900px){ .view-grid .grid{grid-template-columns: repeat(4,minmax(0,1fr))} }
@media (min-width:1200px){ .view-grid .grid{grid-template-columns: repeat(4,minmax(0,1fr))} }
@media (min-width:1440px){ .view-grid .grid{grid-template-columns: repeat(5,minmax(0,1fr))} }

/* ====== Sidebar internals ====== */
.filter-topbar{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--s2);border-bottom:1px solid var(--line)}
.filter-topbar h2{font-size:18px;font-weight:700}

.filter-actions{display:flex;gap:8px}
.btn{border:1px solid transparent;border-radius:20px;padding:8px 14px;font-weight:600;font-size:13px;cursor:pointer;transition:var(--transition)}
.btn.primary{background:var(--primary);color:#fff}
.btn.primary:hover{opacity:.9}
.btn.ghost{background:transparent;border-color:var(--line);color:var(--muted)}
.btn.ghost:hover{background:#f9fafb}

/* Keep action bar visible while scrolling sidebar */
.filter-actions.sticky{
  position:sticky; bottom:0; left:0; right:0;
  background:var(--bg);
  padding:12px 0;
  margin-top:var(--s2);



}

/* Sections */
.filter-section{border-bottom:1px solid var(--line);padding:var(--s2) 0}
.filter-section:last-of-type{border-bottom:none}
.section-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;background:transparent;border:0;padding:8px 0;cursor:pointer;transition:var(--transition)}
.section-toggle .title{font-weight:600;font-size:15px;display:flex;align-items:center;gap:8px}
.section-toggle .title i{font-size:16px;color:var(--muted)}
.section-toggle .chevron{color:var(--muted);transition:var(--transition)}
.filter-section.open .chevron{transform:rotate(180deg)}
.section-body{padding:8px 0 0;display:none}
.filter-section.open .section-body{display:block;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}

/* Options */
.options{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.options.wrap{display:flex;flex-wrap:wrap;gap:8px}
.options.list{display:block}
.options.list li{margin-bottom:8px}
.options.list.tight li{margin-bottom:6px}
.options input[type="checkbox"],.options input[type="radio"]{display:none}

.pill{display:inline-flex;align-items:center;justify-content:center;min-width:44px;padding:6px 15px;border-radius:20px;background:var(--chip);border:1px solid var(--chip-b);font-weight:500;font-size:13px;cursor:pointer;transition:var(--transition);position:relative}
.pill:hover{border-color:var(--primary)}

.rowchip{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:var(--transition);position:relative}
.rowchip:hover{border-color:var(--primary)}
.rowchip .mark{display:none;position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:16px;color:var(--ok)}
input:checked + .rowchip .mark{display:inline;color:#ef4444}
input:checked + .rowchip{color:var(--primary);}

.swatch{width:18px;height:18px;border-radius:6px;border:1px solid rgba(0,0,0,.08);display:inline-block;flex-shrink:0}

.pill{display:inline-flex;align-items:center;justify-content:center;min-width:44px;padding:6px 15px;border-radius:20px;background:var(--chip);border:1px solid var(--chip-b);font-weight:500;font-size:13px;cursor:pointer;transition:var(--transition);position:relative}
  .pill:hover{border-color:var(--primary)}
  .pill .mark{display:none;position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--ok)}
  input:checked + .pill{color: white;background-color: #ff1f59;font-weight: 800;}

/* Price controls */
.price-row2{display:grid;gap:12px}
.price-header{display:flex;align-items:center;justify-content:space-between;font-weight:600;font-size:14px}
.money{font-variant-numeric:tabular-nums}
.dash{opacity:.6}
.slider-wrap{position:relative;height:34px}
.slider-track{position:absolute;left:8px;right:8px;top:15px;height:4px;background:#e5e7eb;border-radius:999px}
.slider-progress{position:absolute;height:100%;background:var(--primary);border-radius:999px;left:0;right:0}
.range-min,.range-max{position:absolute;width:100%;height:34px;background:none;pointer-events:none;-webkit-appearance:none;appearance:none}
.range-min{z-index:2}.range-max{z-index:3}
.range-min::-webkit-slider-thumb,.range-max::-webkit-slider-thumb{pointer-events:auto;-webkit-appearance:none;appearance:none;width:18px;height:18px;background:#fff;border:2px solid var(--primary);border-radius:50%;box-shadow:var(--shadow);cursor:pointer}
.range-min::-moz-range-thumb,.range-max::-moz-range-thumb{pointer-events:auto;width:18px;height:18px;background:#fff;border:2px solid var(--primary);border-radius:50%;box-shadow:var(--shadow);cursor:pointer}
.price-inputs{display:flex;gap:10px}
.price-inputs label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--muted);flex:1}
.price-inputs input{border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:14px;width:100%}
.price-inputs[data-error="1"] input{border-color:#ef4444}

/* Select */
.select{position:relative;display:inline-flex;align-items:center;width:100%}
.select select{appearance:none;-webkit-appearance:none;width:100%;padding:10px 38px 10px 12px;border:1px solid var(--line);border-radius:8px;background:#fff;font-weight:500;font-size:14px;cursor:pointer}
.select i{position:absolute;right:10px;pointer-events:none;color:var(--muted)}

/* Rating visuals */
.rating-stars{display:flex;align-items:center;gap:6px}
.stars{display:inline-flex;gap:1px}
.star{color:#e5e7eb;font-size:16px}
.star.filled{color:inherit}
.rating-label{font-size:14px;margin-left:4px;color:var(--muted)}
.rowchip.rating{padding:8px 12px}
.rating-5 .star.filled{color:#22c55e}
.rating-4 .star.filled{color:#3b82f6}
.rating-3 .star.filled{color:#f59e0b}
.rating-2 .star.filled{color:#f97316}
.rating-1 .star.filled{color:#ef4444}

/* Loading */
.loading{display:none;align-items:center;justify-content:center;padding:16px;color:#555;font-weight:600}
.loading .spinner{width:26px;height:26px;border:3px solid #e5e7eb;border-top-color:#374151;border-radius:50%;animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ====== Mobile / Tablet off-canvas ====== */
@media (max-width:1024px){
  .page{grid-template-columns:1fr}
  .filter-sidebar{
    position:fixed; top:0; right:-100%; width:min(92vw,360px); height:100%;
    border-radius:0; z-index:999; box-shadow:-8px 0 28px rgba(0,0,0,.08);
    overflow:auto; transition:right .25s ease;
    max-height:none; /* full height on mobile */
  }
  .filter-sidebar.active{right:0}
  .filter-toggle-button{display:flex}
}

/* Narrow container tweaks */
@container sidebar (max-width:360px){
  .options.wrap{gap:6px}
  .pill{padding:6px 12px;font-size:12px}
}

/* Motion */
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important}
}

/* Utility */
@media (min-width:1025px){ .phone{display:none !important} }
