/* ══ FILTERS — filter bar, panel, chips, tags ══ */

.filter-bar {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 16px; flex-wrap: wrap;
}

.filter-search-wrap { position: relative; flex: 1; min-width: 160px; max-width: 280px; }
.filter-search {
  width: 100%; background: #0f1318; border: 1px solid #1f2530; border-radius: 8px;
  padding: 8px 12px 8px 34px; font-family: 'Barlow', sans-serif;
  font-size: 13px; color: #dce3ed; outline: none; transition: border-color 0.15s;
}
.filter-search:focus       { border-color: #d4f542; }
.filter-search::placeholder { color: #2a3040; }
.filter-search-icon {
  position: absolute; left: 10px; top: 50%; transform: translateY(-50%);
  font-size: 18px; pointer-events: none; color: #2a3040;
}

.filter-btn {
  display: flex; align-items: center; gap: 6px;
  background: #0f1318; border: 1px solid #1f2530; border-radius: 8px;
  padding: 8px 13px; font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px; font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase;
  color: #7a8a9b; cursor: pointer; transition: all 0.15s; white-space: nowrap;
}
.filter-btn:hover  { border-color: #2a3040; color: #dce3ed; }
.filter-btn.active { background: rgba(212,245,66,0.1); border-color: #d4f542; color: #d4f542; }

.filter-count {
  background: #d4f542; color: #000; font-family: 'Barlow Condensed', sans-serif;
  font-size: 10px; font-weight: 700; border-radius: 4px; padding: 1px 5px; line-height: 1.4;
}

.filter-clear {
  background: transparent; border: none; color: #7a8a9b; cursor: pointer;
  font-size: 11px; font-family: 'Barlow Condensed', sans-serif; font-weight: 700;
  letter-spacing: 0.5px; text-transform: uppercase; padding: 4px 6px;
  border-radius: 6px; transition: color 0.15s; white-space: nowrap;
}
.filter-clear:hover { color: #dce3ed; }

.filter-panel-wrap { position: relative; }
.filter-panel {
  display: none; position: absolute; top: calc(100% + 8px); left: 0;
  width: 340px; background: #141820; border: 1px solid #2a3040;
  border-radius: 12px; z-index: 150; padding: 16px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}
.filter-panel.open { display: block; }

.filter-panel-title {
  font-family: 'Barlow Condensed', sans-serif; font-size: 11px; font-weight: 700;
  letter-spacing: 1.2px; text-transform: uppercase; color: #7a8a9b; margin-bottom: 8px;
}
.filter-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.filter-chip {
  padding: 5px 12px; border-radius: 6px; border: 1px solid #1f2530;
  background: #0f1318; font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px; font-weight: 600; color: #7a8a9b; cursor: pointer; transition: all 0.15s;
}
.filter-chip:hover  { border-color: #2a3040; color: #dce3ed; }
.filter-chip.active { background: rgba(212,245,66,0.1); border-color: #d4f542; color: #d4f542; }

.filter-panel-footer {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 12px; border-top: 1px solid #1f2530; margin-top: 4px;
}

/* ── Light mode ── */
body.light-mode .filter-search { background: #ffffff; border-color: #dde2ec; color: #1a2030; }
body.light-mode .filter-search:focus { border-color: #5a7a00; }
body.light-mode .filter-search::placeholder { color: #b0b8c4; }
body.light-mode .filter-search-icon { color: #b0b8c4; }
body.light-mode .filter-btn { background: #ffffff; border-color: #dde2ec; color: #6b7a8d; }
body.light-mode .filter-btn:hover { border-color: #b0b8c4; color: #1a2030; }
body.light-mode .filter-btn.active { background: rgba(90,122,0,0.08); border-color: #5a7a00; color: #5a7a00; }
body.light-mode .filter-count { background: #5a7a00; color: #fff; }
body.light-mode .filter-clear { color: #8899aa; }
body.light-mode .filter-clear:hover { color: #1a2030; }
body.light-mode .filter-panel { background: #ffffff; border-color: #dde2ec; box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
body.light-mode .filter-panel-title { color: #6b7a8d; }
body.light-mode .filter-chip { background: #f0f3f8; border-color: #dde2ec; color: #6b7a8d; }
body.light-mode .filter-chip:hover { border-color: #b0b8c4; color: #1a2030; }
body.light-mode .filter-chip.active { background: rgba(90,122,0,0.08); border-color: #5a7a00; color: #5a7a00; }
body.light-mode .filter-panel-footer { border-top-color: #e8ecf2; }
