:root{
  --bg:#FBFAF7; --surface:#FFFFFF; --border:rgba(0,0,0,0.10);
  --text:#1E1B16; --muted:#7A756C; --hook:#5E574C;
  --accent:#1E1B16;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:var(--bg); color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}

/* ── header / control bar ───────────────────────────────── */
.wrap{max-width:1180px;margin:0 auto;padding:20px 18px 64px}
.masthead{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;margin:6px 2px 18px}
.masthead h1{font-family:Georgia,"Times New Roman",serif;font-weight:600;font-size:26px;margin:0;letter-spacing:-0.01em}
.masthead .count{color:var(--muted);font-size:13px}

.controls{
  display:flex;align-items:center;gap:10px;margin:0 2px 20px;
  position:sticky;top:0;z-index:30;background:var(--bg);
  padding:10px 0;border-bottom:1px solid var(--border);
}
.controls .left{display:flex;align-items:center;gap:10px;flex:1;min-width:0;flex-wrap:wrap}
.controls .right{display:flex;align-items:center;margin-left:auto}

/* dropdowns */
.dd{position:relative}
.dd-btn{
  display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 13px;
  background:var(--surface);border:1px solid var(--border);border-radius:10px;
  font-size:13.5px;color:var(--text);cursor:pointer;white-space:nowrap;
}
.dd-btn .swatch{width:11px;height:11px;border-radius:3px;flex:0 0 auto}
.dd-btn .caret{color:var(--muted);font-size:10px;margin-left:2px}
.dd-panel{
  position:absolute;top:42px;left:0;z-index:40;min-width:230px;
  background:var(--surface);border:1px solid var(--border);border-radius:12px;
  box-shadow:0 10px 30px rgba(0,0,0,0.12);padding:6px;display:none;
}
.dd.open .dd-panel{display:block}
/* LEGEND / FILTER: uniform-height boxes, single-line, vertically centered */
.dd-opt{
  display:flex;align-items:center;gap:9px;height:34px;padding:0 10px;border-radius:8px;
  cursor:pointer;font-size:13.5px;white-space:nowrap;
}
.dd-opt:hover{background:rgba(0,0,0,0.04)}
.dd-opt .box{
  width:18px;height:18px;border-radius:5px;flex:0 0 auto;border:0.5px solid rgba(0,0,0,0.12);
}
.dd-opt .check{margin-left:auto;color:var(--muted);opacity:0;font-size:12px}
.dd-opt[aria-selected="true"] .check{opacity:1}

/* surprise */
.surprise{
  height:36px;padding:0 14px;border-radius:10px;cursor:pointer;white-space:nowrap;
  background:var(--accent);color:#FBFAF7;border:1px solid var(--accent);font-size:13.5px;font-weight:500;
}
.surprise:hover{opacity:0.9}

/* search: magnifier far right, expands inline */
.search{display:flex;align-items:center;justify-content:flex-end}
.search button{
  width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--surface);
  cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted)
}
.search input{
  width:0;opacity:0;padding:0;margin:0;border:none;height:36px;font-size:14px;
  transition:width .22s ease,opacity .18s ease,padding .22s ease,margin .18s ease;
  background:var(--surface);border-radius:10px;color:var(--text);
}
.search.open input{width:210px;opacity:1;padding:0 12px;margin-right:8px;border:1px solid var(--border)}

/* ── wall grid ──────────────────────────────────────────── */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}
.empty{color:var(--muted);font-size:14px;padding:40px 6px}

/* ── card (locked spec) ─────────────────────────────────── */
.card{
  display:flex;flex-direction:column;background:var(--surface);
  border:0.5px solid var(--border);border-radius:14px;overflow:hidden;
  transition:transform .12s ease,box-shadow .12s ease;
}
.card:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(0,0,0,0.10)}
.card .banner{width:100%;aspect-ratio:21/9;object-fit:cover;display:block;background:#ece9e3}
.card .body{padding:11px 12px 12px;display:flex;flex-direction:column;gap:5px;flex:1}
.card .title{font-size:15px;font-weight:500;line-height:1.25;letter-spacing:-0.005em}
.card .hook{
  font-family:Georgia,"Times New Roman",serif;color:var(--hook);
  font-size:13px;line-height:1.4;flex:1;
}
.card .meta{display:flex;align-items:center;gap:8px;margin-top:4px;font-size:11.5px;color:var(--muted);white-space:nowrap;overflow:hidden}
.pill{
  display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;
  white-space:nowrap;flex:0 0 auto;max-width:100%;overflow:hidden;text-overflow:ellipsis;
}
.meta .sep{opacity:0.5}
.meta .dim{color:var(--muted)}

/* ── story page ─────────────────────────────────────────── */
.story-wrap{max-width:820px;margin:0 auto;padding:18px 18px 80px}
.back{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:13.5px;margin:4px 0 16px}
.back:hover{color:var(--text)}
.story-banner{width:100%;aspect-ratio:21/9;object-fit:cover;border-radius:16px;border:0.5px solid var(--border);display:block;background:#ece9e3}
.story-head{margin:22px 0 6px}
.story-head h1{font-family:Georgia,serif;font-weight:600;font-size:30px;line-height:1.15;margin:0 0 12px;letter-spacing:-0.01em}
.story-meta{display:flex;align-items:center;gap:10px;font-size:12.5px;color:var(--muted);margin-bottom:18px;flex-wrap:wrap}
.story-hook{font-family:Georgia,serif;font-size:19px;line-height:1.45;color:var(--hook);font-style:italic;margin:6px 0 26px}
.prose{font-family:Georgia,serif;font-size:18px;line-height:1.7;color:#2A261F}
.prose p{margin:0 0 1.05em}
.notfound{color:var(--muted);padding:60px 0}

@media (max-width:560px){
  .controls{flex-wrap:wrap}
  .masthead h1{font-size:22px}
  .prose{font-size:17px}
}
