:root {
  --bg: #0b0f17;
  --bg-2: #121826;
  --panel: #161d2b;
  --panel-2: #1c2536;
  --line: #263149;
  --text: #e6ebf5;
  --muted: #8b97ad;
  --accent: #5b8cff;
  --accent-2: #7aa2ff;
  --green: #3fb950;
  --amber: #d6a23b;
  --grey: #5a6577;
  --radius: 14px;
  --shadow: 0 6px 24px rgba(0,0,0,.35);
}

* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  background: radial-gradient(1200px 600px at 80% -10%, #16203a 0%, var(--bg) 55%);
  color: var(--text);
  font: 15px/1.5 -apple-system, "Segoe UI", Roboto, system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}
.muted { color: var(--muted); }
a { color: var(--accent-2); text-decoration: none; }

/* ---------- nav ---------- */
.tom-nav {
  position: sticky; top: 0; z-index: 30;
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; padding-top: max(12px, env(safe-area-inset-top));
  background: rgba(11,15,23,.82); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
}
.tom-brand { display: flex; align-items: center; gap: 9px; color: var(--text); font-weight: 600; font-size: 18px; }
.tom-logo { color: var(--accent); font-size: 22px; }
.tom-brand-text .muted { font-weight: 400; opacity: .6; }
.tom-nav-right { display: flex; align-items: center; gap: 10px; }

.quota-badge {
  font-size: 12px; color: var(--muted); padding: 4px 10px;
  border: 1px solid var(--line); border-radius: 999px; white-space: nowrap;
}
.quota-badge.warn { color: var(--amber); border-color: var(--amber); }
.quota-badge.hot  { color: #ff6b6b; border-color: #ff6b6b; }

/* ---------- buttons ---------- */
.btn { font: inherit; cursor: pointer; border-radius: 10px; border: 1px solid transparent;
  padding: 7px 13px; display: inline-flex; align-items: center; gap: 6px; transition: .15s; }
.btn-accent { background: var(--accent); color: #fff; border-color: var(--accent); }
.btn-accent:hover { background: var(--accent-2); }
.btn-ghost { background: transparent; color: var(--muted); border-color: var(--line); }
.btn-ghost:hover { color: var(--text); border-color: var(--muted); }
.btn-sm { padding: 6px 11px; font-size: 13px; }

/* ---------- layout ---------- */
.tom-main { max-width: 1100px; margin: 0 auto; padding: 20px 16px 64px; }

.page-head { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 18px; }
.filters { display: flex; gap: 6px; }
.chip { background: var(--panel); border: 1px solid var(--line); color: var(--muted);
  padding: 6px 14px; border-radius: 999px; cursor: pointer; font-size: 13px; transition: .15s; }
.chip:hover { color: var(--text); }
.chip.active { background: var(--accent); color: #fff; border-color: var(--accent); }
.search-box { flex: 1; min-width: 160px; background: var(--panel); border: 1px solid var(--line);
  color: var(--text); border-radius: 10px; padding: 8px 13px; font: inherit; }
.search-box:focus { outline: none; border-color: var(--accent); }
.sort-select { background: var(--panel); border: 1px solid var(--line); color: var(--text);
  border-radius: 10px; padding: 8px 11px; font: inherit; cursor: pointer; }
.sort-select:focus { outline: none; border-color: var(--accent); }

/* tag filter row */
.tag-filter { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; margin: -6px 0 16px; }
.tag-filter .tf-label { color: var(--muted); font-size: 12px; margin-right: 2px; }
.tag-chip { background: var(--panel-2); border: 1px solid var(--line); color: var(--muted);
  padding: 3px 10px; border-radius: 999px; cursor: pointer; font-size: 12px; transition: .12s; white-space: nowrap; }
.tag-chip:hover { color: var(--text); }
.tag-chip.on { background: rgba(91,140,255,.2); border-color: var(--accent); color: var(--accent-2); }
.tag-chip .cnt { opacity: .55; margin-left: 4px; }
/* auto-tag filter chips: dashed border, warmer hue, to read as "computed" */
.tag-chip.auto { border-style: dashed; color: var(--amber); }
.tag-chip.auto.on { background: rgba(214,162,59,.18); border-color: var(--amber); color: var(--amber); }
.tf-clear { color: var(--muted); font-size: 12px; cursor: pointer; border: none; background: none; text-decoration: underline; }

/* tags on cards */
.card-tags { display: flex; flex-wrap: wrap; gap: 5px; }
.card-tag { background: var(--panel-2); border: 1px solid var(--line); color: var(--accent-2);
  padding: 1px 8px; border-radius: 999px; font-size: 11px; }
.card-tag.auto { color: var(--amber); border-style: dashed; }

/* tags editor on project page */
.tags-editor { display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  margin: 10px 0 4px; padding: 10px 12px; background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); }
.tags-label { color: var(--muted); font-size: 13px; display: inline-flex; align-items: center; gap: 5px; }
.tag-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.edit-tag { display: inline-flex; align-items: center; gap: 6px; background: rgba(91,140,255,.15);
  border: 1px solid var(--accent); color: var(--accent-2); padding: 2px 6px 2px 10px; border-radius: 999px; font-size: 12px; }
.edit-tag button { background: none; border: none; color: var(--accent-2); cursor: pointer; font-size: 13px; line-height: 1; padding: 0; opacity: .7; }
.edit-tag button:hover { opacity: 1; }
.tag-input { background: var(--bg-2); border: 1px solid var(--line); color: var(--text);
  border-radius: 8px; padding: 5px 10px; font: inherit; font-size: 13px; min-width: 120px; }
.tag-input:focus { outline: none; border-color: var(--accent); }

/* ---------- project grid ---------- */
.projects-grid { display: grid; gap: 14px; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
.proj-card { background: linear-gradient(180deg, var(--panel) 0%, var(--bg-2) 100%);
  border: 1px solid var(--line); border-radius: var(--radius); padding: 16px;
  cursor: pointer; transition: .15s; display: flex; flex-direction: column; gap: 10px; }
.proj-card:hover { border-color: var(--accent); transform: translateY(-2px); box-shadow: var(--shadow); }
.proj-card-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.proj-name { font-weight: 600; font-size: 16px; }
.kind-tag { font-size: 11px; text-transform: uppercase; letter-spacing: .04em;
  padding: 2px 8px; border-radius: 6px; font-weight: 600; }
.kind-tag.code { background: rgba(91,140,255,.15); color: var(--accent-2); }
.kind-tag.docs { background: rgba(63,185,80,.15); color: var(--green); }
.proj-meta { display: flex; align-items: center; gap: 14px; color: var(--muted); font-size: 13px; flex-wrap: wrap; }
.proj-meta .n { color: var(--text); font-weight: 600; }

.dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; flex: none; }
.dot.active { background: var(--green); box-shadow: 0 0 8px var(--green); }
.dot.idle { background: var(--amber); }
.dot.dormant, .dot.empty { background: var(--grey); }
.live-label { display: inline-flex; align-items: center; gap: 6px; }

/* ---------- project view ---------- */
.back-link { color: var(--muted); font-size: 14px; display: inline-flex; align-items: center; gap: 3px; }
.back-link:hover { color: var(--text); }
.project-head { margin: 12px 0 6px; }
.project-title { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.project-title h1 { font-size: 24px; margin: 0; }
.project-sub { color: var(--muted); font-size: 13px; margin-top: 6px; word-break: break-all; }

.tab-bar { display: flex; gap: 4px; border-bottom: 1px solid var(--line); margin: 16px 0 18px; overflow-x: auto; }
.tab { background: none; border: none; color: var(--muted); padding: 10px 14px; cursor: pointer;
  font: inherit; border-bottom: 2px solid transparent; white-space: nowrap; display: inline-flex; gap: 6px; align-items: center; }
.tab:hover { color: var(--text); }
.tab.active { color: var(--text); border-bottom-color: var(--accent); }
.tab-panel { display: none; }
.tab-panel.active { display: block; }

/* files */
.files-layout { display: grid; grid-template-columns: 300px 1fr; gap: 16px; align-items: start; }
.file-tree { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 10px; max-height: 70vh; overflow: auto; }
.tree-node { user-select: none; }
.tree-row { display: flex; align-items: center; gap: 6px; padding: 4px 6px; border-radius: 7px; cursor: pointer; font-size: 14px; }
.tree-row:hover { background: var(--panel-2); }
.tree-row.sel { background: rgba(91,140,255,.18); }
.tree-row.nofile { cursor: default; color: var(--muted); }
.tree-children { margin-left: 14px; border-left: 1px solid var(--line); padding-left: 6px; }
.tree-size { margin-left: auto; color: var(--muted); font-size: 11px; }
.bi.dir { color: var(--accent-2); }
.bi.file { color: var(--muted); }

.file-viewer { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  min-height: 200px; max-height: 72vh; overflow: auto; }
.file-viewer .empty-hint { color: var(--muted); padding: 30px; text-align: center; }
.viewer-head { position: sticky; top: 0; background: var(--panel-2); border-bottom: 1px solid var(--line);
  padding: 9px 14px; display: flex; align-items: center; justify-content: space-between; gap: 8px; font-size: 13px; }
.viewer-body { padding: 16px 18px; }
.viewer-body pre { background: var(--bg-2); border: 1px solid var(--line); border-radius: 10px; padding: 12px; overflow: auto; }
.md-body :is(h1,h2,h3) { border-bottom: 1px solid var(--line); padding-bottom: .3em; }
.md-body code { background: var(--bg-2); padding: .12em .35em; border-radius: 5px; }
.md-body table { border-collapse: collapse; } .md-body td, .md-body th { border: 1px solid var(--line); padding: 5px 9px; }

/* roadmap */
.roadmap-add { display: flex; gap: 8px; margin-bottom: 14px; }
.roadmap-add input[name=title] { flex: 1; }
.roadmap-add input, .roadmap-add select { background: var(--panel); border: 1px solid var(--line);
  color: var(--text); border-radius: 9px; padding: 8px 11px; font: inherit; }
.roadmap-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.rm-item { background: var(--panel); border: 1px solid var(--line); border-radius: 11px;
  padding: 11px 13px; display: flex; align-items: center; gap: 11px; }
.rm-item.done { opacity: .55; }
.rm-check { width: 20px; height: 20px; border-radius: 6px; border: 1.5px solid var(--line);
  background: none; cursor: pointer; flex: none; display: grid; place-items: center; color: var(--green); }
.rm-check.on { background: rgba(63,185,80,.15); border-color: var(--green); }
.rm-title { flex: 1; }
.rm-item.done .rm-title { text-decoration: line-through; }
.prio { font-size: 11px; font-weight: 700; padding: 2px 7px; border-radius: 6px; background: var(--panel-2); color: var(--muted); }
.prio.p1 { color: #ff6b6b; } .prio.p2 { color: var(--amber); }
.rm-suggest { font-size: 11px; color: var(--amber); border: 1px solid var(--amber); border-radius: 6px; padding: 1px 6px; }

/* queue */
.queue-form { max-width: 640px; display: flex; flex-direction: column; gap: 12px; }
.queue-form label, .new-project-form label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--muted); }
.queue-form textarea, .queue-form input { background: var(--panel); border: 1px solid var(--line);
  color: var(--text); border-radius: 10px; padding: 10px 12px; font: inherit; resize: vertical; }
.queue-form .hint, .hint { color: var(--muted); font-size: 13px; }
.or-sep { text-align: center; color: var(--muted); font-size: 12px; }
.queue-result { padding: 12px; border-radius: 10px; background: var(--panel-2); border: 1px solid var(--line); font-size: 14px; }
.queue-result.err { border-color: #ff6b6b; color: #ff8a8a; }

/* activity */
.act-grid { display: grid; gap: 12px; grid-template-columns: repeat(auto-fill, minmax(150px,1fr)); margin-bottom: 18px; }
.stat { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 14px; }
.stat .v { font-size: 24px; font-weight: 700; } .stat .k { color: var(--muted); font-size: 12px; margin-top: 3px; }
.recent-files { list-style: none; padding: 0; margin: 0; }
.recent-files li { display: flex; justify-content: space-between; gap: 12px; padding: 7px 0; border-bottom: 1px solid var(--line); font-size: 14px; }
.recent-files .t { color: var(--muted); font-size: 12px; white-space: nowrap; }

/* ---------- dialog ---------- */
.tom-dialog { background: var(--panel); color: var(--text); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 0; width: min(440px, 92vw); box-shadow: var(--shadow); }
.tom-dialog::backdrop { background: rgba(4,7,13,.6); backdrop-filter: blur(3px); }
.tom-dialog form { padding: 22px; display: flex; flex-direction: column; gap: 14px; }
.tom-dialog h2 { margin: 0; font-size: 18px; }
.tom-dialog label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--muted); }
.tom-dialog input[name=name] { background: var(--bg-2); border: 1px solid var(--line); color: var(--text);
  border-radius: 10px; padding: 10px 12px; font: inherit; }
.kind-pick { border: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.kind-opt { display: flex; align-items: center; gap: 10px; background: var(--bg-2); border: 1px solid var(--line);
  border-radius: 10px; padding: 10px 12px; cursor: pointer; color: var(--text); }
.kind-opt span { display: flex; flex-direction: column; }
.kind-opt small { color: var(--muted); }
.kind-opt:has(input:checked) { border-color: var(--accent); background: rgba(91,140,255,.1); }
.dialog-actions { display: flex; justify-content: flex-end; gap: 8px; }
.form-error { color: #ff8a8a; font-size: 13px; margin: 0; }

/* toast + misc */
.toast-msg { position: fixed; left: 50%; bottom: 24px; transform: translateX(-50%);
  background: var(--panel-2); border: 1px solid var(--line); border-radius: 10px; padding: 11px 16px;
  box-shadow: var(--shadow); z-index: 60; max-width: 90vw; }
.toast-msg.err { border-color: #ff6b6b; }
.loading { color: var(--muted); padding: 24px; text-align: center; }
.empty-state { color: var(--muted); text-align: center; padding: 48px 16px; }
.banner-err { background: rgba(255,107,107,.1); border: 1px solid #ff6b6b; color: #ff9a9a;
  border-radius: 11px; padding: 12px 14px; margin-bottom: 16px; }

/* ---------- responsive ---------- */
@media (max-width: 720px) {
  .files-layout { grid-template-columns: 1fr; }
  .file-tree { max-height: 40vh; }
  .hide-xs { display: none; }
}

/* nav links */
.tom-nav-link { color: var(--muted); font-size: 14px; padding: 4px 6px; border-radius: 6px; }
.tom-nav-link:hover { color: var(--text); }
.tom-nav-link.active { color: var(--text); background: rgba(91,140,255,.12); }

/* cross-project roadmap */
.rm-page-title { font-size: 20px; margin: 0 8px 0 0; }
.rm-toggle { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--muted); white-space: nowrap; }
.rm-add-bar { display: flex; gap: 8px; margin: 0 0 14px; }
.rm-add-bar input[name=text] { flex: 1; min-width: 120px; background: var(--panel); border: 1px solid var(--line);
  color: var(--text); border-radius: 8px; padding: 8px 12px; }
.rm-add-bar input[name=text]:focus { outline: none; border-color: var(--accent); }
.rm-add-bar select { background: var(--panel); border: 1px solid var(--line); color: var(--text);
  border-radius: 8px; padding: 8px 10px; }

.rm-list { display: flex; flex-direction: column; gap: 4px; }
.rm-row { display: flex; align-items: center; gap: 10px; background: var(--panel); border: 1px solid var(--line);
  border-radius: 10px; padding: 8px 12px; }
.rm-row.done { opacity: .55; }
.rm-row.done .rm-text { text-decoration: line-through; }
.rm-mid { flex: 1; display: flex; align-items: baseline; gap: 8px; min-width: 0; }
.rm-text { color: var(--text); overflow: hidden; text-overflow: ellipsis; }
.rm-proj { font-size: 12px; color: var(--accent-2); background: rgba(91,140,255,.12);
  border-radius: 6px; padding: 1px 7px; white-space: nowrap; flex-shrink: 0; }
.rm-group-head { display: flex; align-items: center; gap: 8px; font-weight: 600; color: var(--text);
  margin: 14px 4px 4px; }
.rm-group-n { font-size: 12px; color: var(--muted); background: var(--panel-2); border-radius: 999px; padding: 0 7px; }

.rm-prio-select { font-size: 11px; font-weight: 700; padding: 2px 4px; border-radius: 6px;
  background: var(--panel-2); border: 1px solid var(--line); color: var(--muted); cursor: pointer; }
.rm-prio-select.p1 { color: #ff6b6b; } .rm-prio-select.p2 { color: var(--amber); }
.rm-prio-select.p3 { color: var(--accent-2); } .rm-prio-select.p4 { color: var(--muted); }
.rm-prio-select.p5 { color: var(--muted); opacity: .7; }

/* ---------- projects board (Kanban) ---------- */
.view-toggle { display: inline-flex; border: 1px solid var(--line); border-radius: 9px; overflow: hidden; }
.vt-btn { background: var(--panel); border: none; color: var(--muted); padding: 7px 11px; cursor: pointer; font-size: 14px; display: inline-flex; }
.vt-btn:hover { color: var(--text); }
.vt-btn.active { background: var(--accent); color: #fff; }

.projects-board { display: flex; gap: 14px; align-items: flex-start; overflow-x: auto; padding-bottom: 14px; }
.board-col { flex: 0 0 290px; background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 10px; display: flex; flex-direction: column; gap: 8px; max-height: calc(100vh - 180px); }
.board-col.virtual { background: rgba(90,101,119,.10); border-style: dashed; }
.board-col-head { display: flex; align-items: center; gap: 8px; padding: 2px 4px 6px; border-bottom: 1px solid var(--line); }
.board-col-title { font-weight: 600; font-size: 14px; cursor: text; flex: 1; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.board-col.virtual .board-col-title { color: var(--muted); cursor: default; }
.board-col-count { font-size: 12px; color: var(--muted); background: var(--panel-2); border-radius: 999px; padding: 0 8px; }
.board-col-menu { background: none; border: none; color: var(--muted); cursor: pointer; padding: 2px 4px; border-radius: 6px; }
.board-col-menu:hover { color: var(--text); background: var(--panel-2); }

.board-lane { display: flex; flex-direction: column; gap: 8px; min-height: 18px; border-radius: 10px;
  padding: 4px; overflow-y: auto; transition: background .12s; }
.board-lane.drag-over { background: rgba(91,140,255,.10); outline: 1px dashed var(--accent); }
.board-lane-label { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--muted);
  text-transform: uppercase; letter-spacing: .04em; margin: 2px 2px 0; }
.board-lane-label span { cursor: text; }
.lane-del { background: none; border: none; color: var(--muted); cursor: pointer; font-size: 14px; line-height: 1; padding: 0 2px; opacity: .6; }
.lane-del:hover { opacity: 1; color: #ff8a8a; }

.board-card { background: linear-gradient(180deg, var(--panel) 0%, var(--bg-2) 100%);
  border: 1px solid var(--line); border-radius: 11px; padding: 10px 11px; cursor: pointer;
  display: flex; flex-direction: column; gap: 8px; transition: .12s; }
.board-card:hover { border-color: var(--accent); }
.board-card.dragging { opacity: .4; }
.bc-top { display: flex; align-items: center; gap: 6px; }
.bc-name { font-weight: 600; font-size: 14px; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bc-move { background: none; border: none; color: var(--muted); cursor: grab; padding: 2px; border-radius: 6px; touch-action: none; }
.bc-move:hover { color: var(--text); background: var(--panel-2); }
.bc-meta { display: flex; align-items: center; gap: 9px; color: var(--muted); font-size: 12px; flex-wrap: wrap; }
.bc-meta .n { color: var(--text); font-weight: 600; }

.board-add-col { flex: 0 0 180px; align-self: flex-start; background: none; border: 1px dashed var(--line);
  color: var(--muted); border-radius: var(--radius); padding: 14px; cursor: pointer; font: inherit;
  display: inline-flex; align-items: center; gap: 6px; justify-content: center; }
.board-add-col:hover { color: var(--text); border-color: var(--muted); }

.inline-rename { background: var(--bg-2); border: 1px solid var(--accent); color: var(--text);
  border-radius: 7px; padding: 3px 7px; font: inherit; font-size: 14px; width: 100%; }
.inline-rename:focus { outline: none; }

/* floating menu (move-to / column actions) */
.floating-menu { position: absolute; z-index: 70; background: var(--panel-2); border: 1px solid var(--line);
  border-radius: 10px; box-shadow: var(--shadow); padding: 5px; min-width: 180px; max-height: 60vh; overflow: auto; }
.fm-item { display: block; width: 100%; text-align: left; background: none; border: none; color: var(--text);
  padding: 7px 10px; border-radius: 7px; cursor: pointer; font: inherit; font-size: 13px; }
.fm-item:hover:not(:disabled) { background: var(--accent); color: #fff; }
.fm-item.head { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .04em; cursor: default; padding: 6px 10px 2px; }
.fm-item.sub { padding-left: 18px; }

/* ---------- per-project roadmap board (Board B) ---------- */
.rmb-bar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.rmb-bar .roadmap-add { margin: 0; flex: 1; min-width: 240px; }
.rmb-board { display: flex; gap: 14px; align-items: flex-start; overflow-x: auto; padding-bottom: 14px; }
.rmb-board .board-col { max-height: calc(100vh - 240px); }
.rmb-lane { display: flex; flex-direction: column; gap: 7px; border-radius: 9px; padding: 4px 4px 6px;
  border-top: 1px solid var(--line); transition: background .12s; min-height: 30px; }
.rmb-lane.drag-over { background: rgba(91,140,255,.10); outline: 1px dashed var(--accent); }
.rmb-lane-label { font-size: 10px; font-weight: 700; color: var(--muted); letter-spacing: .04em; margin: 2px; }
.rmb-lane-label.p1 { color: #ff6b6b; } .rmb-lane-label.p2 { color: var(--amber); }
.rmb-lane-label.p3 { color: var(--accent-2); } .rmb-lane-label.p4, .rmb-lane-label.p5 { color: var(--muted); }
.rmb-card { padding: 9px 10px; }
.rmb-card.done { opacity: .55; }
.rmb-card-row { display: flex; align-items: flex-start; gap: 8px; }
.rmb-text { flex: 1; font-size: 13px; line-height: 1.35; word-break: break-word; }
.rmb-card.done .rmb-text { text-decoration: line-through; }
.rmb-card .rm-check { width: 18px; height: 18px; }

/* ---------- Capture (offline-first inbox) ---------- */
.capture-page { max-width: 720px; margin: 0 auto; padding: 8px 4px 40px; }
.capture-form { background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 14px; box-shadow: var(--shadow); }
.capture-text { width: 100%; resize: vertical; min-height: 84px; font: inherit;
  background: var(--bg-2); color: var(--text); border: 1px solid var(--line);
  border-radius: 10px; padding: 12px 13px; line-height: 1.45; }
.capture-text:focus { outline: none; border-color: var(--accent); }
.capture-bar { display: flex; align-items: center; gap: 10px; margin-top: 10px; }
.capture-attach { display: flex; gap: 8px; flex: 1; }
.capture-bar .btn-accent { margin-left: auto; }
.capture-hint { margin: 8px 2px 0; font-size: 12.5px; min-height: 1em; }

.capture-recent { margin-top: 26px; }
.capture-recent-head { display: flex; align-items: baseline; justify-content: space-between;
  gap: 10px; margin-bottom: 10px; }
.capture-recent-head h2 { font-size: 15px; font-weight: 600; margin: 0; letter-spacing: .01em; }
.capture-recent-head .muted { font-size: 12.5px; }
.outbox-list { display: flex; flex-direction: column; gap: 8px; }
.outbox-list .empty { padding: 18px 0; text-align: center; }
.outbox-item { background: var(--panel); border: 1px solid var(--line);
  border-left: 3px solid var(--grey); border-radius: 10px; padding: 10px 13px; }
.outbox-item.queued, .outbox-item.syncing { border-left-color: var(--amber); }
.outbox-item.synced { border-left-color: var(--green); }
.outbox-item.error  { border-left-color: #d6493b; }
.outbox-body { color: var(--text); white-space: pre-wrap; word-break: break-word; line-height: 1.4; }
.outbox-meta { display: flex; align-items: center; flex-wrap: wrap; gap: 8px;
  margin-top: 6px; font-size: 12px; }
.ob-badge { display: inline-flex; align-items: center; gap: 4px; font-weight: 600; }
.ob-badge.queued { color: var(--amber); }
.ob-badge.synced { color: var(--green); }
.ob-badge.error  { color: #e0685c; }
.link-btn { background: none; border: none; color: var(--accent-2); cursor: pointer;
  font: inherit; font-size: 12px; text-decoration: underline; padding: 0; }

/* Attachment thumbnails in the outbox (Phase 4). */
.outbox-thumbs { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.outbox-thumb { width: 52px; height: 52px; border-radius: 8px; object-fit: cover;
  border: 1px solid var(--line); background: var(--bg-2); }
.outbox-thumb.audio { display: inline-flex; align-items: center; justify-content: center;
  color: var(--muted); font-size: 20px; }
.attach-btn { background: var(--panel-2); border: 1px solid var(--line); color: var(--muted);
  border-radius: 9px; padding: 7px 10px; cursor: pointer; font: inherit; font-size: 13px;
  display: inline-flex; align-items: center; gap: 6px; }
.attach-btn:hover { color: var(--text); border-color: var(--muted); }
.attach-preview { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.attach-chip { position: relative; }
.attach-chip img { width: 56px; height: 56px; object-fit: cover; border-radius: 8px;
  border: 1px solid var(--line); }
.attach-chip .rm { position: absolute; top: -6px; right: -6px; width: 18px; height: 18px;
  border-radius: 50%; background: #d6493b; color: #fff; border: none; cursor: pointer;
  font-size: 11px; line-height: 18px; padding: 0; }

/* ---------- Offline screen ---------- */
.offline-screen { max-width: 460px; margin: 14vh auto 0; text-align: center; padding: 0 16px; }
.offline-mark { font-size: 56px; color: var(--accent); }
.offline-screen h1 { font-size: 22px; margin: 12px 0 8px; }
.offline-screen p { line-height: 1.5; }
.offline-actions { display: flex; gap: 10px; justify-content: center; margin-top: 20px; }
.attach-btn.recording { color: #fff; background: #d6493b; border-color: #d6493b; }
.attach-btn.recording:hover { background: #c23e31; }

/* ---------- Inbox / triage ---------- */
.inbox-page { max-width: 760px; margin: 0 auto; padding: 4px 4px 40px; }
.inbox-head { align-items: center; }
.inbox-title { font-size: 19px; margin: 0; }
.inbox-list { display: flex; flex-direction: column; gap: 12px; }
.inbox-list .empty { padding: 28px 0; text-align: center; }
.inbox-card { background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 14px; box-shadow: var(--shadow); }
.inbox-card.archived { opacity: .72; box-shadow: none; }
.inbox-card-body { color: var(--text); white-space: pre-wrap; word-break: break-word;
  line-height: 1.45; }
.inbox-thumbs { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-top: 10px; }
.inbox-thumb { width: 84px; height: 84px; object-fit: cover; border-radius: 10px;
  border: 1px solid var(--line); }
.inbox-audio { height: 34px; max-width: 240px; }
.inbox-file { font-size: 12.5px; color: var(--accent-2); }
.inbox-route { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-top: 12px; }
.inbox-item-text { flex: 1; min-width: 180px; background: var(--bg-2); color: var(--text);
  border: 1px solid var(--line); border-radius: 9px; padding: 8px 11px; font: inherit; }
.inbox-item-text:focus { outline: none; border-color: var(--accent); }
.inbox-project, .inbox-priority { background: var(--panel-2); color: var(--text);
  border: 1px solid var(--line); border-radius: 9px; padding: 8px 9px; font: inherit; }
.inbox-project:focus, .inbox-priority:focus { outline: none; border-color: var(--accent); }
.inbox-meta { margin-top: 10px; font-size: 12px; }

/* ---------- Offline pill ---------- */
.net-pill { display: inline-flex; align-items: center; gap: 5px; font-size: 12px;
  font-weight: 600; color: var(--amber); background: rgba(214,162,59,.14);
  border: 1px solid rgba(214,162,59,.4); border-radius: 999px; padding: 3px 10px; }

/* ---------- Login ---------- */
.login-screen { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 24px; }
.login-card { width: 100%; max-width: 340px; background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--radius); box-shadow: var(--shadow); padding: 28px 24px; text-align: center; }
.login-mark { font-size: 46px; color: var(--accent); line-height: 1; }
.login-title { font-size: 22px; font-weight: 700; margin: 10px 0 2px; }
.login-title .muted { font-weight: 400; opacity: .6; }
.login-sub { font-size: 13px; margin: 0 0 18px; }
.login-card input[type=password] { width: 100%; background: var(--bg-2); color: var(--text);
  border: 1px solid var(--line); border-radius: 10px; padding: 12px 13px; font: inherit; text-align: center; }
.login-card input[type=password]:focus { outline: none; border-color: var(--accent); }
.login-btn { width: 100%; margin-top: 12px; padding: 11px; }
.login-error { color: #e0685c; font-size: 13px; margin: 0 0 14px; }
.tom-logout { display: inline; margin: 0; }

/* ======================================================================
   Mobile (≤600px) — additive overrides ONLY. Nothing here affects ≥600px,
   so desktop + the installed PWA layout are untouched. Tune freely.
   ====================================================================== */
@media (max-width: 600px) {
  /* iOS zoom-on-focus fires when a focused control is <16px — force 16px. */
  input, select, textarea,
  .search-box, .sort-select, .capture-text, .inbox-item-text,
  .tag-input, .inbox-project, .inbox-priority { font-size: 16px; }

  /* Roomier gutters + clearance above the iPhone home indicator. */
  .tom-main { padding: 14px 12px calc(64px + env(safe-area-inset-bottom)); }

  /* Nav: brand on its own row, the links on a full-width row below so they
     never clip (horizontal-scroll as a safety valve), with real tap targets. */
  .tom-nav { flex-wrap: wrap; row-gap: 6px;
             padding-left: max(12px, env(safe-area-inset-left));
             padding-right: max(12px, env(safe-area-inset-right)); }
  .tom-brand { font-size: 16px; }
  .tom-logo { font-size: 20px; }
  .tom-nav-right { width: 100%; justify-content: flex-start; gap: 4px;
                   overflow-x: auto; -webkit-overflow-scrolling: touch;
                   scrollbar-width: none; }
  .tom-nav-right::-webkit-scrollbar { display: none; }
  .tom-nav-link { padding: 8px 10px; font-size: 14px; white-space: nowrap; }

  /* Bigger touch targets across buttons + chips. */
  .btn { padding: 10px 14px; }
  .btn-sm { padding: 9px 12px; font-size: 14px; }
  .chip { padding: 9px 15px; font-size: 14px; }

  /* page-head: stack into full-width rows instead of a cramped wrap.
     Row 1 = filters + view-toggle; Row 2 = search; Row 3 = sort. */
  .page-head { gap: 10px; }
  .filters { order: 1; }
  .view-toggle { order: 2; margin-left: auto; }
  .search-box { order: 3; flex: 1 1 100%; min-width: 0; padding: 11px 13px; }
  .sort-select { order: 4; flex: 1 1 100%; padding: 11px 13px; }

  /* Single-column cards already; a touch more breathing room. */
  .proj-card { padding: 14px; }

  /* Capture compose: full-width comfortable controls. */
  .capture-form { padding: 12px; }
  .capture-text { min-height: 110px; }

  /* Inbox triage: text input takes the row, project/priority/actions below. */
  .inbox-card { padding: 12px; }
  .inbox-item-text { flex: 1 1 100%; min-width: 0; }
  .inbox-project, .inbox-priority { flex: 1 1 auto; }
  .inbox-route .btn { flex: 1 1 auto; justify-content: center; }

  /* Roadmap add bar: stack the text field full-width. */
  .rm-add-bar { flex-wrap: wrap; }
  .rm-add-bar input[name=text] { flex: 1 1 100%; min-width: 0; }
}
