:root {
  --color-silk: #eee5d9;
  --color-marble: #e8e4e0;
  --color-pearl: #fdffff;
  --color-velvet: #222d52;
  --color-velvet-dark: #1a223e;
  --color-champagne: #d2b68a;
  --color-onyx: #000000;
  --color-text-subtle: #9ca3af;
  --color-basil: #4d7c0f;
  --color-basil-light: #ecfccb;
  --color-ruby: #b42318;
  --color-ruby-light: #fee2e2;
  --color-ruby-dark: #8a160e;
  --color-amber: #b48a3a;
  --color-amber-light: #fff4d1;
  --color-grape: #6d28d9;
  --color-grape-light: #ede9fe;

  /* Task contexts: bluish pills, distinct from velvet category pills. */
  --color-context: #2f6fb0;
  --color-context-dark: #1f5390;
  --color-context-light: #e6f0fb;
  --color-context-border: #b9d2f0;

  /* Card dormancy (planning/card-age-dormancy-plan-v2.html) */
  --age-paper-fresh: #ffffff;
  --age-paper-warm: #fdfaf3;
  --age-paper-cool: #f9f2e2;
  --age-paper-cold: #f1e7cf;
  --age-paper-frozen: #ebdfc2;
  --age-grain: rgba(120, 80, 20, 0.04);
  --age-border-aged: rgba(120, 80, 20, 0.3);
  --age-text-cold: #7c2d12;
  --age-text-frozen: #4b5563;
}
/* Inline SVG icons (View/Icon.elm, generated from lucide-static).
   Icons render at the surrounding font-size and inherit text color. */
.icon {
  width: 1em;
  height: 1em;
  vertical-align: -0.125em;
  flex: none;
}

/* Solid fill for "active" states (e.g. pinned ★ vs unpinned ☆ both use Icon.star). */
.icon--filled {
  fill: currentColor;
}
/* GENERATED — do not edit by hand.
   Mask-image data-URIs for CSS `content:` pseudo-element glyphs that Elm can't
   reach, sourced from lucide-static (ISC, https://lucide.dev). Use as:
     .x::before { content: ""; display: inline-block; width: 1em; height: 1em;
       background-color: currentColor;
       -webkit-mask: var(--icon-NAME) center / contain no-repeat;
               mask: var(--icon-NAME) center / contain no-repeat; }
   Regenerate with: node scripts/gen-icons.mjs (after scripts/dev-deps.sh). */
:root {
  --icon-check: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
  --icon-play: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black' stroke='none'%3E%3Cpath d='M5 5a2 2 0 0 1 3.008-1.728l11.997 6.998a2 2 0 0 1 .003 3.458l-12 7A2 2 0 0 1 5 19z'/%3E%3C/svg%3E");
  --icon-swap: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 3 4 7l4 4'/%3E%3Cpath d='M4 7h16'/%3E%3Cpath d='m16 21 4-4-4-4'/%3E%3Cpath d='M20 17H4'/%3E%3C/svg%3E");
  --icon-user: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M19 21v-2a4 4 0 0 0-4-4H9a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E");
}
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

body {
  margin: 0;
  background-color: var(--color-silk);
  height: 100vh;
  height: 100dvh;
  overflow: hidden;
}
.page {
  min-height: 100vh;
  min-height: 100dvh;
  height: 100vh;
  height: 100dvh;
  width: 100vw;
  background-color: var(--color-silk);
  display: flex;
}

.chat-container {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  background-color: var(--color-silk);
  box-shadow: 0 18px 38px rgba(34, 45, 82, 0.08);
  padding: 8px 0 0 0;
}

.board-with-search {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}
.board-with-search > .message-scroll {
  flex: 1;
  min-height: 0;
}

/* Wraps the board's scroll area. The planner side-panel was removed with the
   sessions feature, but this wrapper stays as the flex parent that gives the
   scroll area its bounded height — without it a lane taller than the screen
   can't scroll. */
.board-with-planner {
  display: flex;
  flex: 1;
  min-height: 0;
}
.board-with-planner > :first-child {
  flex: 1;
  min-width: 0;
}
/* Filter Bar */
.filter-bar {
  padding: 0 20px 12px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  background-color: var(--color-silk);
  flex-shrink: 0;
  align-items: center;
}

.filter-label {
  font-size: 12px;
  font-weight: 700;
  color: var(--color-velvet);
  text-transform: uppercase;
  margin-right: -4px;
  letter-spacing: 0.5px;
}
.filter-select {
  padding: 6px 10px;
  border-radius: 8px;
  border: 1px solid #dcdcdc;
  background-color: var(--color-pearl);
  color: var(--color-velvet);
  font-size: 13px;
  outline: none;
  cursor: pointer;
  transition: all 0.2s;
}
.filter-select:hover {
  border-color: var(--color-champagne);
}

.filter-checkbox-wrapper {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--color-velvet);
  cursor: pointer;
  margin-left: 6px;
  user-select: none;
  background: rgba(255, 255, 255, 0.4);
  padding: 4px 8px;
  border-radius: 8px;
  border: 1px solid transparent;
}
.filter-checkbox-wrapper:hover {
  background: rgba(255, 255, 255, 0.6);
  border-color: #dcdcdc;
}
.filter-checkbox {
  accent-color: var(--color-velvet);
  width: 14px;
  height: 14px;
  cursor: pointer;
}
/* Tabs & Input */
.input-field {
  flex: 1;
  min-width: 220px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid transparent;
  background-color: var(--color-pearl);
  color: var(--color-velvet);
  font-size: 16px;
  outline: none;
  resize: vertical;
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.02);
  transition: all 0.3s ease;
}
.input-field::placeholder {
  color: #b0a8a0;
}
.input-field:focus {
  background-color: #fff;
  border-color: var(--color-champagne);
  box-shadow: 0 0 0 4px rgba(210, 182, 138, 0.15);
}

.status {
  padding: 0 18px 8px;
  flex-shrink: 0;
}
.status-card {
  color: var(--color-velvet);
  display: flex;
  align-items: center;
  gap: 10px;
  background: #fff6f0;
  border: 1px solid #f1c9a3;
  padding: 10px 12px;
  border-radius: 12px;
}
.status-card button {
  padding: 6px 10px;
  border: 1px solid #f1c9a3;
  border-radius: 10px;
  background: white;
  cursor: pointer;
  color: var(--color-velvet);
}

.loading-text,
.empty-state {
  margin: 18px 0 8px;
  color: #475569;
  font-size: 14px;
}

/* Bottom Tab Bar */
.tab-bar {
  display: flex;
  align-items: flex-end;
  gap: 0;
  padding: 8px 0 0 0;
  background-color: var(--color-marble);
  overflow-x: auto;
  flex-shrink: 0;
}
.tab {
  padding: 10px 16px;
  border-radius: 0;
  background-color: rgba(255, 255, 255, 0.4);
  color: var(--color-velvet);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  border-bottom: 3px solid transparent;
  transition: all 0.2s;
  white-space: nowrap;
  margin-bottom: 0;
  border-right: 1px solid rgba(0, 0, 0, 0.05);
  display: flex;
  align-items: center;
  gap: 8px;
}
.tab-bar-action {
  margin-left: auto;
  margin-right: 16px;
  margin-bottom: 10px;
  color: #8b1e1e;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  flex-shrink: 0;
  transition: color 0.2s;
}
.tab-bar-action:hover {
  color: #b42318;
  text-decoration: underline;
}
.tab.active {
  background-color: var(--color-pearl);
  border-bottom: 3px solid var(--color-velvet);
  z-index: 10;
  box-shadow: none;
  color: var(--color-velvet-dark);
}
.tab:hover:not(.active) {
  background-color: rgba(255, 255, 255, 0.7);
}
.tab.add-tab {
  background-color: rgba(255, 255, 255, 0.2);
}
.tab-bar-pin-separator {
  align-self: stretch;
  width: 1px;
  background: rgba(34, 45, 82, 0.2);
  margin: 6px 8px 0;
  flex-shrink: 0;
}
.tab.tab-pinned {
  background-color: rgba(255, 244, 209, 0.55);
  font-style: italic;
}
.tab.tab-pinned.active {
  background-color: var(--color-pearl);
  font-style: normal;
}
.toast {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 60;
  background: var(--color-velvet);
  color: #ffffff;
  padding: 10px 14px;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 600;
  box-shadow: 0 12px 28px rgba(34, 45, 82, 0.22);
  animation: toastInOut 2.5s ease-out forwards;
}

.toast.save-toast {
  background: #15803d;
}

@keyframes toastInOut {
  0% {
    opacity: 0;
    transform: translateY(8px);
  }
  12% {
    opacity: 1;
    transform: translateY(0);
  }
  88% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(8px);
  }
}
/* Create Modal */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(26, 34, 62, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 50;
}
.modal-card {
  width: min(420px, 92vw);
  background: var(--color-pearl);
  border-radius: 16px;
  padding: 16px;
  box-shadow: 0 24px 60px rgba(34, 45, 82, 0.25);
  border: 1px solid rgba(34, 45, 82, 0.12);
}
.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}
.modal-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-velvet);
}
.modal-close {
  border: none;
  background: transparent;
  font-size: 20px;
  cursor: pointer;
  color: var(--color-velvet);
}
.modal-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.modal-input {
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid #dcdcdc;
  font-size: 13px;
  color: var(--color-velvet);
}
.modal-scope {
  font-size: 12px;
  color: var(--color-text-subtle);
}
.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
.modal-button {
  padding: 7px 14px;
  border-radius: 8px;
  border: 1px solid #d0d0d0;
  background: #ffffff;
  color: var(--color-velvet);
  font-size: 12px;
  cursor: pointer;
}
.modal-button.primary {
  background: var(--color-velvet);
  border-color: var(--color-velvet);
  color: #ffffff;
}
.modal-button.secondary {
  background: #ffffff;
}
.capture-modal-backdrop {
  z-index: 70;
}
.capture-modal-card {
  width: min(860px, 95vw);
  max-height: min(86vh, 860px);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.capture-form-row {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.capture-form-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-velvet);
}
.capture-message-input {
  min-height: 120px;
  resize: vertical;
}
.capture-pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.capture-pill-row .context-tag {
  height: 30px;
  padding: 6px 12px;
  font-size: 12px;
  text-transform: none;
}
.capture-empty-note {
  font-size: 12px;
  color: var(--color-text-subtle);
  padding: 4px 0;
}
.capture-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
  padding-top: 4px;
}
.project-selector-backdrop {
  z-index: 60;
}
.project-selector-card {
  width: min(760px, 94vw);
  max-height: min(78vh, 760px);
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.project-selector-meta {
  font-size: 12px;
  color: var(--color-text-subtle);
}
.project-selector-empty {
  margin: 0;
  padding: 14px 0;
  font-size: 13px;
  color: var(--color-text-subtle);
}
.project-selector-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 8px;
  max-height: min(52vh, 460px);
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 2px;
}
.project-selector-option {
  border: 1px solid #d9deea;
  border-radius: 10px;
  background: #ffffff;
  color: var(--color-onyx);
  padding: 10px 12px;
  font-size: 13px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  cursor: pointer;
  transition:
    border-color 0.2s,
    background-color 0.2s,
    box-shadow 0.2s;
  text-align: left;
}
.project-selector-option:hover {
  border-color: #b7c1d9;
  box-shadow: 0 2px 6px rgba(34, 45, 82, 0.08);
}
.project-selector-option.selected {
  border-color: var(--color-velvet);
  background: #f4f7ff;
}
.project-selector-option-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.project-selector-option-check {
  color: var(--color-basil);
  font-weight: 700;
}
.project-selector-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}
@media (max-width: 640px) {
  .capture-modal-card {
    width: min(560px, 96vw);
    max-height: min(90vh, 860px);
  }
  .project-selector-card {
    width: min(520px, 96vw);
    max-height: min(82vh, 760px);
  }
  .project-selector-grid {
    grid-template-columns: repeat(auto-fill, minmax(145px, 1fr));
  }
}
/* Edit Card Modal */
.edit-card-modal-backdrop {
  z-index: 65;
}
.edit-card-modal-card {
  width: 90vw;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
}
.edit-card-modal-body {
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow-y: auto;
}
.edit-card-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.edit-card-field-header {
  display: flex;
  align-items: center;
  gap: 6px;
}
.edit-card-add-person-btn {
  border: none;
  background: none;
  color: var(--color-text-subtle);
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  padding: 0 4px;
  line-height: 1;
}
.edit-card-add-person-btn:hover {
  color: var(--color-velvet);
}
.edit-card-pill-block {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: 6px;
}
.edit-card-pill-block:first-of-type {
  margin-top: 2px;
}
.edit-card-pill-block-header {
  display: flex;
  align-items: center;
  gap: 6px;
}
.edit-card-pill-block-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-subtle);
}
.create-person-overlay-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(26, 34, 62, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  border-radius: 16px;
}
.create-person-overlay-card {
  width: min(360px, 85%);
  background: var(--color-pearl);
  border-radius: 12px;
  padding: 16px;
  box-shadow: 0 12px 40px rgba(34, 45, 82, 0.25);
  border: 1px solid rgba(34, 45, 82, 0.12);
}
.create-person-contexts {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.edit-card-textarea {
  width: 100%;
  min-height: 120px;
  resize: vertical;
  font-family: inherit;
  font-size: 13px;
  padding: 8px;
  border-radius: 6px;
  border: 1px solid #d0d0d0;
  box-sizing: border-box;
}
.edit-card-refs {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 4px;
}
.edit-card-refs-label {
  font-size: 12px;
  color: var(--color-text-subtle);
}
.edit-card-refs-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.edit-card-ref-item {
  font-size: 12px;
  color: var(--color-text-subtle);
  padding: 2px 0;
}

.kanban-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 4px;
}
.card-trello-link {
  flex-shrink: 0;
  font-size: 14px;
  text-decoration: none;
  opacity: 0.6;
  cursor: pointer;
}
.card-trello-link:hover {
  opacity: 1;
}

/* ---- References panel inside the EditCard modal ---- */

.edit-card-refs {
  margin-top: 12px;
  padding: 10px 12px;
  background: var(--color-pearl);
  border: 1px solid var(--color-marble);
  border-radius: 8px;
}

.edit-card-refs-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}

.edit-card-refs-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}

.edit-card-refs-backlinks {
  margin-top: 10px;
  padding-top: 8px;
  border-top: 1px dashed rgba(34, 45, 82, 0.1);
}

.edit-card-refs-backlinks .filter-label {
  display: block;
  margin-bottom: 4px;
}
/* Card next tasks */
.card-next-tasks {
  display: flex;
  flex-direction: column;
  gap: 3px;
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px solid rgba(34, 45, 82, 0.08);
}
.card-next-tasks.is-grouped {
  gap: 6px;
}
.card-next-group {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.card-next-group-header {
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #6b7280;
  font-weight: 600;
}
.card-next-task {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: 11px;
}

/* Compact icon-only add-task button, at the end of the card description.
   Shown when a card has no active task; opens the editor on "default". */
.card-add-task-icon {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px dashed #b8b0a0;
  border-radius: 5px;
  background: transparent;
  color: #8a8170;
  font-size: 13px;
  line-height: 1;
  cursor: pointer;
  padding: 0;
  transition:
    border-color 0.12s ease,
    color 0.12s ease,
    background 0.12s ease;
}
.card-add-task-icon:hover {
  border-color: var(--color-velvet);
  color: var(--color-velvet);
  background: #eef2fb;
}

.card-next-task-main {
  display: flex;
  align-items: center;
  gap: 4px;
}
.card-next-task-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
  padding-left: 20px;
}
.card-next-task-checkbox {
  flex-shrink: 0;
  width: 14px;
  height: 14px;
}
.card-next-task-text {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.card-next-task-pill {
  font-size: 9px;
  padding: 0 4px;
  border-radius: 6px;
  background: #e2e8f0;
  color: #4a5568;
  cursor: pointer;
  white-space: nowrap;
}
.card-next-task-pill:hover {
  opacity: 0.8;
}
.card-next-task-pill-done {
  text-decoration: line-through;
  opacity: 0.5;
  background: #c6f6d5;
  color: #276749;
}

.edit-card-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.edit-card-board-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 4px;
}
.edit-card-board-label {
  font-size: 12px;
  color: var(--color-text-subtle);
  min-width: 60px;
}
/* Task Lists in Edit Card Modal */
.edit-card-task-lists {
  display: flex;
  flex-direction: column;
  gap: 8px;
  border-top: 1px solid #e0e0e0;
  padding-top: 12px;
  margin-top: 4px;
}
.task-lists-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.task-lists-content {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.task-list-section {
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  padding: 8px;
}
.task-list-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}
.task-list-title {
  font-weight: 600;
  font-size: 13px;
  flex: 1;
}
.task-list-edit-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  color: var(--color-text-subtle);
  cursor: pointer;
  font-size: 14px;
  padding: 0 4px;
}
.task-list-edit-btn:hover {
  color: var(--color-velvet, #222d52);
}
.task-list-edit-btn:disabled {
  opacity: 0.5;
  cursor: default;
}
.task-list-delete-btn {
  background: none;
  border: none;
  color: var(--color-text-subtle);
  cursor: pointer;
  font-size: 16px;
  padding: 0 4px;
}
.task-list-delete-btn:hover {
  color: #e53e3e;
}
.task-list-items {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.task-item {
  display: flex;
  flex-direction: column;
  padding: 4px 6px;
  border-radius: 4px;
  background: #fafafa;
  border: 1px solid transparent;
  cursor: grab;
  transition:
    opacity 0.12s ease,
    border-color 0.12s ease,
    background-color 0.12s ease;
}
.task-item:active {
  cursor: grabbing;
}
.task-item:hover {
  background: #f0f0f0;
}
.task-item.is-dragging {
  opacity: 0.34;
  border: 1px dashed rgba(34, 45, 82, 0.35);
  background: rgba(34, 45, 82, 0.05);
}
.task-item.task-done {
  opacity: 0.6;
}
.task-item.task-done.is-dragging {
  opacity: 0.2;
}
.task-item.task-obsolete {
  opacity: 0.4;
}
.task-item.task-obsolete.is-dragging {
  opacity: 0.2;
}
.task-drop-zone-empty {
  min-height: 32px;
  border: 1px dashed rgba(34, 45, 82, 0.22);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  color: var(--color-text-subtle);
  background: rgba(34, 45, 82, 0.03);
}
.task-list-drop-target {
  min-height: 20px;
}
.task-item-main {
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
}
.task-drag-handle {
  cursor: grab;
  color: var(--color-text-subtle);
  font-size: 12px;
  user-select: none;
}
.task-checkbox {
  flex-shrink: 0;
}
.task-text {
  flex: 1;
  font-size: 13px;
  cursor: pointer;
  word-break: break-word;
}
/* Card-modal tasks are read-only (edit happens in the task editor); only the
   grip stays interactive. The row still drags, so the body keeps the grab cursor. */
.task-item-readonly .task-text {
  cursor: grab;
}
.task-item-readonly .task-checkbox {
  cursor: default;
}
.task-text-done {
  text-decoration: line-through;
  color: var(--color-text-subtle);
}
.task-text-obsolete {
  text-decoration: line-through;
  color: #aaa;
}
.task-status-badge {
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 8px;
  white-space: nowrap;
  font-weight: 500;
}
.task-status-next {
  background: #c6f6d5;
  color: #276749;
}
.task-status-planned {
  background: #e2e8f0;
  color: #4a5568;
}
.task-status-done {
  background: #c6f6d5;
  color: #276749;
  opacity: 0.7;
}
.task-status-obsolete {
  background: #fed7d7;
  color: #9b2c2c;
  opacity: 0.7;
}
.task-status-snoozed {
  background: #fefcbf;
  color: #975a16;
}
.task-deadline-badge {
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 8px;
  white-space: nowrap;
  font-weight: 500;
  background: #fed7e2;
  color: #97266d;
}
.task-parallel-badge {
  font-size: 11px;
  font-weight: 600;
}
.task-parallel-badge-active {
  color: #805ad5;
}
.task-parallel-badge-inactive {
  color: #cbd5e0;
}
.task-parallel-badge-clickable {
  cursor: pointer;
}
.task-parallel-badge-clickable:hover {
  color: #6b46c1;
}
.task-estimate-badge {
  font-size: 10px;
  color: var(--color-text-subtle);
  background: #edf2f7;
  padding: 1px 5px;
  border-radius: 6px;
}
.task-add-row {
  margin-top: 4px;
}
.task-add-form,
.task-list-create-form {
  display: flex;
  gap: 4px;
}
.task-add-input,
.task-list-name-input {
  flex: 1;
  font-size: 12px;
  padding: 4px 8px;
  border: 1px solid #d0d0d0;
  border-radius: 4px;
}
.task-add-btn,
.task-list-create-btn {
  padding: 4px 10px;
  font-size: 13px;
  border: 1px solid #d0d0d0;
  border-radius: 4px;
  background: #f7fafc;
  cursor: pointer;
}
.task-add-btn:hover:not(:disabled),
.task-list-create-btn:hover:not(:disabled) {
  background: #edf2f7;
}
/* Task details panel */
.task-details {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 8px 8px 8px 32px;
  border-top: 1px solid #edf2f7;
  margin-top: 4px;
}
.task-detail-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
}
.task-detail-label {
  min-width: 90px;
  color: var(--color-text-subtle);
  font-size: 12px;
}
.task-detail-input {
  flex: 1;
  font-size: 12px;
  padding: 3px 6px;
  border: 1px solid #d0d0d0;
  border-radius: 4px;
  max-width: 200px;
}
.task-detail-clear-btn {
  font-size: 11px;
  color: var(--color-text-subtle);
  background: none;
  border: none;
  cursor: pointer;
  text-decoration: underline;
}
.task-detail-ack-btn {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 9px;
  color: var(--color-amber);
  background: var(--color-amber-light);
  border: 1px solid var(--color-amber);
  border-radius: 12px;
  cursor: pointer;
}
.task-detail-ack-btn:hover {
  color: var(--color-pearl);
  background: var(--color-amber);
}
.task-detail-obsolete-btn,
.task-detail-delete-btn {
  font-size: 12px;
  padding: 3px 10px;
  border: 1px solid #d0d0d0;
  border-radius: 4px;
  background: #f7fafc;
  cursor: pointer;
}
.task-detail-delete-btn {
  color: #e53e3e;
  border-color: #e53e3e;
}
.task-detail-delete-btn:hover {
  background: #fed7d7;
}
.capture-task-lists {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}
.capture-task-list {
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  padding: 6px 8px;
}
.capture-task-list-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 4px;
}
.capture-task-list-name {
  font-weight: 600;
  font-size: 12px;
}
.capture-task-list-tasks {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.capture-task-list-task {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  padding: 1px 0;
}
.capture-task-bullet {
  color: var(--color-text-subtle);
}
.task-list-create {
  margin-top: 4px;
}
/* Item Row Layout */
.item-row {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 24px;
  width: 100%;
  padding-right: 12px;
}

.message {
  --message-accent: var(--color-velvet);
  flex: 1 1 0;
  min-width: 0;
  background-color: var(--color-pearl);
  border-radius: 18px;
  padding: 14px 18px;
  box-shadow: 0 4px 15px rgba(34, 45, 82, 0.08);
  line-height: 1.5;
  border: 2px solid transparent;
  transition: all 0.3s ease;
  color: var(--color-onyx);
  cursor: default;
  position: relative;
}
.message.editing {
  border-color: var(--color-champagne);
  box-shadow: 0 8px 20px rgba(34, 45, 82, 0.12);
}
.message-main {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: stretch;
}
.message-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.message-top-right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  flex-shrink: 0;
}
.message-content {
  flex: 1 1 auto;
  min-width: 0;
  width: 100%;
}
.message-lane {
  position: relative;
  padding-left: 16px;
}
.message-lane::before {
  content: "";
  position: absolute;
  left: 0;
  top: 4px;
  bottom: 4px;
  width: 4px;
  border-radius: 999px;
  background: var(--message-accent, var(--color-velvet));
}
.message-side {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
  flex-wrap: wrap;
  flex: 1 1 auto;
}
.type-symbol {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
}
.type-symbol.editing {
  transform: scale(1.05);
}
.type-symbol svg {
  width: 100%;
  height: 100%;
  display: block;
}
.message-side .persons-container,
.message-side .context-stack {
  justify-content: flex-start;
  flex-wrap: wrap;
}

@media (max-width: 640px) {
  .message-top {
    flex-direction: column;
    align-items: stretch;
  }
  .message-top-right {
    width: 100%;
    justify-content: flex-end;
  }
  .message-side {
    width: 100%;
  }
}
.message:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(34, 45, 82, 0.12);
  border-color: var(--color-champagne);
  z-index: 5;
}
.message:focus-within {
  z-index: 5;
}
.message.menu-open {
  z-index: 20;
}
.message.status-purple {
  background-color: #f2e8fb;
  border-color: #d9c7ef;
  --message-accent: #b99bdc;
}
.message.status-red {
  background-color: #fde2e2;
  border-color: #f1b8b8;
  --message-accent: #e18686;
}
.message.status-yellow {
  background-color: #fff2c6;
  border-color: #efd89b;
  --message-accent: #d9b764;
}
.message-body {
  font-size: 15px;
  white-space: pre-wrap;
  color: var(--color-onyx);
}
.message-body-input {
  width: 100%;
  border-radius: 12px;
  border: 1px solid rgba(34, 45, 82, 0.2);
  background: #fff;
  padding: 8px 10px;
  font-size: 15px;
  line-height: 1.5;
  color: var(--color-onyx);
  resize: vertical;
}
.message-body-input:focus {
  outline: none;
  border-color: var(--color-velvet);
  box-shadow: 0 0 0 2px rgba(34, 45, 82, 0.12);
}
.message-meta {
  display: flex;
  justify-content: flex-end;
}
.time-state {
  color: #000;
  font-size: 12px;
  letter-spacing: 0.5px;
}
.message-score-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.score-state {
  font-size: 12px;
  color: var(--color-champagne);
  font-weight: 600;
  letter-spacing: 0.5px;
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
}
.score-state:hover,
.score-state.active {
  color: var(--color-velvet);
}
.score-state:focus {
  outline: none;
  text-decoration: underline;
}
.item-logs {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 12px;
  color: #000;
  padding-left: 10px;
  border-left: 2px solid rgba(34, 45, 82, 0.12);
}
.item-log-entry {
  display: flex;
  gap: 6px;
  align-items: baseline;
}
.item-log-time {
  font-weight: 600;
  letter-spacing: 0.2px;
  color: #000;
}
.item-log-body {
  color: #000;
}
.item-command-input {
  margin-top: 8px;
  width: 100%;
  border: none;
  border-bottom: 1px dotted rgba(34, 45, 82, 0.2);
  background: transparent;
  padding: 4px 0;
  font-size: 15px;
  color: var(--color-velvet);
  outline: none;
}
.item-command-input::placeholder {
  color: rgba(34, 45, 82, 0.35);
  font-style: italic;
}
.item-command-input:focus {
  border-bottom-color: var(--color-champagne);
}
.item-score-stack {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.item-score-panel {
  padding: 10px 12px;
  border-radius: 12px;
  background-color: rgba(34, 45, 82, 0.04);
  border: 1px solid rgba(34, 45, 82, 0.08);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.score-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-velvet);
}
.score-fields {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 8px 12px;
}
.score-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.score-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--color-velvet);
}
.score-select {
  border-radius: 8px;
  border: 1px solid rgba(34, 45, 82, 0.18);
  background-color: var(--color-pearl);
  padding: 4px 8px;
  font-size: 12px;
  color: var(--color-velvet);
  cursor: pointer;
}
.score-select:focus {
  outline: none;
  border-color: var(--color-champagne);
  box-shadow: 0 0 0 3px rgba(210, 182, 138, 0.2);
}
.score-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 12px;
  align-items: center;
}
.score-summary-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-champagne);
}
.score-summary-value {
  font-size: 12px;
  font-weight: 700;
  color: var(--color-onyx);
}
.time {
  font-size: 12px;
  color: var(--color-champagne);
  font-weight: 600;
  letter-spacing: 0.5px;
}
/* Markdown Styles */
.md-h1 {
  font-size: 1.4em;
  font-weight: 800;
  margin: 0.5em 0 0.3em;
  color: var(--color-velvet);
}
.md-h2 {
  font-size: 1.2em;
  font-weight: 700;
  margin: 0.4em 0 0.2em;
  color: var(--color-velvet);
}
.md-h3 {
  font-size: 1.1em;
  font-weight: 600;
  margin: 0.3em 0 0.1em;
  color: var(--color-velvet);
}
.md-code-line {
  font-family: "Menlo", "Monaco", "Courier New", monospace;
  font-size: 0.9em;
  background-color: #f3f4f6;
  color: #d14;
  padding: 0 4px;
  border-radius: 4px;
  display: block;
  white-space: pre;
}
.md-link {
  color: var(--color-velvet);
  text-decoration: underline;
  text-decoration-thickness: 2px;
}
.md-link:hover {
  color: var(--color-onyx);
}
.md-bullet {
  display: flex;
  gap: 8px;
  margin-left: 4px;
}
.md-bullet-point {
  font-weight: bold;
  color: var(--color-champagne);
}
.md-subtask {
  display: flex;
  gap: 8px;
  align-items: center;
  margin: 2px 0;
}
.md-subtask-next {
  background-color: rgba(80, 135, 255, 0.2);
  border-radius: 10px;
  display: inline-block;
  padding: 2px 6px;
}
.md-task-id {
  font-weight: 700;
  color: inherit;
  margin-right: 6px;
}
.md-checkbox {
  width: 16px;
  height: 16px;
  accent-color: var(--color-velvet);
  cursor: pointer;
}
.md-subtask-done {
  text-decoration: line-through;
  color: #888;
}
.context-stack {
  display: flex;
  flex-direction: row;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}

/* Composite Context/Project Pill */
.context-project-pill {
  position: relative; /* Anchor for the dropdown */
  display: inline-flex;
  align-items: stretch;
  border-radius: 16px;
  /* overflow: hidden;  <-- REMOVED to allow dropdown to show */
  overflow: visible;
  z-index: 2;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  background-color: #8fb6e1;
  color: white;
  border: 1px solid #8fb6e1;
  transition: all 0.2s;
  height: 26px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
  padding: 0; /* Reset padding, children handle it */
  gap: 0;
}

.context-project-pill:hover {
  transform: translateY(-1px);
}

.context-project-pill:hover .cpp-context,
.context-project-pill:hover .cpp-project,
.context-project-pill:hover .context-project-menu-toggle {
  opacity: 0.9;
}

.cpp-context {
  padding: 0 8px 0 10px;
  height: 100%;
  display: flex;
  align-items: center;
  color: white;
  text-transform: capitalize;
  /* Round left corners */
  border-top-left-radius: 15px;
  border-bottom-left-radius: 15px;
}

.cpp-project {
  /* Blend into the pill */
  background-color: transparent;
  color: white;
  padding: 0 8px;
  display: flex;
  align-items: center;
  height: 100%;
  margin: 0;
  border-radius: 0;
  /* Vertical separator line */
  border-left: 1px solid rgba(255, 255, 255, 0.3);
}

.context-tag {
  height: 26px;
  padding: 4px 12px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  color: var(--color-text-subtle);
  background: transparent;
  border: 1px solid #dcdcdc;
  text-transform: uppercase;
  transition: all 0.2s;
  white-space: nowrap;
}
.context-tag:hover {
  border-color: var(--color-champagne);
  color: var(--color-velvet);
}
.context-tag.active {
  background-color: var(--color-champagne);
  color: white;
  border-color: var(--color-champagne);
}

/* Context Project Dropdown Menu */
.context-project-menu-toggle {
  background: transparent;
  border: none;
  /* Vertical separator line */
  border-left: 1px solid rgba(255, 255, 255, 0.3);
  color: white;
  cursor: pointer;
  padding: 0 8px;
  font-size: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  transition: background 0.2s;
  /* Round right corners */
  border-top-right-radius: 15px;
  border-bottom-right-radius: 15px;
}

.context-project-menu-toggle:hover {
  background-color: rgba(0, 0, 0, 0.1);
}

.context-project-menu {
  position: absolute;
  top: 100%;
  left: 0;
  bottom: auto;
  margin-top: 4px;
  margin-bottom: 0;
  background-color: white;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  box-shadow:
    0 10px 15px -3px rgba(0, 0, 0, 0.1),
    0 4px 6px -2px rgba(0, 0, 0, 0.05);
  z-index: 1000;
  min-width: 180px;
  display: flex;
  flex-direction: column;
  max-height: min(240px, 60vh);
  overflow-y: auto;
  overflow-x: hidden;
  padding: 4px 0;
}

.context-project-menu.open-up {
  top: auto;
  bottom: 100%;
  margin-top: 0;
  margin-bottom: 4px;
}

.context-project-option {
  padding: 8px 12px;
  font-size: 13px;
  color: var(--color-velvet);
  background: none;
  border: none;
  text-align: left;
  cursor: pointer;
  transition: background 0.2s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.context-project-option.assigned {
  background-color: rgba(80, 135, 255, 0.12);
  color: var(--color-onyx);
}
.context-project-option.assigned::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  margin-right: 6px;
  vertical-align: -0.125em;
  background-color: var(--color-basil);
  -webkit-mask: var(--icon-check) center / contain no-repeat;
  mask: var(--icon-check) center / contain no-repeat;
}

.context-project-option:hover {
  background-color: #f3f4f6;
}

.context-project-option.create {
  color: var(--color-basil);
  font-weight: 600;
  border-top: 1px solid #f3f4f6;
  margin-top: 2px;
}

.context-project-option.create:hover {
  background-color: var(--color-basil-light);
}
.persons-container {
  display: flex;
  align-items: center;
  gap: 8px;
}
.person-stack {
  display: flex;
  flex-direction: row;
  gap: -8px;
  align-items: center;
}
.person-circle {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background-color: var(--color-velvet);
  color: var(--color-pearl);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  border: 2px solid var(--color-silk);
  transition: all 0.2s;
  text-transform: uppercase;
  position: relative;
}
.person-circle:hover {
  transform: scale(1.1);
  background-color: #bf4040;
}
.add-person-wrapper {
  position: relative;
  width: 24px;
  height: 24px;
  overflow: hidden;
  border-radius: 50%;
  background: var(--color-marble);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  border: 1px dashed #aaa;
}
.add-person-icon {
  font-size: 14px;
  color: #777;
  pointer-events: none;
}
.person-select {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
  font-size: 16px;
}

.person-block {
  display: flex;
  flex-direction: column;
  gap: 6px;
  background: var(--color-pearl);
  border: 1px solid rgba(34, 45, 82, 0.1);
  border-radius: 16px;
  padding: 16px;
  box-shadow: 0 12px 24px rgba(34, 45, 82, 0.08);
}

/* The person's own row sits flush inside the white block, so drop its
   card chrome to avoid a box-in-a-box. */
.person-block .management-row {
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
}
/* Right Sidebar */
.right-metadata {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 16px;
  padding-top: 8px;
  flex-wrap: wrap;
}
.capture-metadata {
  justify-content: flex-start;
  padding-top: 4px;
}
.capture-sticky {
  margin-left: auto;
}
/* Management Views */
.management-container {
  display: flex;
  flex-direction: column;
  gap: 16px;
  height: 100%;
  width: 100%;
  padding: 24px;
  overflow-y: auto;
  background-color: var(--color-silk);
}
.management-header {
  font-size: 24px;
  font-weight: 700;
  color: var(--color-velvet);
}
.management-card {
  background: var(--color-pearl);
  border: 1px solid rgba(34, 45, 82, 0.1);
  border-radius: 16px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow: 0 12px 24px rgba(34, 45, 82, 0.08);
}
.management-card-title {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-velvet);
}
.management-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.management-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  background: var(--color-pearl);
  border: 1px solid rgba(34, 45, 82, 0.1);
  border-radius: 12px;
  padding: 12px;
}
.management-input {
  flex: 1 1 180px;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid #dcdcdc;
  background: #ffffff;
  color: var(--color-velvet);
  font-size: 13px;
}
.management-contexts {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.management-contexts.empty {
  color: var(--color-text-subtle);
  font-size: 12px;
}
.management-context {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid rgba(34, 45, 82, 0.12);
  background: rgba(255, 255, 255, 0.7);
  font-size: 12px;
  color: var(--color-velvet);
}
.management-context-name {
  white-space: nowrap;
}
.management-actions {
  display: flex;
  gap: 8px;
}
.management-button {
  padding: 6px 12px;
  border-radius: 8px;
  border: 1px solid #d0d0d0;
  background: #ffffff;
  color: var(--color-velvet);
  font-size: 12px;
  cursor: pointer;
}
.management-button.primary {
  background: var(--color-velvet);
  border-color: var(--color-velvet);
  color: #ffffff;
}
.management-button.danger {
  background: var(--color-ruby);
  border-color: var(--color-ruby);
  color: #ffffff;
}
.management-button.pin-button {
  background: #ffffff;
  border-color: #d0d0d0;
  color: var(--color-velvet);
}
.management-button.pin-button.is-pinned {
  background: #fff4d1;
  border-color: #b48a3a;
  color: #5a3a14;
}
.management-empty {
  color: var(--color-text-subtle);
  font-size: 14px;
}
.kanban-scroll {
  padding: 12px 0;
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  overflow: auto;
}
.kanban-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
}
.kanban-toolbar-group {
  display: flex;
  align-items: center;
  gap: 8px;
}
.kanban-board-select {
  min-width: 220px;
}
.kanban-list-input {
  min-width: 180px;
}
.kanban-board {
  display: flex;
  flex-direction: column;
  min-height: 100%;
}
.kanban-columns {
  display: flex;
  align-items: stretch;
  gap: 12px;
  flex: 1;
  padding-bottom: 0;
}
.kanban-list-column {
  width: min(320px, 80vw);
  min-width: 260px;
  background: #f6f2eb;
  border: 1px solid rgba(34, 45, 82, 0.14);
  border-radius: 14px;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}
.kanban-list-header {
  padding: 10px;
  border-bottom: 1px solid rgba(34, 45, 82, 0.08);
}
.kanban-list-title-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.kanban-list-title {
  font-weight: 700;
  color: var(--color-velvet-dark);
}
.kanban-list-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.kanban-list-actions .management-button {
  padding: 4px 8px;
  font-size: 11px;
}
.kanban-list-rename {
  display: flex;
  gap: 6px;
  align-items: center;
}
.kanban-list-rename-input {
  min-width: 120px;
}
.kanban-single-lane {
  display: flex;
  flex-direction: column;
}
.kanban-add-card {
  margin: 8px 10px 0;
  border: 1px solid rgba(34, 45, 82, 0.14);
  border-radius: 10px;
  background: linear-gradient(180deg, #ffffff 0%, rgba(248, 250, 255, 0.96) 100%);
  color: var(--color-velvet);
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
  padding: 3px 0 4px;
  cursor: pointer;
  transition:
    border-color 0.16s ease,
    background-color 0.16s ease,
    box-shadow 0.16s ease,
    color 0.16s ease;
}
.kanban-add-card-top {
  margin-top: 8px;
  margin-bottom: 2px;
}
.kanban-add-card-bottom {
  margin-top: 2px;
  margin-bottom: 10px;
}
.kanban-add-card:hover:not(:disabled) {
  border-color: rgba(34, 45, 82, 0.3);
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 2px 6px rgba(34, 45, 82, 0.1);
  color: var(--color-velvet-dark);
}
.kanban-add-card:active:not(:disabled) {
  background: rgba(232, 228, 224, 0.55);
  box-shadow: inset 0 1px 2px rgba(34, 45, 82, 0.12);
}
.kanban-add-card:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.kanban-add-card:focus-visible {
  outline: 2px solid rgba(34, 45, 82, 0.35);
  outline-offset: 1px;
}
.kanban-list-cards {
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.kanban-list-tail {
  flex: 1;
  min-height: 0;
}
.kanban-drop-slot {
  min-height: 4px;
  border-radius: 8px;
  border: 1px dashed transparent;
  transition:
    border-color 0.12s ease,
    min-height 0.12s ease,
    background-color 0.12s ease,
    box-shadow 0.12s ease;
}
.kanban-drop-slot.is-dragging {
  min-height: 10px;
  border-color: rgba(34, 45, 82, 0.08);
}
.kanban-drop-slot.is-target {
  min-height: 56px;
  border-color: rgba(34, 45, 82, 0.22);
  background: rgba(34, 45, 82, 0.05);
  box-shadow: inset 0 0 0 1px rgba(34, 45, 82, 0.08);
}
.kanban-drop-slot.is-dragging:hover {
  border-color: rgba(34, 45, 82, 0.2);
}
.kanban-card {
  background: #ffffff;
  border: 1px solid rgba(34, 45, 82, 0.16);
  border-radius: 10px;
  padding: 10px;
  box-shadow: 0 6px 14px rgba(34, 45, 82, 0.12);
  cursor: default;
  transition: box-shadow 0.12s ease;
}
.kanban-card.is-draggable {
  cursor: grab;
}
.kanban-card.is-draggable:active {
  cursor: grabbing;
}
.kanban-card.is-dragging {
  opacity: 0.34;
  border: 1px dashed rgba(34, 45, 82, 0.35);
  background: rgba(34, 45, 82, 0.05);
  box-shadow: none;
}
.kanban-card.is-muted {
  opacity: 0.55;
  transition: opacity 120ms ease;
}
.kanban-card.is-muted:hover {
  opacity: 1;
}

/* Awoken: a snooze elapsed and is awaiting acknowledgement — ruby outline so
   it pops out of the board. Overrides any mute opacity (it needs attention). */
.kanban-card.is-awoken {
  opacity: 1;
  border-color: var(--color-ruby);
  box-shadow: 0 0 0 2px var(--color-ruby-light);
}

/* The lane holding an awoken card gets a faint ruby wash + a slow breathe so a
   board that needs attention is spottable before you read individual cards. */
.kanban-list-column.has-awoken-card {
  background: #fbeeec;
  border-color: rgba(180, 35, 24, 0.45);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.65),
    0 0 0 1px rgba(180, 35, 24, 0.1);
  animation: laneBreathe 4s ease-in-out infinite;
}
.kanban-list-column.has-awoken-card .kanban-list-header {
  border-bottom-color: rgba(180, 35, 24, 0.22);
}

.card-snooze-ack-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-left: 6px;
  padding: 1px 9px;
  font-size: 11px;
  font-weight: 600;
  color: var(--color-ruby);
  background: var(--color-ruby-light);
  border: 1px solid var(--color-ruby);
  border-radius: 12px;
  cursor: pointer;
  transition:
    color 0.14s ease,
    background-color 0.14s ease;
  /* modest halo loop to draw the eye without being noisy */
  animation: rubyPulse 2.2s ease-in-out infinite;
}
.card-snooze-ack-chip:hover {
  color: var(--color-pearl);
  background: var(--color-ruby);
}
/* gentle bell nudge near the end of each loop */
.card-snooze-ack-chip .icon {
  animation: bellNudge 2.2s ease-in-out infinite;
  transform-origin: 50% 10%;
}

@keyframes rubyPulse {
  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(180, 35, 24, 0);
  }
  50% {
    box-shadow: 0 0 0 4px rgba(180, 35, 24, 0.18);
  }
}
@keyframes bellNudge {
  0%,
  84%,
  100% {
    transform: rotate(0);
  }
  88% {
    transform: rotate(-9deg);
  }
  92% {
    transform: rotate(7deg);
  }
  96% {
    transform: rotate(-4deg);
  }
}
@keyframes laneBreathe {
  0%,
  100% {
    background: #fbeeec;
  }
  50% {
    background: #f9e4e1;
  }
}

@media (prefers-reduced-motion: reduce) {
  .card-snooze-ack-chip,
  .card-snooze-ack-chip .icon,
  .kanban-list-column.has-awoken-card {
    animation: none;
  }
}
.kanban-card-title {
  font-size: 13px;
  color: var(--color-velvet-dark);
  line-height: 1.35;
}
.kanban-card-meta {
  margin-top: 6px;
  font-size: 11px;
  color: #6b7280;
}
.kanban-card-actions {
  margin-top: 8px;
  display: flex;
  justify-content: flex-end;
}

/* Owner footer — rendered on every card so heights stay uniform.
   Owner name/glyph appears only when the card has an owner that should
   be shown for this board; otherwise the left side is an empty spacer.
   The #id always sits on the right. Distinct from .card-next-task-pill
   by position (full-width footer vs inline pill), size, and the leading
   kind glyph. */
.kanban-card.has-owner-footer {
  padding-bottom: 0;
}
.card-owner-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  width: calc(100% + 20px);
  margin: 8px -10px 0;
  padding: 5px 10px;
  border-top: 1px solid rgba(34, 45, 82, 0.1);
  border-radius: 0 0 9px 9px;
  line-height: 1.3;
  color: #6b7280;
}
.card-owner-footer-name {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: none;
  background: transparent;
  padding: 0;
  margin: 0;
  font: inherit;
  font-size: 11px;
  color: #6b7280;
  text-align: left;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  cursor: pointer;
}
.card-owner-footer-name.is-empty {
  cursor: default;
}
button.card-owner-footer-name:hover {
  color: var(--color-velvet-dark);
}
.card-owner-footer-id {
  font-size: 10.5px;
  font-family: "JetBrains Mono", Consolas, monospace;
  color: #6b7280;
  flex-shrink: 0;
}
.card-owner-glyph {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  font-size: 12px;
  line-height: 1;
  color: #6b7280;
  font-family: "Segoe UI Symbol", "Apple Symbols", "Symbola", sans-serif;
}

.virtual-list-lanes {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-top: 10px;
  flex: 1;
}
.virtual-lane {
  display: flex;
  flex-direction: column;
}
.virtual-lane-list {
  flex: 1;
}
.virtual-lane-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--color-velvet-dark);
  padding: 0 10px;
}
.virtual-lane-empty {
  margin: 0;
  padding: 6px 10px 0;
  font-size: 11px;
}
/* Card dormancy — paper background (Variant D) and inline age label
   (Variant G), gated to Cool or older. See
   planning/card-age-dormancy-plan-v2.html. */

/* Variant D — paper background per bucket. Loaded after 20-kanban.css so
   these rules win over the default white card background. */
.kanban-card.bucket-fresh {
  background: var(--age-paper-fresh);
}
.kanban-card.bucket-warm {
  background: var(--age-paper-warm);
}
.kanban-card.bucket-cool {
  background: var(--age-paper-cool);
}
.kanban-card.bucket-cold {
  background: var(--age-paper-cold);
  border-color: var(--age-border-aged);
}
.kanban-card.bucket-frozen {
  background: var(--age-paper-frozen);
  border-color: var(--age-border-aged);
  background-image: repeating-linear-gradient(45deg, var(--age-grain) 0 2px, transparent 2px 6px);
}

/* Variant G — inline age label in the same row as #id, comma-separated.
   The .card-owner-footer-id span carries both the label and the id text
   on the right side of the footer. */
.age-inline {
  font-family: "JetBrains Mono", Consolas, monospace;
}
.age-inline.bucket-cool {
  color: var(--age-text-cold);
}
.age-inline.bucket-cold {
  color: var(--age-text-cold);
}
.age-inline.bucket-frozen {
  color: var(--age-text-frozen);
  font-weight: 600;
}
/* Custom Multi-Select Dropdowns */
.multi-select-container {
  position: relative;
  display: inline-block;
  user-select: none;
}

.multi-select-trigger {
  padding: 6px 12px;
  border-radius: 8px;
  border: 1px solid #dcdcdc;
  background-color: var(--color-pearl);
  color: var(--color-velvet);
  font-size: 13px;
  cursor: pointer;
  transition: all 0.2s;
  min-width: 140px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}

.multi-select-trigger:hover,
.multi-select-trigger.active {
  border-color: var(--color-champagne);
  background-color: #fff;
}

.multi-select-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 6px;
  background-color: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
  z-index: 100;
  min-width: 220px;
  max-height: 300px;
  overflow-y: auto;
  padding: 6px 0;
  display: flex;
  flex-direction: column;
}

.multi-select-option {
  display: flex;
  align-items: center;
  padding: 8px 12px;
  cursor: pointer;
  font-size: 13px;
  color: var(--color-velvet);
  gap: 10px;
  transition: background 0.15s;
}

.multi-select-option:hover {
  background-color: #f3f4f6;
}

.multi-select-checkbox {
  accent-color: var(--color-velvet);
  width: 15px;
  height: 15px;
  cursor: pointer;
}

.ms-backdrop {
  position: fixed;
  inset: 0;
  z-index: 99;
  cursor: default;
}

.count-badge {
  background: var(--color-velvet);
  color: white;
  font-size: 10px;
  padding: 1px 5px;
  border-radius: 10px;
  margin-left: auto;
}
/* Shared styles for cross-entity reference chips and backlinks.
   Used by Page.Log (already styled separately under .log-ref-chip), and by
   View.Backlinks on the event modal + card editor. */

.backlinks-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.ref-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  border: 1px solid #d6d0c4;
  border-radius: 5px;
  padding: 1px 7px;
  background: #fbf9f3;
  color: var(--color-velvet-dark);
}

.ref-chip.log {
  background: #fff6db;
  border-color: #d9c47a;
}

.ref-chip.event {
  background: #f3f0ff;
  border-color: #b6acec;
}

.ref-chip.card {
  background: #d8eedb;
  border-color: #76b07c;
}

.ref-chip-glyph {
  font-size: 10.5px;
  color: var(--color-text-subtle);
}

.ref-chip-label {
  max-width: 240px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ref-chip-x {
  background: transparent;
  border: none;
  color: var(--color-text-subtle);
  cursor: pointer;
  font-size: 11px;
  padding: 0;
  line-height: 1;
}

.ref-chip-x:hover {
  color: var(--color-velvet-dark);
}

.ref-chip-add {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  color: var(--color-text-subtle);
  border: 1px dashed #cfc8b6;
  border-radius: 5px;
  padding: 1px 7px;
  cursor: pointer;
  background: transparent;
}

.ref-chip-add:hover {
  color: var(--color-velvet);
  border-color: var(--color-velvet);
}
/* SSE connection indicator */
.sse-indicator {
  position: fixed;
  bottom: 12px;
  right: 12px;
  z-index: 100;
}
.sse-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  cursor: default;
}
.sse-dot.connected {
  background: #4caf50;
}
.sse-dot.reconnecting {
  background: #ff9800;
  animation: sse-pulse 1.5s ease-in-out infinite;
}
.sse-dot.stale {
  background: #f44336;
}
.sse-tooltip {
  position: absolute;
  bottom: 16px;
  right: 0;
  white-space: nowrap;
  font-size: 12px;
  padding: 4px 8px;
  border-radius: 6px;
  background: var(--color-velvet);
  color: white;
  display: none;
}
.sse-indicator:hover .sse-tooltip {
  display: block;
}
@keyframes sse-pulse {
  0%,
  100% {
    opacity: 0.3;
  }
  50% {
    opacity: 1;
  }
}
.board-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 16px 16px 0;
  flex-shrink: 0;
}
.quick-search-group {
  position: relative;
}
.quick-search-input {
  min-width: 200px;
}
.quick-search-dropdown {
  position: absolute;
  top: 100%;
  right: 0;
  min-width: 320px;
  max-width: 480px;
  max-height: 350px;
  overflow-y: auto;
  background: var(--card-bg, #fff);
  border: 1px solid var(--border-color, #ccc);
  border-radius: 6px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
  z-index: 100;
  margin-top: 4px;
}
.quick-search-result {
  padding: 8px 12px;
  cursor: pointer;
  border-bottom: 1px solid var(--border-color, #eee);
}
.quick-search-result:last-child {
  border-bottom: none;
}
.quick-search-result:hover {
  background: var(--hover-bg, #f0f0f0);
}
.quick-search-result-title {
  display: block;
  font-weight: 500;
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 440px;
}
.quick-search-result-boards {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.quick-search-board-chip {
  display: inline-block;
  font-size: 11px;
  padding: 1px 6px;
  background: var(--chip-bg, #e0e0e0);
  border-radius: 3px;
  color: var(--chip-color, #555);
}
.quick-search-result-task {
  font-size: 12px;
  color: var(--muted-color, #666);
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 440px;
}
.quick-search-task-label {
  font-weight: 500;
  color: var(--muted-color, #888);
}
.quick-search-no-results {
  padding: 12px;
  color: var(--muted-color, #888);
  text-align: center;
  font-size: 13px;
}
/* ── Task Type Selector (in add row) ──────────────── */

.task-type-selector {
  display: flex;
  gap: 2px;
}

.task-type-pill {
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 10px;
  border: 1px solid #dcdcdc;
  background: var(--color-pearl);
  cursor: pointer;
  white-space: nowrap;
}

.task-type-pill.active {
  background: var(--color-velvet);
  color: white;
  border-color: var(--color-velvet);
}

/* ── Log task type ─────────────────────────────────── */

.task-item.task-log {
  background: #fbf9f3;
  border-left: 3px solid var(--color-champagne);
  padding-left: 8px;
}

.task-item.task-log:hover {
  background: #f5f1e6;
}

.task-item.task-log .task-item-main {
  align-items: flex-start;
}

.task-item.task-log .task-text {
  font-style: italic;
  color: #5a3a14;
  text-decoration: none;
  white-space: pre-wrap;
  cursor: text;
}

.task-log-marker {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 18px;
  color: var(--color-champagne);
  font-size: 16px;
  line-height: 1;
  user-select: none;
}

.task-log-text {
  flex: 1;
}

.task-log-date {
  font-size: 10.5px;
  color: var(--color-text-subtle);
  font-style: normal;
  margin-left: auto;
  flex-shrink: 0;
  padding-left: 8px;
  white-space: nowrap;
  align-self: center;
}

.task-status-badge.task-status-log {
  display: none;
}

/* Logs render with their own visual cue; suppress the small
   status badge to keep the row uncluttered. */
.task-item.task-log .task-deadline-badge,
.task-item.task-log .task-parallel-badge,
.task-item.task-log .task-estimate-badge {
  display: none;
}
/* Log timeline page */
.log-page {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  background-color: var(--color-silk);
  overflow: hidden;
}

.log-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  border-bottom: 1px solid var(--color-marble);
  background: var(--color-pearl);
  flex-wrap: wrap;
}

.log-nav-button {
  background: var(--color-pearl);
  border: 1px solid var(--color-marble);
  border-radius: 6px;
  padding: 4px 10px;
  cursor: pointer;
  font-size: 14px;
  color: var(--color-velvet);
}

.log-nav-button:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.log-date-picker {
  border: 1px solid var(--color-marble);
  border-radius: 6px;
  padding: 4px 8px;
  font-size: 14px;
}

.log-search-input {
  flex: 1;
  min-width: 180px;
  border: 1px solid var(--color-marble);
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 14px;
}

.log-error {
  padding: 8px 20px;
  background: var(--color-ruby-light);
  color: var(--color-ruby);
  font-size: 13px;
}

.log-empty {
  padding: 20px;
  color: var(--color-text-subtle);
  text-align: center;
}

.log-timeline {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 16px 20px 12px;
  overflow-y: auto;
}

.log-day-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.log-day-header {
  font-size: 12px;
  color: #6b7280;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--color-marble);
}

.log-day-empty {
  font-size: 13px;
  color: var(--color-text-subtle);
  font-style: italic;
}

.log-entry {
  display: flex;
  gap: 12px;
  padding: 8px 12px;
  background: var(--color-pearl);
  border: 1px solid var(--color-marble);
  border-radius: 8px;
  cursor: text;
  transition: background-color 1.5s ease;
}

.log-entry.empty {
  background: transparent;
  border-style: dashed;
}

.log-entry.editing {
  border-color: var(--color-velvet);
}

.log-entry.highlight {
  background: var(--color-basil-light);
  transition: background-color 0.2s ease;
}

.log-entry-time {
  color: var(--color-text-subtle);
  font-size: 12px;
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
  padding-top: 2px;
  min-width: 44px;
}

.log-entry-body {
  flex: 1;
  min-width: 0;
  font-size: 14px;
  color: var(--color-velvet);
  white-space: pre-wrap;
  word-wrap: break-word;
}

.log-entry-text > div {
  min-height: 1em;
}

.log-entry-placeholder {
  color: var(--color-text-subtle);
  font-style: italic;
}

.log-entry-textarea {
  flex: 1;
  border: none;
  background: transparent;
  font: inherit;
  color: var(--color-velvet);
  resize: vertical;
  outline: none;
  padding: 0;
  width: 100%;
}

.log-create-row {
  display: flex;
  justify-content: center;
  padding: 12px 0 8px;
}

.log-create-button {
  background: var(--color-velvet);
  color: var(--color-pearl);
  border: none;
  border-radius: 8px;
  padding: 10px 20px;
  font-size: 14px;
  cursor: pointer;
}

.log-create-button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.log-search-results {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 12px 20px;
  overflow-y: auto;
  gap: 8px;
}

.log-search-status {
  color: var(--color-text-subtle);
  font-size: 13px;
  margin: 0;
}

.log-search-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.log-search-hit {
  background: var(--color-pearl);
  border: 1px solid var(--color-marble);
  border-radius: 8px;
  padding: 10px 12px;
  cursor: pointer;
}

.log-search-hit:hover {
  border-color: var(--color-velvet);
}

.log-search-hit-date {
  display: block;
  font-size: 12px;
  color: var(--color-text-subtle);
  margin-bottom: 4px;
}

.log-search-hit-body {
  font-size: 14px;
  color: var(--color-velvet);
  white-space: pre-wrap;
  word-wrap: break-word;
}

/* ---- Per-entry meta row (owner chip + tag chips + add affordances) ---- */
.log-entry-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
  padding-top: 6px;
  border-top: 1px dashed rgba(34, 45, 82, 0.1);
}

.log-owner-chip-wrap {
  position: relative;
  display: inline-flex;
}

.log-owner-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11.5px;
  border: 1px solid var(--color-marble);
  border-radius: 999px;
  padding: 1px 8px;
  background: var(--color-pearl);
  cursor: pointer;
  color: var(--color-velvet-dark);
  font: inherit;
  font-size: 11.5px;
}

.log-owner-chip.person {
  background: #e0e7ff;
  border-color: #6366f1;
  color: #4338ca;
}

.log-owner-chip.project {
  background: #fde8d4;
  border-color: #c97f33;
  color: #8b4f17;
}

.log-owner-chip.missing {
  background: var(--color-ruby-light);
  border-color: var(--color-ruby);
  color: var(--color-ruby);
}

.log-owner-pick-menu {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 4px;
  background: var(--color-pearl);
  border: 1px solid #cfc8b6;
  border-radius: 6px;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.12);
  min-width: 200px;
  padding: 4px 0;
  z-index: 50;
}

.log-owner-pick-group {
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-subtle);
  padding: 6px 10px 2px;
}

.log-owner-pick-opt {
  padding: 4px 10px;
  font-size: 12.5px;
  cursor: pointer;
}

.log-owner-pick-opt:hover {
  background: #eef2fb;
}

/* ---- Tag chips and auto-suggest ---- */
.log-tag-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  border: 1px solid #b3c4dd;
  border-radius: 999px;
  padding: 1px 7px;
  background: #eef2fb;
  color: #2d4673;
}

.log-tag-chip-x {
  background: transparent;
  border: none;
  color: var(--color-text-subtle);
  cursor: pointer;
  font-size: 11px;
  padding: 0;
  line-height: 1;
}

.log-tag-suggest {
  position: relative;
  display: inline-block;
}

.log-tag-suggest-input {
  border: 1px dashed #cfc8b6;
  border-radius: 999px;
  padding: 1px 8px;
  font: inherit;
  font-size: 11px;
  outline: none;
  min-width: 80px;
  background: transparent;
  color: var(--color-velvet);
}

.log-tag-suggest-input:focus {
  border-style: solid;
  border-color: var(--color-velvet);
  background: var(--color-pearl);
}

.log-tag-suggest-menu {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 4px;
  background: var(--color-pearl);
  border: 1px solid #cfc8b6;
  border-radius: 6px;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.12);
  min-width: 160px;
  padding: 4px 0;
  z-index: 50;
}

.log-tag-suggest-opt {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 4px 10px;
  font-size: 12px;
  cursor: pointer;
}

.log-tag-suggest-opt:hover {
  background: #eef2fb;
}

.log-tag-suggest-opt.create {
  color: var(--color-basil);
  border-top: 1px solid var(--color-marble);
}

.log-tag-suggest-count {
  color: var(--color-text-subtle);
  font-size: 10.5px;
}

/* ---- Reference chips and picker modal ---- */
.log-ref-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  border: 1px solid #d6d0c4;
  border-radius: 5px;
  padding: 1px 7px;
  background: #fbf9f3;
  color: var(--color-velvet-dark);
}

.log-ref-chip.log {
  background: #fff6db;
  border-color: #d9c47a;
}

.log-ref-chip.event {
  background: #f3f0ff;
  border-color: #b6acec;
}

.log-ref-chip.card {
  background: #d8eedb;
  border-color: #76b07c;
}

.log-ref-chip-glyph {
  font-size: 10.5px;
  color: var(--color-text-subtle);
}

.log-ref-chip-label {
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.log-ref-chip-x {
  background: transparent;
  border: none;
  color: var(--color-text-subtle);
  cursor: pointer;
  font-size: 11px;
  padding: 0;
  line-height: 1;
}

.log-ref-chip-add {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  color: var(--color-text-subtle);
  border: 1px dashed #cfc8b6;
  border-radius: 5px;
  padding: 1px 7px;
  cursor: pointer;
  background: transparent;
}

.log-ref-picker-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(20, 20, 30, 0.55);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 8vh;
  z-index: 1000;
}

.log-ref-picker-card {
  background: #fdfdfa;
  border-radius: 12px;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.35);
  width: min(540px, 90vw);
  border: 1px solid #e3dccc;
  overflow: hidden;
}

.log-ref-picker-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 14px;
  border-bottom: 1px solid var(--color-marble);
  background: #fbf9f3;
}

.log-ref-picker-title {
  font-weight: 700;
  color: var(--color-velvet-dark);
}

.log-ref-picker-close {
  background: transparent;
  border: none;
  color: var(--color-text-subtle);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
}

.log-ref-picker-body {
  padding: 12px 14px;
}

.log-ref-picker-search {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid #cfc8b6;
  border-radius: 6px;
  padding: 6px 10px;
  font: inherit;
  background: #fbfaf6;
}

.log-ref-picker-kind-seg {
  display: inline-flex;
  border: 1px solid #cfc8b6;
  border-radius: 6px;
  overflow: hidden;
  background: #fbfaf6;
  margin: 10px 0 6px;
}

.log-ref-picker-seg {
  padding: 4px 12px;
  font-size: 12.5px;
  border-right: 1px solid #cfc8b6;
  color: var(--color-velvet-dark);
  cursor: pointer;
}

.log-ref-picker-seg:last-child {
  border-right: none;
}

.log-ref-picker-seg.active {
  background: var(--color-velvet);
  color: #fff;
  font-weight: 600;
}

.log-ref-picker-status {
  color: var(--color-text-subtle);
  font-size: 13px;
  margin: 8px 0 0;
}

.log-ref-picker-results {
  margin-top: 6px;
  max-height: 320px;
  overflow-y: auto;
  border: 1px solid var(--color-marble);
  border-radius: 6px;
  background: var(--color-pearl);
}

.log-ref-picker-hit {
  display: grid;
  grid-template-columns: 56px 1fr 90px;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  font-size: 12.5px;
  border-bottom: 1px solid #f4f1ea;
  cursor: pointer;
}

.log-ref-picker-hit:last-child {
  border-bottom: none;
}

.log-ref-picker-hit:hover {
  background: #eef2fb;
}

.log-ref-picker-kind {
  font-size: 10px;
  text-align: center;
  padding: 0 6px;
  border-radius: 999px;
  border: 1px solid #cfc8b6;
}

.log-ref-picker-kind.log {
  background: #fff6db;
  border-color: #d9c47a;
}

.log-ref-picker-kind.event {
  background: #f3f0ff;
  border-color: #b6acec;
}

.log-ref-picker-kind.card {
  background: #d8eedb;
  border-color: #76b07c;
}

.log-ref-picker-when {
  color: var(--color-text-subtle);
  font-size: 11px;
  text-align: right;
  font-variant-numeric: tabular-nums;
}
/* Save error modal — sits above every other modal so the user must
   address it before continuing. */
.save-error-backdrop {
  z-index: 100;
  background: rgba(180, 35, 24, 0.18);
}

.save-error-card {
  width: min(480px, 92vw);
  border-color: rgba(180, 35, 24, 0.35);
}

.save-error-card .modal-header h3 {
  color: var(--color-ruby);
  margin: 0;
  font-size: 16px;
}

.save-error-context {
  margin: 4px 0 0 0;
  font-size: 12.5px;
  color: var(--color-text-subtle);
}

.save-error-message {
  margin: 8px 0 0 0;
  font-size: 13.5px;
  color: var(--color-velvet);
  font-weight: 600;
}

.save-error-help {
  margin: 12px 0;
  font-size: 12.5px;
  color: var(--color-velvet);
  line-height: 1.45;
}
/* ============================================================================
 * Events tab — see planning/event-tab-plan.html
 *
 * Color tokens come from 00-tokens.css. Layout matches the rest of the app
 * (single-column pane above the bottom TabBar).
 * ============================================================================ */

.events-page {
  flex: 1;
  display: flex;
  flex-direction: column;
  background-color: var(--color-silk);
  overflow-y: auto;
  padding: 16px 22px 12px;
  gap: 12px;
}

.events-error {
  background: var(--color-ruby-light);
  border-left: 4px solid var(--color-ruby);
  color: var(--color-ruby);
  padding: 8px 12px;
  border-radius: 4px;
  font-size: 13px;
}

.events-toast {
  position: fixed;
  bottom: 60px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-velvet-dark);
  color: #fff;
  padding: 8px 14px;
  border-radius: 6px;
  font-size: 13px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
  z-index: 50;
}

/* ---- Composer ---------------------------------------------------------- */

.events-composer {
  background: #fff;
  border: 1px solid #d6d0c4;
  border-radius: 8px;
  padding: 12px 14px;
}

.events-composer-row {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 8px;
  position: relative;
}

.events-composer-input {
  flex: 1;
  min-width: 220px;
  border: 1px solid #cfc8b6;
  border-radius: 5px;
  padding: 6px 9px;
  background: #fbfaf6;
  font: inherit;
}

.events-composer-date {
  border: 1px solid #cfc8b6;
  border-radius: 5px;
  padding: 6px 9px;
  background: #fbfaf6;
  font-family: "JetBrains Mono", Consolas, monospace;
  font-size: 12.5px;
}

.events-composer-textarea {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid #cfc8b6;
  border-radius: 5px;
  padding: 8px 10px;
  min-height: 56px;
  background: #fbfaf6;
  font: inherit;
  resize: vertical;
}

.events-composer-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
  margin-top: 8px;
  flex-wrap: wrap;
}

.events-composer-status {
  display: flex;
  align-items: center;
  gap: 8px;
}

.events-composer-buttons {
  display: flex;
  gap: 6px;
}

/* ---- Kind segmented control -------------------------------------------- */

.events-kind-seg {
  display: inline-flex;
  border: 1px solid #cfc8b6;
  border-radius: 6px;
  overflow: hidden;
  background: #fbfaf6;
}

.events-seg {
  padding: 5px 11px;
  font-size: 12.5px;
  border-right: 1px solid #cfc8b6;
  color: var(--color-velvet-dark);
  cursor: pointer;
  user-select: none;
}

.events-seg:last-child {
  border-right: none;
}

.events-seg.active {
  background: var(--color-velvet);
  color: #fff;
  font-weight: 600;
}

/* ---- Owner picker ------------------------------------------------------ */

.events-owner-pick-wrap {
  position: relative;
  display: inline-block;
}

.events-owner-pick {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid #cfc8b6;
  border-radius: 5px;
  padding: 4px 9px;
  background: #fbfaf6;
  font-size: 12.5px;
  cursor: pointer;
  font: inherit;
  color: inherit;
}

.events-owner-pick:hover {
  background: #f4f1ea;
  border-color: var(--color-velvet);
}

.events-owner-caret {
  color: var(--color-text-subtle);
  font-size: 10px;
  margin-left: 2px;
}

.events-missing-hint {
  color: var(--color-ruby);
  font-size: 12px;
}

.events-owner-label {
  color: var(--color-text-subtle);
  font-size: 11.5px;
}

.events-owner-chip {
  padding: 1px 8px;
  border-radius: 999px;
  font-size: 11.5px;
  border: 1px solid;
}

.events-owner-chip.project {
  background: #e0e7ff;
  border-color: #6366f1;
  color: #4338ca;
}

.events-owner-chip.person {
  background: #fef3c7;
  border-color: var(--color-champagne);
  color: #92400e;
}

.events-owner-chip.missing {
  background: var(--color-ruby-light);
  border-color: var(--color-ruby);
  color: var(--color-ruby);
  font-weight: 700;
}

.events-owner-menu {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  background: #fff;
  border: 1px solid #d6d0c4;
  border-radius: 6px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.1);
  padding: 8px 0;
  min-width: 200px;
  z-index: 60;
}

.events-owner-group {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-subtle);
  padding: 6px 12px 2px;
}

.events-owner-opt {
  padding: 5px 12px;
  cursor: pointer;
  font-size: 13px;
}

.events-owner-opt:hover {
  background: var(--color-marble);
}

/* ---- Recurrence row ---------------------------------------------------- */

.events-recurrence-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  font-size: 12.5px;
  color: var(--color-velvet-dark);
}

.events-recurrence-interval {
  width: 64px;
  border: 1px solid #cfc8b6;
  border-radius: 5px;
  padding: 4px 6px;
  background: #fbfaf6;
}

.events-recurrence-select {
  border: 1px solid #cfc8b6;
  border-radius: 5px;
  padding: 4px 6px;
  background: #fbfaf6;
  font: inherit;
}

/* ---- N-leg transaction form ------------------------------------------- */

.events-tx-form {
  background: #fbfaf6;
  border: 1px solid #ece8de;
  border-radius: 6px;
  padding: 10px 12px;
  margin-bottom: 8px;
}

.events-tx-legs {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.events-tx-leg {
  display: grid;
  grid-template-columns: 1fr 130px 30px;
  gap: 8px;
  align-items: center;
}

.events-leg-acct,
.events-leg-amt {
  border: 1px solid #cfc8b6;
  border-radius: 5px;
  padding: 5px 8px;
  background: #fff;
  font: inherit;
  width: 100%;
  box-sizing: border-box;
}

.events-leg-acct {
  font-family: "JetBrains Mono", Consolas, monospace;
  font-size: 12.5px;
}

.events-leg-amt {
  font-family: "JetBrains Mono", Consolas, monospace;
  font-size: 12.5px;
  text-align: right;
}

.events-leg-acct.missing,
.events-leg-amt.missing {
  border-color: #b48a3a;
  background: #fffaf0;
}

.events-leg-x {
  background: transparent;
  border: none;
  color: var(--color-text-subtle);
  font-size: 16px;
  cursor: pointer;
  line-height: 1;
}

.events-tx-sum {
  display: flex;
  justify-content: space-between;
  font-family: "JetBrains Mono", Consolas, monospace;
  font-size: 12.5px;
  border-top: 1px dashed #cfc8b6;
  padding-top: 6px;
  margin-top: 8px;
}

.events-tx-sum.ok {
  color: var(--color-basil);
}

.events-tx-sum.bad {
  color: var(--color-ruby);
  font-weight: 700;
}

/* Account autocomplete */
.events-ac-host {
  position: relative;
}

.events-ac-menu {
  position: absolute;
  top: calc(100% + 2px);
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid #d6d0c4;
  border-radius: 6px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.1);
  z-index: 60;
  max-height: 180px;
  overflow-y: auto;
}

.events-ac-opt {
  padding: 5px 10px;
  font-family: "JetBrains Mono", Consolas, monospace;
  font-size: 12.5px;
  cursor: pointer;
}

.events-ac-opt:hover {
  background: var(--color-marble);
}

/* ---- Filter bar -------------------------------------------------------- */

.events-filter-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
}

.events-filter-dd {
  position: relative;
  display: inline-block;
}

.events-filter-dd-btn {
  border: 1px solid #cfc8b6;
  background: #fbfaf6;
  border-radius: 5px;
  padding: 5px 10px;
  cursor: pointer;
  font: inherit;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.events-filter-count {
  background: var(--color-velvet);
  color: #fff;
  border-radius: 999px;
  padding: 0 7px;
  font-size: 11px;
  font-weight: 700;
}

.events-filter-menu {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  background: #fff;
  border: 1px solid #d6d0c4;
  border-radius: 6px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.1);
  padding: 8px 0;
  min-width: 220px;
  z-index: 50;
}

.events-filter-group {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-subtle);
  padding: 6px 12px 2px;
}

.events-filter-check {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 12px;
  font-size: 13px;
  cursor: pointer;
}

.events-filter-check:hover {
  background: var(--color-marble);
}

.events-filter-sep {
  border-top: 1px solid #ece8de;
  margin: 6px 0;
}

.events-filter-info {
  color: var(--color-text-subtle);
  font-size: 12px;
}

/* ---- Timeline lane dividers ------------------------------------------- */

.events-lanes {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.events-lane-divider {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 14px 0 4px;
  font-size: 11.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-velvet);
}

.events-lane-divider.awaiting {
  color: var(--color-ruby);
}

.events-lane-divider.past {
  color: var(--color-text-subtle);
}

.events-lane-line {
  flex: 1;
  height: 1px;
  background: currentColor;
  opacity: 0.25;
}

.events-empty-band {
  color: var(--color-text-subtle);
  font-size: 12.5px;
  margin: 0 0 0 4px;
}

/* ---- Event row -------------------------------------------------------- */

.events-event {
  background: #ffffff;
  border: 1px solid #d6d0c4;
  border-radius: 8px;
  padding: 10px 12px;
  display: grid;
  grid-template-columns: 110px 1fr auto;
  gap: 12px;
  align-items: start;
  position: relative;
}

.events-event.kind-tx {
  grid-template-columns: 110px 1fr 200px auto;
  background: #f3f0ff;
  border-color: #c7d2fe;
}

.events-when {
  font-family: "JetBrains Mono", Consolas, monospace;
  font-size: 12px;
  color: var(--color-velvet-dark);
  line-height: 1.35;
}

.events-when-day {
  font-size: 13px;
  font-weight: 700;
}

.events-when-sub {
  color: var(--color-text-subtle);
  font-size: 11px;
}

.events-body {
  font-size: 13.5px;
}

.events-title {
  font-weight: 600;
  margin-bottom: 2px;
}

.events-desc {
  color: #4b5563;
  font-size: 13px;
  white-space: pre-wrap;
}

.events-meta {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 6px;
  align-items: center;
}

.events-actions {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: stretch;
}

.events-event.upcoming-soon {
  border: 1px solid var(--color-champagne);
  background: #fff8e1;
  box-shadow:
    0 1px 0 rgba(210, 182, 138, 0.5),
    0 4px 12px rgba(210, 182, 138, 0.2);
}

.events-event.awaiting-ack {
  border: 1.5px solid var(--color-ruby);
  background: #fff1ee;
  box-shadow: 0 0 0 3px rgba(180, 35, 24, 0.08);
}

.events-event.awaiting-ack::before {
  content: "";
  position: absolute;
  left: -1.5px;
  top: -1.5px;
  bottom: -1.5px;
  width: 4px;
  background: var(--color-ruby);
  border-radius: 8px 0 0 8px;
}

.events-event.past {
  background: #f4f1ea;
  color: var(--color-text-subtle);
  border-color: #d8d2c2;
}

.events-event.past.kind-tx {
  background: #ecebff;
}

.events-event.past .events-when,
.events-event.past .events-title {
  color: var(--color-text-subtle);
}

.events-event.draft {
  background: repeating-linear-gradient(135deg, #fffaf0 0 10px, #fff4d8 10px 20px);
  border: 1.5px dashed #b48a3a;
}

/* Pills ------------------------------------------------------------------ */

.events-pill {
  font-size: 11px;
  padding: 1px 7px;
  border-radius: 999px;
  background: #ece8de;
  color: var(--color-velvet-dark);
  border: 1px solid #d6d0c4;
}

.events-pill.recurring {
  background: var(--color-basil-light);
  border-color: var(--color-basil);
  color: var(--color-basil);
}

.events-pill.linked {
  background: #e0e7ff;
  border-color: #6366f1;
  color: #4338ca;
}

.events-pill.overdue {
  background: var(--color-ruby-light);
  border-color: var(--color-ruby);
  color: var(--color-ruby);
  font-weight: 700;
}

.events-pill.due-now {
  background: #fff8e1;
  border-color: var(--color-champagne);
  color: #92400e;
  font-weight: 700;
}

.events-pill.upcoming {
  background: #dcfce7;
  border-color: #16a34a;
  color: #166534;
}

.events-pill.kind-tx {
  background: #e0e7ff;
  border-color: #6366f1;
  color: #4338ca;
}

.events-pill.incomplete {
  background: #fff4d1;
  border-color: #b48a3a;
  color: #8a6608;
  font-weight: 700;
}

.events-pill.posted {
  background: var(--color-basil-light);
  border-color: var(--color-basil);
  color: var(--color-basil);
}

.events-pill.owner-proj {
  background: #e0e7ff;
  border-color: #6366f1;
  color: #4338ca;
}

.events-pill.owner-pers {
  background: #fef3c7;
  border-color: var(--color-champagne);
  color: #92400e;
}

/* Ledger panel inside transaction rows */
.events-ledger {
  font-family: "JetBrains Mono", Consolas, monospace;
  font-size: 12px;
  line-height: 1.4;
}

.events-ledger-leg {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 1px 0;
}

.events-ledger-acct {
  color: #4338ca;
}

.events-ledger-acct.placeholder {
  color: #b48a3a;
  font-style: italic;
}

.events-ledger-amt.debit {
  color: var(--color-ruby);
}

.events-ledger-amt.credit {
  color: var(--color-basil);
}

.events-ledger-sum {
  display: flex;
  justify-content: space-between;
  border-top: 1px dashed #c7d2fe;
  padding-top: 3px;
  margin-top: 3px;
  font-weight: 700;
}

.events-ledger-sum.bad {
  color: var(--color-ruby);
}

/* ---- Buttons ----------------------------------------------------------- */

.events-btn {
  border: 1px solid #cfc8b6;
  background: #fbfaf6;
  border-radius: 5px;
  padding: 4px 10px;
  font-size: 12.5px;
  cursor: pointer;
  font: inherit;
}

.events-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.events-btn.primary {
  background: var(--color-velvet);
  color: #fff;
  border-color: var(--color-velvet);
}

.events-btn.ghost {
  background: transparent;
  border-color: transparent;
  color: var(--color-velvet);
}

.events-btn.danger {
  background: var(--color-ruby-light);
  border-color: var(--color-ruby);
  color: var(--color-ruby);
}

.events-btn.basil {
  background: var(--color-basil-light);
  border-color: var(--color-basil);
  color: var(--color-basil);
}

.events-btn.small {
  padding: 2px 7px;
  font-size: 11.5px;
}

.events-btn.active {
  background: var(--color-basil);
  color: #fff;
  border-color: var(--color-basil);
}

/* ---- Load more --------------------------------------------------------- */

.events-load-more {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 12px 0;
  padding: 10px 14px;
  background: #f4f1ea;
  border: 1px dashed #d6d0c4;
  border-radius: 6px;
  font-size: 12.5px;
}

.events-load-more-info {
  color: var(--color-text-subtle);
}

/* ---- TabBar badge for awaiting count ---------------------------------- */

.tab .tab-badge {
  display: inline-block;
  margin-left: 6px;
  background: var(--color-ruby);
  color: #fff;
  border-radius: 999px;
  padding: 1px 6px;
  font-size: 10.5px;
  font-weight: 700;
}
/* ============================================================================
 * Event modal — unified Create + Edit. See planning/event-modal-plan.html.
 * Builds on the base .modal-backdrop / .modal-card primitives in 06-modals.css.
 * ============================================================================ */

.event-modal-backdrop {
  /* Inherits .modal-backdrop centring + dim layer. */
  z-index: 60;
}

.event-modal-card {
  width: min(720px, 92vw);
  height: min(820px, 92vh);
  display: flex;
  flex-direction: column;
  padding: 0; /* sections supply their own padding */
}

.event-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid #ece8de;
  background: #fbf9f3;
}

.event-modal-id {
  font-family: "JetBrains Mono", Consolas, monospace;
  font-size: 11.5px;
  color: var(--color-text-subtle);
  margin-left: 8px;
}

.event-modal-body {
  padding: 14px 16px;
  overflow-y: auto;
  flex: 1;
}

.event-modal-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  border-top: 1px solid #ece8de;
  background: #fbf9f3;
  gap: 8px;
}

.event-modal-footer-right {
  display: flex;
  gap: 6px;
  margin-left: auto;
}

.event-modal-error {
  color: var(--color-ruby);
  font-size: 12px;
}

/* ---- Field row ---- */

.event-modal-field {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 8px 12px;
  margin: 8px 0;
  align-items: start;
}

.event-modal-field-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-subtle);
  padding-top: 6px;
}

.event-modal-input,
.event-modal-textarea {
  border: 1px solid #cfc8b6;
  border-radius: 5px;
  padding: 6px 9px;
  background: #fbfaf6;
  font: inherit;
  width: 100%;
  box-sizing: border-box;
}

.event-modal-textarea {
  min-height: 80px;
  resize: vertical;
}

/* ---- Kind segmented control ---- */

.event-modal-kind-seg {
  display: inline-flex;
  border: 1px solid #cfc8b6;
  border-radius: 6px;
  overflow: hidden;
  background: #fbfaf6;
}

.event-modal-seg {
  padding: 5px 11px;
  font-size: 12.5px;
  border-right: 1px solid #cfc8b6;
  color: var(--color-velvet-dark);
  cursor: pointer;
  user-select: none;
}

.event-modal-seg:last-child {
  border-right: none;
}

.event-modal-seg.active {
  background: var(--color-velvet);
  color: #fff;
  font-weight: 600;
}

/* ---- Owner picker ---- */

.event-modal-owner-pick-wrap {
  position: relative;
  display: inline-block;
}

.event-modal-owner-pick {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid #cfc8b6;
  border-radius: 5px;
  padding: 4px 9px;
  background: #fbfaf6;
  font: inherit;
  color: inherit;
  font-size: 12.5px;
  cursor: pointer;
}

.event-modal-owner-pick:hover {
  background: #f4f1ea;
  border-color: var(--color-velvet);
}

.event-modal-owner-chip {
  padding: 1px 8px;
  border-radius: 999px;
  font-size: 11.5px;
  border: 1px solid;
}

.event-modal-owner-chip.project {
  background: #e0e7ff;
  border-color: #6366f1;
  color: #4338ca;
}

.event-modal-owner-chip.person {
  background: #fef3c7;
  border-color: var(--color-champagne);
  color: #92400e;
}

.event-modal-owner-chip.missing {
  background: var(--color-ruby-light);
  border-color: var(--color-ruby);
  color: var(--color-ruby);
  font-weight: 700;
}

.event-modal-owner-caret {
  color: var(--color-text-subtle);
  font-size: 10px;
}

.event-modal-owner-menu {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  background: #fff;
  border: 1px solid #d6d0c4;
  border-radius: 6px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.15);
  padding: 8px 0;
  min-width: 220px;
  max-height: 320px;
  overflow-y: auto;
  z-index: 70;
}

.event-modal-owner-group {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-subtle);
  padding: 6px 12px 2px;
}

.event-modal-owner-opt {
  padding: 5px 12px;
  cursor: pointer;
  font-size: 13px;
}

.event-modal-owner-opt:hover {
  background: var(--color-marble);
}

/* ---- Transaction legs ---- */

.event-modal-tx-legs {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 6px;
}

.event-modal-tx-leg {
  display: grid;
  grid-template-columns: 1fr 130px 30px;
  gap: 8px;
  align-items: center;
}

.event-modal-leg-acct,
.event-modal-leg-amt {
  border: 1px solid #cfc8b6;
  border-radius: 5px;
  padding: 5px 8px;
  background: #fff;
  font: inherit;
  width: 100%;
  box-sizing: border-box;
}

.event-modal-leg-acct {
  font-family: "JetBrains Mono", Consolas, monospace;
  font-size: 12.5px;
}

.event-modal-leg-amt {
  font-family: "JetBrains Mono", Consolas, monospace;
  font-size: 12.5px;
  text-align: right;
}

.event-modal-leg-acct.missing,
.event-modal-leg-amt.missing {
  border-color: #b48a3a;
  background: #fffaf0;
}

.event-modal-leg-x {
  background: transparent;
  border: none;
  color: var(--color-text-subtle);
  font-size: 16px;
  cursor: pointer;
  line-height: 1;
}

.event-modal-tx-sum {
  display: flex;
  justify-content: space-between;
  font-family: "JetBrains Mono", Consolas, monospace;
  font-size: 12.5px;
  border-top: 1px dashed #cfc8b6;
  padding-top: 6px;
  margin-top: 8px;
}

.event-modal-tx-sum.ok {
  color: var(--color-basil);
}

.event-modal-tx-sum.bad {
  color: var(--color-ruby);
  font-weight: 700;
}

/* ---- Account autocomplete ---- */

.event-modal-ac-host {
  position: relative;
}

.event-modal-ac-menu {
  position: absolute;
  top: calc(100% + 2px);
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid #d6d0c4;
  border-radius: 6px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.15);
  max-height: 180px;
  overflow-y: auto;
  z-index: 70;
}

.event-modal-ac-opt {
  padding: 5px 10px;
  font-family: "JetBrains Mono", Consolas, monospace;
  font-size: 12.5px;
  cursor: pointer;
}

.event-modal-ac-opt:hover {
  background: var(--color-marble);
}

/* ---- Recurrence editor ---- */

.event-modal-recurrence {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  font-size: 12.5px;
  color: var(--color-velvet-dark);
}

.event-modal-recurrence-interval {
  width: 60px;
  border: 1px solid #cfc8b6;
  border-radius: 5px;
  padding: 4px 6px;
  background: #fbfaf6;
  font: inherit;
}

.event-modal-recurrence-select {
  border: 1px solid #cfc8b6;
  border-radius: 5px;
  padding: 4px 6px;
  background: #fbfaf6;
  font: inherit;
}

.event-modal-anchor {
  width: auto !important;
  display: inline-block !important;
}

.event-modal-recurrence-hint {
  color: var(--color-text-subtle);
  font-size: 11.5px;
}

/* ---- State badge ---- */

.event-modal-state-pill {
  font-size: 11px;
  padding: 1px 7px;
  border-radius: 999px;
  background: #ece8de;
  color: var(--color-velvet-dark);
  border: 1px solid #d6d0c4;
  display: inline-block;
}

.event-modal-state-pill.future {
  background: #dcfce7;
  border-color: #16a34a;
  color: #166534;
}

.event-modal-state-pill.awaiting {
  background: var(--color-ruby-light);
  border-color: var(--color-ruby);
  color: var(--color-ruby);
  font-weight: 700;
}

.event-modal-state-pill.past {
  background: #f4f1ea;
  color: var(--color-text-subtle);
}

.event-modal-state-pill.draft {
  background: #fff4d1;
  border-color: #b48a3a;
  color: #8a6608;
  font-weight: 700;
}

/* ---- Buttons (modal-scoped) ---- */

.event-modal-btn {
  border: 1px solid #cfc8b6;
  background: #fbfaf6;
  border-radius: 5px;
  padding: 5px 12px;
  font-size: 13px;
  cursor: pointer;
  font: inherit;
}

.event-modal-btn.primary {
  background: var(--color-velvet);
  color: #fff;
  border-color: var(--color-velvet);
}

.event-modal-btn.ghost {
  background: transparent;
  border-color: transparent;
  color: var(--color-velvet);
}

.event-modal-btn.danger {
  background: var(--color-ruby-light);
  border-color: var(--color-ruby);
  color: var(--color-ruby);
}

.event-modal-btn.small {
  padding: 3px 8px;
  font-size: 11.5px;
}

.event-modal-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ---- References row inside the event modal ---- */

.event-modal-refs-wrap {
  position: relative;
}

.event-modal-refs-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}

/* ---- Toolbar on the Events tab (replaces the old composer) ---- */

.events-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 4px;
}
/* Task Editor — modal popover for a single task group */

.task-editor-backdrop {
  align-items: flex-start;
  padding-top: 6vh;
}

.task-editor-card {
  width: min(560px, 94vw);
  max-height: 84vh;
  overflow-y: auto;
  padding: 14px 16px;
}

.task-editor-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid #ece8de;
  padding-bottom: 8px;
  margin-bottom: 10px;
}

/* Group-cycling navigator in the header: ‹ name count › */
.task-editor-group-nav {
  display: flex;
  align-items: center;
  gap: 8px;
}

.task-editor-group-arrow {
  width: 24px;
  height: 24px;
  border-radius: 5px;
  border: 1px solid #d6d0c4;
  background: #fbfaf6;
  color: var(--color-velvet-dark);
  font-size: 14px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.task-editor-group-arrow:hover {
  border-color: var(--color-velvet);
}

.task-editor-group-arrow:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

.task-editor-group-arrow:disabled:hover {
  border-color: #d6d0c4;
}

.task-editor-group-count {
  font-size: 10.5px;
  color: var(--color-text-subtle);
  background: #ece8de;
  border-radius: 8px;
  padding: 1px 7px;
  font-variant-numeric: tabular-nums;
}

/* Quick add / Edit / Add mode selector */
.task-editor-mode-seg {
  display: inline-flex;
  border: 1px solid #cfc8b6;
  border-radius: 6px;
  overflow: hidden;
  background: #fbfaf6;
  margin-bottom: 10px;
}

.task-editor-mode-btn {
  padding: 5px 14px;
  font-size: 12.5px;
  border: none;
  border-right: 1px solid #cfc8b6;
  background: transparent;
  color: var(--color-velvet-dark);
  cursor: pointer;
  user-select: none;
}

.task-editor-mode-btn:last-child {
  border-right: none;
}

.task-editor-mode-btn.active {
  background: var(--color-velvet);
  color: #fff;
  font-weight: 600;
}

.task-editor-scope {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-subtle);
}

.task-editor-scope b {
  color: var(--color-velvet-dark);
  text-transform: none;
  letter-spacing: 0;
  font-size: 13px;
}

.task-editor-close {
  width: 22px;
  height: 22px;
  border-radius: 4px;
  border: 1px solid #d6d0c4;
  background: white;
  color: #6b7280;
  font-size: 14px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.task-editor-section,
.task-editor-section-label {
  margin: 10px 0 4px;
}

.task-editor-section-label {
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-subtle);
}

.task-editor-section-label .small {
  text-transform: none;
  letter-spacing: 0;
}

/* Task list inside the editor */
.editor-task-list {
  border: 1px solid #ece8de;
  border-radius: 6px;
  background: #fbfaf6;
  padding: 4px;
  margin: 4px 0 12px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.editor-task-row {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 8px;
  border-radius: 4px;
  background: white;
  border: 1px solid #ece8de;
  font-size: 12.5px;
}

.editor-task-row.is-current {
  border-color: #d6deef;
  background: #eef2fb;
}

/* In Edit/Add the rows are clickable to select. */
.editor-task-list.is-selectable .editor-task-row {
  cursor: pointer;
}

/* Edit mode: the selected task whose controls are live. */
.editor-task-row.is-selected {
  border-color: var(--color-context-border);
  background: var(--color-context-light);
  box-shadow: inset 3px 0 0 var(--color-context);
}

/* Add mode: the anchor that + Before / + After insert around. */
.editor-task-row.is-anchor {
  border-color: var(--color-basil);
  background: var(--color-basil-light);
  box-shadow: inset 3px 0 0 var(--color-basil);
}

.editor-task-row.is-log {
  background: #fbf9f3;
  border-left: 3px solid var(--color-champagne);
}

/* A task ticked done in this session stays on screen, struck through, so it
   can still be un-ticked. */
.editor-task-row.is-done {
  opacity: 0.6;
}

.editor-task-row.is-done .editor-task-text {
  text-decoration: line-through;
}

.editor-task-row.is-drop-hint {
  border-style: dashed;
  border-color: var(--color-velvet);
  background: #f4f1e9;
}

.editor-task-row.is-dragging {
  opacity: 0.4;
  border: 1px dashed rgba(34, 45, 82, 0.35);
  background: rgba(34, 45, 82, 0.05);
}

.editor-task-handle {
  color: #b8b0a0;
  cursor: grab;
  user-select: none;
  font-size: 13px;
  line-height: 1;
  padding: 0 2px;
}

.editor-task-row.is-dragging .editor-task-handle {
  cursor: grabbing;
}

.editor-task-checkbox {
  width: 13px;
  height: 13px;
  flex-shrink: 0;
}

.editor-task-marker {
  color: var(--color-champagne);
  font-weight: 700;
  flex-shrink: 0;
  width: 13px;
  text-align: center;
  line-height: 1;
}

.editor-task-text {
  flex: 1;
  color: var(--color-velvet-dark);
}

.editor-task-text.is-log {
  font-style: italic;
  color: #5a5044;
}

.editor-task-pill {
  font-size: 9.5px;
  padding: 1px 6px;
  border-radius: 8px;
  background: #e2e8f0;
  color: #4a5568;
  flex-shrink: 0;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.editor-task-pill.is-next {
  background: var(--color-basil-light);
  color: var(--color-basil);
}

.editor-task-pill.is-waiting {
  background: #f3e6fb;
  color: #6b25a0;
}

.editor-task-pill.is-planned {
  background: #ece8de;
  color: #6b6045;
}

.editor-task-pill.is-snoozed {
  background: #fff4d1;
  color: #5a3a14;
}

.editor-task-pill.is-awoken {
  background: var(--color-amber);
  color: var(--color-pearl);
}

.editor-task-date {
  font-size: 10.5px;
  color: var(--color-text-subtle);
  flex-shrink: 0;
}

.editor-task-empty {
  text-align: center;
  padding: 14px 8px;
  color: var(--color-text-subtle);
  font-size: 12.5px;
  font-style: italic;
}

/* Categories row */
.cat-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.cat-btn {
  background: white;
  border: 1px solid #d6d0c4;
  border-radius: 14px;
  padding: 3px 10px;
  font-size: 12px;
  cursor: pointer;
  color: var(--color-velvet-dark);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.cat-btn:hover {
  border-color: var(--color-velvet);
}

.cat-btn.is-active {
  background: var(--color-velvet);
  color: white;
  border-color: var(--color-velvet);
}

.cat-btn.is-active .cat-btn-count {
  color: rgba(255, 255, 255, 0.75);
}

.cat-btn-count {
  font-size: 10px;
  color: var(--color-text-subtle);
}

.cat-btn-remove {
  color: rgba(255, 255, 255, 0.55);
  font-size: 11px;
  line-height: 1;
  padding: 0 2px 0 4px;
  margin-left: 2px;
  opacity: 0;
  transition: opacity 120ms ease;
}

.cat-btn:hover .cat-btn-remove {
  opacity: 1;
}

.cat-btn-remove:hover {
  color: white;
}

.cat-btn:not(.is-active) .cat-btn-remove {
  color: rgba(0, 0, 0, 0.3);
}

.cat-btn:not(.is-active):hover .cat-btn-remove {
  color: var(--color-ruby);
  opacity: 1;
}

.cat-btn-add {
  border-style: dashed;
  color: var(--color-text-subtle);
  background: transparent;
}

.cat-btn-add:hover {
  color: var(--color-velvet);
  border-color: var(--color-velvet);
}

/* Sentence bank */
.cat-sentences {
  margin-top: 6px;
  padding: 8px 10px;
  background: #f4f1e9;
  border: 1px dashed #d6d0c4;
  border-radius: 6px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.cat-sentences-group {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.cat-sentences-group-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-subtle);
}

.cat-sentences-group-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.qb-btn {
  background: white;
  border: 1px solid #d6d0c4;
  border-radius: 16px;
  padding: 4px 10px;
  font-size: 12px;
  cursor: pointer;
  color: var(--color-velvet-dark);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.qb-btn:hover {
  border-color: var(--color-velvet);
}

.qb-btn-remove {
  color: rgba(0, 0, 0, 0.25);
  font-size: 11px;
  line-height: 1;
  margin-left: 4px;
  padding: 0 2px;
  opacity: 0;
  transition: opacity 120ms ease;
}

.qb-btn:hover .qb-btn-remove {
  opacity: 1;
  color: var(--color-ruby);
}

.qb-btn-add {
  border-style: dashed;
  color: var(--color-text-subtle);
  background: transparent;
}

.qb-btn-add:hover {
  color: var(--color-velvet);
  border-color: var(--color-velvet);
}

/* Inline forms (create category, create sentence) */
.inline-form {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 6px;
  border: 1px dashed var(--color-velvet);
  border-radius: 14px;
  background: white;
}

.inline-form input {
  border: none;
  outline: none;
  font-size: 12px;
  font-family: inherit;
  background: transparent;
  color: var(--color-velvet-dark);
  padding: 2px 2px;
  min-width: 80px;
}

.inline-form input.is-icon {
  min-width: 26px;
  text-align: center;
}

.inline-form-confirm {
  background: var(--color-velvet);
  color: white;
  border: none;
  border-radius: 50%;
  width: 18px;
  height: 18px;
  font-size: 11px;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.inline-form-confirm:disabled {
  background: #cbd5e0;
  cursor: default;
}

.inline-form-cancel {
  color: var(--color-text-subtle);
  cursor: pointer;
  font-size: 13px;
  padding: 0 4px;
}

/* Compose row */
.editor-input {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.editor-input textarea {
  width: 100%;
  border: 1px solid #d6d0c4;
  border-radius: 6px;
  padding: 8px 10px;
  font-size: 13px;
  font-family: inherit;
  min-height: 56px;
  resize: vertical;
  box-sizing: border-box;
  background: white;
  color: var(--color-velvet-dark);
}

.editor-input textarea:focus {
  outline: 2px solid var(--color-velvet);
  outline-offset: -2px;
}

.editor-input textarea.is-filled-by-quickbuild {
  background: #fffdf3;
  border-color: var(--color-amber);
}

/* Compose type toggle reuses the shared .task-type-selector / .task-type-pill
   styling (css/25-task-types.css); only the top spacing is editor-specific. */
.editor-compose-type {
  margin-top: 4px;
}

/* Action row */
.editor-actions {
  display: flex;
  gap: 8px;
  justify-content: space-between;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid #ece8de;
}

.editor-actions .left,
.editor-actions .right {
  display: flex;
  gap: 8px;
}

.editor-actions .btn {
  border: 1px solid #d6d0c4;
  background: white;
  padding: 6px 14px;
  border-radius: 6px;
  font-size: 13px;
  cursor: pointer;
  color: var(--color-velvet-dark);
}

.editor-actions .btn:hover {
  border-color: var(--color-velvet);
}

/* The primary action commits the "next" task, so it carries the same green
   as the is-next status pill. */
.editor-actions .btn-primary {
  background: var(--color-basil);
  color: white;
  border-color: var(--color-basil);
}

.editor-actions .btn-primary:hover {
  background: #3f6a0c;
}

.editor-actions .btn-secondary {
  background: #ece8de;
}

/* Destructive action (Edit mode "Delete task"). */
.editor-actions .btn-danger {
  background: white;
  color: var(--color-ruby);
  border-color: #e8b4ae;
}

.editor-actions .btn-danger:hover {
  background: var(--color-ruby-light);
  border-color: var(--color-ruby);
}

.editor-actions .btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.editor-actions .btn-decision {
  background: var(--color-amber-light);
  color: #5a3a14;
  border-color: var(--color-amber);
}

/* Quick-add shortcuts to the left of "+ Before": Plan (planner-blue) opens the
   placement modal, Focus (basil-green) starts the global timer. */
.editor-actions .task-editor-plan {
  background: var(--color-context-light);
  color: var(--color-context);
  border-color: var(--color-context-border);
}

.editor-actions .task-editor-focus {
  background: var(--color-basil-light);
  color: var(--color-basil);
  border-color: #cbe3a6;
}

/* Footer "Done" action: shown when every task on the card is done; moves the
   card into Done on every board it sits on. Full-width green call-to-action. */
.task-editor-done-footer {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid #ece8de;
}

.task-editor-done-footer .btn-done-card {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 14px;
  border-radius: 6px;
  border: 1px solid var(--color-basil);
  background: var(--color-basil);
  color: white;
  font-size: 13.5px;
  font-weight: 700;
  cursor: pointer;
}

.task-editor-done-footer .btn-done-card:hover {
  background: #3f6a0c;
}

/* Delete category confirm */
.cat-delete-confirm {
  margin-top: 8px;
  padding: 8px 10px;
  background: var(--color-ruby-light);
  border: 1px solid var(--color-ruby);
  border-radius: 6px;
  font-size: 12.5px;
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}

.cat-delete-confirm .btn {
  padding: 4px 10px;
  font-size: 12px;
  border-radius: 5px;
  border: 1px solid #d6d0c4;
  background: white;
  cursor: pointer;
}

.cat-delete-confirm .btn-decision {
  background: var(--color-ruby);
  color: white;
  border-color: var(--color-ruby);
}

/* Card next-task pill — clickable affordance */
.card-next-task.is-clickable {
  border-radius: 6px;
  padding: 2px 4px;
  margin: 0 -4px;
  cursor: pointer;
  transition: background 120ms ease;
}

.card-next-task.is-clickable:hover {
  background: #eef2fb;
}

/* Quick-snooze slider on a task row in the task editor modal. */
.editor-task-row-wrap {
  display: flex;
  flex-direction: column;
}
.editor-task-snooze {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 1px 0 4px 26px;
}
.editor-task-snooze-label {
  font-size: 10.5px;
  color: var(--color-text-subtle);
  white-space: nowrap;
}
.editor-task-snooze-range {
  flex: 1;
  max-width: 160px;
  accent-color: var(--color-velvet);
  height: 16px;
  cursor: pointer;
}
.editor-task-snooze-readout {
  font-size: 10.5px;
  color: var(--color-text-subtle);
  white-space: nowrap;
}
.editor-task-snooze-days {
  font-weight: 600;
  color: var(--color-velvet);
}
.editor-task-snooze-date {
  color: #5a3a14;
}

/* Parallel checkbox for the next created task (Quick add / Add modes). */
.editor-compose-parallel {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
  font-size: 12px;
  color: var(--color-velvet-dark);
  cursor: pointer;
  user-select: none;
}

.editor-compose-parallel input {
  cursor: pointer;
}

.editor-compose-parallel-label {
  cursor: pointer;
}

/* Same slider in the compose area: full width, not indented under a row, with
   a dashed separator above it. */
.editor-compose-snooze {
  margin: 8px 0 0;
  padding-top: 8px;
  border-top: 1px dashed #ece8de;
}

.editor-compose-snooze .editor-task-snooze-label {
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.editor-compose-snooze .editor-task-snooze-range {
  max-width: 200px;
}

.editor-compose-snooze .editor-task-snooze-readout {
  margin-left: auto;
}
/* Task contexts — bluish pills, used in the task editor and card edit modal,
   plus a read-only variant on the kanban card. Twins .cat-* in 30-task-editor.css. */

.ctx-section {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.ctx-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}

.ctx-btn {
  background: white;
  border: 1px solid var(--color-context-border);
  border-radius: 14px;
  padding: 3px 10px;
  font-size: 12px;
  font-family: inherit;
  cursor: pointer;
  color: var(--color-context-dark);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ctx-btn:hover {
  border-color: var(--color-context);
}

.ctx-btn.is-active {
  background: var(--color-context);
  color: white;
  border-color: var(--color-context);
}

.ctx-btn-icon {
  font-size: 12px;
  line-height: 1;
}

.ctx-btn-add {
  border-style: dashed;
  color: var(--color-text-subtle);
  background: transparent;
}

.ctx-btn-add:hover {
  color: var(--color-context);
  border-color: var(--color-context);
}

.ctx-btn-remove {
  color: rgba(255, 255, 255, 0.7);
  font-size: 11px;
  line-height: 1;
  padding: 0 2px 0 4px;
  cursor: pointer;
}

.ctx-btn-remove:hover {
  color: white;
}

/* Person picker popover */
.ctx-person-pop {
  border: 1px solid var(--color-context-border);
  background: white;
  border-radius: 8px;
  padding: 8px;
  width: 220px;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.1);
}

.ctx-person-pop-title {
  font-size: 11px;
  color: var(--color-text-subtle);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 6px;
}

.ctx-person-pop-empty {
  font-size: 12px;
  color: var(--color-text-subtle);
  padding: 2px 4px;
}

.ctx-person-opt {
  display: block;
  width: 100%;
  text-align: left;
  border: 1px solid #e2ddd1;
  background: white;
  border-radius: 6px;
  padding: 4px 8px;
  margin: 3px 0;
  cursor: pointer;
  font-size: 12.5px;
  font-family: inherit;
  color: var(--color-velvet-dark);
}

.ctx-person-opt:hover {
  border-color: var(--color-context);
  background: var(--color-context-light);
}

.ctx-person-opt.is-new {
  border-style: dashed;
  color: var(--color-context-dark);
  font-weight: 600;
}

/* The contexts row inside the card-edit task details aligns its label like
   the other detail rows but lets the pills wrap. */
.task-detail-row-contexts {
  align-items: flex-start;
}

/* Read-only pill shown on the kanban card's lead task in place of "Next". */
.ctx-pill {
  font-size: 10px;
  padding: 0 7px;
  border-radius: 9px;
  font-weight: 600;
  background: var(--color-context-light);
  color: var(--color-context-dark);
  border: 1px solid var(--color-context-border);
  white-space: nowrap;
}

.ctx-pill.is-person::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  margin-right: 4px;
  vertical-align: -0.125em;
  background-color: currentColor;
  -webkit-mask: var(--icon-user) center / contain no-repeat;
  mask: var(--icon-user) center / contain no-repeat;
}
/* Persons tab — per-person owned tasks, events & logs.
   See planning/person-tab-owner-sections-plan.html. */

.owned-sections {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.owned-section-label {
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-subtle);
  margin-bottom: 4px;
  display: flex;
  gap: 6px;
  align-items: center;
}

.owned-count {
  font-size: 10px;
  background: #ece8de;
  color: #6b6045;
  border-radius: 8px;
  padding: 0 6px;
}

.owned-list {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.owned-empty {
  font-size: 12px;
  font-style: italic;
  color: var(--color-text-subtle);
  padding: 4px 2px;
}

/* Tasks — clickable rows that open the card */
.owned-task-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 8px;
  border-radius: 5px;
  background: white;
  border: 1px solid #ece8de;
  font-size: 12.5px;
  cursor: pointer;
  transition:
    background 0.12s ease,
    border-color 0.12s ease;
}

.owned-task-row:hover {
  background: #eef2fb;
  border-color: #d6deef;
}

.owned-task-text {
  flex: 1;
  color: var(--color-velvet-dark);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.owned-task-card {
  font-size: 10.5px;
  color: var(--color-text-subtle);
  white-space: nowrap;
  max-width: 45%;
  overflow: hidden;
  text-overflow: ellipsis;
}

.owned-task-pill {
  font-size: 9.5px;
  padding: 1px 6px;
  border-radius: 8px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  flex-shrink: 0;
  background: #e2e8f0;
  color: #4a5568;
}

.owned-task-pill.is-next {
  background: var(--color-basil-light);
  color: var(--color-basil);
}

.owned-task-pill.is-snoozed {
  background: #fff4d1;
  color: #5a3a14;
}

.owned-task-pill.is-awoken {
  background: var(--color-amber);
  color: var(--color-pearl);
}

.owned-task-pill.is-planned {
  background: #ece8de;
  color: #6b6045;
}

/* Events — date + title + kind chip */
.owned-event-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 8px;
  border-radius: 5px;
  background: #fbfaf6;
  border: 1px solid #ece8de;
  font-size: 12.5px;
}

.owned-event-date {
  font-size: 10.5px;
  color: var(--color-text-subtle);
  white-space: nowrap;
  min-width: 44px;
}

.owned-event-title {
  flex: 1;
  color: var(--color-velvet-dark);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.owned-event-kind {
  font-size: 9.5px;
  padding: 1px 6px;
  border-radius: 8px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  flex-shrink: 0;
  background: var(--color-context-light);
  color: var(--color-context);
  border: 1px solid var(--color-context-border);
}

.owned-event-kind.is-tx {
  background: var(--color-amber-light);
  color: #5a3a14;
  border-color: var(--color-amber);
}

/* Logs — champagne left border like editor logs */
.owned-log-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 5px 8px;
  border-radius: 5px;
  background: #fbf9f3;
  border: 1px solid #ece8de;
  border-left: 3px solid var(--color-champagne);
  font-size: 12.5px;
}

.owned-log-date {
  font-size: 10.5px;
  color: var(--color-text-subtle);
  white-space: nowrap;
  min-width: 44px;
}

.owned-log-body {
  flex: 1;
  color: #5a5044;
  font-style: italic;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
/* Task Planner tab (see planning/task-planner-plan.html).
   Chosen design: V5 layout with square, lightly-rounded 15-min blocks (4/row),
   basil->amber overrun gradient, grape parallel rows, left-half list. */

.planner-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items: start;
  padding: 14px 18px 40px;
  /* Fill the tab body so the bottom tab bar stays pinned to the bottom. */
  flex: 1;
  min-height: 0;
  overflow-y: auto;
}
/* ----- Focus stack (right-hand panel) ----- */
.focus-stack {
  border: 1px solid #e3dccc;
  border-radius: 12px;
  min-height: 320px;
  background: var(--color-pearl);
  padding: 12px 14px;
  /* Drop the box down past the slot-tabs row so its top lines up with the
     first task row in the left column. */
  margin-top: 45px;
}
.fs-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.fs-title {
  font-size: 13px;
  font-weight: 800;
  color: var(--color-velvet-dark);
}
.fs-depth {
  font-size: 11px;
  font-weight: 700;
  color: var(--color-text-subtle);
  background: #f1ece1;
  border-radius: 999px;
  padding: 1px 9px;
}

/* ad-hoc capture */
.fs-adhoc {
  display: flex;
  gap: 6px;
}
.fs-adhoc-input {
  flex: 1;
  min-width: 0;
  border: 1px solid #d6d0c4;
  border-radius: 8px;
  padding: 7px 10px;
  font-size: 12.5px;
  font-family: inherit;
  color: var(--color-velvet-dark);
  background: #fff;
}
.fs-add {
  border: 1px solid var(--color-context);
  background: var(--color-context-light);
  color: var(--color-context);
  border-radius: 8px;
  padding: 0 12px;
  font-weight: 800;
  font-size: 16px;
  line-height: 1;
  cursor: pointer;
  font-family: inherit;
}
.fs-ctxrow {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 8px 0 14px;
}
.fs-ctx-label {
  font-size: 11.5px;
  color: var(--color-text-subtle);
}
.fs-ctx {
  display: inline-flex;
  border: 1px solid #d6d0c4;
  border-radius: 8px;
  overflow: hidden;
}
.fs-ctx-btn {
  border: none;
  background: #fff;
  color: var(--color-text-subtle);
  font-size: 11.5px;
  font-weight: 700;
  padding: 4px 12px;
  cursor: pointer;
  font-family: inherit;
}
.fs-ctx-btn.on {
  background: var(--color-velvet);
  color: var(--color-pearl);
}

/* the stack itself: a connected spine, top occurrence first */
.fs-stack {
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
}
.fs-stack::before {
  content: "";
  position: absolute;
  left: 6px;
  top: 14px;
  bottom: 14px;
  width: 2px;
  background: repeating-linear-gradient(#d8d2c5, #d8d2c5 4px, transparent 4px, transparent 8px);
}
.fs-card {
  position: relative;
  margin-left: 18px;
  border: 1px solid rgba(34, 45, 82, 0.16);
  border-radius: 10px;
  background: #fff;
  padding: 9px 10px;
}
.fs-card + .fs-card {
  margin-top: 8px;
}
.fs-card::before {
  content: "";
  position: absolute;
  /* Centre the 8px dot on the 2px dotted rail (.fs-stack::before at left:6px). */
  left: -16px;
  top: 18px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #cfc9bc;
  border: 2px solid #fff;
  box-shadow: 0 0 0 1px #cfc9bc;
}
.fs-card.current.running {
  border-color: var(--color-basil);
  box-shadow:
    0 0 0 2px var(--color-basil-light),
    inset 3px 0 0 var(--color-basil);
  background: linear-gradient(90deg, #f6faf0, #fff 70%);
}
.fs-card.current.running::before {
  background: var(--color-basil);
  box-shadow:
    0 0 0 1px var(--color-basil),
    0 0 6px var(--color-basil);
}
.fs-card.current.paused {
  border-color: var(--color-amber);
  box-shadow:
    0 0 0 2px var(--color-amber-light),
    inset 3px 0 0 var(--color-amber);
  background: linear-gradient(90deg, #fdf8ec, #fff 70%);
}
.fs-card.current.paused::before {
  background: var(--color-amber);
  box-shadow: 0 0 0 1px var(--color-amber);
}
.fs-card.adhoc {
  border-style: dashed;
}
.fs-card.buried {
  opacity: 0.9;
}
.fs-card.done .fs-text {
  text-decoration: line-through;
  color: var(--color-text-subtle);
}
.fs-row1 {
  display: flex;
  align-items: center;
  gap: 7px;
}
.fs-tag {
  font-size: 9.5px;
  font-weight: 800;
  padding: 1px 6px;
  border-radius: 999px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
}
.fs-tag.cur {
  background: var(--color-basil);
  color: #fff;
}
.fs-tag.cur.pau {
  background: var(--color-amber);
}
.fs-tag.bur {
  background: #e7e2d6;
  color: #6b6655;
}
.fs-tag.ad {
  background: var(--color-grape-light);
  color: var(--color-grape);
}
.fs-text {
  flex: 1;
  min-width: 0;
  font-size: 12.5px;
  font-weight: 700;
  color: var(--color-velvet-dark);
  line-height: 1.25;
}
.fs-timer {
  font-family: "JetBrains Mono", Consolas, monospace;
  font-size: 12px;
  color: var(--color-text-subtle);
  white-space: nowrap;
}
.fs-card.current.running .fs-timer {
  color: var(--color-basil);
  font-weight: 800;
}
.fs-card.current.paused .fs-timer {
  color: var(--color-amber);
}
.fs-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 6px;
  gap: 8px;
}
.fs-card-src {
  font-size: 10.5px;
  color: var(--color-text-subtle);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.fs-acts {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}
.fs-btn {
  border: 1px solid #d6d0c4;
  background: var(--color-pearl);
  border-radius: 7px;
  height: 26px;
  min-width: 28px;
  padding: 0 8px;
  font-size: 12px;
  cursor: pointer;
  color: var(--color-velvet);
  font-family: inherit;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.fs-btn.play {
  background: var(--color-basil-light);
  border-color: var(--color-basil);
  color: var(--color-basil);
  font-weight: 800;
}
.fs-btn.done {
  background: var(--color-basil-light);
  border-color: var(--color-basil);
  color: var(--color-basil);
  font-weight: 800;
}
.fs-btn.kill {
  color: var(--color-amber);
}
.fs-btn.kill:hover {
  background: var(--color-amber-light);
  border-color: var(--color-amber);
}
.fs-locked {
  font-size: 10px;
  color: #bdb6a8;
  font-style: italic;
}
.fs-empty {
  color: var(--color-text-subtle);
  font-size: 12px;
  text-align: center;
  padding: 26px 12px;
  border: 1.5px dashed #ddd6c8;
  border-radius: 10px;
}
.fs-return {
  font-size: 11px;
  color: var(--color-basil);
  font-weight: 700;
  margin-top: 10px;
  padding-left: 6px;
}

.planner-list-tabs {
  display: flex;
  gap: 6px;
  padding: 4px 0 12px;
  align-items: center;
}
.planner-list-tab {
  padding: 6px 16px;
  border-radius: 8px;
  border: 1px solid #d6d0c4;
  background: var(--color-pearl);
  cursor: pointer;
  font-weight: 700;
  font-size: 13px;
  color: var(--color-velvet);
}
.planner-list-tab.active {
  background: var(--color-velvet);
  color: var(--color-pearl);
  border-color: var(--color-velvet);
}
.planner-add-btn {
  margin-left: auto;
}

/* Active list's remaining-time summary, pushed to the right of the slot tabs. */
.tp-list-summary {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 14px;
  font-family: "JetBrains Mono", Consolas, monospace;
  font-size: 12.5px;
  background: var(--color-pearl);
  border: 1px solid #e3dccc;
  border-radius: 8px;
  padding: 5px 12px;
}
.tp-list-summary .lbl {
  color: var(--color-text-subtle);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  margin-right: 5px;
}
.tp-list-summary .sum {
  color: var(--color-velvet-dark);
  font-weight: 700;
}
.tp-list-summary .end {
  color: var(--color-basil);
  font-weight: 700;
}
.tp-list-summary .over {
  color: var(--color-amber);
  font-weight: 700;
}
.tp-list-summary .sep {
  color: #d6d0c4;
}

.tp-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.tp-row {
  display: grid;
  grid-template-columns: 34px 76px auto 1fr auto;
  gap: 14px;
  align-items: center;
  /* Uniform row height (squares are capped at 4h, so they never exceed this). */
  min-height: 92px;
  background: #fff;
  border: 1px solid rgba(34, 45, 82, 0.14);
  border-radius: 10px;
  padding: 9px 26px 9px 9px;
  position: relative;
}
.tp-row.gap-after {
  margin-bottom: 42px;
}
.tp-row.gap-after::after {
  content: "";
  position: absolute;
  left: 9px;
  right: 26px;
  bottom: -22px;
  border-bottom: 1px dashed rgba(34, 45, 82, 0.18);
}

.tp-pos {
  text-align: center;
  font-size: 26px;
  font-weight: 800;
  color: var(--color-text-subtle);
  font-family: "JetBrains Mono", Consolas, monospace;
  line-height: 1.1;
}
.tp-row.active .tp-pos {
  color: var(--color-basil);
}

.tp-blocks {
  display: grid;
  grid-template-columns: repeat(4, 16px);
  gap: 4px;
  align-content: center;
}

/* Minutes between the squares and the rest of the row. */
.tp-minutes {
  font-size: 17px;
  font-weight: 700;
  color: var(--color-velvet-dark);
  white-space: nowrap;
  text-align: center;
}
.tp-minutes.over {
  color: var(--color-amber);
}
.tp-minutes .unit,
.tp-minutes .est {
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text-subtle);
}
.blk {
  width: 16px;
  height: 16px;
  border-radius: 5px;
  border: 1px solid rgba(34, 45, 82, 0.18);
  background: #efeadf;
}
.blk.full {
  background: var(--color-basil);
  border-color: var(--color-basil);
}
.blk.partial {
  background: linear-gradient(135deg, var(--color-basil) 55%, #efeadf 55%);
  border-color: var(--color-basil);
}
.blk.edge {
  background: linear-gradient(135deg, var(--color-basil), var(--color-amber));
  border-color: var(--color-amber);
}
.blk.over {
  background: var(--color-amber);
  border-color: var(--color-amber);
}

.tp-main {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 3px;
  min-width: 0;
}
.tp-end {
  font-size: 11px;
  color: var(--color-basil);
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.tp-end.over {
  color: var(--color-amber);
}
.tp-end.par {
  color: var(--color-grape);
}

/* Background parallel time badge — visible, but kept out of squares/minutes/Σ. */
.tp-par-time {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 10.5px;
  font-weight: 700;
  color: var(--color-grape);
  font-family: "JetBrains Mono", Consolas, monospace;
  margin-top: 2px;
}

/* Static "auto-recording" chip that replaces play/pause on a parallel row. */
.tp-par-rec {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 700;
  color: var(--color-grape);
  background: var(--color-grape-light);
  border: 1px solid #d9cef2;
  border-radius: 999px;
  padding: 3px 9px;
  white-space: nowrap;
}
.tp-par-rec-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--color-grape);
  animation: tp-par-pulse 1.6s infinite;
}
@keyframes tp-par-pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(109, 40, 217, 0.5);
  }
  70% {
    box-shadow: 0 0 0 6px rgba(109, 40, 217, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(109, 40, 217, 0);
  }
}
.tp-descline {
  display: flex;
  align-items: flex-start;
  gap: 7px;
}
.tp-check {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  margin-top: 1px;
  border: 1.5px solid rgba(34, 45, 82, 0.4);
  border-radius: 4px;
  background: #fff;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  color: #fff;
  line-height: 1;
}
.tp-check.done {
  background: var(--color-basil);
  border-color: var(--color-basil);
}
.tp-desc {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--color-velvet-dark);
  line-height: 1.3;
}
/* Parent card's description, muted, aligned under the task text (past the check). */
.tp-card-desc {
  font-size: 11.5px;
  font-weight: 500;
  color: var(--color-text-subtle);
  line-height: 1.25;
  padding-left: 23px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}
.tp-row.done .tp-card-desc {
  opacity: 0.6;
}
/* Controls live in their own right-hand column, vertically centered. */
.tp-ctrls {
  display: flex;
  gap: 14px;
  flex-wrap: nowrap;
  justify-content: flex-end;
  align-self: center;
}
/* Buttons are grouped (play/pause · parallel · the two +5 · edit); a small
   internal gap keeps a group tight, the larger .tp-ctrls gap separates them. */
.tp-ctrl-group {
  display: flex;
  gap: 4px;
}
.tp-ico {
  border: 1px solid #d6d0c4;
  background: var(--color-pearl);
  border-radius: 8px;
  min-width: 34px;
  height: 30px;
  padding: 0 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 13.5px;
  color: var(--color-velvet);
}
.tp-ico:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.tp-ico.play {
  background: var(--color-basil-light);
  border-color: var(--color-basil);
  color: var(--color-basil);
  font-weight: 800;
}
.tp-ico.pause {
  background: #e8ecf6;
  border-color: var(--color-velvet);
  color: var(--color-velvet);
  font-weight: 800;
}
.tp-ico.par.on {
  background: var(--color-grape-light);
  border-color: var(--color-grape);
  color: var(--color-grape);
  font-weight: 800;
}

.tp-remove {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 17px;
  height: 17px;
  border-radius: 5px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--color-text-subtle);
  cursor: pointer;
  font-size: 12px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.tp-remove:hover {
  background: var(--color-amber-light);
  color: #5a3a14;
  border-color: var(--color-amber);
}
.tp-grip {
  position: absolute;
  bottom: 5px;
  right: 7px;
  color: rgba(34, 45, 82, 0.22);
  font-size: 11px;
  cursor: grab;
}

.tp-row.active {
  background: linear-gradient(90deg, #f3f7ec 0%, #fbfdf7 60%);
  border-color: var(--color-basil);
  box-shadow: inset 3px 0 0 var(--color-basil);
}
.tp-row.done {
  background: #f6f4ef;
  opacity: 0.62;
}
.tp-row.done .tp-desc {
  text-decoration: line-through;
  color: var(--color-text-subtle);
}
.tp-row.done .tp-time {
  color: var(--color-text-subtle);
}
.tp-row.parallel {
  border-color: var(--color-grape);
  background: linear-gradient(90deg, #f5f1fc 0%, #fdfcff 60%);
  animation: tp-parallel 3.8s ease-in-out infinite;
}
.tp-row.parallel .tp-pos {
  color: var(--color-grape);
}
@keyframes tp-parallel {
  0%,
  100% {
    box-shadow:
      inset 3px 0 0 var(--color-grape),
      inset 0 0 0 9999px rgba(109, 40, 217, 0.02);
  }
  50% {
    box-shadow:
      inset 3px 0 0 var(--color-grape),
      inset 0 0 0 9999px rgba(109, 40, 217, 0.075);
  }
}

/* Drag & drop feedback. The native HTML5 drag image is the "ghost"; the source
   row dims, and the target slot (the row the item will land on) is highlighted.
   Slots are fixed positions, so dropping moves the item to that exact slot. */
.tp-row.dragging {
  opacity: 0.34;
  border: 1px dashed rgba(34, 45, 82, 0.35);
  background: rgba(34, 45, 82, 0.05);
  box-shadow: none;
}
.tp-row.drop-target {
  border-color: var(--color-context);
  box-shadow: inset 0 0 0 2px var(--color-context);
  background: rgba(47, 111, 176, 0.06);
}

/* Empty slot rows (gaps between placed positions). */
.tp-empty-slot {
  min-height: 44px;
  border-style: dashed;
  border-color: rgba(34, 45, 82, 0.12);
  background: transparent;
}
.tp-empty-slot .tp-pos {
  color: rgba(34, 45, 82, 0.28);
}
.tp-empty-cell {
  grid-column: 2 / -1;
  color: rgba(34, 45, 82, 0.22);
  font-size: 13px;
}

.tp-empty {
  color: var(--color-text-subtle);
  font-size: 13px;
  padding: 24px 6px;
}

/* tab-bar focus pill */
.tab-focus-pip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--color-basil-light);
  color: var(--color-basil);
  border: 1px solid var(--color-basil);
  border-radius: 999px;
  padding: 0 7px;
  font-size: 10px;
  font-weight: 800;
  font-family: "JetBrains Mono", Consolas, monospace;
}

/* placement modal: set-estimate popover and pick-slot list */
.placement-task {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-velvet-dark);
  padding: 2px 0 6px;
}
.slot-pick {
  display: flex;
  gap: 8px;
  margin: 8px 0 4px;
}
.planner-mini-list {
  border: 1px solid #e6e0d4;
  border-radius: 10px;
  overflow: hidden;
  margin-top: 10px;
}
.planner-mini-row {
  display: grid;
  grid-template-columns: 34px 1fr auto;
  align-items: center;
  border-bottom: 1px solid #efe9dd;
}
.planner-mini-row:last-child {
  border-bottom: none;
}
/* The task being placed, if it's already on this list. */
.planner-mini-row.is-current {
  background: var(--color-basil-light);
  box-shadow: inset 3px 0 0 var(--color-basil);
}
.planner-mini-row.is-current .planner-mini-desc {
  font-weight: 700;
}
.planner-mini-here {
  padding: 0 10px;
  font-size: 11px;
  font-weight: 700;
  color: var(--color-basil);
  white-space: nowrap;
}
.placement-hint {
  font-size: 12px;
  color: var(--color-basil);
  padding: 2px 0 6px;
}
.planner-mini-num {
  text-align: center;
  font-family: "JetBrains Mono", Consolas, monospace;
  font-weight: 800;
  font-size: 15px;
  color: var(--color-velvet);
  padding: 9px 0;
  cursor: pointer;
  border-right: 1px solid #efe9dd;
  background: #f7f3ea;
}
.planner-mini-num:hover {
  background: var(--color-context-light, #e6f0fb);
  color: var(--color-context, #2f6fb0);
}
.planner-mini-desc {
  padding: 9px 12px;
  font-size: 12.5px;
  color: var(--color-velvet-dark);
}
.planner-mini-desc.empty {
  color: #c3bcb0;
  font-style: italic;
}

/* kanban planner-mode placement button (between checkbox and description) */
.task-place-btn {
  width: 20px;
  height: 18px;
  border-radius: 5px;
  border: 1px dashed var(--color-context, #2f6fb0);
  background: var(--color-context-light, #e6f0fb);
  color: var(--color-context, #2f6fb0);
  cursor: pointer;
  font-size: 12px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  flex-shrink: 0;
}
.planner-mode-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  border: 1px solid #d6d0c4;
  border-radius: 999px;
  padding: 4px 12px;
  background: var(--color-pearl);
  font-size: 12px;
  font-weight: 600;
  color: var(--color-velvet);
}
.planner-mode-toggle.on {
  background: var(--color-velvet);
  color: var(--color-pearl);
  border-color: var(--color-velvet);
}
