/* ──────────────────────────────────────────────────────────
   TO DO — Kanban board (Phase 6i)
   Matches the demo's 4-column Tasks board. Scoped to #panel-board.
   Most card/badge/pill classes (.kb-card, .tlr-priority, .pri-*,
   .tlr-avatar, .task-filter-pill, .board-head*) already live in
   design.css; this only adds the board chrome + column grid.
────────────────────────────────────────────────────────── */
#panel-board { padding: 0; }
#panel-board .board-head { padding: 28px 32px 18px; }
#panel-board .board-head-title { font-size: 22px; font-weight: 700; color: var(--text); letter-spacing: -0.4px; }

/* Filter bar (pills + sort label) */
#panel-board .board-filter-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 32px;
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
  gap: 10px;
}
#panel-board .board-filter-pills { display: flex; gap: 6px; flex-wrap: wrap; }
#panel-board .board-sort-label {
  font-family: var(--font-mono); font-size: 9px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase; color: var(--text-3);
}

/* Column grid */
#panel-board .board-kanban {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  padding: 18px 28px 48px;
  align-items: start;
}
#panel-board .board-col {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
  background: var(--surface);
  border: 1px solid rgba(45,106,79,0.28);
  border-radius: 12px;
  padding: 14px 14px 18px;
}
#panel-board .board-col-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 4px;
}
#panel-board .board-col-title { font-size: 13px; font-weight: 700; color: var(--text); letter-spacing: -0.1px; }
#panel-board .board-col-count { font-family: var(--font-mono); font-size: 10px; color: var(--text-3); }
#panel-board .board-col-add {
  font-size: 12px; color: var(--text-3); padding: 8px 4px; text-align: left;
  background: none; border: none; cursor: pointer; font-family: var(--font-body);
  transition: color 120ms;
}
#panel-board .board-col-add:hover { color: var(--text); }

/* Drag-and-drop affordances */
#panel-board .kb-card { cursor: grab; }
#panel-board .kb-card:active { cursor: grabbing; }
#panel-board .kb-card.kb-dragging {
  opacity: 0.5;
  cursor: grabbing;
  box-shadow: 0 12px 32px rgba(0,0,0,0.18);
}
#panel-board .board-col.kb-drop-target {
  border-color: var(--green);
  background: rgba(45,106,79,0.05);
  box-shadow: inset 0 0 0 1px rgba(45,106,79,0.35);
}
#panel-board .kb-col-empty {
  border: 1px dashed var(--border-med);
  border-radius: 8px;
  padding: 18px 10px;
  text-align: center;
  font-size: 11px;
  color: var(--text-3);
  transition: border-color 120ms, color 120ms;
}
#panel-board .board-col.kb-drop-target .kb-col-empty {
  border-color: var(--green);
  color: var(--green);
}

/* Card internals */
#panel-board .kb-card-top {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 8px; gap: 8px;
}
#panel-board .kb-badges { display: flex; align-items: center; gap: 6px; min-width: 0; flex-wrap: wrap; }
#panel-board .kb-cat {
  font-family: var(--font-mono); font-size: 8px; font-weight: 700;
  letter-spacing: 0.6px; text-transform: uppercase; color: var(--text-3);
  white-space: nowrap;
}
#panel-board .kb-title {
  font-size: 13px; font-weight: 600; color: var(--text);
  letter-spacing: -0.1px; line-height: 1.35; margin-bottom: 4px;
  /* Keep long titles tidy: clamp to 2 lines instead of overflowing. */
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden; overflow-wrap: anywhere; word-break: break-word;
}
#panel-board .kb-title-done { color: var(--text-3); text-decoration: line-through; }
#panel-board .kb-card:not(:has(.kb-desc)) .kb-title { margin-bottom: 0; }
#panel-board .kb-desc {
  font-size: 11px; color: var(--text-3); line-height: 1.45; margin-bottom: 8px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden; overflow-wrap: anywhere; word-break: break-word;
}
#panel-board .kb-card-foot {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 10px; padding-top: 8px; border-top: 1px solid var(--border); gap: 8px;
}
#panel-board .kb-assignee { display: flex; align-items: center; gap: 6px; min-width: 0; }
#panel-board .kb-assignee .tlr-avatar { width: 22px; height: 22px; font-size: 8px; letter-spacing: 0.3px; }
#panel-board .kb-assignee span { font-size: 11px; color: var(--text-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#panel-board .kb-date {
  font-family: var(--font-mono); font-size: 9px; font-weight: 600;
  padding: 3px 8px; border-radius: 20px; background: var(--surface-2);
  color: var(--text-3); flex-shrink: 0; white-space: nowrap;
}
#panel-board .board-kanban-empty {
  grid-column: 1 / -1;
  text-align: center; color: var(--text-3);
  font-size: 13px; padding: 60px 0;
}

/* Responsive: collapse columns on narrow viewports */
@media (max-width: 1100px) {
  #panel-board .board-kanban { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 680px) {
  #panel-board .board-kanban { grid-template-columns: 1fr; }
}

/* Share Cards placeholder (account menu → My Share Cards) */
.sc-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
  padding: 56px 32px;
  max-width: 460px;
  margin: 0 auto;
}
.sc-ph-icon {
  font-size: 40px;
  line-height: 1;
  color: var(--green, var(--text-3));
  opacity: 0.85;
}
.sc-ph-title { font-size: 17px; font-weight: 700; color: var(--text); letter-spacing: -0.2px; }
.sc-ph-desc { font-size: 13px; color: var(--text-3); line-height: 1.6; }

/* ───────────────────────────────────────────────────────────────
   Task Board — detail / add / archive MODAL
   ---------------------------------------------------------------
   Root cause of the unstyled "Task" popup (paste-1781025025267.png):
   the design migration links design.css but NOT board.css. design.css
   defines `.board-modal` as a *card* (board-modal-overlay + board-modal)
   while our markup uses `.board-modal` as the full-screen OVERLAY and
   `.board-modal-card` as the card — the board.css semantics, which have
   no styles loaded. design.css also lacks `.board-modal-card`,
   `.board-detail-*`, `.bd-comment-*`, and `.board-archive-*`, so the
   meta / comments / compose blocks render as plain text.

   Fix (CSS-only, same pattern as the Events sub-tab restore): port the
   board.css modal block here (overrides.css loads AFTER design.css). We
   explicitly RESET the width/border/radius/shadow/transform that
   design.css's `.board-modal` card rule would otherwise leak onto our
   overlay element. No JS / no API callsite touched.
   ─────────────────────────────────────────────────────────────── */
.board-modal {
  position: fixed; inset: 0; z-index: 9999;
  width: auto; max-width: none;
  border: none; border-radius: 0; box-shadow: none; transform: none;
  background: rgba(30, 28, 24, 0.45);
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-4);
  animation: boardModalFade var(--duration-base) var(--ease);
}
@keyframes boardModalFade { from { opacity: 0; } to { opacity: 1; } }
.board-modal-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  width: 100%; max-width: 460px; max-height: 90vh;
  overflow-y: auto;
  padding: var(--space-6) var(--space-6);
  display: flex; flex-direction: column; gap: var(--space-4);
}
.board-modal-title { font-family: var(--font-body); font-size: var(--text-md); font-weight: 700; color: var(--text); margin: 0; letter-spacing: -0.2px; }
.board-modal-label { display: flex; flex-direction: column; gap: 6px; font-family: var(--font-body); font-size: var(--text-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px; color: var(--text-3); }
.board-modal-input { font-family: var(--font-body); font-size: var(--text-base); color: var(--text); background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 10px 12px; width: 100%; box-sizing: border-box; transition: border-color var(--duration-fast) var(--ease), box-shadow var(--duration-fast) var(--ease); text-transform: none; letter-spacing: normal; font-weight: 400; }
.board-modal-input::placeholder { color: var(--text-3); }
.board-modal-input:focus { outline: none; border-color: var(--indigo); box-shadow: 0 0 0 3px rgba(45, 106, 79, 0.12); }
textarea.board-modal-input { resize: vertical; min-height: 72px; line-height: 1.5; }
.board-modal-actions { display: flex; justify-content: flex-end; gap: var(--space-2); margin-top: var(--space-2); }
.board-modal-cancel { background: transparent; color: var(--text-3); border: 1px solid var(--border); padding: var(--space-2) var(--space-4); border-radius: var(--radius); font-family: var(--font-body); font-size: var(--text-sm); font-weight: 500; text-transform: none; letter-spacing: normal; cursor: pointer; transition: background var(--duration-fast) var(--ease), color var(--duration-fast) var(--ease); }
.board-modal-cancel:hover { background: var(--surface-2); color: var(--text); }
.board-modal-submit { background: var(--emerald); color: #fff; border: none; padding: var(--space-2) var(--space-5); border-radius: var(--radius); font-family: var(--font-body); font-size: var(--text-sm); font-weight: 600; text-transform: none; letter-spacing: normal; cursor: pointer; transition: opacity var(--duration-fast) var(--ease); }
.board-modal-submit:hover { opacity: var(--opacity-hover); }
.board-modal-submit:disabled { opacity: var(--opacity-disabled); cursor: not-allowed; }

/* Task detail: meta line, save status, comments thread, composer */
.board-detail-meta { font-family: var(--font-body); font-size: var(--text-xs); color: var(--text-3); padding: var(--space-3) 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); margin-top: var(--space-1); }
.board-detail-meta .bd-meta-row { margin: 2px 0; }
.board-detail-meta .bd-who { color: var(--text-3); font-weight: 600; }
.board-detail-save-status { font-family: var(--font-body); font-size: var(--text-xs); color: var(--text-3); align-self: center; margin-right: var(--space-2); min-height: 16px; transition: opacity var(--duration-base) var(--ease); }
.board-detail-save-status.saved { color: var(--emerald); font-weight: 600; }
.board-detail-comments-header { font-family: var(--font-body); font-size: var(--text-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px; color: var(--text-3); margin-top: var(--space-1); }
.board-detail-comments { display: flex; flex-direction: column; gap: var(--space-2); max-height: 260px; overflow-y: auto; padding-right: 4px; }
.board-detail-comment { display: flex; flex-direction: column; gap: 4px; padding: var(--space-3); background: var(--surface-2); border-radius: var(--radius-sm); border: 1px solid var(--border); }
.board-detail-comment .bd-comment-head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-2); font-family: var(--font-body); font-size: var(--text-xs); }
.board-detail-comment .bd-comment-who { font-weight: 700; color: var(--text); }
.board-detail-comment .bd-comment-when { color: var(--text-3); }
.board-detail-comment .bd-comment-body { font-family: var(--font-body); font-size: var(--text-sm); color: var(--text); line-height: 1.5; white-space: pre-wrap; word-wrap: break-word; }
.board-detail-comment .bd-comment-delete { background: none; border: none; cursor: pointer; font-size: var(--text-sm); color: var(--text-3); padding: 0 4px; line-height: 1; }
.board-detail-comment .bd-comment-delete:hover { color: var(--coral); }
.board-detail-comments-empty { font-family: var(--font-body); font-size: var(--text-sm); color: var(--text-3); text-align: center; padding: var(--space-4) 0; }
.board-detail-compose { display: flex; gap: var(--space-2); align-items: flex-end; }
.board-detail-compose textarea { flex: 1; min-height: 48px; }

/* Completed Archive list rows */
.board-archive-sub { font-family: var(--font-body); font-size: var(--text-xs); color: var(--text-3); margin: 0; }
.board-archive-list { display: flex; flex-direction: column; gap: var(--space-2); max-height: 50vh; overflow-y: auto; margin: 0; padding: 0; }
.board-archive-empty { font-family: var(--font-body); font-size: var(--text-sm); color: var(--text-3); text-align: center; padding: var(--space-5) 0; }
.board-archive-row { display: flex; align-items: flex-start; gap: var(--space-3); padding: var(--space-3); border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--surface); }
.board-archive-row .arch-check { color: var(--emerald); font-weight: 700; flex-shrink: 0; }
.board-archive-row .arch-body { flex: 1; min-width: 0; }
.board-archive-row .arch-title { font-family: var(--font-body); font-size: var(--text-base); font-weight: 600; color: var(--text); line-height: 1.3; word-wrap: break-word; }
.board-archive-row .arch-desc { font-family: var(--font-body); font-size: var(--text-xs); color: var(--text-3); margin-top: 4px; line-height: 1.4; word-wrap: break-word; }
.board-archive-row .arch-meta { font-family: var(--font-body); font-size: var(--text-xs); color: var(--text-3); margin-top: 6px; }
.board-archive-row .arch-meta .arch-who { color: var(--text-3); font-weight: 600; }
