:root {
  --maxw: 1040px;
  --gap: 1rem;
  --radius: 14px;
  --border: #e9e9e9;
  --text: #1f1f1f;
  --muted: #666;
  --bg: #fff;
  --shadow: 0 10px 28px rgba(0,0,0,.08);
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { font-family: system-ui, -apple-system, Segoe UI, Roboto, sans-serif; color: var(--text); background: var(--bg); }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 1.5rem; }
.header { display: grid; gap: .5rem; align-items: start; }
.title { margin: 0; font-weight: 800; letter-spacing: -0.01em; }
.lede { margin: 0; color: var(--muted); }
.nav { display: flex; gap: .75rem; margin-top: .5rem; flex-wrap: wrap; }
.nav a { color: inherit; text-decoration: none; padding: .25rem .5rem; border-radius: 8px; }
.nav a:hover { background: #f6f6f6; }

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--gap);
  margin-top: 1rem;
}
.card {
  display: block;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1rem;
  text-decoration: none;
  color: inherit;
  background: #fff;
  transition: transform .12s ease, box-shadow .12s ease;
}
.card:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.thumb { aspect-ratio: 16/9; border-radius: 10px; overflow: hidden; background: #f7f7f7; margin: 0 0 .75rem; }
.thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.card-title { margin: 0 0 .25rem; font-size: 1.05rem; font-weight: 700; }
.card-desc { margin: 0 0 .5rem; color: var(--muted); }
.pill {
  display: inline-block;
  font-size: .75rem;
  padding: .2rem .5rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  color: #333;
  background: #fafafa;
}

.foot { color: var(--muted); text-align: center; padding-top: .5rem; border-top: 1px solid var(--border); }

@media (prefers-color-scheme: dark) {
  :root {
    --border: #2a2a2a;
    --text: #eaeaea;
    --muted: #b0b0b0;
    --bg: #0b0b0b;
    --shadow: 0 10px 28px rgba(0,0,0,.4);
  }
  .card, .thumb { background: #111; }
  .nav a:hover { background: #151515; }
  .pill { background: #141414; color: #dcdcdc; border-color: #2a2a2a; }
  .foot { border-top-color: #1a1a1a; }
}
