:root {
  --bg: #0c0e12;
  --panel: #14181f;
  --panel-2: #1a1f28;
  --line: #242b37;
  --ink: #e8eaf0;
  --dim: #8d96a6;
  --accent: #7aa2ff;
  --accent-2: #ffb454;
  --on: #2a3a5c;
  --bad: #f0685a;
}
* { box-sizing: border-box; }
body {
  margin: 0; background: var(--bg); color: var(--ink);
  font: 13px/1.45 ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  -webkit-font-smoothing: antialiased;
}

.topbar {
  display: flex; align-items: center; gap: 16px;
  padding: 14px 22px; border-bottom: 1px solid var(--line); background: var(--panel);
  position: sticky; top: 0; z-index: 5;
}
.brand { display: flex; align-items: baseline; gap: 12px; }
.brand h1 { margin: 0; font-size: 18px; letter-spacing: .04em; }
.brand h2 { margin: 0; font-size: 12px; font-weight: 400; color: var(--dim); }
.spacer { flex: 1; }
.count .cnum { font-size: 16px; font-weight: 700; color: var(--accent); }
.count .clabel { color: var(--dim); }
.clearbtn {
  background: var(--bg); border: 1px solid var(--line); color: var(--dim);
  border-radius: 6px; padding: 7px 12px; cursor: pointer; font: inherit;
}
.clearbtn:hover { border-color: var(--bad); color: var(--ink); }

.shell { display: grid; grid-template-columns: 240px 1fr; align-items: start; }

/* ── facets ── */
.facets {
  padding: 18px; border-right: 1px solid var(--line); background: var(--panel);
  position: sticky; top: 57px; height: calc(100vh - 57px); overflow-y: auto;
  display: flex; flex-direction: column; gap: 20px;
}
.facet .flabel { display: block; color: var(--dim); font-size: 11px; letter-spacing: .06em; text-transform: uppercase; margin-bottom: 9px; }
.chips { display: flex; flex-wrap: wrap; gap: 6px; }
.chip {
  background: var(--bg); border: 1px solid var(--line); color: var(--dim);
  border-radius: 999px; padding: 4px 10px; cursor: pointer; font: inherit; font-size: 12px;
}
.chip:hover { border-color: var(--accent); color: var(--ink); }
.chip.on { background: var(--on); border-color: var(--accent); color: #fff; }
.facet-exclude .chip.on { background: #4a2420; border-color: var(--bad); color: #ffd9d4; }

.range { display: flex; flex-direction: column; gap: 4px; }
.range input[type=range] { width: 100%; accent-color: var(--accent); }
.rangeval { color: var(--ink); font-variant-numeric: tabular-nums; margin-top: 2px; }

/* ── results ── */
.results { padding: 18px 22px 60px; }
.searchbar { margin-bottom: 16px; }
#search {
  width: 100%; max-width: 360px; background: var(--panel-2); border: 1px solid var(--line);
  border-radius: 8px; color: var(--ink); padding: 9px 12px; font: inherit;
}
#search:focus { outline: none; border-color: var(--accent); }

.grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px;
}
.card {
  background: var(--panel); border: 1px solid var(--line); border-radius: 10px; overflow: hidden;
  display: flex; flex-direction: column; transition: border-color .12s, transform .12s;
}
.card:hover { border-color: var(--accent); transform: translateY(-2px); }
.poster {
  height: 84px; background: linear-gradient(135deg, #1c2433, #11151c);
  display: flex; align-items: flex-start; justify-content: space-between; padding: 8px 10px;
}
.score {
  font-weight: 700; color: var(--bg); background: var(--accent-2);
  border-radius: 6px; padding: 1px 7px; font-size: 13px;
}
.runtime { color: var(--dim); font-size: 11px; }
.cardbody { padding: 9px 11px 11px; flex: 1; display: flex; flex-direction: column; gap: 5px; }
.ctitle { font-weight: 600; line-height: 1.3; }
.cdecade { color: var(--dim); font-size: 11px; }
.cgenres { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 3px; }
.cg {
  font-size: 10px; color: var(--accent); background: rgba(122,162,255,.1);
  border-radius: 4px; padding: 1px 6px;
}
.more {
  display: block; margin: 22px auto 0; background: var(--panel-2); border: 1px solid var(--line);
  color: var(--ink); border-radius: 8px; padding: 9px 20px; cursor: pointer; font: inherit;
}
.more:hover { border-color: var(--accent); }
