/* ===== SIDEBAR ===== */
.sidebar {
  width: 260px;
  flex-shrink: 0;
  background: #fff;
  border-right: 1px solid var(--border);
  padding: 20px 16px;
  position: sticky;
  top: 62px;
  height: calc(100vh - 62px);
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: #ddd transparent;
}
.sidebar::-webkit-scrollbar { width: 4px; }
.sidebar::-webkit-scrollbar-thumb { background: #ddd; border-radius: 4px; }

.sidebar-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 18px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--green);
}
.sidebar-title {
  font-family: 'Playfair Display', serif;
  font-size: 18px;
  font-weight: 700;
  color: var(--green);
}
.btn-clear {
  background: none;
  border: 1px solid #ddd;
  border-radius: 6px;
  padding: 4px 10px;
  font-size: 11px;
  color: #888;
  cursor: pointer;
  transition: all .2s;
}
.btn-clear:hover { border-color: var(--green); color: var(--green); }

/* ===== FILTER GROUPS ===== */
.filter-group {
  margin-bottom: 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid #f0f0f0;
}
.filter-group:last-child { border-bottom: none; }

.filter-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: #555;
  margin-bottom: 9px;
}

/* CHIPS */
.fchips { display: flex; flex-wrap: wrap; gap: 6px; }
.fchip {
  padding: 5px 12px;
  border-radius: 20px;
  border: 1px solid var(--border);
  background: #fafafa;
  font-size: 12px;
  cursor: pointer;
  transition: all .2s;
  color: #555;
  font-family: inherit;
}
.fchip:hover { border-color: var(--green); color: var(--green); }
.fchip.active { background: var(--green); border-color: var(--green); color: #fff; }

/* CHECKBOXES */
.fcheck-list { display: flex; flex-direction: column; gap: 7px; }
.fcheck {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: #444;
  cursor: pointer;
  padding: 4px 0;
}
.fcheck input[type="checkbox"] {
  width: 15px;
  height: 15px;
  accent-color: var(--green);
  cursor: pointer;
  flex-shrink: 0;
}
.fcheck:hover { color: var(--green); }
.fcheck-feat { font-size: 13px; font-weight: 500; color: #333; }

/* PRICE INPUTS */
.price-inputs {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
}
.price-inp {
  flex: 1;
  min-width: 0;
  padding: 7px 8px !important;
  font-size: 12px !important;
}
.price-dash { color: #aaa; font-size: 13px; flex-shrink: 0; }

/* PRESETS */
.price-presets { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 6px; }
.preset {
  padding: 4px 8px;
  border: 1px solid #ddd;
  border-radius: 6px;
  background: #fafafa;
  font-size: 10px;
  cursor: pointer;
  color: #666;
  transition: all .2s;
  font-family: inherit;
}
.preset:hover { border-color: var(--green); color: var(--green); background: #f0f7f0; }
.preset.active { background: var(--green); border-color: var(--green); color: #fff; }

/* FILTER COUNT */
.filter-count {
  background: var(--green);
  color: #fff;
  border-radius: 8px;
  padding: 9px 12px;
  text-align: center;
  font-size: 13px;
  font-weight: 500;
  margin-top: 4px;
}

@media (max-width: 900px) {
  .sidebar {
    width: 100%;
    height: auto;
    position: static;
    border-right: none;
    border-bottom: 1px solid var(--border);
  }
  .fcheck-list { flex-direction: row; flex-wrap: wrap; }
}
