:root {
  --bg: #0f1720; --panel: #16212e; --panel2: #1c2a3a; --line: #26384c;
  --text: #e7eef6; --muted: #8aa0b6; --accent: #5eb0ef; --accent2: #163049;
  --good: #4ec9a0; --warn: #ffd479; --bad: #f08a8a; --high: #f0a35e;
  --radius: 12px;
}
* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  background: var(--bg); color: var(--text); font-size: 15px; line-height: 1.45;
}
button { font: inherit; cursor: pointer; }
a { color: var(--accent); }
input, select, textarea {
  font: inherit; background: var(--panel2); color: var(--text);
  border: 1px solid var(--line); border-radius: 8px; padding: 8px 10px; width: 100%;
}
textarea { min-height: 70px; resize: vertical; }
label { display: block; font-size: 13px; color: var(--muted); margin: 10px 0 4px; }

/* layout */
header {
  display: flex; align-items: center; gap: 14px; padding: 10px 16px;
  background: var(--panel); border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 20;
}
header .brand { font-weight: 700; display: flex; align-items: center; gap: 8px; }
header .brand img { width: 26px; height: 26px; }
header .spacer { flex: 1; }
header .who { color: var(--muted); font-size: 13px; }
nav.tabs { display: flex; gap: 4px; overflow-x: auto; padding: 6px 10px; background: var(--panel);
  border-bottom: 1px solid var(--line); position: sticky; top: 53px; z-index: 19; }
nav.tabs button {
  background: transparent; color: var(--muted); border: none; padding: 8px 12px;
  border-radius: 8px; white-space: nowrap;
}
nav.tabs button.active { background: var(--accent2); color: var(--text); }
main { padding: 16px; max-width: 1100px; margin: 0 auto; }

/* buttons */
.btn { background: var(--accent2); color: var(--text); border: 1px solid var(--line);
  border-radius: 8px; padding: 8px 14px; }
.btn.primary { background: var(--accent); color: #06121f; border-color: var(--accent); font-weight: 600; }
.btn.ghost { background: transparent; }
.btn.danger { color: var(--bad); border-color: #4a2a2a; background: transparent; }
.btn.small { padding: 4px 9px; font-size: 13px; }
.row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.between { justify-content: space-between; }

/* cards / dashboard */
.grid { display: grid; gap: 14px; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px; }
.card h3 { margin: 0 0 10px; font-size: 14px; color: var(--muted); font-weight: 600; }
.stat { font-size: 30px; font-weight: 700; }
.stat.bad { color: var(--bad); } .stat.good { color: var(--good); }
.kv { display: flex; justify-content: space-between; padding: 4px 0; border-bottom: 1px dashed var(--line); }
.kv:last-child { border-bottom: none; }

/* lists */
.list { display: flex; flex-direction: column; gap: 8px; }
.item-row { background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
  padding: 10px 12px; display: flex; gap: 10px; align-items: flex-start; }
.item-row .grow { flex: 1; min-width: 0; }
.item-row .title { font-weight: 600; }
.item-row .sub { color: var(--muted); font-size: 13px; margin-top: 2px; word-break: break-word; }
.epic-group h2 { font-size: 15px; margin: 18px 0 8px; color: var(--accent); }

/* badges */
.badge { display: inline-block; padding: 2px 8px; border-radius: 999px; font-size: 12px;
  border: 1px solid var(--line); color: var(--muted); }
.badge.open { color: var(--accent); } .badge.in_progress { color: var(--warn); }
.badge.blocked { color: var(--bad); } .badge.done { color: var(--good); }
.badge.high { color: var(--high); border-color: var(--high); }
.badge.overdue { color: var(--bad); border-color: var(--bad); }
.badge.keep { color: var(--good); } .badge.sell { color: var(--accent); }
.badge.dispose { color: var(--bad); } .badge.donate { color: var(--warn); }

.check { width: 22px; height: 22px; border-radius: 6px; border: 2px solid var(--line);
  background: transparent; flex: none; margin-top: 1px; }
.check.done { background: var(--good); border-color: var(--good); color: #06121f; }
.done-text .title { text-decoration: line-through; color: var(--muted); }

/* modal */
.overlay { position: fixed; inset: 0; background: rgba(0,0,0,.6); display: flex;
  align-items: flex-start; justify-content: center; padding: 24px 12px; z-index: 50; overflow:auto; }
.modal { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  width: 100%; max-width: 540px; padding: 18px; }
.modal h2 { margin: 0 0 8px; font-size: 18px; }

/* login */
.login-wrap { min-height: 80vh; display: flex; align-items: center; justify-content: center; }
.login-wrap .card { width: 100%; max-width: 360px; }

.muted { color: var(--muted); }
.empty { color: var(--muted); text-align: center; padding: 30px; }
.tag-select { display: flex; gap: 6px; flex-wrap: wrap; }
.tag-select button { background: var(--panel2); border: 1px solid var(--line); color: var(--muted);
  border-radius: 999px; padding: 4px 10px; font-size: 13px; }
.tag-select button.on { background: var(--accent2); color: var(--text); border-color: var(--accent); }
.toast { position: fixed; bottom: 18px; left: 50%; transform: translateX(-50%);
  background: var(--panel2); border: 1px solid var(--line); padding: 10px 16px; border-radius: 10px; z-index: 80; }
