/* =============================================================================
   ACTIONS DASHBOARD — Definitive (System of Growth)
   3 active columns + collapsed Archive Drawer below.
   Lens: Current Heading 100% · Future Horizon + Intentions at 60% (hover → 100%).
   Cartographer aesthetic: serif display, ink palette, gold accents only on data.
   ========================================================================== */

.actions-dash {
  display: flex; flex-direction: column; gap: 0;
  min-width: 0;
}
.actions-dash > .section-head { margin-bottom: 16px; }

.actions-dash__head {
  display: flex; flex-direction: column; gap: 4px;
  padding-bottom: 0;
  border-bottom: none;
}
.actions-dash__title {
  margin: 6px 0 4px;
  color: var(--ink-1);
}
.actions-dash__sub {
  margin: 0;
  color: var(--ink-3);
  max-width: 64ch;
  text-wrap: pretty;
}
.actions-dash__tools {
  display: flex; gap: 8px; align-items: center;
  margin-top: 10px;
}

/* === The "Morning Review" ritual button — prominent gold-accent pulse === */
.actions-dash__btn {
  font-family: var(--font-sans-tight);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 12px 18px;
  border: 1px solid var(--stone-3);
  background: transparent;
  color: var(--ink-2);
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 10px;
  transition: all var(--duration-hover) var(--ease-quiet);
}
.actions-dash__btn:hover { border-color: var(--gold-1); color: var(--gold-2); background: var(--gold-soft); }

/* New Action button — primary capture trigger */
.actions-dash__btn--capture {
  border-color: var(--ink-1);
  color: var(--ink-1);
  background: #fff;
}
.actions-dash__btn--capture:hover {
  background: var(--gold-1);
  color: var(--gold-3);
  border-color: var(--gold-1);
}
.actions-dash__btn-plus {
  font-family: var(--font-serif-display);
  font-size: 16px;
  line-height: 1;
  margin-right: -2px;
}
.actions-dash__kbd {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.02em;
  padding: 2px 6px;
  border: 1px solid var(--stone-3);
  color: var(--ink-3);
  text-transform: none;
  background: var(--parchment-1);
  margin-left: 4px;
}
.actions-dash__btn--capture:hover .actions-dash__kbd {
  background: rgba(255,255,255,0.18);
  border-color: rgba(255,255,255,0.4);
  color: var(--gold-3);
}

.actions-dash__btn--ritual {
  position: relative;
  background: var(--gold-1);
  border-color: var(--gold-1);
  color: var(--gold-3);
  font-weight: 600;
  padding: 14px 22px;
  letter-spacing: 0.26em;
  overflow: visible;
}
.actions-dash__btn--ritual:hover {
  background: var(--gold-2); border-color: var(--gold-2); color: #fff;
}
.actions-dash__btn-pulse {
  position: absolute;
  inset: -3px;
  border: 1.5px solid var(--gold-1);
  pointer-events: none;
  animation: ritualPulse 2200ms ease-in-out infinite;
}
@keyframes ritualPulse {
  0%   { transform: scale(1);    opacity: 0.85; }
  60%  { transform: scale(1.18); opacity: 0; }
  100% { transform: scale(1.18); opacity: 0; }
}

/* =============================================================================
   THE COLUMNS GRID  —  3 active columns + narrow Archive column on the right
   ========================================================================= */
.cols {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr)) 92px;
  gap: 0;
  align-items: stretch;
}

.col {
  background: var(--parchment-1);
  border: none;
  border-right: 2px solid var(--stone-2);
  padding: 14px 14px 18px;
  display: flex; flex-direction: column; gap: 14px;
  height: 720px;
  min-width: 0;
  transition:
    opacity 220ms ease-in-out,
    filter 220ms ease-in-out,
    border-color var(--duration-hover) var(--ease-quiet),
    background var(--duration-hover) var(--ease-quiet);
}

.col__list {
  display: flex; flex-direction: column; gap: 8px;
  flex: 1 1 auto;
  position: relative;
  overflow-y: auto;
  padding-right: 4px;
  scrollbar-width: thin;
  scrollbar-color: var(--stone-3) transparent;
}
.col__list::-webkit-scrollbar { width: 6px; }
.col__list::-webkit-scrollbar-thumb { background: var(--stone-3); }
.col__list::-webkit-scrollbar-track { background: transparent; }

/* === The Lens ===
   Default: all columns at 100%.
   When a column is hovered, focused, or a drop target, the other two dim to 60%. */
.col { opacity: 1; }

/* column text: dark ink on parchment (no dark-board overrides needed) */
.cols:has(.col:hover)         .col:not(:hover)         { opacity: 0.6; filter: saturate(0.9); }
.cols:has(.col:focus-within)  .col:not(:focus-within)  { opacity: 0.6; filter: saturate(0.9); }
.cols:has(.col.is-drag-over)  .col:not(.is-drag-over)  { opacity: 0.6; filter: saturate(0.9); }

.col--intentions {
  /* no special background — board dark handles depth */
}

/* Drag-over highlight */
.col.is-drag-over {
  border-color: var(--gold-1);
  background: var(--gold-soft);
  box-shadow: inset 0 0 0 1px var(--gold-1);
}

/* === Column header === */
.col__head {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  gap: 4px;
  padding: 8px 8px 10px;
  border-bottom: 1px solid var(--stone-2);
}
.col__eye {
  grid-column: 1 / -1;
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.col--heading .col__eye { color: var(--gold-2); }
.col__title {
  grid-column: 1;
  margin: 4px 0 0;
  color: var(--ink-1);
}
.col__sub {
  grid-column: 1 / -1;
  font-family: var(--font-serif-italic);
  font-style: italic;
  font-size: 12px;
  color: var(--ink-3);
}
.col__count {
  grid-row: 2; grid-column: 2;
  align-self: end;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-3);
}

/* The task list */
.col__empty {
  position: absolute;
  inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-serif-italic);
  font-style: italic;
  font-size: 12px;
  line-height: 1.45;
  color: var(--ink-3);
  opacity: 0.6;
  letter-spacing: 0.04em;
  pointer-events: none;
  text-align: center;
  padding: 24px;
}

/* =============================================================================
   TASK CARD
   ========================================================================= */
.task {
  position: relative;
  display: grid;
  grid-template-columns: 3px 34px 1fr;
  gap: 10px;
  align-items: stretch;
  background: #fff;
  border: 1px solid var(--stone-2);
  padding: 10px 12px 10px 0;
  box-shadow: 0 1px 0 rgba(0,0,0,0.03), 0 8px 14px -10px rgba(0,0,0,0.10);
  cursor: grab;
  transition:
    transform var(--duration-hover) var(--ease-quiet),
    box-shadow var(--duration-hover) var(--ease-quiet),
    border-color var(--duration-hover) var(--ease-quiet),
    opacity var(--duration-hover) var(--ease-quiet);
  outline: none;
}
.task:hover {
  transform: scale(1.02);
  border-color: var(--gold-1);
  box-shadow: 0 2px 0 rgba(0,0,0,0.04), 0 18px 28px -14px rgba(0,0,0,0.20);
  z-index: 2;
}
.task:focus-visible { outline: 2px solid var(--gold-1); outline-offset: 2px; }
.task:active { cursor: grabbing; }

/* Drag state */
.task.is-dragging {
  opacity: 0.9; box-shadow: none; border-style: dashed; cursor: grabbing; z-index: 1000;
}

/* Realize animation (kept as a no-op for completed-flow; CSS transitions handle the in-place shrink). */
@keyframes realize { 0%{transform:scale(1);} 100%{transform:scale(1);} }
.task.is-realizing { pointer-events: none; }

/* Dismiss animation — card lifts to a flight layer and flies into the Archive.
   The handler sets `position: fixed` + computed `--fly-x` / `--fly-y` on the card,
   so the animation lands at the archive column's center regardless of source col. */
@keyframes dismiss {
  0%   { transform: translate(0, 0)                            scale(1)    rotate(0deg);  opacity: 1; }
  15%  { transform: translate(8px, -2px)                       scale(0.98) rotate(0.6deg); opacity: 1; }
  100% { transform: translate(var(--fly-x, 240%), var(--fly-y, 0px)) scale(0.16) rotate(6deg); opacity: 0; }
}
.task.is-dismissing {
  animation: dismiss 620ms cubic-bezier(0.42, 0, 0.78, 0.42) forwards;
  pointer-events: none;
  transform-origin: center center;
  box-shadow: 0 24px 36px -12px rgba(0,0,0,0.30), 0 8px 18px -8px rgba(0,0,0,0.25);
}

/* Archived state (in drawer) */
.task.is-archived {
  opacity: 0.85;
  background: var(--parchment-1);
  box-shadow: none;
  cursor: default;
}
.task.is-archived:hover { transform: none; box-shadow: none; border-color: var(--stone-2); }
.task.is-archived .task__title { text-decoration: line-through; text-decoration-color: var(--ink-4); }
.task.is-archived .task__text  { color: var(--ink-3); }

/* Stale task: subtle warmer-amber outline */
.task.is-stale {
  background: linear-gradient(180deg, rgba(250,204,21,0.04), #fff);
}

/* High-resonance / True North alignment — gold outline + faint cream wash */
.task.is-high-resonance {
  border-color: rgba(187,152,99,0.5);
  background: linear-gradient(180deg, rgba(187,152,99,0.05), #fff 70%);
  box-shadow:
    0 1px 0 rgba(0,0,0,0.03),
    0 8px 14px -10px rgba(0,0,0,0.10);
  padding-top: 20px;
  margin-top: 16px;
}
.task.is-high-resonance:hover {
  border-color: var(--gold-1);
  box-shadow:
    0 2px 0 rgba(0,0,0,0.04),
    0 18px 28px -14px rgba(187,152,99,0.28);
}

/* True North badge — solid gold status chip with subtle glow */
.task__north {
  position: absolute;
  top: -13px;
  right: 12px;
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--font-sans-tight);
  font-weight: 700;
  font-size: 8.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-1);
  padding: 4px 10px 4px 7px;
  background: var(--gold-1);
  border: 0;
  box-shadow:
    0 0 0 1px rgba(187,152,99,0.5),
    0 3px 8px -2px rgba(187,152,99,0.45);
  z-index: 3;
  pointer-events: none;
  border-radius: 2px;
}
.task__north-ico {
  font-size: 10px;
  line-height: 1;
  color: var(--ink-1);
}
.task__north span[aria-hidden] {
  font-size: 11px;
  line-height: 1;
  color: var(--parchment-0);
}

/* Compact (drawer) variant */
.task.is-compact {
  grid-template-columns: 6px 28px 1fr;
  padding: 10px 12px 10px 0;
  gap: 10px;
}
.task.is-compact .task__title { font-size: 14px; line-height: 18px; }
.task.is-compact .task__text  { font-size: 11px; line-height: 16px; }
.task.is-compact .task__realize { width: 22px; height: 22px; margin-top: 2px; margin-left: 2px; }
.task.is-compact .task__realize-check { width: 14px; height: 14px; }

/* Domain color bar — absolute so it reliably covers full card height */
.task__strip {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 4px;
}

/* === Realize circle — primary anchor ===
   Default (uncompleted): empty gold-bordered circle, no fill.
   Hover: fills gold, white check appears, scales up.
   Completed: shrinks to a smaller filled circle with the check (a quiet badge).
   Completed + hover: check swaps to an undo arc — click to revert. */
.task__realize {
  align-self: start;
  margin-top: 2px;
  margin-left: 2px;
  width: 26px; height: 26px;
  border-radius: 9999px;
  border: 1.5px solid var(--gold-1);
  background: #fff;
  color: var(--gold-1);
  cursor: pointer;
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.4) inset,
    0 4px 10px -4px rgba(187,152,99,0.20);
  transition:
    width 260ms var(--ease-instrument),
    height 260ms var(--ease-instrument),
    margin-top 260ms var(--ease-instrument),
    transform 180ms var(--ease-quiet),
    box-shadow 220ms var(--ease-quiet),
    background 200ms var(--ease-quiet),
    color 200ms var(--ease-quiet),
    border-color 200ms var(--ease-quiet);
}
.task__realize:hover {
  background: var(--gold-1);
  color: #fff;
  transform: scale(1.08);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.4) inset,
    0 6px 14px -2px rgba(187,152,99,0.55),
    0 0 0 6px rgba(187,152,99,0.16);
}
.task__realize:active { transform: scale(0.96); }
.task__realize:focus-visible {
  outline: 2px solid var(--gold-1);
  outline-offset: 3px;
}
.task__realize-ring { display: none; }

.task__realize-check,
.task__realize-undo {
  position: absolute;
  display: block;
  color: currentColor;
  opacity: 0;
  transition: opacity 180ms var(--ease-quiet);
  pointer-events: none;
}
/* Uncompleted: check appears on hover only */
.task__realize:hover .task__realize-check { opacity: 1; }

/* === Completed state ===
   Card stays in column; only title + Aligned badge + realize circle remain visible. */
.task.is-completed .task__realize {
  width: 30px; height: 30px;
  margin-top: 12px;
  background: var(--gold-1);
  color: #fff;
  border-color: var(--gold-1);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.4) inset,
    0 3px 8px -3px rgba(187,152,99,0.40);
}
.task.is-completed .task__realize:hover {
  transform: scale(1.08);
  background: var(--ink-2);
  border-color: var(--ink-2);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.25) inset,
    0 4px 10px -3px rgba(26,28,28,0.30);
}
.task.is-completed .task__realize-check { opacity: 1; }
.task.is-completed .task__realize:hover .task__realize-check { opacity: 0; }
.task.is-completed .task__realize:hover .task__realize-undo { opacity: 1; }

.task.is-completed .task__title {
  text-decoration: line-through;
  text-decoration-thickness: 1.5px;
  text-decoration-color: var(--ink-3);
  color: var(--ink-3);
}
.task.is-completed .task__text,
.task.is-completed .task__foot,
.task.is-completed .task__prune,
.task.is-completed .task__due { display: none; }
.task.is-completed { background: var(--parchment-1); cursor: default; }
.task.is-completed:hover {
  transform: none;
  border-color: var(--gold-1);
  box-shadow: 0 1px 0 rgba(0,0,0,0.03);
}
.task.is-completed.is-high-resonance { background: linear-gradient(180deg, rgba(187,152,99,0.07), var(--parchment-1) 60%); }

/* Drawer states (Realized / Dismissed folder rendering) */
.task__realize--done {
  background: var(--gold-1);
  color: #fff;
  cursor: default;
  box-shadow: 0 1px 0 rgba(255,255,255,0.4) inset;
  width: 44px; height: 44px;
  border-radius: 9999px;
  display: inline-flex; align-items: center; justify-content: center;
  align-self: start;
  margin-top: 10px;
  margin-left: 4px;
  border: 0;
}
.task__realize--done .task__realize-check { opacity: 1; position: static; }
.task__realize--dismissed {
  background: var(--ink-4);
  color: #fff;
  cursor: default;
  box-shadow: 0 1px 0 rgba(255,255,255,0.2) inset;
  width: 44px; height: 44px;
  border-radius: 9999px;
  display: inline-flex; align-items: center; justify-content: center;
  align-self: start;
  margin-top: 10px;
  margin-left: 4px;
  border: 0;
}
.task__realize--dismissed .task__realize-check { opacity: 1; position: static; }

/* Task body */
.task__body {
  display: flex; flex-direction: column; gap: 6px;
  min-width: 0;
}
.task__head {
  display: flex; align-items: center; gap: 10px;
  flex-wrap: wrap;
}
.task__domain {
  font-family: var(--font-sans-tight);
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.task__due {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--gold-2);
  letter-spacing: 0.02em;
  padding: 1px 6px;
  border: 1px solid var(--gold-soft);
  background: var(--gold-soft);
}
.task__prune {
  margin-left: auto;
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  background: transparent;
  border: 1px solid var(--attention-amber);
  color: var(--attention-amber);
  padding: 2px 8px;
  cursor: pointer;
  transition: all var(--duration-hover) var(--ease-quiet);
}
.task__prune:hover { background: rgba(250,204,21,0.12); }

.task__title {
  margin: 0;
  color: var(--ink-1);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-wrap: pretty;
}
.task__text {
  margin: 0;
  font-family: var(--font-serif-display);
  font-size: 12px;
  line-height: 17px;
  color: var(--ink-2);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-wrap: pretty;
}


/* Clickable title */
.task__title--link {
  cursor: pointer;
  transition: color var(--duration-hover) var(--ease-quiet);
}
.task__title--link:hover {
  color: var(--gold-2);
  text-decoration: underline;
  text-decoration-color: var(--gold-1);
  text-underline-offset: 2px;
}

/* Body text — 3-line clamp */
.task__text--clamp {
  -webkit-line-clamp: 3;
}

/* Foot — Remove pill anchored bottom-right */
.task__foot {
  display: flex; align-items: center; justify-content: flex-end;
  margin-top: 6px;
  gap: 8px;
}
.task__foot:empty { display: none; }

.task__dismiss {
  background: transparent;
  border: 1px solid var(--stone-3);
  color: var(--ink-3);
  padding: 5px 12px;
  font-family: var(--font-sans-tight);
  font-weight: 500;
  font-size: 9px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  cursor: pointer;
  opacity: 0.6;
  transition: all var(--duration-hover) var(--ease-quiet);
}
.task:hover .task__dismiss,
.task:focus-within .task__dismiss { opacity: 1; }
.task__dismiss:hover {
  border-color: var(--friction-pink);
  color: var(--friction-pink);
  background: var(--friction-pink-bg);
}

/* Legacy ×-corner button rules left harmless if present */
.task__close { display: none; }
.task__tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--tag-color, var(--ink-2));
}
.task__tag-ico {
  width: 12px; height: 12px;
  mask: var(--ico) center/contain no-repeat;
  -webkit-mask: var(--ico) center/contain no-repeat;
}
.task__weight {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-2);
}
.task__weight-bar {
  width: 40px; height: 4px;
  background: var(--stone-2);
  position: relative;
  overflow: hidden;
  display: inline-block;
}
.task__weight-bar > span {
  position: absolute; top: 0; left: 0; bottom: 0;
  background: var(--gold-1);
  display: block;
}
.task__dismiss {
  background: transparent;
  border: 1px solid var(--stone-3);
  color: var(--ink-3);
  padding: 4px 10px;
  font-family: var(--font-sans-tight);
  font-weight: 500;
  font-size: 9px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all var(--duration-hover) var(--ease-quiet);
}
.task__dismiss:hover {
  border-color: var(--friction-pink);
  color: var(--friction-pink);
  background: var(--friction-pink-bg);
}

/* === Resonance % removed from task cards —
   High alignment is shown as the gold outline + True North chip instead. === */

/* Column header — title row with hover-only + */
.col__title-row {
  display: flex; align-items: center; gap: 8px;
  grid-column: 1 / -1;
}
.col__add {
  width: 22px; height: 22px;
  background: transparent;
  border: 1px solid var(--stone-3);
  color: var(--ink-3);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  opacity: 0;
  transition: opacity var(--duration-hover) var(--ease-quiet),
              border-color var(--duration-hover) var(--ease-quiet),
              color var(--duration-hover) var(--ease-quiet),
              background var(--duration-hover) var(--ease-quiet);
}
.col:hover .col__add,
.col:focus-within .col__add { opacity: 1; }
.col__add:hover {
  border-color: var(--gold-1);
  color: var(--gold-2);
  background: var(--gold-soft);
}

/* =============================================================================
   CAPTURE ACTION MODAL
   ========================================================================= */
.capture-veil {
  position: fixed; inset: 0;
  background: rgba(13,27,47,0.45);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex; align-items: flex-start; justify-content: center;
  z-index: 120;
  padding: 8vh 24px 24px;
  overflow-y: auto;
  animation: captureVeilIn 200ms var(--ease-instrument);
}
@keyframes captureVeilIn { from { opacity: 0; } to { opacity: 1; } }

.capture {
  width: min(620px, 100%);
  background: var(--parchment-0);
  border: 1px solid var(--stone-3);
  box-shadow:
    0 0 0 1px var(--gold-soft),
    0 30px 60px -20px rgba(0,0,0,0.32),
    0 12px 28px -12px rgba(0,0,0,0.22);
  padding: 32px 36px 28px;
  display: flex; flex-direction: column; gap: 20px;
  animation: captureIn 280ms var(--ease-instrument);
}
@keyframes captureIn {
  from { transform: translateY(12px) scale(0.985); opacity: 0; }
  to   { transform: translateY(0)    scale(1);     opacity: 1; }
}

.capture__head {
  display: flex; flex-direction: column; align-items: center;
  gap: 4px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--stone-2);
  text-align: center;
}
.capture__eye {
  color: var(--gold-2);
  letter-spacing: 0.32em;
}
.capture__lede {
  margin: 0;
  font-family: var(--font-serif-italic);
  font-style: italic;
  font-size: 15px;
  color: var(--ink-2);
  text-wrap: pretty;
}

/* Generic field */
.capture__field {
  display: flex; flex-direction: column; gap: 8px;
  min-width: 0;
}
.capture__field--align {
  display: flex; flex-direction: column; gap: 8px;
  min-width: 0;
}
.capture__label {
  display: flex; align-items: baseline; gap: 8px;
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.capture__req,
.capture__opt {
  font-family: var(--font-serif-italic);
  font-style: italic;
  font-size: 11px;
  letter-spacing: 0.02em;
  text-transform: none;
  color: var(--ink-4);
}
.capture__req { color: var(--gold-2); }

/* Inputs */
.capture__input {
  font-family: var(--font-serif-display);
  font-size: 16px;
  line-height: 24px;
  color: var(--ink-1);
  background: transparent;
  border: 0;
  outline: none;
  padding: 4px 0 6px;
  width: 100%;
}
.capture__input::placeholder { color: var(--ink-4); font-style: italic; }
.capture__input--name {
  font-size: 26px;
  line-height: 34px;
  letter-spacing: -0.005em;
  padding-bottom: 8px;
}
.capture__input--desc {
  font-family: var(--font-sans-tight);
  font-weight: 400;
  font-size: 13px;
  line-height: 20px;
  color: var(--ink-2);
  border: 1px solid var(--stone-2);
  background: #fff;
  padding: 10px 12px;
  resize: vertical;
  min-height: 56px;
  transition: border-color var(--duration-hover) var(--ease-quiet);
}
.capture__input--desc:focus { border-color: var(--gold-1); }
.capture__input--date {
  border: 1px solid var(--stone-2);
  background: #fff;
  padding: 10px 12px;
  font-family: var(--font-serif-display);
  font-size: 14px;
  margin-top: 6px;
}
.capture__input--date:focus { border-color: var(--gold-1); }
.capture__rule {
  display: block;
  height: 1px;
  background: linear-gradient(90deg, var(--gold-1) 0%, var(--gold-1) 32px, var(--stone-2) 32px, var(--stone-2) 100%);
}

/* Horizon pills */
.capture__pills {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.capture__pill {
  display: flex; flex-direction: column; align-items: flex-start; gap: 4px;
  padding: 12px 14px;
  background: #fff;
  border: 1px solid var(--stone-2);
  cursor: pointer;
  text-align: left;
  transition: all var(--duration-hover) var(--ease-quiet);
}
.capture__pill:hover {
  border-color: var(--gold-1);
  background: var(--parchment-1);
}
.capture__pill.is-on {
  border-color: var(--gold-1);
  background: var(--gold-soft);
  box-shadow: inset 3px 0 0 var(--gold-1);
}
.capture__pill-tag {
  font-family: var(--font-serif-display);
  font-size: 14px;
  color: var(--ink-1);
}
.capture__pill-dest {
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.capture__pill.is-on .capture__pill-dest { color: var(--gold-2); }

/* Capture type selector — Action / Daily Log / Practice */
.capture__type {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  margin-bottom: 16px;
}
.capture__type-pill {
  padding: 8px 10px;
  background: #fff;
  border: 1px solid var(--stone-2);
  cursor: pointer;
  font-family: var(--font-sans-tight);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-3);
  transition: all var(--duration-hover) var(--ease-quiet);
}
.capture__type-pill:hover {
  border-color: var(--gold-1);
  background: var(--parchment-1);
}
.capture__type-pill.is-active {
  border-color: var(--gold-1);
  background: var(--gold-soft);
  color: var(--gold-2);
}

/* Auto-Align button — the "smart" action */
.capture__autoalign {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  gap: 10px;
  padding: 14px 22px;
  background: var(--gold-1);
  color: var(--gold-3);
  border: 0;
  font-family: var(--font-sans-tight);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow:
    0 0 0 1px rgba(187,152,99,0.65),
    0 6px 14px -4px rgba(187,152,99,0.45),
    0 0 18px rgba(212,175,55,0.20);
  transition: transform 180ms var(--ease-quiet), background 200ms var(--ease-quiet), box-shadow 220ms var(--ease-quiet);
}
.capture__autoalign:hover {
  background: var(--gold-2);
  transform: translateY(-1px);
  color: #fff;
  box-shadow:
    0 0 0 1px var(--gold-2),
    0 8px 16px -4px rgba(187,152,99,0.55),
    0 0 24px rgba(212,175,55,0.30);
}
.capture__autoalign:active { transform: translateY(0); }
.capture__autoalign-glyph {
  font-family: var(--font-serif-display);
  font-size: 14px;
  line-height: 1;
}
.capture__autoalign-msg {
  margin: -8px 0 0;
  font-family: var(--font-serif-italic);
  font-style: italic;
  font-size: 13px;
  color: var(--gold-2);
  text-align: center;
  transition: opacity 800ms ease;
}
.capture__autoalign-msg.is-fading { opacity: 0; }

/* Manual overrides */
.capture__overrides {
  display: flex; flex-direction: column; gap: 14px;
  padding: 16px;
  background: var(--parchment-1);
  border: 1px solid var(--stone-2);
}
.capture__overrides-eye {
  color: var(--ink-3);
  letter-spacing: 0.28em;
}

/* Domain chips — color-coded by life-domain */
.capture__domains {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.capture__domain-chip {
  position: relative;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 12px 7px 8px;
  background: #fff;
  border: 1px solid var(--stone-2);
  cursor: pointer;
  font-family: var(--font-sans-tight);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-2);
  transition: all var(--duration-hover) var(--ease-quiet);
}
.capture__domain-strip {
  display: inline-block;
  width: 4px; height: 12px;
  background: var(--chip-color, var(--ink-3));
}
.capture__domain-chip:hover {
  border-color: var(--chip-color);
  color: var(--ink-1);
}
.capture__domain-chip.is-on {
  border-color: var(--chip-color);
  color: var(--ink-1);
  background: #fff;
  box-shadow: inset 0 -2px 0 var(--chip-color);
}

/* Value-Aligned toggle */
.capture__align-toggle {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  background: #fff;
  border: 1px solid var(--stone-2);
  cursor: pointer;
  font-family: var(--font-serif-display);
  font-size: 14px;
  color: var(--ink-1);
  transition: all var(--duration-hover) var(--ease-quiet);
  width: fit-content;
}
.capture__align-toggle:hover { border-color: var(--gold-1); }
.capture__align-toggle.is-on {
  border-color: var(--gold-1);
  background: var(--gold-soft);
}
.capture__align-box {
  width: 16px; height: 16px;
  border: 1.5px solid var(--ink-3);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--gold-2);
  background: #fff;
  transition: all var(--duration-hover) var(--ease-quiet);
}
.capture__align-toggle.is-on .capture__align-box {
  background: var(--gold-1);
  border-color: var(--gold-1);
  color: #fff;
}
.capture__align-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-family: var(--font-sans-tight);
  font-weight: 600;
  font-size: 9px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--parchment-0);
  padding: 3px 8px;
  background: var(--gold-1);
  box-shadow:
    0 0 0 1px rgba(187,152,99,0.6),
    0 2px 8px -2px rgba(187,152,99,0.55),
    0 0 12px rgba(212,175,55,0.25);
}
.capture__align-badge span { font-size: 10px; line-height: 1; }

/* Footer */
.capture__foot {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 18px;
  border-top: 1px solid var(--stone-2);
}
.capture__dismiss {
  background: transparent;
  border: 0;
  padding: 0;
  font-family: var(--font-sans-tight);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-3);
  cursor: pointer;
  border-bottom: 1px solid transparent;
  transition: color var(--duration-hover) var(--ease-quiet), border-color var(--duration-hover) var(--ease-quiet);
}
.capture__dismiss:hover { color: var(--ink-1); border-bottom-color: var(--ink-3); }

.capture__commit {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 12px 22px;
  background: var(--ink-1);
  color: var(--parchment-0);
  border: 0;
  font-family: var(--font-sans-tight);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background var(--duration-hover) var(--ease-quiet), opacity var(--duration-hover) var(--ease-quiet);
}
.capture__commit:hover { background: var(--gold-1); color: var(--gold-3); }
.capture__commit:disabled { opacity: 0.35; cursor: not-allowed; }
.capture__commit:disabled:hover { background: var(--ink-1); color: var(--parchment-0); }
.capture__kbd {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.04em;
  padding: 2px 6px;
  border: 1px solid rgba(255,255,255,0.25);
  color: rgba(255,255,255,0.65);
  text-transform: none;
}
.capture__commit:hover .capture__kbd {
  border-color: rgba(40,24,0,0.35);
  color: var(--gold-3);
}

/* === Morning Haze button — moon glyph */
.actions-dash__btn--haze {
  border-color: var(--stone-3);
  color: var(--ink-2);
  background: var(--parchment-1);
}
.actions-dash__btn--haze:hover {
  border-color: var(--ink-2);
  color: var(--ink-1);
  background: var(--parchment-2);
}
.actions-dash__btn--haze .actions-dash__btn-plus {
  font-family: var(--font-serif-display);
  font-size: 14px;
  color: var(--ink-2);
}

/* === THE MORNING HAZE === */
.actions-dash__board {
  position: relative;
  background: var(--parchment-0);
  padding: 0;
  transition: filter 320ms var(--ease-instrument);
}
.actions-dash__board.is-hazed { /* the wash handles the visual */ }

.refresh {
  position: absolute;
  inset: 0;
  z-index: 70;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 80px 32px 32px;
  animation: refreshIn 320ms var(--ease-instrument);
}
@keyframes refreshIn { from { opacity: 0; } to { opacity: 1; } }

.refresh__wash {
  position: absolute;
  inset: 0;
  background: rgba(168, 162, 158, 0.80);
  backdrop-filter: blur(2px) saturate(0.6);
  -webkit-backdrop-filter: blur(2px) saturate(0.6);
}

.refresh__ritual {
  position: relative;
  width: min(540px, 100%);
  background: var(--parchment-0);
  border: 1px solid var(--stone-3);
  box-shadow:
    0 0 0 1px rgba(187,152,99,0.18),
    0 30px 60px -20px rgba(13,27,47,0.45),
    0 12px 28px -12px rgba(13,27,47,0.30);
  padding: 32px 36px 28px;
  display: flex; flex-direction: column; align-items: center;
  gap: 14px;
  text-align: center;
  animation: refreshRitualIn 360ms var(--ease-instrument);
}
@keyframes refreshRitualIn {
  from { transform: translateY(-12px); opacity: 0; }
  to   { transform: translateY(0);     opacity: 1; }
}

.refresh__eye {
  color: var(--gold-2);
  letter-spacing: 0.32em;
}
.refresh__title {
  margin: 4px 0 0;
  font-family: var(--font-serif-display);
  font-weight: 400;
  font-size: 30px;
  line-height: 38px;
  letter-spacing: -0.01em;
  color: var(--ink-1);
}
.refresh__sub {
  margin: 0;
  font-family: var(--font-serif-display);
  font-style: italic;
  font-size: 15px;
  line-height: 24px;
  color: var(--ink-2);
  max-width: 44ch;
  text-wrap: pretty;
}
.refresh__sub strong {
  font-style: normal;
  font-weight: 600;
  color: var(--gold-2);
}

.refresh__actions {
  display: flex; flex-direction: column; align-items: center;
  gap: 10px;
  margin-top: 8px;
}

.refresh__btn {
  font-family: var(--font-sans-tight);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  padding: 14px 30px;
  cursor: pointer;
  border: 0;
  transition: all var(--duration-hover) var(--ease-quiet);
  position: relative;
}
.refresh__btn--primary {
  background: var(--gold-1);
  color: var(--gold-3);
  box-shadow:
    0 0 0 1px rgba(187,152,99,0.65),
    0 6px 14px -4px rgba(187,152,99,0.45),
    0 0 18px rgba(212,175,55,0.20);
}
.refresh__btn--primary:hover {
  background: var(--gold-2);
  color: #fff;
  transform: translateY(-1px);
}
.refresh__btn--primary:active { transform: translateY(0); }
.refresh__btn-pulse {
  position: absolute;
  inset: -3px;
  border: 1.5px solid var(--gold-1);
  pointer-events: none;
  animation: ritualPulse 2200ms ease-in-out infinite;
}

.refresh__btn--link {
  background: transparent;
  color: var(--ink-3);
  padding: 8px 12px;
  letter-spacing: 0.22em;
  border-bottom: 1px solid transparent;
}
.refresh__btn--link:hover {
  color: var(--ink-1);
  border-bottom-color: var(--ink-3);
}

.refresh__note {
  margin: 6px 0 0;
  font-family: var(--font-serif-italic);
  font-style: italic;
  font-size: 12px;
  line-height: 18px;
  color: var(--ink-4);
  max-width: 40ch;
}

/* =============================================================================
   ARCHIVE COLUMN  —  narrow 4th column, expandable via chevron overlay
   ========================================================================= */
.archive-col {
  background: var(--parchment-2);
  border: 1px dashed var(--stone-3);
  height: 720px;
  position: relative;
  display: flex; flex-direction: column; align-items: center; gap: 14px;
  padding: 16px 0;
  cursor: pointer;
  transition: opacity 220ms ease-in-out, filter 220ms ease-in-out,
              background var(--duration-hover) var(--ease-quiet),
              border-color var(--duration-hover) var(--ease-quiet),
              box-shadow var(--duration-hover) var(--ease-quiet);
}
.archive-col.is-drag-over {
  background: var(--gold-soft);
  border-color: var(--gold-1);
  border-style: solid;
  box-shadow: inset 0 0 0 1px var(--gold-1);
}
/* Lens parity — narrow column dims with the rest */
.cols:has(.col:hover)        .archive-col:not(:hover) { opacity: 0.6; filter: saturate(0.9); }
.cols:has(.col:focus-within) .archive-col            { opacity: 0.6; filter: saturate(0.9); }
.cols:has(.col.is-drag-over) .archive-col:not(.is-drag-over) { opacity: 0.6; filter: saturate(0.9); }
.cols:has(.archive-col:hover)        .col:not(:hover)        { opacity: 0.6; filter: saturate(0.9); }
.cols:has(.archive-col.is-drag-over) .col:not(.is-drag-over) { opacity: 0.6; filter: saturate(0.9); }

.archive-col__chev {
  width: 32px; height: 32px;
  background: #fff;
  border: 1px solid var(--stone-3);
  color: var(--ink-2);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: all var(--duration-hover) var(--ease-quiet);
}
.archive-col__chev:hover {
  border-color: var(--gold-1);
  color: var(--gold-2);
  background: var(--gold-soft);
}
.archive-col__title {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-family: var(--font-serif-display);
  font-size: 11px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin: 8px 0;
}
.archive-col.is-drag-over .archive-col__title { color: var(--gold-2); }
.archive-col__drop {
  flex: 1 1 auto;
  align-self: stretch;
  margin: 0 12px;
  border: 1.5px dashed var(--stone-3);
  background: #fff;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 8px;
  transition: all var(--duration-hover) var(--ease-quiet);
}
.archive-col.is-drag-over .archive-col__drop {
  border-style: solid;
  border-color: var(--gold-1);
  background: rgba(187,152,99,0.10);
}
.archive-col__drop-ico {
  font-family: var(--font-mono);
  font-size: 18px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-3);
  letter-spacing: 0;
}
.archive-col.is-drag-over .archive-col__drop-ico { color: var(--gold-2); }
.archive-col__drop-lbl {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.archive-col.is-drag-over .archive-col__drop-lbl { color: var(--gold-2); }
.archive-col__meta {
  display: flex; flex-direction: column; gap: 6px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-3);
  align-items: center;
}
.archive-col__count strong {
  font-family: var(--font-serif-display);
  font-weight: 400;
  font-size: 16px;
  color: var(--ink-1);
  margin-right: 4px;
}

/* === Expanded overlay (slide-in from right) === */
.archive-overlay {
  position: fixed; inset: 0;
  background: rgba(13,27,47,0.45);
  backdrop-filter: blur(4px);
  z-index: 88;
  animation: archiveOverlayIn 200ms var(--ease-instrument);
}
@keyframes archiveOverlayIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.archive-panel {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: min(520px, 96vw);
  background: var(--parchment-2);
  color: var(--ink-1);
  border-left: 1px solid var(--stone-3);
  box-shadow: -20px 0 40px -10px rgba(0,0,0,0.18);
  z-index: 90;
  padding: 32px;
  display: flex; flex-direction: column; gap: 18px;
  overflow: auto;
  animation: archivePanelIn 240ms var(--ease-instrument);
}
@keyframes archivePanelIn {
  from { transform: translateX(40px); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}
.archive-panel__head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--stone-2);
}
.archive-panel__title {
  margin: 4px 0 0;
  font-family: var(--font-serif-display);
  font-size: 24px;
  color: var(--ink-1);
}
.archive-panel__close {
  background: transparent;
  border: 1px solid var(--stone-3);
  width: 32px; height: 32px;
  cursor: pointer;
  font-family: var(--font-serif-display);
  font-size: 18px;
  color: var(--ink-2);
  transition: border-color var(--duration-hover), color var(--duration-hover);
}
.archive-panel__close:hover { border-color: var(--gold-1); color: var(--gold-1); }
.archive-panel__sub {
  margin: 0;
  font-family: var(--font-serif-italic);
  font-size: 13px;
  color: var(--ink-3);
  text-wrap: pretty;
}
.archive-folders {
  display: flex; flex-direction: column; gap: 24px;
  margin-top: 8px;
}
.archive-folder { display: flex; flex-direction: column; gap: 10px; min-width: 0; }
.archive-folder__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 4px 8px;
  border-bottom: 1px solid var(--stone-2);
}
.archive-folder__eye {
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--ink-3);
}
.archive-folder--dismissed .archive-folder__eye { color: var(--ink-4); }
.archive-folder__count {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-3);
}
.archive-folder__list { display: flex; flex-direction: column; gap: 8px; }
.archive-folder__empty {
  padding: 14px;
  font-family: var(--font-serif-italic);
  font-size: 12px;
  color: var(--ink-4);
  margin: 0;
}
.archive-panel .task.is-compact { background: #fff; }
.archive-drawer.is-drag-over .archive-drawer__tab {
  border-style: solid;
  border-color: var(--gold-1);
  background: var(--gold-soft);
  color: var(--gold-2);
}
.archive-drawer.is-drag-over .archive-drawer__drop-hint {
  color: var(--gold-2);
  border-color: var(--gold-1);
  background: rgba(187,152,99,0.20);
}
.archive-drawer__tab {
  display: grid;
  grid-template-columns: 18px auto 1fr auto;
  gap: 16px;
  align-items: center;
  width: 100%;
  background: var(--parchment-1);
  border: 1.5px dashed var(--stone-3);
  padding: 18px 22px;
  cursor: pointer;
  font-family: var(--font-sans-tight);
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-2);
  transition: color var(--duration-hover) var(--ease-quiet), background var(--duration-hover) var(--ease-quiet), border-color var(--duration-hover) var(--ease-quiet);
}
.archive-drawer.is-open .archive-drawer__tab {
  background: var(--parchment-2);
  border-style: solid;
  border-color: var(--stone-2);
}
.archive-drawer__tab:hover {
  color: var(--ink-1);
  border-color: var(--gold-1);
  background: var(--parchment-1);
}
.archive-drawer__tab:hover .archive-drawer__drop-hint {
  color: var(--gold-2);
  border-color: var(--gold-1);
}
.archive-drawer__chev {
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--ink-3);
}
.archive-drawer.is-open .archive-drawer__chev,
.archive-drawer__tab:hover .archive-drawer__chev { color: var(--gold-2); }
.archive-drawer__lbl {
  font-family: var(--font-serif-display);
  font-weight: 400;
  font-size: 15px;
  letter-spacing: 0.02em;
  text-transform: none;
  color: var(--ink-1);
  justify-self: start;
}
.archive-drawer__drop-hint {
  justify-self: center;
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-sans-tight);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-3);
  padding: 6px 14px;
  border: 1px dashed var(--stone-3);
  background: #fff;
  transition: color var(--duration-hover) var(--ease-quiet), border-color var(--duration-hover) var(--ease-quiet), background var(--duration-hover) var(--ease-quiet);
}
.archive-drawer.is-open .archive-drawer__drop-hint { display: none; }
.archive-drawer__drop-ico {
  font-family: var(--font-mono);
  font-size: 12px;
  color: currentColor;
  letter-spacing: 0;
}
.archive-drawer__meta {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--font-sans-tight);
  font-size: 10px; letter-spacing: 0.22em;
  color: var(--ink-2);
}
.archive-drawer__meta > span {
  display: inline-flex; align-items: center; gap: 4px;
  color: var(--ink-2);
}
.archive-drawer__meta strong {
  font-weight: 600;
  color: var(--ink-1);
}
.archive-drawer__sep {
  color: var(--stone-3) !important;
  font-weight: 400;
  padding: 0 4px;
}
.archive-drawer__open-lbl {
  color: var(--gold-2) !important;
  font-weight: 600;
  letter-spacing: 0.28em;
}
.archive-drawer__tab:hover .archive-drawer__open-lbl { color: var(--gold-1) !important; }

.archive-drawer__body {
  border-top: 1px solid var(--stone-2);
  padding: 24px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  background: var(--parchment-1);
}

.archive-folder {
  display: flex; flex-direction: column; gap: 10px;
  min-width: 0;
}
.archive-folder__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 4px 8px;
  border-bottom: 1px solid var(--stone-2);
}
.archive-folder__eye {
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.archive-folder--dismissed .archive-folder__eye { color: var(--ink-4); }
.archive-folder__count {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-3);
}
.archive-folder__list { display: flex; flex-direction: column; gap: 8px; }
.archive-folder__empty {
  padding: 14px;
  font-family: var(--font-serif-italic);
  font-size: 12px;
  color: var(--ink-4);
  margin: 0;
}

/* =============================================================================
   MORNING REVIEW MODAL
   ========================================================================= */
.mr-veil {
  position: fixed; inset: 0;
  background: rgba(13,27,47,0.55);
  backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  z-index: 110;
  padding: 32px;
}
.mr {
  width: min(520px, 100%);
  background: var(--parchment-0);
  border: 1px solid var(--stone-3);
  padding: 32px;
  display: flex; flex-direction: column; gap: 16px;
  box-shadow: 0 24px 48px -16px rgba(0,0,0,0.32);
  animation: mrIn 240ms var(--ease-instrument);
}
@keyframes mrIn {
  from { transform: translateY(8px); opacity: 0; }
  to   { transform: translateY(0);   opacity: 1; }
}
.mr__eye {
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--gold-2);
}
.mr__title {
  margin: 4px 0 0;
  font-family: var(--font-serif-display);
  font-size: 28px;
  color: var(--ink-1);
}
.mr__sub {
  margin: 0;
  color: var(--ink-3);
  font-family: var(--font-serif-display);
  font-size: 14px;
}
.mr__actions {
  display: flex; gap: 12px;
  margin-top: 8px;
}
.mr__btn {
  font-family: var(--font-sans-tight);
  font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
  padding: 14px 22px;
  background: transparent;
  border: 1px solid var(--stone-3);
  color: var(--ink-2);
  cursor: pointer;
  transition: all var(--duration-hover) var(--ease-quiet);
}
.mr__btn:hover { border-color: var(--gold-1); color: var(--gold-2); background: var(--gold-soft); }
.mr__btn--primary {
  background: var(--gold-1);
  border-color: var(--gold-1);
  color: var(--gold-3);
}
.mr__btn--primary:hover { background: var(--gold-2); color: #fff; border-color: var(--gold-2); }
.mr__dismiss {
  align-self: flex-start;
  background: transparent; border: 0; padding: 0;
  font-family: var(--font-sans-tight);
  font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-3);
  cursor: pointer;
  margin-top: 4px;
}
.mr__dismiss:hover { color: var(--gold-2); }


/* =============================================================================
   Task Detail Modal
   ============================================================================= */
.task-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px;
  background: rgba(13, 27, 47, 0.55);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  animation: refreshIn 220ms var(--ease-instrument);
}
.task-modal__panel {
  width: min(580px, 100%);
  background: var(--parchment-0);
  border: 1px solid var(--stone-3);
  box-shadow: 0 30px 60px -20px rgba(13,27,47,0.45), 0 12px 28px -12px rgba(13,27,47,0.30);
  padding: 32px 36px 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  animation: refreshRitualIn 280ms var(--ease-instrument);
}
.task-modal__head {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.task-modal__domain {
  letter-spacing: 0.3em;
  font-size: 10px;
}
.task-modal__title {
  margin: 0;
  font-family: var(--font-serif-display);
  font-weight: 600;
  font-size: 22px;
  line-height: 30px;
  color: var(--ink-1);
}
.task-modal__age {
  font-family: var(--font-sans-tight);
  font-size: 11px;
  color: var(--ink-4);
  letter-spacing: 0.12em;
}
.task-modal__snippet {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.task-modal__snippet-eye {
  letter-spacing: 0.28em;
  font-size: 10px;
  color: var(--ink-4);
}
.task-modal__quote {
  margin: 0;
  padding: 12px 16px;
  border-left: 2px solid var(--gold-1);
  font-family: var(--font-serif-display);
  font-style: italic;
  font-size: 14px;
  line-height: 22px;
  color: var(--ink-2);
  background: rgba(187,152,99,0.05);
}
.task-modal__expand {
  align-self: flex-start;
  background: transparent;
  border: 0;
  padding: 0;
  font-family: var(--font-sans-tight);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold-2);
  cursor: pointer;
}
.task-modal__expand:hover { text-decoration: underline; }
.task-modal__context {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.task-modal__loading {
  font-family: var(--font-serif-display);
  font-style: italic;
  font-size: 13px;
  color: var(--ink-4);
}
.task-modal__ctx-para {
  margin: 0;
  font-family: var(--font-serif-display);
  font-size: 13px;
  line-height: 20px;
  color: var(--ink-3);
}
.task-modal__ctx-para--before,
.task-modal__ctx-para--after { opacity: 0.65; }
.task-modal__ctx-para--highlight {
  color: var(--ink-1);
  opacity: 1;
  font-weight: 500;
}
.task-modal__foot {
  display: flex;
  justify-content: flex-end;
  margin-top: 4px;
}

/* =============================================================================
   Responsive
   ========================================================================= */
@media (max-width: 1180px) {
  .cols { grid-template-columns: 1fr; }
  .archive-drawer__body { grid-template-columns: 1fr; }
  .col--horizon, .col--intentions { opacity: 1; filter: none; }
}

/* ── Drop Slot ─────────────────────────────────────── */
.drop-slot {
  height: 2px;
  margin: 1px 0;
  border-radius: 2px;
  background: transparent;
  pointer-events: none;
  flex-shrink: 0;
  transition: height 0.12s ease, background 0.12s ease, box-shadow 0.12s ease;
}
.drop-slot.is-active {
  height: 36px;
  border: 1.5px dashed var(--gold, #BB9863);
  border-radius: 8px;
  background: rgba(187, 152, 99, 0.05);
  box-shadow: inset 0 0 0 1px rgba(187,152,99,0.15);
}

/* =============================================================================
   DETAIL DRAWER  —  slide-in from right, full-height panel
   ========================================================================= */
.drawer-backdrop {
  position: fixed; inset: 0;
  background: rgba(13,27,47,0.40);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  z-index: 1100;
  animation: captureVeilIn 180ms var(--ease-instrument);
}

.detail-drawer {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: min(560px, 96vw);
  background: var(--parchment-0);
  border-left: 1px solid var(--stone-3);
  box-shadow: -24px 0 48px -12px rgba(13,27,47,0.22), -4px 0 12px -4px rgba(13,27,47,0.10);
  z-index: 1200;
  display: flex; flex-direction: column;
  overflow: hidden;
  animation: drawerSlideIn 240ms var(--ease-instrument);
}
@keyframes drawerSlideIn {
  from { transform: translateX(56px); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}

.detail-drawer__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 28px 16px;
  border-bottom: 1px solid var(--stone-2);
  flex-shrink: 0;
  gap: 16px;
}
.detail-drawer__eyebrow {
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--ink-4);
}
.detail-drawer__title-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.detail-drawer__domain-dot {
  flex-shrink: 0;
  width: 10px; height: 10px;
  border-radius: 50%;
  margin-top: 10px;
}
.detail-drawer__save-status {
  font-family: var(--font-serif-italic);
  font-style: italic;
  font-size: 12px;
  color: var(--ink-4);
  min-width: 52px;
  text-align: right;
  transition: color 200ms ease;
}
.detail-drawer__save-status.is-saving { color: var(--gold-2); }
.detail-drawer__close {
  width: 32px; height: 32px;
  background: transparent;
  border: 1px solid var(--stone-3);
  color: var(--ink-2);
  cursor: pointer;
  font-family: var(--font-serif-display);
  font-size: 18px;
  display: inline-flex; align-items: center; justify-content: center;
  transition: border-color var(--duration-hover), color var(--duration-hover);
  flex-shrink: 0;
}
.detail-drawer__close:hover { border-color: var(--gold-1); color: var(--gold-1); }

.detail-drawer__body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 24px 28px;
  display: flex; flex-direction: column; gap: 20px;
  scrollbar-width: thin;
  scrollbar-color: var(--stone-3) transparent;
}
.detail-drawer__body::-webkit-scrollbar { width: 6px; }
.detail-drawer__body::-webkit-scrollbar-thumb { background: var(--stone-3); }

.detail-drawer__field {
  display: flex; flex-direction: column; gap: 6px;
}
.detail-drawer__label {
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--ink-3);
}
.detail-drawer__input {
  font-family: var(--font-serif-display);
  font-size: 22px; line-height: 30px;
  color: var(--ink-1);
  border: 0;
  border-bottom: 1px solid var(--stone-2);
  background: transparent;
  outline: none;
  width: 100%;
  padding: 4px 0 8px;
  transition: border-color var(--duration-hover);
}
.detail-drawer__input:focus { border-bottom-color: var(--gold-1); }
.detail-drawer__textarea {
  font-family: var(--font-sans-tight);
  font-size: 13px; line-height: 20px;
  color: var(--ink-2);
  border: 1px solid var(--stone-2);
  background: #fff;
  padding: 10px 12px;
  resize: vertical;
  min-height: 72px;
  outline: none;
  transition: border-color var(--duration-hover);
}
.detail-drawer__textarea:focus { border-color: var(--gold-1); }

/* Origin snippet — immutable quote */
.detail-drawer__snippet {
  padding: 12px 16px;
  border-left: 2px solid var(--gold-1);
  background: rgba(187,152,99,0.05);
}
.detail-drawer__snippet p {
  margin: 0;
  font-family: var(--font-serif-display);
  font-style: italic;
  font-size: 13px; line-height: 21px;
  color: var(--ink-3);
}

/* AI Refine button */
.detail-drawer__refine {
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 16px;
  background: transparent;
  border: 1px solid var(--gold-1);
  color: var(--gold-2);
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase;
  cursor: pointer;
  transition: all var(--duration-hover) var(--ease-quiet);
}
.detail-drawer__refine:hover {
  background: var(--gold-soft);
  color: var(--gold-3);
  border-color: var(--gold-2);
}
.detail-drawer__refine:disabled { opacity: 0.4; cursor: not-allowed; }

/* Update timeline */
.detail-drawer__timeline {
  display: flex; flex-direction: column; gap: 8px;
  margin-top: 4px;
}
.detail-drawer__update {
  display: flex; flex-direction: column; gap: 3px;
  padding: 10px 12px;
  background: var(--parchment-1);
  border-left: 2px solid var(--stone-3);
}
.detail-drawer__update-date {
  font-family: var(--font-mono);
  font-size: 10px; color: var(--ink-4);
}
.detail-drawer__update-body {
  margin: 0;
  font-family: var(--font-serif-display);
  font-size: 13px; line-height: 20px;
  color: var(--ink-2);
}

/* Add update input */
.detail-drawer__add-update {
  display: flex; gap: 8px;
}
.detail-drawer__update-input {
  flex: 1;
  font-family: var(--font-serif-display);
  font-size: 13px;
  border: 1px solid var(--stone-2);
  background: #fff;
  padding: 8px 12px;
  outline: none;
  transition: border-color var(--duration-hover);
}
.detail-drawer__update-input:focus { border-color: var(--gold-1); }
.detail-drawer__update-submit {
  padding: 8px 14px;
  background: var(--ink-1);
  color: var(--parchment-0);
  border: 0;
  font-family: var(--font-sans-tight);
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  cursor: pointer;
  transition: background var(--duration-hover);
}
.detail-drawer__update-submit:hover { background: var(--gold-1); color: var(--gold-3); }

/* Footer actions */
.detail-drawer__foot {
  flex-shrink: 0;
  padding: 14px 28px 18px;
  border-top: 1px solid var(--stone-2);
  display: flex; gap: 8px; align-items: center;
  flex-wrap: wrap;
}
.detail-drawer__action {
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase;
  padding: 9px 14px;
  background: transparent;
  border: 1px solid var(--stone-3);
  color: var(--ink-2);
  cursor: pointer;
  transition: all var(--duration-hover) var(--ease-quiet);
}
.detail-drawer__action:hover { border-color: var(--gold-1); color: var(--gold-2); background: var(--gold-soft); }
.detail-drawer__action--done:hover { border-color: var(--gold-2); color: var(--gold-3); background: var(--gold-soft); }
.detail-drawer__action--archive:hover { border-color: var(--ink-2); color: var(--ink-1); }
.detail-drawer__action--delete {
  color: var(--friction-pink);
  border-color: var(--friction-pink);
  margin-left: auto;
  opacity: 0.55;
}
.detail-drawer__action--delete:hover {
  background: var(--friction-pink-bg);
  color: var(--friction-pink);
  border-color: var(--friction-pink);
  opacity: 1;
}
.detail-drawer__action--delete-confirm {
  background: var(--friction-pink-bg);
  border-color: var(--friction-pink);
  color: var(--friction-pink);
  opacity: 1;
  font-weight: 600;
  margin-left: auto;
}

/* =============================================================================
   REVIEW MODE  —  full-screen overlay
   ========================================================================= */
.review-mode-veil {
  position: fixed; inset: 0;
  background: rgba(13,27,47,0.52);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 130;
  display: flex; align-items: flex-start; justify-content: center;
  padding: 6vh 24px 40px;
  overflow-y: auto;
  animation: captureVeilIn 220ms var(--ease-instrument);
}

/* old inner-panel .review-mode removed — see .review-mode__panel below */

.review-mode__head {
  padding: 28px 32px 20px;
  border-bottom: 1px solid var(--stone-2);
  display: flex; flex-direction: column; gap: 6px;
}
.review-mode__eye {
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.30em; text-transform: uppercase;
  color: var(--gold-2);
}
.review-mode__title {
  margin: 4px 0 0;
  font-family: var(--font-serif-display);
  font-weight: 400;
  font-size: 28px;
  color: var(--ink-1);
}
.review-mode__sub {
  margin: 2px 0 0;
  font-family: var(--font-serif-display);
  font-style: italic;
  font-size: 14px;
  color: var(--ink-3);
}

.review-mode__body {
  padding: 24px 32px;
  display: flex; flex-direction: column; gap: 22px;
}

.review-mode__section-title {
  display: flex; align-items: center; gap: 10px;
  margin: 0 0 10px;
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.26em; text-transform: uppercase;
  color: var(--ink-3);
  padding-bottom: 8px;
  border-bottom: 1px solid var(--stone-2);
}
.review-mode__section-count {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--gold-2);
}

.review-mode__item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px;
  background: var(--parchment-1);
  border: 1px solid var(--stone-2);
  gap: 14px;
}
.review-mode__item-title {
  font-family: var(--font-serif-display);
  font-size: 15px; color: var(--ink-1);
  flex: 1;
}
.review-mode__item-meta {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--gold-2);
  white-space: nowrap;
}

.review-mode__empty {
  padding: 16px;
  font-family: var(--font-serif-italic);
  font-style: italic;
  font-size: 13px;
  color: var(--ink-4);
  text-align: center;
}

.review-mode__foot {
  padding: 18px 32px 24px;
  border-top: 1px solid var(--stone-2);
  display: flex; gap: 12px; align-items: center;
}
.review-mode__btn {
  font-family: var(--font-sans-tight);
  font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase;
  padding: 14px 24px;
  cursor: pointer;
  border: 1px solid var(--stone-3);
  background: transparent;
  color: var(--ink-2);
  transition: all var(--duration-hover) var(--ease-quiet);
}
.review-mode__btn:hover { border-color: var(--gold-1); color: var(--gold-2); background: var(--gold-soft); }
.review-mode__btn--primary {
  background: var(--gold-1);
  border-color: var(--gold-1);
  color: var(--gold-3);
  font-weight: 600;
}
.review-mode__btn--primary:hover { background: var(--gold-2); color: #fff; border-color: var(--gold-2); }
.review-mode__skip {
  margin-left: auto;
  background: transparent; border: 0; padding: 0;
  font-family: var(--font-sans-tight);
  font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-4); cursor: pointer;
  transition: color var(--duration-hover);
}
.review-mode__skip:hover { color: var(--ink-2); }

/* =============================================================================
   UNDO TOAST
   ========================================================================= */
.undo-toast {
  position: fixed;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex; align-items: center; gap: 14px;
  padding: 12px 18px;
  background: var(--ink-1);
  color: var(--parchment-0);
  border: 0;
  box-shadow: 0 8px 24px -6px rgba(13,27,47,0.45), 0 2px 8px -2px rgba(13,27,47,0.25);
  z-index: 300;
  animation: toastIn 220ms var(--ease-instrument);
  white-space: nowrap;
}
@keyframes toastIn {
  from { transform: translateX(-50%) translateY(14px); opacity: 0; }
  to   { transform: translateX(-50%) translateY(0);    opacity: 1; }
}
.undo-toast__msg {
  font-family: var(--font-sans-tight);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--parchment-1);
}
.undo-toast__undo {
  font-family: var(--font-sans-tight);
  font-weight: 600;
  font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
  padding: 6px 12px;
  background: var(--gold-1);
  color: var(--gold-3);
  border: 0;
  cursor: pointer;
  transition: background var(--duration-hover);
}
.undo-toast__undo:hover { background: var(--gold-2); color: #fff; }
.undo-toast__close {
  width: 22px; height: 22px;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.2);
  color: rgba(255,255,255,0.5);
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 14px;
  transition: border-color var(--duration-hover), color var(--duration-hover);
}
.undo-toast__close:hover { border-color: rgba(255,255,255,0.6); color: #fff; }

/* =============================================================================
   SORT CONTROL  —  per-column sort dropdown
   ========================================================================= */
.col__sort-wrap {
  grid-column: 1 / -1;
  display: flex; align-items: center; gap: 8px;
  margin-top: 4px;
  position: relative;
}
.col__sort-btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: transparent;
  border: 1px solid var(--stone-2);
  padding: 4px 10px;
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-3);
  cursor: pointer;
  transition: all var(--duration-hover) var(--ease-quiet);
}
.col__sort-btn:hover { border-color: var(--gold-1); color: var(--gold-2); background: var(--gold-soft); }
.col__sort-chip {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--gold-soft);
  border: 1px solid var(--gold-1);
  padding: 2px 8px;
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--gold-2);
}
.col__sort-menu {
  position: absolute;
  top: 100%; left: 0;
  margin-top: 4px;
  background: var(--parchment-0);
  border: 1px solid var(--stone-3);
  box-shadow: 0 8px 20px -6px rgba(13,27,47,0.20);
  z-index: 40;
  min-width: 180px;
  display: flex; flex-direction: column;
  animation: captureIn 160ms var(--ease-instrument);
}
.col__sort-opt {
  padding: 9px 14px;
  font-family: var(--font-sans-tight);
  font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-2);
  cursor: pointer;
  background: transparent;
  border: 0;
  text-align: left;
  transition: background var(--duration-hover), color var(--duration-hover);
}
.col__sort-opt:hover { background: var(--gold-soft); color: var(--gold-2); }
.col__sort-opt.is-active { color: var(--gold-2); background: var(--parchment-1); font-weight: 600; }

/* =============================================================================
   TASK OPEN AFFORDANCE  — ↗ appears on hover
   ========================================================================= */
.task__open {
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px;
  font-size: 13px;
  color: var(--ink-3);
  cursor: pointer;
  opacity: 0;
  transition: opacity var(--duration-hover) var(--ease-quiet), color var(--duration-hover);
  margin-left: auto;
  flex-shrink: 0;
}
.task:hover .task__open { opacity: 1; }
.task__open:hover { color: var(--gold-2); }

/* =============================================================================
   DUE DATE CHIPS  —  state-coded status badges
   ========================================================================= */
.chip {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.02em;
  padding: 2px 7px;
  border: 1px solid;
  white-space: nowrap;
}
.chip--far {
  color: var(--ink-3);
  border-color: var(--stone-3);
  background: transparent;
}
.chip--upcoming {
  color: var(--gold-2);
  border-color: var(--gold-soft);
  background: var(--gold-soft);
}
.chip--today {
  color: var(--gold-3);
  border-color: var(--gold-1);
  background: var(--gold-soft);
  font-weight: 600;
}
.chip--drifted {
  color: var(--friction-pink, #e2445c);
  border-color: rgba(226,68,92,0.25);
  background: rgba(226,68,92,0.07);
}
.chip--drifted::before {
  content: "⚓";
  font-size: 9px;
  opacity: 0.7;
}

/* =============================================================================
   ARCHIVE DRAWER  —  new list-based items with Restore button
   ========================================================================= */
.archive-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px;
  background: #fff;
  border: 1px solid var(--stone-2);
  transition: border-color var(--duration-hover);
}
.archive-item:hover { border-color: var(--stone-3); }
.archive-item__title {
  flex: 1;
  font-family: var(--font-serif-display);
  font-size: 14px; line-height: 20px;
  color: var(--ink-2);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.archive-item__restore {
  flex-shrink: 0;
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase;
  padding: 5px 10px;
  background: transparent;
  border: 1px solid var(--stone-3);
  color: var(--ink-3);
  cursor: pointer;
  transition: all var(--duration-hover) var(--ease-quiet);
}
.archive-item__restore:hover {
  border-color: var(--gold-1);
  color: var(--gold-2);
  background: var(--gold-soft);
}

/* =============================================================================
   DETAIL DRAWER — actual JSX class names
   ========================================================================= */
.detail-drawer__inner {
  display: flex; flex-direction: column;
  height: 100%;
  overflow: hidden;
}
.detail-drawer__scroll-body {
  flex: 1 1 auto;
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: var(--stone-3) transparent;
}
.detail-drawer__scroll-body::-webkit-scrollbar { width: 5px; }
.detail-drawer__scroll-body::-webkit-scrollbar-thumb { background: var(--stone-3); }
.detail-drawer__zone {
  padding: 20px 28px;
  display: flex; flex-direction: column; gap: 12px;
}
.detail-drawer__zone--header {
  padding-bottom: 8px;
}
.detail-drawer__zone--updates {
}
.detail-drawer__zone--footer {
  flex-shrink: 0;
  display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
  padding: 14px 28px;
}
.detail-drawer__topbar {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
}
.detail-drawer__topbar-right {
  display: flex; align-items: center; gap: 10px;
}
.detail-drawer__save-state {
  display: block;
  font-family: var(--font-serif-italic);
  font-style: italic; font-size: 11px;
  color: var(--ink-4);
  margin-top: 2px;
  transition: color 200ms;
}
.detail-drawer__save-state.is-saved { color: var(--gold-2); }
.detail-drawer__title-input {
  font-family: var(--font-serif-display);
  font-weight: 600;
  font-size: 22px; line-height: 30px;
  color: var(--ink-1);
  border: 0; border-bottom: 1px solid var(--stone-2);
  background: transparent; outline: none; flex: 1; min-width: 0;
  padding: 4px 0 8px;
  transition: border-color var(--duration-hover);
}
.detail-drawer__title-input:focus { border-bottom-color: var(--gold-1); }
.detail-drawer__title-input::placeholder { color: var(--ink-4); font-style: italic; }
.detail-drawer__origin {
  display: flex; flex-direction: column; gap: 4px;
}
.detail-drawer__origin-label {
  font-family: var(--font-sans-tight);
  font-size: 8px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--ink-4);
}
.detail-drawer__origin-quote {
  margin: 0;
  padding: 10px 14px;
  border-left: 2px solid var(--gold-1);
  background: rgba(187,152,99,0.05);
  font-family: var(--font-serif-display);
  font-style: italic; font-size: 12px; line-height: 19px;
  color: var(--ink-3);

}
.detail-drawer__desc-input {
  font-family: var(--font-sans-tight);
  font-size: 13px; line-height: 20px; color: var(--ink-2);
  border: 1px solid var(--stone-2); background: #fff;
  padding: 10px 12px; resize: vertical; min-height: 60px;
  outline: none; transition: border-color var(--duration-hover);
}
.detail-drawer__desc-input:focus { border-color: var(--gold-1); }
.detail-drawer__desc-input::placeholder { color: var(--ink-4); font-style: italic; }
.detail-drawer__refine-err {
  margin: 0;
  font-family: var(--font-sans-tight);
  font-size: 11px; color: var(--friction-pink, #e2445c);
}
.detail-drawer__updates-eye {
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.26em; text-transform: uppercase;
  color: var(--ink-3);
}
.detail-drawer__timeline-empty {
  margin: 0;
  font-family: var(--font-serif-italic);
  font-size: 12px; color: var(--ink-4);
}
.detail-drawer__note-input-wrap {
  display: flex; gap: 8px; align-items: flex-end;
}
.detail-drawer__note-input {
  flex: 1;
  font-family: var(--font-serif-display);
  font-size: 13px; color: var(--ink-2);
  border: 1px solid var(--stone-2); background: #fff;
  padding: 8px 12px; resize: none; outline: none;
  transition: border-color var(--duration-hover);
}
.detail-drawer__note-input:focus { border-color: var(--gold-1); }
.detail-drawer__note-submit {
  flex-shrink: 0;
  padding: 8px 14px;
  background: var(--ink-1); color: var(--parchment-0); border: 0;
  font-family: var(--font-sans-tight);
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  cursor: pointer;
  transition: background var(--duration-hover);
}
.detail-drawer__note-submit:hover { background: var(--gold-1); color: var(--gold-3); }
.detail-drawer__note-submit:disabled { opacity: 0.35; cursor: not-allowed; }
.detail-drawer__mark-done,
.detail-drawer__archive {
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase;
  padding: 9px 14px;
  background: transparent; border: 1px solid var(--stone-3); color: var(--ink-2);
  cursor: pointer; transition: all var(--duration-hover) var(--ease-quiet);
}
.detail-drawer__mark-done:hover { border-color: var(--gold-1); color: var(--gold-2); background: var(--gold-soft); }
.detail-drawer__archive:hover { border-color: var(--ink-2); color: var(--ink-1); }
.detail-drawer__delete-link {
  margin-left: auto;
  background: transparent; border: 0; padding: 4px 0;
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--friction-pink, #e2445c);
  cursor: pointer; opacity: 0.5;
  transition: opacity var(--duration-hover);
  border-bottom: 1px solid transparent;
}
.detail-drawer__delete-link:hover { opacity: 1; border-bottom-color: currentColor; }
.detail-drawer__delete-confirm {
  margin-left: auto;
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.detail-drawer__delete-confirm span {
  font-family: var(--font-sans-tight);
  font-size: 11px; color: var(--ink-2);
}
.detail-drawer__delete-confirm-btn {
  padding: 7px 12px;
  background: rgba(226,68,92,0.12);
  border: 1px solid var(--friction-pink, #e2445c);
  color: var(--friction-pink, #e2445c);
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase;
  cursor: pointer; font-weight: 600;
}
.detail-drawer__delete-cancel {
  background: transparent; border: 0; padding: 4px;
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-3); cursor: pointer;
}
.detail-drawer__delete-cancel:hover { color: var(--ink-1); }

/* =============================================================================
   REVIEW MODE — actual JSX class names
   ========================================================================= */
.review-mode {
  position: fixed; inset: 0;
  background: rgba(13,27,47,0.52);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 130;
  display: flex; align-items: center; justify-content: center;
  padding: 32px 24px;
}
.review-mode__panel {
  width: min(600px, 100%);
  background: var(--parchment-0);
  border: 1px solid var(--stone-3);
  box-shadow: 0 32px 64px -20px rgba(13,27,47,0.38);
  padding: 32px 36px 28px;
  display: flex; flex-direction: column; gap: 16px;
  max-height: 80vh; overflow-y: auto;
  animation: captureIn 260ms var(--ease-instrument);
}
.review-mode__section {
  display: flex; flex-direction: column; gap: 8px;
}
.review-mode__section-eye {
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--ink-3);
  padding-bottom: 6px;
  border-bottom: 1px solid var(--stone-2);
}
.review-mode__list {
  display: flex; flex-direction: column; gap: 6px;
}
.review-mode__row {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 9px 12px;
  background: var(--parchment-1); border: 1px solid var(--stone-2);
}
.review-mode__row-title {
  font-family: var(--font-serif-display);
  font-size: 14px; color: var(--ink-1); flex: 1;
}
.review-mode__row-meta {
  font-family: var(--font-mono);
  font-size: 10px; color: var(--gold-2); white-space: nowrap;
}
.review-mode__new-count {
  margin: 0;
  font-family: var(--font-serif-italic);
  font-style: italic; font-size: 13px;
  color: var(--gold-2);
}
.review-mode__clean {
  margin: 0;
  font-family: var(--font-serif-italic);
  font-style: italic; font-size: 14px;
  color: var(--ink-3); text-align: center;
  padding: 16px 0;
}
.review-mode__actions {
  display: flex; gap: 12px; padding-top: 8px;
  border-top: 1px solid var(--stone-2);
  margin-top: 4px;
}
.review-mode__begin {
  font-family: var(--font-sans-tight);
  font-weight: 600;
  font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase;
  padding: 14px 24px;
  background: var(--gold-1); border: 0; color: var(--gold-3);
  cursor: pointer; transition: background var(--duration-hover);
  box-shadow: 0 4px 12px -4px rgba(187,152,99,0.45);
}
.review-mode__begin:hover { background: var(--gold-2); color: #fff; }

/* label-caps utility (used in drawer) */
.label-caps {
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--ink-3);
}

/* =============================================================================
   TASK CARD v2 — body as open target, no domain label, no archive btn
   ========================================================================= */

/* Entire body area is the drawer-open hit target */
.task__body--open {
  cursor: pointer;
  border-radius: 2px;
  transition: background 200ms var(--ease-quiet);
  padding: 2px 4px 4px 0;
  margin: -2px -4px -4px 0;
}
.task__body--open:hover {
  background: rgba(187,152,99,0.06);
}

/* Title — sized by .card-title class, open-hint stays inline */
.task .task__title {
  font-size: 14px;
  line-height: 20px;
  display: block;
}
/* Remove old link underline behavior — body area handles the click */
.task .task__title--link,
.task .task__title {
  cursor: inherit;
  text-decoration: none;
}
.task .task__title--link:hover,
.task .task__title:hover {
  color: var(--ink-1);
  text-decoration: none;
}

/* ↗ open hint — lives at end of title, visible on body hover */
.task__open-hint {
  flex-shrink: 0;
  font-size: 13px;
  color: var(--gold-2);
  opacity: 0;
  transition: opacity 180ms var(--ease-quiet);
  line-height: 1;
  margin-left: auto;
}
.task__body--open:hover .task__open-hint {
  opacity: 1;
}

/* Body text — clean, no stale footer space */
.task__body--open .task__text {
  margin-top: 4px;
  color: var(--ink-2);
}

/* Due date chip row — compact above title */
.task__body--open .task__head {
  margin-bottom: 4px;
}

/* =============================================================================
   DETAIL DRAWER FOOTER — 3 stacked full-width buttons
   ========================================================================= */
.detail-drawer__zone--footer {
  flex-direction: column;
  gap: 10px;
  padding: 20px 28px 28px;
  border-top: 1px solid var(--stone-2);
}

/* Primary — Mark as Done */
.detail-drawer__btn-done {
  width: 100%;
  padding: 13px 20px;
  background: var(--gold-1);
  color: var(--gold-3);
  border: 0;
  font-family: var(--font-sans-tight);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  cursor: pointer;
  text-align: center;
  transition: background var(--duration-hover), color var(--duration-hover);
}
.detail-drawer__btn-done:hover {
  background: var(--gold-2);
  color: #fff;
}

/* Secondary — Archive (visible stroke box) */
.detail-drawer__btn-archive {
  width: 100%;
  padding: 12px 20px;
  background: transparent;
  color: var(--ink-2);
  border: 1px solid var(--stone-3);
  font-family: var(--font-sans-tight);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  cursor: pointer;
  text-align: center;
  transition: border-color var(--duration-hover), color var(--duration-hover), background var(--duration-hover);
}
.detail-drawer__btn-archive:hover {
  border-color: var(--ink-2);
  background: var(--parchment-1);
  color: var(--ink-1);
}

/* Tertiary — Delete (text only, centered, no border) */
.detail-drawer__btn-delete {
  width: 100%;
  padding: 6px 20px;
  background: transparent;
  border: 0;
  font-family: var(--font-sans-tight);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-4);
  cursor: pointer;
  text-align: center;
  transition: color var(--duration-hover);
}
.detail-drawer__btn-delete:hover {
  color: var(--friction-pink, #e2445c);
}
.detail-drawer__btn-delete--confirm {
  color: var(--friction-pink, #e2445c);
  font-weight: 600;
  letter-spacing: 0.22em;
  animation: confirmPulse 0.25s ease;
}
.detail-drawer__btn-delete--confirm:hover { opacity: 0.8; }
@keyframes confirmPulse { from { opacity: 0.5; } to { opacity: 1; } }

/* Delete confirm state */
.detail-drawer__delete-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 14px 28px 16px;
  border-top: 1px solid var(--stone-2);
  background: rgba(226,68,92,0.04);
}
.detail-drawer__delete-warn {
  font-family: var(--font-sans-tight);
  font-size: 11px;
  color: var(--ink-3);
  letter-spacing: 0.04em;
}
.detail-drawer__btn-delete-confirm {
  width: 100%;
  padding: 11px 0;
  background: rgba(226,68,92,0.12);
  border: 1px solid var(--friction-pink, #e2445c);
  color: var(--friction-pink, #e2445c);
  font-family: var(--font-sans-tight);
  font-weight: 600;
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  cursor: pointer;
}
.detail-drawer__btn-delete-cancel {
  background: transparent;
  border: 0;
  padding: 4px;
  font-family: var(--font-sans-tight);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  cursor: pointer;
}
.detail-drawer__btn-delete-cancel:hover { color: var(--ink-1); }

/* =============================================================================
   COLUMN HEADER v2 — eye + title/count/controls row + subtitle
   ========================================================================= */
.col__head {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 4px 4px 14px;
  border-bottom: 1px solid var(--stone-2);
}

.col__eye {
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.col--heading .col__eye { color: var(--gold-2); }

.col__title-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.col__title {
  color: var(--ink-1);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Count badge — small pill beside title */
.col__count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 6px;
  background: var(--parchment-2);
  border: 1px solid var(--stone-2);
  font-family: var(--font-sans-tight);
  font-weight: 600;
  font-size: 11px;
  color: var(--ink-2);
  letter-spacing: 0;
}

/* Controls row — sort + add button, pushed to far right */
.col__head-controls {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-left: auto;
}

/* Sort control sits inline — override col__sort-wrap grid column */
.col__sort-wrap {
  position: relative;
  margin-top: 0;
  grid-column: unset;
}

/* Compact sort icon button */
.col__sort-btn {
  width: 32px;
  height: 32px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
}
.col__sort-chip {
  height: 32px;
  padding: 0 10px;
  font-size: 9px;
}

/* + Add Task — gold primary button */
.col__add-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: 32px;
  padding: 0 14px;
  background: var(--gold-1);
  color: var(--gold-3);
  border: 0;
  font-family: var(--font-sans-tight);
  font-weight: 600;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background var(--duration-hover), color var(--duration-hover);
  white-space: nowrap;
  box-shadow: 0 2px 8px -3px rgba(187,152,99,0.45);
}
.col__add-btn:hover {
  background: var(--gold-2);
  color: #fff;
}

/* Subtitle */
.col__sub {
  font-family: var(--font-serif-italic);
  font-style: italic;
  font-size: 12px;
  color: var(--ink-3);
  letter-spacing: 0.02em;
}

/* =============================================================================
   REALIZE CIRCLE v2 — small, proportional to text (≈ 22px)
   ========================================================================= */
.task__realize {
  width: 22px !important;
  height: 22px !important;
  margin-top: 3px !important;
  margin-left: 6px !important;
  border-radius: 9999px;
  border: 1.5px solid var(--stone-3);
  background: #fff;
  color: var(--ink-3);
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
  align-self: start;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition:
    border-color 180ms var(--ease-quiet),
    background 180ms var(--ease-quiet),
    color 180ms var(--ease-quiet),
    transform 150ms var(--ease-quiet);
}
.task__realize:hover {
  border-color: var(--gold-1);
  background: var(--gold-soft);
  color: var(--gold-2);
  transform: scale(1.12);
  box-shadow: 0 0 0 4px rgba(187,152,99,0.12);
}
.task__realize svg.task__realize-check,
.task__realize svg.task__realize-undo {
  width: 11px !important;
  height: 11px !important;
}

/* Completed state — filled small circle */
.task.is-completed .task__realize {
  width: 22px !important;
  height: 22px !important;
  margin-top: 3px !important;
  background: var(--gold-1) !important;
  border-color: var(--gold-1) !important;
  color: #fff !important;
}
.task.is-completed .task__realize:hover {
  background: var(--ink-2) !important;
  border-color: var(--ink-2) !important;
}

/* Grid layout: strip(3px) + circle(30px) + body */
.task {
  grid-template-columns: 3px 30px 1fr;
}
.task.is-compact {
  grid-template-columns: 3px 26px 1fr;
}

/* Strip is position:absolute — pin circle and body to correct columns */
.task__realize { grid-column: 2; }
.task__body    { grid-column: 3; padding-top: 2px; padding-bottom: 2px; }

/* =============================================================================
   DASHBOARD HEADER v2 — Actions Dashboard title + inline tools
   ========================================================================= */
.actions-dash__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--stone-2);
  flex-wrap: wrap;
}

.actions-dash__identity {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.actions-dash__title {
  margin: 0;
  font-family: var(--font-serif-display);
  font-size: 40px;
  line-height: 46px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--ink-1);
}

.actions-dash__sub {
  margin: 0;
  font-family: var(--font-serif-italic);
  font-style: italic;
  font-size: 14px;
  color: var(--ink-3);
  letter-spacing: 0.02em;
}

.actions-dash__tools {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

/* Ghost secondary buttons */
.actions-dash__btn--ghost {
  font-family: var(--font-sans-tight);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 11px 18px;
  border: 1px solid var(--stone-3);
  background: transparent;
  color: var(--ink-2);
  cursor: pointer;
  transition: border-color var(--duration-hover), color var(--duration-hover), background var(--duration-hover);
}
.actions-dash__btn--ghost:hover {
  border-color: var(--gold-1);
  color: var(--gold-2);
  background: var(--gold-soft);
}

/* Primary capture button */
.actions-dash__btn--capture {
  font-family: var(--font-sans-tight);
  font-weight: 600;
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 11px 20px;
  background: var(--gold-1);
  color: var(--gold-3);
  border: 0;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: background var(--duration-hover), color var(--duration-hover);
  box-shadow: 0 2px 10px -4px rgba(187,152,99,0.5);
}
.actions-dash__btn--capture:hover {
  background: var(--gold-2);
  color: #fff;
}
.actions-dash__btn-plus {
  font-size: 16px;
  line-height: 1;
  font-weight: 400;
}
.actions-dash__kbd {
  font-family: var(--font-mono);
  font-size: 9px;
  padding: 2px 5px;
  border: 1px solid rgba(255,255,255,0.3);
  color: rgba(255,255,255,0.7);
  background: transparent;
}
.actions-dash__btn--capture:hover .actions-dash__kbd {
  border-color: rgba(40,24,0,0.25);
  color: var(--gold-3);
}

/* Open hint — › chevron at right edge of card, appears on body hover */
.task__open-hint {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 18px;
  font-family: var(--font-serif-display);
  line-height: 1;
  color: var(--stone-3);
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms var(--ease-quiet), color 180ms var(--ease-quiet);
}
.task__body--open:hover ~ .task__open-hint,
.task:hover .task__open-hint {
  opacity: 1;
  color: var(--gold-1);
}
/* ensure article is positioned for absolute child */
.task { position: relative; }

/* =============================================================================
   DUE DATE PROMPT — inline card below dropped task
   ========================================================================= */
.due-prompt {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px 16px 12px;
  background: var(--parchment-0);
  border: 1px solid var(--gold-1);
  border-top: 3px solid var(--gold-1);
  box-shadow: 0 4px 14px -6px rgba(187,152,99,0.30);
  animation: captureIn 200ms var(--ease-instrument);
  margin-top: -2px;
}

.due-prompt__label {
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--gold-2);
}

.due-prompt__chips {
  display: flex;
  gap: 6px;
}

.due-prompt__chip {
  flex: 1;
  padding: 8px 10px;
  background: var(--parchment-1);
  border: 1px solid var(--stone-3);
  color: var(--ink-2);
  font-family: var(--font-sans-tight);
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all var(--duration-hover) var(--ease-quiet);
  text-align: center;
}
.due-prompt__chip:hover {
  border-color: var(--gold-1);
  background: var(--gold-soft);
  color: var(--gold-2);
}
.due-prompt__chip--date {
  flex: 0 0 auto;
  padding: 8px 14px;
}

.due-prompt__custom {
  display: flex;
  gap: 6px;
  align-items: center;
}
.due-prompt__input {
  flex: 1;
  font-family: var(--font-serif-display);
  font-size: 13px;
  color: var(--ink-1);
  border: 1px solid var(--gold-1);
  background: #fff;
  padding: 7px 10px;
  outline: none;
}
.due-prompt__set {
  padding: 7px 14px;
  background: var(--gold-1);
  border: 0;
  color: var(--gold-3);
  font-family: var(--font-sans-tight);
  font-weight: 600;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background var(--duration-hover);
}
.due-prompt__set:hover { background: var(--gold-2); color: #fff; }
.due-prompt__set:disabled { opacity: 0.35; cursor: not-allowed; }

.due-prompt__skip {
  align-self: center;
  background: transparent;
  border: 0;
  padding: 2px 0;
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-4);
  cursor: pointer;
  transition: color var(--duration-hover);
  border-bottom: 1px solid transparent;
}
.due-prompt__skip:hover {
  color: var(--ink-2);
  border-bottom-color: var(--ink-3);
}

/* =============================================================================
   NEEDS-DATE INDICATOR — amber pulse on deadline-bound cards missing due date
   ========================================================================= */
/* needs-date: no border change — tag is added in JSX instead */
.task__add-date {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: transparent;
  border: 1px dashed rgba(187,152,99,0.45);
  color: var(--gold-1);
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 2px 7px;
  cursor: pointer;
  transition: all 0.12s;
}
.task__add-date:hover {
  border-color: var(--gold-1);
  background: rgba(187,152,99,0.08);
}

.due-prompt__input.is-error { border-color: var(--friction-pink, #e2445c); }
.due-prompt__err {
  font-family: var(--font-sans-tight);
  font-size: 9px; letter-spacing: 0.16em;
  color: var(--friction-pink, #e2445c);
}

/* =============================================================================
   CAPTURE MODAL — date picker section (Today / This Week / month-day input)
   ========================================================================= */
.capture__date-picker {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.capture__date-chips {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.capture__date-chip {
  flex: 0 0 auto;
  padding: 6px 14px;
  font-family: var(--font-sans-tight);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  background: transparent;
  border: 1px solid var(--ink-5, #ccc);
  color: var(--ink-2);
  cursor: pointer;
  transition: border-color var(--duration-hover), color var(--duration-hover), background var(--duration-hover);
}
.capture__date-chip:hover {
  border-color: var(--gold-1);
  color: var(--gold-2);
}
.capture__date-chip.is-active {
  background: var(--gold-1);
  border-color: var(--gold-1);
  color: var(--gold-3);
}

.capture__date-input {
  width: 100%;
  font-family: var(--font-serif-display);
  font-size: 14px;
  color: var(--ink-1);
  border: 1px solid var(--ink-5, #ccc);
  background: #fff;
  padding: 8px 12px;
  outline: none;
  transition: border-color var(--duration-hover);
  box-sizing: border-box;
}
.capture__date-input:focus { border-color: var(--gold-1); }
.capture__date-input.is-error { border-color: var(--friction-pink, #e2445c); }

.capture__date-err {
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.16em;
  color: var(--friction-pink, #e2445c);
}

/* =============================================================================
   DATE-LIFECYCLE SYSTEM — left-bar color shifts + chip phase colors
   ========================================================================= */

/* Left-bar override by deadline phase (overrides domain color for deadline-bound) */
.task[data-due-state="healthy"]   .task__strip { background: var(--lifecycle-healthy,  #4c9f70) !important; }
.task[data-due-state="impending"] .task__strip { background: var(--lifecycle-impending, #d97706) !important; }
.task[data-due-state="overdue"]   .task__strip { background: var(--lifecycle-overdue,   #9b2335) !important; }
.task[data-due-state="today"]     .task__strip { background: var(--lifecycle-today,     #bb9863) !important; }

/* DueDateChip phase colors */
.task__due.chip--healthy   { color: var(--lifecycle-healthy,  #4c9f70); }
.task__due.chip--today     { color: var(--lifecycle-today,    #bb9863); font-weight: 600; }
.task__due.chip--impending { color: var(--lifecycle-impending,#d97706); font-weight: 600; }
.task__due.chip--overdue   { color: var(--lifecycle-overdue,  #9b2335); font-weight: 700; letter-spacing: 0.01em; }

/* Chip micro-copy (sub-label inside deadline prompt + capture chips) */
.due-prompt__chip { flex-direction: column; align-items: center; gap: 2px; }
.due-prompt__chip-label { font-family: var(--font-sans-tight); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; }
.due-prompt__chip-sub   { font-family: var(--font-sans-tight); font-size: 8px;  letter-spacing: 0.14em; text-transform: lowercase; opacity: 0.6; }

.capture__date-chip { flex-direction: column; align-items: center; gap: 2px; }
.capture__chip-label { font-family: var(--font-sans-tight); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; }
.capture__chip-sub   { font-family: var(--font-sans-tight); font-size: 8px;  letter-spacing: 0.14em; text-transform: lowercase; opacity: 0.6; }

/* =============================================================================
   TASK CARD — footer tray (due-date metadata row + deadline prompt)
   ========================================================================= */
.task__footer {
  grid-column: 2 / -1;
  padding: 4px 10px 8px;
}

.task__due {
  font-family: var(--font-sans-tight);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* due-prompt inside card footer — strip outer padding since footer provides it */
.task__footer .due-prompt {
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
  margin: 0;
}
.task__footer .due-prompt__label {
  font-size: 8px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-4);
  display: block;
  margin-bottom: 6px;
}

/* =============================================================================
   TASK CARD — title hover: underline + chevron
   ========================================================================= */
.task__title {
  position: relative;
  display: inline;
}

.task__body--open:hover .task__title {
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--ink-4);
}

/* chevron nudges right on body hover */
.task__body--open .task__open-hint {
  display: inline-block;
  transition: transform 150ms ease, opacity 150ms ease;
}
.task__body--open:hover .task__open-hint {
  opacity: 1;
  transform: translateX(3px);
}

/* =============================================================================
   CALENDAR PICKER
   ========================================================================= */
.cal-picker {
  margin-top: 8px;
  background: #fff;
  border: 1px solid var(--ink-5, #ddd);
  padding: 10px;
  user-select: none;
}

.cal-picker__nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}

.cal-picker__nav-btn {
  background: transparent;
  border: 0;
  font-size: 18px;
  color: var(--ink-2);
  cursor: pointer;
  padding: 2px 8px;
  line-height: 1;
  transition: color var(--duration-hover);
}
.cal-picker__nav-btn:hover { color: var(--gold-1); }

.cal-picker__month-label {
  font-family: var(--font-sans-tight);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-2);
}

.cal-picker__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
}

.cal-picker__day-head {
  font-family: var(--font-sans-tight);
  font-size: 8px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-4);
  text-align: center;
  padding-bottom: 4px;
}

.cal-picker__day {
  aspect-ratio: 1;
  background: transparent;
  border: 0;
  font-family: var(--font-sans-tight);
  font-size: 11px;
  color: var(--ink-2);
  cursor: pointer;
  border-radius: 2px;
  transition: background var(--duration-hover), color var(--duration-hover);
  display: flex;
  align-items: center;
  justify-content: center;
}
.cal-picker__day:hover:not(:disabled) { background: var(--gold-1); color: var(--gold-3); }
.cal-picker__day.is-today  { border: 1px solid var(--gold-1); color: var(--gold-2); }
.cal-picker__day.is-selected { background: var(--gold-1); color: var(--gold-3); font-weight: 700; }
.cal-picker__day.is-past   { color: var(--ink-5, #ccc); cursor: not-allowed; }

/* =============================================================================
   DETAIL DRAWER — due date zone
   ========================================================================= */
.detail-drawer__zone--due {
  padding: 14px 20px;
}

.detail-drawer__zone-eye {
  display: block;
  font-family: var(--font-sans-tight);
  font-size: 8px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-4);
  margin-bottom: 8px;
}

.detail-drawer__due-display {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.detail-drawer__due-state {
  font-family: var(--font-sans-tight);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.06em;
}

.detail-drawer__due-set {
  font-family: var(--font-sans-tight);
  font-size: 10px;
  letter-spacing: 0.10em;
  color: var(--ink-4);
  text-transform: uppercase;
}

.detail-drawer__due-edit-btn {
  background: transparent;
  border: 1px solid var(--ink-5, #ddd);
  padding: 4px 12px;
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  cursor: pointer;
  align-self: flex-start;
  margin-top: 4px;
  transition: border-color var(--duration-hover), color var(--duration-hover);
}
.detail-drawer__due-edit-btn:hover { border-color: var(--gold-1); color: var(--gold-2); }

.detail-drawer__due-set-btn {
  background: transparent;
  border: 0;
  padding: 0;
  font-family: var(--font-sans-tight);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-4);
  cursor: pointer;
  transition: color var(--duration-hover);
  border-bottom: 1px dashed var(--ink-5);
}
.detail-drawer__due-set-btn:hover { color: var(--gold-1); border-bottom-color: var(--gold-1); }

.detail-drawer__due-picker { display: flex; flex-direction: column; gap: 8px; }

.detail-drawer__due-chips {
  display: flex;
  gap: 6px;
}
.detail-drawer__due-chip {
  flex: 1;
  padding: 6px 10px;
  background: transparent;
  border: 1px solid var(--ink-5, #ddd);
  font-family: var(--font-sans-tight);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-2);
  cursor: pointer;
  transition: border-color var(--duration-hover), color var(--duration-hover);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}
.detail-drawer__due-chip:hover { border-color: var(--gold-1); color: var(--gold-2); }
.detail-drawer__due-chip-sub {
  font-size: 8px;
  letter-spacing: 0.12em;
  text-transform: lowercase;
  opacity: 0.6;
}
.detail-drawer__due-chip--active {
  border-color: var(--gold-2);
  background: var(--gold-2);
  color: var(--parchment-0);
  font-weight: 600;
}
.detail-drawer__due-chip--active .detail-drawer__due-chip-sub {
  opacity: 0.85;
  color: var(--parchment-0);
}
.detail-drawer__due-feedback {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.detail-drawer__due-feedback-label {
  font-family: var(--font-sans-tight);
  font-size: 12px;
  color: var(--ink-2);
  letter-spacing: 0.04em;
}
.detail-drawer__due-placeholder {
  font-family: var(--font-sans-tight);
  font-size: 11px;
  color: var(--ink-4);
  letter-spacing: 0.04em;
  margin: 0 0 4px;
}

.detail-drawer__due-clear {
  background: transparent;
  border: 0;
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--friction-pink, #e2445c);
  cursor: pointer;
  padding: 0;
  align-self: flex-start;
  border-bottom: 1px solid transparent;
  transition: border-color var(--duration-hover);
}
.detail-drawer__due-clear:hover { border-bottom-color: var(--friction-pink, #e2445c); }

/* =============================================================================
   CALENDAR PICKER — compact size override for drawer context
   ========================================================================= */
.detail-drawer__due-picker .cal-picker {
  max-width: 260px;
}
.detail-drawer__due-picker .cal-picker__day {
  width: 30px;
  height: 30px;
  font-size: 10px;
}
.detail-drawer__due-picker .cal-picker__day-head {
  font-size: 7px;
}

/* =============================================================================
   DETAIL DRAWER — expandable snippet toggle
   ========================================================================= */
.detail-drawer__snippet-toggle {
  display: inline;
  background: transparent;
  border: 0;
  padding: 0;
  font-family: var(--font-serif-italic);
  font-style: italic;
  font-size: inherit;
  color: var(--gold-2);
  cursor: pointer;
  transition: color var(--duration-hover);
}
.detail-drawer__snippet-toggle:hover { color: var(--gold-1); }

/* =============================================================================
   DETAIL DRAWER — pinned topbar (always visible above scroll)
   ========================================================================= */
.detail-drawer__topbar--pinned {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px 14px 28px;
  border-bottom: 1px solid var(--stone-2);
  background: var(--parchment-0);
  gap: 12px;
}

/* =============================================================================
   ARCHIVE FOLDER — show more button
   ========================================================================= */
.archive-folder__show-more {
  width: 100%;
  padding: 8px 16px;
  background: transparent;
  border: 0;
  border-top: 1px solid var(--stone-2);
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--ink-4);
  cursor: pointer;
  text-align: center;
  transition: color var(--duration-hover), background var(--duration-hover);
}
.archive-folder__show-more:hover {
  color: var(--gold-2);
  background: var(--parchment-1);
}

/* =============================================================================
   SEGMENT CONTEXT — journal source with before/after neighbours
   ========================================================================= */
.segment-context {
  margin: 0 0 1.25rem;
  padding: 0;
}
.segment-context__eye {
  display: block;
  font-size: 9px;
  letter-spacing: 0.18em;
  color: var(--ink-4);
  margin-bottom: 0.6rem;
}
.segment-context__neighbor {
  font-size: 12px;
  line-height: 1.55;
  color: var(--ink-4);
  opacity: 0.45;
  margin: 0 0 0.35rem;
  padding: 0 0 0 10px;
  border-left: 2px solid var(--stone-2);
  font-style: italic;
}
.segment-context__segment {
  font-size: 13px;
  line-height: 1.65;
  color: var(--ink-2);
  margin: 0 0 0.35rem;
  padding: 8px 12px;
  border-left: 2px solid var(--gold-2);
  background: var(--parchment-1);
  border-radius: 0 4px 4px 0;
}
.segment-context__highlight {
  background: transparent;
  border-bottom: 2px solid var(--gold-2);
  color: inherit;
  font-weight: 500;
}

.segment-context__highlight-block {
  margin: 0 0 0.5rem;
  padding: 8px 12px;
  border-left: 3px solid var(--gold-2);
  background: rgba(187, 152, 99, 0.08);
  border-radius: 0 4px 4px 0;
  font-size: 13px;
  line-height: 1.65;
  color: var(--ink-1);
  font-style: normal;
}
.segment-context__highlight-block--in-context {
  background: rgba(187, 152, 99, 0.13);
}
.segment-context__expanded {
  margin-top: 0.35rem;
}
.segment-context__context-chunk {
  font-size: 12px;
  line-height: 1.55;
  color: var(--ink-3);
  opacity: 0.65;
  margin: 0 0 0.25rem;
  padding: 0 0 0 10px;
  border-left: 2px solid var(--stone-2);
}
.segment-context__context-chunk--before { margin-bottom: 0.35rem; }
.segment-context__context-chunk--after  { margin-top: 0.35rem; }
.segment-context__full-text {
  font-size: 13px;
  line-height: 1.65;
  color: var(--ink-2);
  margin: 0 0 0.5rem;
  padding: 8px 12px;
  border-left: 2px solid var(--stone-2);
  border-radius: 0 4px 4px 0;
}
.segment-context__inline-highlight {
  text-decoration: underline;
  text-decoration-color: var(--gold-2);
  text-decoration-thickness: 2px;
  text-underline-offset: 2px;
  font-weight: 500;
  color: var(--ink-1);
  text-decoration-style: solid;
}
/* =============================================================================
   ACTION SUGGESTION CARD
   ========================================================================= */
.suggestion-card {
  margin: 0 0 12px;
  padding: 12px 14px;
  background: var(--parchment-1);
  border: 1px solid var(--stone-2);
  border-left: 3px solid var(--gold-2);
  border-radius: 6px;
}
.suggestion-card__eyebrow {
  display: block;
  font-size: 9px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-4);
  margin-bottom: 6px;
}
.suggestion-card__body {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 10px;
}
.suggestion-card__dot {
  flex-shrink: 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-top: 4px;
}
.suggestion-card__text {
  font-size: 13px;
  line-height: 1.5;
  color: var(--ink-1);
}
.suggestion-card__actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.suggestion-card__btn {
  padding: 4px 10px;
  font-size: 11px;
  border-radius: 4px;
  border: 1px solid var(--stone-2);
  background: transparent;
  cursor: pointer;
  color: var(--ink-2);
  transition: background var(--duration-hover), color var(--duration-hover);
}
.suggestion-card__btn:hover          { background: var(--stone-1); }
.suggestion-card__btn--add           { border-color: var(--gold-2); color: var(--gold-2); font-weight: 600; }
.suggestion-card__btn--add:hover     { background: var(--gold-2); color: var(--parchment-0); }
.suggestion-card__btn--dismiss       { opacity: 0.6; }
.suggestion-card__btn--clear         { opacity: 0.5; font-size: 10px; }

/* Dismiss undo toast */
.suggestion-undo-toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--ink-1);
  color: var(--parchment-0);
  padding: 8px 18px;
  border-radius: 6px;
  font-size: 12px;
  z-index: 10000;
  display: flex;
  align-items: center;
  gap: 10px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.25);
}
.suggestion-undo-toast__btn {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.4);
  color: inherit;
  padding: 2px 8px;
  border-radius: 3px;
  cursor: pointer;
  font-size: 11px;
}
.suggestion-undo-toast__btn:hover { background: rgba(255,255,255,0.15); }

/* Morning Refresh consequence note */
.review-mode__cta-group {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}
.review-mode__consequence {
  font-size: 10px;
  color: var(--ink-4);
  opacity: 0.7;
  letter-spacing: 0.04em;
}
.segment-context__toggle {
  display: inline;
  background: transparent;
  border: 0;
  padding: 0;
  margin-left: 4px;
  font-size: 11px;
  color: var(--gold-2);
  cursor: pointer;
  text-decoration: underline;
  font-family: inherit;
}
.segment-context__toggle:hover { opacity: 0.75; }

/* ── Triage Banner ────────────────────────────────────────────────────────── */
/* ── Triage Banner ───────────────────────────────────────────────────────── */
.triage-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 13px 20px;
  background: var(--void-0);
  border: none;
  color: rgba(255,255,255,0.9);
  font-family: var(--font-sans, 'Space Grotesk', sans-serif);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  text-align: left;
  transition: background 0.15s;
}
.triage-banner:hover { background: rgb(20,38,64); }
.triage-banner__star  { font-size: 12px; color: var(--gold-1); }
.triage-banner__count { font-weight: 700; color: #fff; }
.triage-banner__cta   { margin-left: auto; font-size: 11px; opacity: 0.6; }

/* ── Triage Overlay + Drawer ─────────────────────────────────────────────── */
.triage-overlay {
  position: absolute;
  inset: 0;
  background: rgba(26, 28, 28, 0.50);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 48px;
  z-index: 300;
}
.triage-drawer {
  width: min(640px, 92vw);
  max-height: 80vh;
  background: var(--parchment-0, #fffdf9);
  border: 1px solid rgba(0,0,0,0.10);
  box-shadow: 0 8px 32px rgba(0,0,0,0.18);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.triage-drawer__head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  border-bottom: 1px solid rgba(0,0,0,0.08);
  flex-shrink: 0;
}
.triage-drawer__eye   { font-size: 10px; letter-spacing: 0.1em; color: var(--ink-3, rgba(26,28,28,0.45)); text-transform: uppercase; }
.triage-drawer__count { font-size: 12px; color: var(--gold-1, #bba063); letter-spacing: 0.05em; margin-right: auto; }
.triage-drawer__close {
  background: transparent; border: none; color: var(--ink-3, rgba(26,28,28,0.45));
  font-size: 20px; cursor: pointer; padding: 0 4px; line-height: 1;
}
.triage-drawer__close:hover { color: var(--ink-1); }

.triage-drawer__body  { overflow-y: auto; flex: 1; padding: 0 20px 8px; }
.triage-drawer__foot  {
  padding: 12px 20px;
  border-top: 1px solid rgba(0,0,0,0.07);
  display: flex;
  justify-content: flex-end;
  align-items: center;
  flex-shrink: 0;
}

/* Date separator */
.triage-drawer__group + .triage-drawer__group { margin-top: 8px; }
.triage-drawer__date-sep {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 16px 0 10px;
}
.triage-drawer__date-sep::before,
.triage-drawer__date-sep::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(0,0,0,0.08);
}
.triage-drawer__date-label {
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3, rgba(26,28,28,0.45));
  white-space: nowrap;
}

/* Triage Card */
.triage-card {
  padding: 16px 0;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
.triage-card:last-child { border-bottom: none; }

/* Header */
.triage-card__head {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 10px;
}
.triage-card__dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.triage-card__domain-label {
  font-size: 10px;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--ink-3);
  flex: 1;
}
.triage-card__edit-btn {
  background: transparent;
  border: 1px solid rgba(0,0,0,0.14);
  color: var(--ink-3);
  font-size: 10px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 2px 8px;
  cursor: pointer;
  border-radius: 2px;
}
.triage-card__edit-btn:hover { border-color: var(--gold-1); color: var(--gold-1); }

/* View mode title */
.triage-card__title {
  font-size: 15px;
  font-family: var(--font-serif, 'Newsreader', serif);
  color: var(--ink-1);
  margin: 0 0 12px;
  line-height: 1.45;
}

/* Edit mode */
.triage-card__edit { margin-bottom: 12px; }
.triage-card__domain-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 10px;
}
.triage-card__domain-chip {
  display: flex;
  align-items: center;
  gap: 5px;
  background: transparent;
  border: 1px solid rgba(0,0,0,0.14);
  color: var(--ink-3);
  font-size: 10px;
  letter-spacing: 0.04em;
  padding: 3px 8px;
  cursor: pointer;
  border-radius: 2px;
  transition: all 0.12s;
}
.triage-card__domain-chip.is-active { font-weight: 600; }
.triage-card__domain-chip-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.triage-card__input, .triage-card__textarea {
  width: 100%;
  box-sizing: border-box;
  background: rgba(0,0,0,0.03);
  border: 1px solid rgba(0,0,0,0.14);
  color: var(--ink-1);
  font-size: 13px;
  font-family: var(--font-sans);
  padding: 6px 10px;
  outline: none;
  border-radius: 2px;
  margin-bottom: 6px;
  display: block;
}
.triage-card__input:focus, .triage-card__textarea:focus { border-color: var(--gold-1); }
.triage-card__textarea { resize: vertical; min-height: 48px; }

/* Source / snippet blockquote */
.triage-card__source { margin-bottom: 12px; }
.triage-card__source-quote {
  margin: 0;
  padding: 8px 12px;
  border-left: 2px solid var(--gold-1);
  font-size: 12px;
  font-style: italic;
  color: var(--ink-3);
  line-height: 1.55;
  background: rgba(187,152,99,0.05);
}
.triage-card__source-toggle {
  background: transparent; border: none;
  color: var(--gold-1); font-size: 11px;
  cursor: pointer; padding: 4px 0; margin-top: 4px;
  letter-spacing: 0.03em;
}

/* Actions row */
.triage-card__actions {
  display: flex;
  align-items: center;
  gap: 8px;
}
.triage-card__placements { display: flex; gap: 5px; flex: 1; flex-wrap: wrap; }
.triage-card__place {
  background: rgba(187,152,99,0.08);
  border: 1px solid rgba(187,152,99,0.28);
  color: var(--gold-1);
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 5px 12px;
  cursor: pointer;
  border-radius: 2px;
  transition: background 0.12s;
}
.triage-card__place:hover { background: rgba(187,152,99,0.2); }
.triage-card__place--date { border-style: dashed; }
.triage-card__place--date.is-picking { background: rgba(187,152,99,0.18); border-style: solid; }
.triage-card__trash {
  background: transparent;
  border: 1px solid rgba(0,0,0,0.14);
  color: var(--ink-3);
  width: 30px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  border-radius: 2px;
  flex-shrink: 0;
  transition: all 0.12s;
}
.triage-card__trash:hover { border-color: #c0392b; color: #c0392b; }

/* Inline date picker row */
.triage-card__date-input-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}
.triage-card__date-input {
  border: 1px solid rgba(187,152,99,0.4);
  background: rgba(0,0,0,0.02);
  color: var(--ink-1);
  font-size: 12px;
  padding: 4px 8px;
  outline: none;
  border-radius: 2px;
  flex: 1;
}
.triage-card__date-input:focus { border-color: var(--gold-1); }
.triage-card__date-cancel {
  background: transparent; border: none;
  color: var(--ink-3); font-size: 11px;
  cursor: pointer; padding: 4px 0;
}

/* Delete all + confirm */
.triage-drawer__delete-all {
  background: transparent;
  border: none;
  color: var(--ink-3);
  font-size: 11px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  cursor: pointer;
  padding: 4px 0;
}
.triage-drawer__delete-all:hover { color: #c0392b; }
.triage-drawer__confirm {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  justify-content: flex-end;
}
.triage-drawer__confirm-msg {
  font-size: 11px;
  color: var(--ink-2);
  letter-spacing: 0.03em;
}
.triage-drawer__confirm-yes {
  background: #c0392b;
  border: none;
  color: #fff;
  font-size: 11px;
  padding: 5px 14px;
  cursor: pointer;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: 2px;
}
.triage-drawer__confirm-no {
  background: transparent;
  border: 1px solid rgba(0,0,0,0.14);
  color: var(--ink-3);
  font-size: 11px;
  padding: 5px 14px;
  cursor: pointer;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: 2px;
}
.triage-drawer__confirm-no:hover { border-color: var(--ink-2); color: var(--ink-2); }


/* =============================================================================
   RESPONSIVE BREAKPOINTS
   ========================================================================= */

/* Tablet — 2-col board, auto-height columns */
@media (max-width: 1180px) {
  /* existing rule already sets .cols to 1fr — extend it here */
  .col {
    height: auto;
    max-height: 70vh;
    overflow-y: auto;
  }
  .actions-dash__head {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }
  .actions-dash__title {
    font-size: 30px;
    line-height: 36px;
  }
  .actions-dash__tools {
    width: 100%;
    justify-content: flex-start;
  }
}

/* Narrow tablet / large phone */
@media (max-width: 768px) {
  .actions-dash {
    padding: 20px 16px;
  }
  .actions-dash__title {
    font-size: 26px;
    line-height: 32px;
  }
  .col {
    padding: 14px 10px;
    max-height: 60vh;
  }
  /* Task card: tighter on narrow screens */
  .task {
    padding: 8px 10px 8px 0;
  }
  .task__strip {
    /* absolute — no change needed, follows card height automatically */
  }
  /* Reduce ALIGNED badge right-padding so title has more room */
  .task.is-high-resonance .task__body {
    padding-right: 72px;
  }
  .task__north {
    right: 8px;
    font-size: 8px;
    padding: 3px 8px 3px 6px;
  }
  /* Triage drawer cards */
  .triage-card__placements {
    flex-wrap: wrap;
    gap: 6px;
  }
  .triage-card__place--date {
    flex: 1 1 100%;
  }
}

/* Mobile */
@media (max-width: 480px) {
  .actions-dash {
    padding: 14px 10px;
  }
  .actions-dash__title {
    font-size: 22px;
    line-height: 28px;
  }
  .col {
    padding: 10px 8px;
    gap: 10px;
    max-height: 55vh;
  }
  .task {
    padding: 8px 8px 8px 0;
    gap: 8px;
  }
  .task.is-high-resonance .task__body {
    padding-right: 64px;
  }
  .task__north {
    right: 6px;
    top: -8px;
    font-size: 7.5px;
    letter-spacing: 0.14em;
    padding: 3px 7px 3px 5px;
  }
  .triage-card {
    padding: 14px 12px 12px;
  }
  .triage-card__actions {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  .triage-card__placements {
    flex-wrap: wrap;
    gap: 6px;
  }
  .triage-card__place--date {
    flex: 1 1 100%;
    text-align: center;
  }
  .triage-card__trash {
    align-self: flex-end;
  }
  /* Banner */
  .triage-drawer__banner {
    flex-direction: column;
    gap: 8px;
    align-items: flex-start;
  }
  .triage-drawer__banner-actions {
    width: 100%;
    justify-content: flex-end;
  }
}


/* =============================================================================
   D ash2 layout overrides
   ========================================================================= */
.actions-dash--dash2 {
  gap: 10px;
}
.actions-dash__head--dash2 {
  display: none;
}
.dash2-topbar {
  position: sticky;
  top: 0;
  z-index: 12;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 12px;
  border: 1px solid var(--stone-2);
  background: rgba(248, 243, 233, 0.96);
  backdrop-filter: blur(8px);
}
.dash2-topbar__legend {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.dash2-topbar__label {
  font-family: var(--font-sans-tight);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-3);
  white-space: nowrap;
}
.dash2-domain-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--stone-2);
  background: #fff;
  padding: 5px 8px;
  font-family: var(--font-sans-tight);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-2);
  white-space: nowrap;
}
.dash2-domain-pill__dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  flex: 0 0 auto;
}
.dash2-topbar__actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex: 0 0 auto;
}
.dash2-topbar__status {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  color: var(--ink-3);
  white-space: nowrap;
}
.dash2-compact-btn {
  padding: 7px 10px;
  font-size: 10px;
  line-height: 1;
}
.dash2-capstrip {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}
.dash2-capstrip__panel {
  background: var(--parchment-1);
  border: 1px solid var(--stone-2);
  box-shadow: 0 1px 0 rgba(0,0,0,0.03), 0 12px 20px -16px rgba(0,0,0,0.14);
  padding: 10px 12px;
  min-width: 0;
}
.dash2-capstrip__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}
.dash2-capstrip__title {
  font-family: var(--font-sans-tight);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.dash2-capstrip__meta {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-3);
  white-space: nowrap;
}
.dash2-capstrip__body {
  margin-top: 8px;
}
.dash2-capstrip__prompt {
  margin: 0;
  font-family: var(--font-serif-display);
  font-size: 12px;
  line-height: 1.35;
  color: var(--ink-2);
}
.dash2-capstrip__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

/* Acceptance Buffer — inline triage rows in the Hub panel */
.dash2-buffer-list {
  display: grid;
  gap: 4px;
}
.dash2-buffer-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 8px;
  height: 30px;
}
.dash2-buffer-row__title {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-family: var(--font-sans-tight);
  font-size: 12px;
  color: var(--ink-1);
}
.dash2-buffer-accepts {
  display: flex;
  gap: 4px;
}
.dash2-buffer-accept {
  padding: 4px 8px;
  background: #fff;
  border: 1px solid var(--stone-2);
  cursor: pointer;
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-2);
  transition: all var(--duration-hover) var(--ease-quiet);
}
.dash2-buffer-accept:hover {
  border-color: var(--gold-1);
  background: var(--gold-soft);
  color: var(--gold-2);
}
.dash2-buffer-dismiss {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
  font-size: 11px;
  line-height: 1;
  color: var(--ink-3);
  transition: all var(--duration-hover) var(--ease-quiet);
}
.dash2-buffer-dismiss:hover {
  border-color: var(--stone-3);
  color: var(--ink-1);
}
.dash2-buffer-foot {
  display: flex;
  justify-content: flex-end;
  margin-top: 6px;
}
.dash2-buffer-review {
  padding: 4px 6px;
  background: transparent;
  border: none;
  cursor: pointer;
  font-family: var(--font-sans-tight);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--gold-2);
}
.dash2-buffer-review:hover {
  color: var(--gold-1);
  text-decoration: underline;
}
.dash2-buffer-empty {
  margin: 0;
  font-family: var(--font-serif-italic);
  font-style: italic;
  font-size: 12px;
  line-height: 1.4;
  color: var(--ink-3);
  opacity: 0.6;
}
.dash2-meter-panel {
  width: 100%;
}
.dash2-metrics-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
  gap: 10px;
  align-items: stretch;
}
.dash2-meter-list {
  display: grid;
  gap: 8px;
  margin-top: 8px;
}
.dash2-meter-row {
  display: grid;
  grid-template-columns: auto minmax(110px, 150px) 16px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
}
.dash2-meter-row__glyph {
  width: 14px;
  height: 14px;
  flex: 0 0 auto;
  -webkit-mask: var(--ico) center / 76% no-repeat;
  mask: var(--ico) center / 76% no-repeat;
}
.practice-chip {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  background: var(--parchment-1);
  border: 1px solid var(--stone-2);
}
.practice-chip__glyph {
  width: 14px;
  height: 14px;
  flex: 0 0 auto;
  -webkit-mask: var(--ico) center / 78% no-repeat;
  mask: var(--ico) center / 78% no-repeat;
}
.practice-chip__name {
  font-family: var(--font-serif-display);
  font-size: 13px;
  color: var(--ink-1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dash2-meter-row__trend {
  font-size: 9px;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
}
.dash2-meter-row__trend.is-up,
.dash2-meter-row__trend.is-up_strong { color: #22c55e; }
.dash2-meter-row__trend.is-down      { color: #f87171; opacity: 0.8; }
.dash2-meter-row__trend.is-flat      { color: var(--ink-2, #888); opacity: 0.75; }
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
@media (prefers-reduced-motion: reduce) {
  .dash2-meter-row__fill { transition: none; }
  .cols--dash2 .col { transition: none; }
}
.dash2-meter-row__label {
  font-family: var(--font-sans-tight);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dash2-meter-row__track {
  position: relative;
  height: 12px;
  min-width: 0;
  background: rgba(120, 113, 108, 0.12);
  border: 1px solid var(--stone-2);
  overflow: hidden;
}
.dash2-meter-row__track::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 1px;
  background: rgba(0, 0, 0, 0.18);
}
.dash2-meter-row__fill {
  display: block;
  height: 100%;
  background: var(--gold-1);
  transition: width 320ms var(--ease-quiet, ease);
}
.dash2-meter-row__pct {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-3);
  white-space: nowrap;
}
.dash2-mirrors {
  display: flex;
  flex-direction: column;
  gap: 8px;
  height: 100%;
  min-height: 0;
}
.dash2-mirror-stack {
  display: grid;
  gap: 8px;
  flex: 1 1 auto;
  min-height: 0;
}
.dash2-mirror-nav {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.dash2-mirror-card {
  background: #fff;
  border: 1px solid var(--stone-2);
  padding: 8px 10px;
  display: grid;
  gap: 3px;
  min-height: 148px;
}

.dash2-mirror-card.is-clickable {
  cursor: pointer;
  transition: transform 140ms ease, border-color 140ms ease, box-shadow 140ms ease, background-color 140ms ease;
}

.dash2-mirror-card.is-clickable:hover,
.dash2-mirror-card.is-clickable:focus-visible {
  transform: translateY(-1px);
  border-color: #8ea18c;
  box-shadow: 0 10px 24px rgba(20, 28, 37, 0.10);
  background: #fcfdfc;
  outline: none;
}

.dash2-mirror-card.is-clickable:active {
  transform: translateY(0);
}
.dash2-mirror-card__eyebrow {
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.dash2-mirror-card__quote,
.dash2-mirror-card__desc {
  margin: 0;
  color: var(--ink-2);
}
.dash2-mirror-card__quote {
  font-family: var(--font-serif-display);
  font-size: 11px;
  line-height: 1.25;
  word-spacing: -0.02em;
}
.dash2-mirror-card__desc {
  font-size: 10px;
  line-height: 1.3;
  word-spacing: -0.02em;
}
.dash2-mirror-card__evidence {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 8px;
  margin-top: 2px;
  font-family: var(--font-sans-tight);
  font-size: 9px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.dash2-mirror-card__evidence span:first-child {
  color: var(--gold-2);
}
.dash2-mirror-card__link {
  justify-self: end;
  margin-top: 4px;
  font-family: var(--font-serif-italic);
  font-size: 12px;
  color: var(--gold-2);
}
.actions-dash__board--dash2 {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.cols--dash2 {
  display: flex;
  gap: 10px;
  align-items: stretch;
}
.cols--dash2 .col {
  flex: 1 1 0;
  height: clamp(280px, 40vh, 390px);
  min-width: 0;
}
.cols--dash2 .col.is-expanded {
  flex: 1.35 1.35 0;
}
.cols--dash2 .col.is-collapsed {
  flex: 0.88 1 0;
  opacity: 0.88;
}
.cols--dash2 .col__list {
  max-height: none;
}
.cols--dash2 .col__head {
  grid-template-columns: minmax(0, 1fr) auto;
}
.col__title-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  min-width: 0;
}
.col__title-row .col__title {
  min-width: 0;
}
.col__head-controls {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-left: auto;
}
.col__expand-btn {
  width: 28px;
  height: 28px;
  border: 1px solid var(--stone-3);
  background: var(--parchment-1);
  color: var(--ink-2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 13px;
  line-height: 1;
  transition: all var(--duration-hover) var(--ease-quiet);
}
.col__expand-btn:hover,
.col__expand-btn.is-on {
  border-color: var(--gold-1);
  color: var(--gold-2);
  background: var(--gold-soft);
}
.bucket-tray {
  padding-top: 0;
}
.bucket-tray .archive-col {
  min-height: 68px;
  height: auto;
  width: 100%;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  padding: 12px 14px;
}
.bucket-tray .archive-col__title {
  white-space: nowrap;
  writing-mode: horizontal-tb;
  transform: none;
  margin: 0;
  letter-spacing: 0.2em;
  font-size: 11px;
}
.bucket-tray .archive-col__meta {
  margin-left: auto;
  flex-direction: row;
  align-items: center;
}
.bucket-tray .archive-col__drop {
  flex: 1 1 auto;
  flex-direction: row;
  align-self: center;
  min-height: 0;
  justify-content: center;
  margin: 0 8px;
  padding: 8px 10px;
}
.bucket-tray .archive-col__drop-lbl {
  writing-mode: horizontal-tb;
  transform: none;
  letter-spacing: 0.2em;
}
.bucket-tray .archive-col__chev {
  align-self: center;
}
.bucket-tray .archive-panel {
  width: min(520px, 92vw);
}
@media (max-width: 1200px) {
  .dash2-capstrip {
    grid-template-columns: 1fr;
  }
  .dash2-metrics-grid {
    grid-template-columns: 1fr;
  }
  .dash2-meter-panel {
    width: 100%;
  }
  .cols--dash2 {
    flex-direction: column;
  }
  .cols--dash2 .col,
  .cols--dash2 .col.is-expanded,
  .cols--dash2 .col.is-collapsed {
    flex: 1 1 auto;
    height: auto;
    min-height: 360px;
  }
  .bucket-tray .archive-col {
    flex-wrap: wrap;
  }
  .bucket-tray .archive-col__meta {
    margin-left: 0;
  }
}


.main-content--dash2 {
  min-height: 0;
}
.view-container--dash2 {
  min-height: 0;
}
.dashboard-stage--dash2 {
  padding: 12px 16px 24px;
}
@media (max-width: 768px) {
  .dashboard-stage--dash2 {
    padding: 12px 12px 20px;
  }
}

/* ── Value Velocity click → evidence drawer ─────────────────────────────── */
.dash2-meter-row.is-clickable { cursor: pointer; }
.dash2-meter-row.is-clickable:hover .dash2-meter-row__label { color: var(--gold-2); }
.dash2-meter-row.is-clickable:focus-visible { outline: 2px solid var(--gold-1); outline-offset: 2px; }

.waypoint-drawer-veil {
  position: fixed; inset: 0;
  background: rgba(20, 18, 15, 0.38);
  display: flex; justify-content: flex-end;
  z-index: 1000;
}
.value-drawer-veil {
  position: fixed; inset: 0;
  background: rgba(20, 18, 15, 0.38);
  display: flex; justify-content: flex-end;
  z-index: 1000;
}
.value-drawer {
  width: min(440px, 92vw); height: 100%;
  background: var(--parchment-1);
  border-left: 1px solid var(--stone-2);
  box-shadow: -20px 0 40px -24px rgba(0, 0, 0, 0.4);
  display: flex; flex-direction: column;
  position: relative; overflow-y: auto;
}
.value-drawer__close {
  position: absolute; top: 12px; right: 14px;
  background: none; border: none; cursor: pointer;
  font-size: 16px; color: var(--ink-3); line-height: 1;
}
.value-drawer__head { padding: 22px 22px 16px; border-bottom: 1px solid var(--stone-2); }
.value-drawer__eye {
  font-family: var(--font-sans-tight); font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase;
}
.value-drawer__title {
  margin: 6px 0 10px;
  font-family: var(--font-serif-display); font-size: 22px; color: var(--ink-1);
}
.value-drawer__metrics { display: flex; align-items: baseline; gap: 12px; }
.value-drawer__pct { font-family: var(--font-serif-display); font-size: 28px; color: var(--ink-1); }
.value-drawer__trend { font-family: var(--font-mono); font-size: 11px; color: var(--ink-3); }
.value-drawer__desc { margin: 12px 0 0; font-size: 13px; line-height: 1.5; color: var(--ink-2); }
.value-drawer__body { padding: 16px 22px 28px; display: grid; gap: 12px; }
.value-drawer__sec { color: var(--ink-3); }
.value-ev {
  border: 1px solid var(--stone-2); background: #fff;
  padding: 12px 14px; display: grid; gap: 6px;
}
.value-ev__just { margin: 0; font-size: 13px; line-height: 1.45; color: var(--ink-1); }
.value-ev__quote {
  margin: 0; font-family: var(--font-serif-italic); font-style: italic;
  font-size: 12px; line-height: 1.45; color: var(--ink-2);
  border-left: 2px solid var(--stone-3); padding-left: 10px;
}
.value-ev__foot {
  display: flex; gap: 12px;
  font-family: var(--font-mono); font-size: 10px; color: var(--ink-3);
}

/* ── Momentum Log strip (above the action center) ───────────────────────── */
.momentum-strip {
  display: flex; align-items: center; gap: 14px;
  margin: 10px 0;
  padding: 8px 12px;
  border: 1px solid var(--stone-2);
  background: var(--parchment-1);
  overflow: hidden;
}
.momentum-strip__eye {
  font-family: var(--font-sans-tight); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--ink-3); white-space: nowrap; flex: 0 0 auto;
}
.momentum-strip__items {
  display: flex; gap: 8px; align-items: center;
  overflow-x: auto; flex: 1 1 auto; scrollbar-width: thin; padding-bottom: 2px;
}
.momentum-chip {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 5px 10px; border: 1px solid var(--stone-2); background: #fff;
  white-space: nowrap; flex: 0 0 auto;
}
.momentum-chip__glyph {
  width: 13px; height: 13px; flex: 0 0 auto;
  -webkit-mask: var(--ico) center / 76% no-repeat; mask: var(--ico) center / 76% no-repeat;
}
.momentum-chip__name { font-family: var(--font-serif-display); font-size: 12px; color: var(--ink-1); }
.momentum-chip__dot {
  width: 7px; height: 7px; border-radius: 999px;
  border: 1px solid var(--stone-3); background: transparent; flex: 0 0 auto;
}
.momentum-chip__dot.is-done { border-color: transparent; }
.momentum-strip__empty {
  font-family: var(--font-serif-italic); font-style: italic; font-size: 12px;
  color: var(--ink-3); opacity: 0.6;
}

/* ── Acceptance column (incoming triage as first action column) ─────────── */
.col--acceptance .col__list { gap: 10px; }
.col--acceptance .triage-card__placements { flex-wrap: wrap; gap: 4px; }
.col--acceptance .triage-card__place { font-size: 11px; padding: 4px 8px; }
.col-acceptance__review {
  margin-top: 4px; align-self: flex-end;
  background: none; border: none; cursor: pointer; padding: 4px 2px;
  font-family: var(--font-sans-tight); font-size: 11px; letter-spacing: 0.04em;
  color: var(--gold-2);
}
.col-acceptance__review:hover { text-decoration: underline; }

/* ── Acceptance slim cards (quick triage; click → full review popup) ─────── */
.accept-card {
  border: 1px solid var(--stone-2); background: #fff;
  padding: 8px 10px; cursor: pointer;
  display: grid; gap: 7px;
  transition: border-color var(--duration-hover) var(--ease-quiet);
}
.accept-card:hover { border-color: var(--gold-1); }
.accept-card:focus-visible { outline: 2px solid var(--gold-1); outline-offset: 2px; }
.accept-card__top { display: flex; align-items: center; gap: 7px; }
.accept-card__dot { width: 8px; height: 8px; border-radius: 999px; flex: 0 0 auto; }
.accept-card__title {
  font-family: var(--font-serif-display); font-size: 13px; color: var(--ink-1); line-height: 1.3;
  flex: 1 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.accept-card__dismiss {
  background: none; border: none; cursor: pointer; color: var(--ink-3);
  font-size: 13px; line-height: 1; padding: 0 2px; flex: 0 0 auto;
}
.accept-card__dismiss:hover { color: var(--ink-1); }
.accept-card__actions { display: flex; gap: 5px; }
.accept-card__actions button {
  flex: 1 1 0; padding: 4px 6px; cursor: pointer;
  border: 1px solid var(--stone-2); background: var(--parchment-1);
  font-family: var(--font-sans-tight); font-size: 10px; letter-spacing: 0.04em; color: var(--ink-2);
}
.accept-card__actions button:hover { border-color: var(--gold-1); color: var(--gold-2); background: var(--gold-soft); }

/* ── Acceptance v2: wider column, accent bar, sticky View-all, drag ─────── */
.cols--dash2 .col--acceptance { flex: 1.35 1.35 0; }
.col--acceptance { padding-bottom: 0; }
.col__list--acceptance { overflow: visible; }

.accept-card { position: relative; padding-left: 12px; }
.accept-card::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--accent, var(--stone-3));
}
.accept-card__grip { color: var(--ink-3); font-size: 12px; cursor: grab; flex: 0 0 auto; line-height: 1; }
.accept-card:active { cursor: grabbing; }
.accept-card__title { font-size: 14px; }

.col-acceptance__review {
  margin: 8px 0 0; width: 100%;
  border: 1px solid var(--stone-2);
  background: var(--parchment-1);
  padding: 9px 10px; cursor: pointer;
  font-family: var(--font-sans-tight); font-size: 11px; letter-spacing: 0.06em;
  color: var(--gold-2); text-align: center; flex: 0 0 auto;
}
.col-acceptance__review:hover { background: var(--gold-soft); }

/* ── TriageStepper popup (focused one-at-a-time review) ─────────────────── */
.triage-stepper {
  position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: min(440px, 94vw); max-height: 86vh; overflow: hidden;
  background: var(--parchment-1); border: 1px solid var(--stone-2);
  box-shadow: 0 30px 60px -24px rgba(0, 0, 0, 0.45);
  display: flex; flex-direction: column; z-index: 70;
}
.triage-stepper__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; border-bottom: 1px solid var(--stone-2);
}
.triage-stepper__count { color: var(--ink-3); }
.triage-stepper__close { background: none; border: none; font-size: 20px; cursor: pointer; color: var(--ink-3); line-height: 1; }
.triage-stepper__body { padding: 8px 16px; overflow-y: auto; }
.triage-stepper__nav {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 12px 16px; border-top: 1px solid var(--stone-2);
}
.triage-stepper__nav button {
  background: var(--parchment-1); border: 1px solid var(--stone-2); cursor: pointer;
  padding: 6px 12px; font-family: var(--font-sans-tight); font-size: 12px; color: var(--ink-2);
}
.triage-stepper__nav button:disabled { opacity: 0.4; cursor: default; }
.triage-stepper__hint { font-family: var(--font-serif-italic); font-style: italic; font-size: 11px; color: var(--ink-3); }

/* ── Cap analytics height so the action center + View-all + tray stay above fold ── */
.dash2-metrics-grid > section {
  max-height: 360px;
  display: flex; flex-direction: column; overflow: hidden;
}
.dash2-metrics-grid > section > .dash2-meter-list,
.dash2-metrics-grid > section > .dash2-mirrors {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: visible;
}

/* ── Acceptance v3: minimal single-line cards (drag or click) ───────────── */
.accept-card {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 10px 9px 14px;
  min-height: 0;
}
.accept-card .accept-card__title {
  flex: 1 1 auto; min-width: 0; font-size: 13px;
}
.accept-card__grip { cursor: grab; }

/* ── Inbox v4: clear bucket overlap + provisional 'incoming' look ───────── */
.dash2-metrics-grid > section { max-height: 360px; }
.dash2-metrics-grid > .dash2-meter-panel { max-height: none; overflow: visible; }
.actions-dash__board--dash2 { gap: 14px; }

/* incoming cards read as provisional (not yet placed) vs solid board cards */
.accept-card {
  background: var(--parchment-2, #efe6d4);
  border: 1px dashed var(--stone-3);
}
.accept-card:hover { border-style: solid; border-color: var(--gold-1); background: #fff; }
.col--acceptance .col__head { opacity: 0.95; }

/* ── Inbox column = darker 'staging' zone (set apart, needs attention) ──── */
.col--acceptance {
  background: rgb(234, 226, 206);
  border-left: 3px solid var(--stone-3);
}
.col--acceptance .col__sub em { color: var(--ink-2); }
.col--acceptance .accept-card {
  background: var(--parchment-1);
  border: 1px dashed var(--stone-3);
}
.col--acceptance .accept-card:hover {
  background: #fff; border-style: solid; border-color: var(--gold-1);
}
.col--acceptance .col-acceptance__review {
  background: rgba(253, 249, 238, 0.7);
}

/* ── v5: tighter headers, View-all inside box, slim lane cards (brief) ──── */

/* tighten all column headers */
.cols--dash2 .col__head { padding: 6px 8px 6px; }
.cols--dash2 .col__sub { font-size: 11px; }
.col--acceptance .col__sub em { font-size: 11px; }

/* keep View all inside the darker Inbox box */
.col--acceptance { padding-bottom: 10px; }
.col--acceptance .col-acceptance__review { margin-top: 8px; }

/* slim the Today/Soon/Vision cards per the redesign brief */
.cols--dash2 .task {
  grid-template-columns: 3px 24px 1fr;
  gap: 8px;
  padding: 7px 10px 7px 0;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.03);
}
.cols--dash2 .task:hover {
  transform: none;
  box-shadow: 0 4px 10px -6px rgba(0, 0, 0, 0.22);
}
.cols--dash2 .task .task__text { display: none; }       /* body hidden in slim view; full text on click */
.cols--dash2 .task .task__title { font-size: 13px; line-height: 1.3; }
.cols--dash2 .task__realize { width: 22px; height: 22px; }

/* ── Momentum Log v2: fixed-geometry rhythm rows ────────────────────────── */
.momentum-log {
  margin: 10px 0; border: 1px solid var(--stone-2);
  background: var(--parchment-1); padding: 8px 12px 10px;
}
.momentum-log__head { display: flex; align-items: center; gap: 12px; margin-bottom: 6px; }
.momentum-log__eye {
  font-family: var(--font-sans-tight); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--ink-3); flex: 0 0 auto;
}
.momentum-log__hint {
  font-family: var(--font-serif-italic); font-style: italic; font-size: 11px;
  color: var(--ink-3); flex: 1 1 auto;
}
.momentum-log__toggle {
  background: none; border: 1px solid var(--stone-2); cursor: pointer;
  font-family: var(--font-sans-tight); font-size: 10px; letter-spacing: 0.06em;
  color: var(--ink-2); padding: 4px 8px; flex: 0 0 auto;
}
.momentum-log__toggle:hover { border-color: var(--gold-1); color: var(--gold-2); }
.momentum-log__empty {
  font-family: var(--font-serif-italic); font-style: italic; font-size: 12px; color: var(--ink-3); margin: 4px 0;
}
.momentum-log__rows { display: flex; flex-direction: column; gap: 3px; }
.momentum-log__rows.is-expanded { max-height: 240px; overflow-y: auto; scrollbar-width: thin; }
.mlog-row {
  display: grid; grid-template-columns: 16px 16px minmax(70px, 1fr) auto auto;
  align-items: center; gap: 8px; padding: 3px 4px;
}
.mlog-row:hover { background: var(--parchment-2); }
.mlog-row__grip { color: var(--stone-3); cursor: grab; font-size: 12px; opacity: 0; transition: opacity .12s; }
.mlog-row:hover .mlog-row__grip { opacity: 1; }
.mlog-row__glyph {
  width: 14px; height: 14px;
  -webkit-mask: var(--ico) center / 76% no-repeat; mask: var(--ico) center / 76% no-repeat;
}
.mlog-row__name {
  font-family: var(--font-serif-display); font-size: 13px; color: var(--ink-1);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mlog-row__grid { display: inline-flex; gap: 3px; }
.mlog-cell {
  width: 12px; height: 12px; border-radius: 2px;
  border: 1px solid var(--stone-3); background: transparent;
}
.mlog-cell.is-done { border-color: transparent; }
.mlog-menu { position: relative; }
.mlog-menu__btn {
  background: none; border: none; cursor: pointer; color: var(--ink-3);
  font-size: 15px; line-height: 1; padding: 2px 4px;
}
.mlog-menu__btn:hover { color: var(--ink-1); }
.mlog-menu__btn:disabled { opacity: .4; cursor: default; }
.mlog-menu__pop {
  position: absolute; right: 0; top: 100%; z-index: 30;
  background: #fff; border: 1px solid var(--stone-2);
  box-shadow: 0 10px 24px -12px rgba(0,0,0,0.3);
  min-width: 140px; max-height: 220px; overflow-y: auto;
}
.mlog-menu__item {
  display: block; width: 100%; text-align: left; background: none; border: none; cursor: pointer;
  padding: 6px 10px; font-family: var(--font-sans-tight); font-size: 11px; color: var(--ink-2);
}
.mlog-menu__item:hover:not(:disabled) { background: var(--gold-soft); color: var(--gold-2); }
.mlog-menu__item.is-current { color: var(--ink-3); cursor: default; }
.momentum-log.is-busy { opacity: 0.7; pointer-events: none; }

/* ── Momentum Log v3: weekday headers, Today column, circular cells ─────── */
.momentum-log__add {
  background: none; border: 1px solid var(--stone-2); cursor: pointer;
  font-family: var(--font-sans-tight); font-size: 10px; letter-spacing: 0.06em;
  color: var(--gold-2); padding: 4px 8px; flex: 0 0 auto;
}
.momentum-log__add:hover { border-color: var(--gold-1); background: var(--gold-soft); }

.mlog-colhead, .mlog-row {
  display: grid;
  grid-template-columns: 14px 16px minmax(58px, 128px) 1fr auto auto auto;
  align-items: center; gap: 8px;
}
.mlog-colhead { padding: 0 4px 4px; }
.mlog-colhead__lead { grid-column: 1 / 5; }
.mlog-colhead__menu { width: 22px; }
.mlog-collbl {
  width: 18px; text-align: center;
  font-family: var(--font-serif-display); font-size: 11px; color: var(--ink-3);
}
.mlog-collbl--today { width: auto; padding: 0 2px; color: var(--gold-2); letter-spacing: 0.04em; }

.mlog-days { display: inline-flex; gap: 6px; align-items: center; }
.mlog-dot {
  width: 18px; height: 18px; border-radius: 50%; flex: 0 0 auto;
  border: 1.5px dashed var(--stone-3); background: transparent;
}
.mlog-dot.is-done { border-style: solid; border-color: transparent; }
.mlog-dot--today {
  width: 20px; height: 20px; cursor: pointer; padding: 0;
  border: 1.5px dashed var(--stone-3);
  box-shadow: 0 0 0 3px var(--gold-soft);
  transition: box-shadow var(--duration-hover) var(--ease-quiet);
}
.mlog-dot--today.is-done { border-style: solid; border-color: transparent; }
.mlog-dot--today:hover:not(:disabled) { box-shadow: 0 0 0 3px var(--gold-1); }

.mlog-row__leader {
  align-self: center; height: 0; margin: 0 6px;
  border-bottom: 1px dotted var(--stone-3);
}
.mlog-row:hover { background: var(--parchment-2); }

/* + Add practice inline form */
.mlog-add { display: flex; align-items: center; gap: 8px; padding: 6px 4px 8px; margin-bottom: 4px; flex-wrap: wrap; }
.mlog-add__name { flex: 0 0 200px; padding: 5px 8px; border: 1px solid var(--stone-2); background: #fff; font-size: 12px; }
.mlog-add__domains { display: flex; gap: 4px; }
.mlog-add__dom {
  width: 22px; height: 22px; border: 1px solid var(--stone-2); border-radius: 50%;
  padding: 0; cursor: pointer; display: flex; align-items: center; justify-content: center; background: #fff;
}
.mlog-add__dom.is-active { border-width: 2px; }
.mlog-add__dot { width: 11px; height: 11px; border-radius: 50%; }
.mlog-add__go {
  padding: 5px 12px; border: 1px solid var(--gold-1); background: var(--gold-soft);
  color: var(--gold-2); cursor: pointer; font-family: var(--font-sans-tight); font-size: 11px;
}
.mlog-add__go:disabled { opacity: 0.5; cursor: default; }
.mlog-add__x { background: none; border: none; cursor: pointer; color: var(--ink-3); font-size: 14px; }

/* ── Momentum Log v4: full-width even day cells (wells) ─────────────────── */
.mlog-colhead, .mlog-row {
  grid-template-columns: 14px 16px minmax(70px, 150px) 1fr;
  gap: 10px;
}
.mlog-colhead__lead { grid-column: 1 / 4; }
.mlog-track {
  display: grid;
  grid-template-columns: 16px repeat(6, minmax(0, 1fr)) 66px;
  align-items: center; gap: 6px;
}
.mlog-leader { border-bottom: 1px dotted var(--stone-3); height: 0; align-self: center; }
.mlog-collbl { justify-self: center; width: auto; }
.mlog-collbl--today { justify-self: center; }
.mlog-slot {
  display: flex; align-items: center; justify-content: center;
  height: 30px; border-radius: 8px;
  background: rgba(120, 113, 108, 0.06);
}
.mlog-slot--today {
  gap: 4px; padding: 0 5px;
  background: var(--gold-soft);
  box-shadow: inset 0 0 0 1px var(--gold-1);
}
.mlog-dot {
  width: 20px; height: 20px; border-radius: 50%; flex: 0 0 auto;
  border: 1.5px dashed var(--stone-3); background: transparent;
}
.mlog-dot.is-done { border-style: solid; border-color: transparent; }
.mlog-dot--today {
  width: 20px; height: 20px; cursor: pointer; padding: 0;
  box-shadow: none;
}
.mlog-dot--today:hover:not(:disabled) { border-color: var(--gold-2); }
.mlog-row { padding: 2px 4px; }

/* ── Momentum cells: clickable, gold + on empty hover, open detail drawer ── */
.mlog-dot { position: relative; padding: 0; cursor: pointer; }
.mlog-dot:disabled { cursor: default; }
.mlog-dot__plus {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  color: var(--gold-1); font-size: 14px; line-height: 1; opacity: 0;
  transition: opacity .12s; pointer-events: none;
}
.mlog-dot:not(.is-done):hover { border-color: var(--gold-1); }
.mlog-dot:not(.is-done):hover .mlog-dot__plus { opacity: 1; }
.mlog-dot.is-done:hover { box-shadow: 0 0 0 2px var(--gold-soft); }
.mlog-dot--today.is-done:hover { box-shadow: 0 0 0 2px var(--gold-1); }

/* ── Split-Axis Value Velocity ───────────────────────────────────── */
.dash2-splitaxis {
  flex: 1;
  min-width: 0;
}

.dash2-splitaxis__bars {
  display: block;
  position: relative;
  width: 100%;
  height: 26px;
  overflow: hidden;
}

.dash2-splitaxis__past {
  position: absolute;
  right: 50%;
  top: 50%;
  transform: translateY(-50%);
  height: 11px;
  border-radius: 3px 0 0 3px;
  opacity: 0.65;
  transition: width 0.3s ease;
}

.dash2-splitaxis__today {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translateY(-50%);
  height: 13px;
  border-radius: 0 3px 3px 0;
  transition: width 0.3s ease;
}

/* hover-reveal counts — opaque pill so they're readable over bars */
.dash2-splitaxis__count-past,
.dash2-splitaxis__count-today {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-mono, monospace);
  font-size: 9px;
  line-height: 1;
  color: var(--ink-1, #ccc);
  background: var(--parchment-1, #f5f0e8);
  padding: 1px 4px;
  border-radius: 3px;
  opacity: 0;
  transition: opacity 0.15s ease;
  white-space: nowrap;
  z-index: 10;
  pointer-events: none;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}
.dash2-splitaxis__count-past  { right: calc(50% + 3px); }
.dash2-splitaxis__count-today { left:  calc(50% + 3px); }

.dash2-meter-row:hover .dash2-splitaxis__count-past,
.dash2-meter-row:focus-within .dash2-splitaxis__count-past,
.dash2-meter-row:hover .dash2-splitaxis__count-today,
.dash2-meter-row:focus-within .dash2-splitaxis__count-today { opacity: 1; }



.dash2-splitaxis-header {
  display: flex;
  font-size: 9px;
  color: var(--ink-3, #555);
  opacity: 0.6;
  padding: 0 0 4px 0;
  margin-left: calc(14px + 8px + clamp(110px, 150px, 150px) + 8px);
}
.dash2-splitaxis-header__past {
  flex: 1;
  text-align: right;
  padding-right: 6px;
}
.dash2-splitaxis-header__today {
  flex: 1;
  padding-left: 6px;
}

/* ValueDrawer sparkline */
.value-drawer__sparkline { display: flex; align-items: center; gap: 8px; margin-top: 6px; color: var(--ink-2, #888); }
.value-drawer__spark-label { font-size: 9px; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-3, #555); }
.vd-trend { font-size: 10px; }
.vd-trend.is-up { color: #22c55e; }
.vd-trend.is-down { color: #f87171; }

/* Evidence trail — practice vs segment distinction */
.value-ev--practice { background: var(--parchment-1); border-color: var(--stone-3); }
.value-ev__practice-badge { display: flex; align-items: center; gap: 5px; font-size: 9px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-3); font-family: var(--font-mono); }
.value-ev__practice-icon { font-size: 7px; }
.value-ev__weight { color: var(--ink-3); font-family: var(--font-mono); font-size: 10px; }

/* ── Anchored Ledger — nested practices under Value Velocity ──────────────── */
.ledger-caret{ background:none;border:none;cursor:pointer;font-family:'JetBrains Mono',monospace;
  font-size:11px;color:var(--ink-3);width:30px;text-align:left;padding:0 2px 0 0;flex:0 0 auto; }
.ledger-caret:hover{ color:var(--gold-2); }
.ledger-uncharted{ margin-left:auto;color:var(--ink-4);font-family:'JetBrains Mono',monospace;
  font-size:12px;padding-right:6px; }
.ledger-practices{ padding:2px 0 12px 38px; }
.ledger-prow{ display:flex;align-items:center;gap:10px;padding:3px 0; }
.ledger-pname{ flex:0 0 116px;font-size:13px;color:var(--ink-2); }
.ledger-track{ flex:1;display:flex; }
.ledger-cell{ flex:1;display:flex;align-items:center;justify-content:center;height:18px; }
.ledger-cell > i{ width:10px;height:10px;border-radius:50%;border:1px solid var(--stone-3);display:block; }
.ledger-cell > i.on{ border:none; }
.ledger-axis{ display:flex;align-items:center;gap:10px;margin-top:1px; }
.ledger-day{ flex:1;text-align:center;font-size:10px;color:var(--ink-4);font-family:'JetBrains Mono',monospace; }
.ledger-day.is-today{ color:var(--ink-2);font-weight:600; }
.ledger-empty{ font-size:13px;color:var(--ink-4);font-style:italic;padding:4px 0 4px 116px; }

.ledger-row{ grid-template-columns: auto auto minmax(110px,150px) 16px minmax(0,1fr) !important; }
.ledger-uncharted{ text-align:right; }

/* ── Anchored Ledger v2 — clearer accordion + full-width bar ──────────────── */
.ledger-row2{ display:grid; grid-template-columns:24px minmax(140px,1fr) minmax(120px,2fr) 14px;
  align-items:center; gap:10px; padding:3px 0; }
.ledger-arrow{ background:none;border:none;cursor:pointer;font-size:14px;line-height:1;
  color:var(--ink-3);padding:6px 2px;width:24px;text-align:center; }
.ledger-arrow:hover{ color:var(--gold-2); }
.ledger-name{ display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;
  padding:6px 0;min-width:0;text-align:left; }
.ledger-name__glyph{ width:14px;height:14px;flex:0 0 auto;
  -webkit-mask:var(--ico) center / 76% no-repeat; mask:var(--ico) center / 76% no-repeat; }
.ledger-name__text{ font-family:var(--font-serif-display);font-size:14px;color:var(--ink-1);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.ledger-name:hover .ledger-name__text{ color:var(--gold-2);text-decoration:underline;text-underline-offset:3px; }
.ledger-name__n{ font-family:var(--font-mono);font-size:10px;color:var(--ink-4);flex:0 0 auto; }
.ledger-vbar{ display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;
  padding:0;position:relative;width:100%; }
.ledger-vbar__track{ flex:1;height:13px;background:rgba(120,113,108,0.12);
  border:1px solid var(--stone-2);position:relative;overflow:hidden; }
.ledger-vbar__fill{ display:block;height:100%;min-width:2px;transition:width 320ms var(--ease-quiet, ease); }
.ledger-vbar__today{ display:flex;align-items:center;gap:4px;font-family:var(--font-mono);
  font-size:10px;color:var(--ink-3);flex:0 0 auto; }
.ledger-vbar__today > i{ width:7px;height:7px;border-radius:50%;display:block;box-shadow:0 0 6px currentColor; }
.ledger-vbar__hint{ position:absolute;right:0;top:-15px;font-family:var(--font-mono);font-size:10px;
  color:var(--gold-2);opacity:0;transition:opacity .12s;white-space:nowrap;pointer-events:none; }
.ledger-vbar:hover .ledger-vbar__hint{ opacity:1; }
.ledger-vbar:hover .ledger-vbar__track{ border-color:var(--gold-1); }
.ledger-vbar--empty{ color:var(--ink-4);font-family:var(--font-mono);font-size:11px; }
.ledger-trend{ font-size:10px;width:14px;text-align:center;line-height:1; }
.ledger-trend.is-up,.ledger-trend.is-up_strong{ color:#22c55e; }
.ledger-trend.is-down{ color:#f87171;opacity:.8; }
.ledger-trend.is-flat{ color:var(--ink-4); }
.ledger-practices{ padding:2px 0 12px 34px; }

/* ── Anchored Ledger v3 — mode tabs + All Practices flat view ─────────────── */
.ledger-tabs{ display:flex; align-items:center; gap:2px; margin:6px 0 8px;
  border-bottom:1px solid var(--stone-2); padding-bottom:4px; }
.ledger-tab{ background:none; border:none; cursor:pointer; font-family:var(--font-sans-tight);
  font-size:11px; letter-spacing:.1em; text-transform:uppercase; padding:4px 8px;
  color:var(--ink-3); border-bottom:2px solid transparent; margin-bottom:-5px; }
.ledger-tab.is-active{ color:var(--gold-2); border-bottom-color:var(--gold-1); }
.ledger-tab:hover{ color:var(--gold-2); }
.ledger-tabs__sp{ flex:1; }
.ledger-tabs__axis{ font-family:var(--font-mono); font-size:10px; color:var(--ink-4); }
.ledger-flat__head{ display:flex; align-items:center; gap:10px; margin:2px 0 4px; }
.ledger-flat__lead{ flex:0 0 220px; font-family:var(--font-sans-tight); font-size:10px;
  letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.ledger-frow{ display:flex; align-items:center; gap:10px; padding:6px 0;
  border-top:1px solid var(--stone-2); }
.ledger-frow__id{ flex:0 0 220px; display:flex; align-items:center; gap:8px; min-width:0; }
.ledger-fdot{ width:9px; height:9px; border-radius:50%; flex:0 0 auto; }
.ledger-fname{ font-family:var(--font-serif-display); font-size:14px; color:var(--ink-1);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ledger-fval{ font-family:var(--font-mono); font-size:10px; color:var(--ink-4); flex:0 0 auto; }

.ledger-body{ max-height:300px; overflow-y:auto; scrollbar-width:thin; scrollbar-color:var(--stone-3) transparent; }
.ledger-body::-webkit-scrollbar{ width:7px; }
.ledger-body::-webkit-scrollbar-thumb{ background:var(--stone-3); border-radius:4px; }

.ledger-trend.is-down{ color:var(--drift-teal); opacity:1; }
.app-header__domain-pill--all{ letter-spacing:.04em; }

.ledger-vbar__track{ display:flex; }
.ledger-vbar__past{ height:100%; transition:width 320ms var(--ease-quiet, ease); }
.ledger-vbar__todayseg{ height:100%; filter:brightness(1.4); box-shadow:0 0 9px currentColor; border-left:2px solid rgba(255,255,255,.7); }
.ledger-vbar__today{ color:var(--gold-2); min-width:16px; }
.ledger-vbar__today--none{ color:var(--ink-5); }

.ledger-vbar__todayseg{ height:100%; filter:none; box-shadow:none; border-left:1px solid rgba(0,0,0,.25);
  background-color:transparent;
  background-image:repeating-linear-gradient(45deg, var(--c) 0, var(--c) 3px, rgba(255,253,249,.7) 3px, rgba(255,253,249,.7) 6px); }
.ledger-key{ display:flex; align-items:center; gap:5px; font-family:var(--font-mono); font-size:10px; color:var(--ink-4); }
.ledger-key__solid{ width:14px; height:9px; background:var(--ink-3); display:inline-block; }
.ledger-key__hatch{ width:14px; height:9px; display:inline-block; margin-left:6px;
  background-image:repeating-linear-gradient(45deg, var(--ink-3) 0, var(--ink-3) 3px, rgba(255,253,249,.7) 3px, rgba(255,253,249,.7) 6px); }

.ledger-cell{ background:none; border:none; cursor:pointer; padding:0; }
.ledger-cell:hover > i{ border-color:var(--gold-1); }
.ledger-cell:hover > i.on{ filter:brightness(1.12); }

/* All Practices — bigger dots + hover "+" to log */
.ledger-frow .ledger-cell > i{ width:15px; height:15px; position:relative; }
.ledger-frow .ledger-cell:hover > i:not(.on){ border-color:var(--gold-1); }
.ledger-frow .ledger-cell:hover > i:not(.on)::after{ content:'+'; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); font-size:13px; line-height:1; font-weight:600; color:var(--gold-2); font-family:var(--font-mono); }

/* ledger-day: 2-row layout (letter + date number) */
.ledger-day { display:flex; flex-direction:column; align-items:center; gap:1px; }
.ledger-day__num { font-size:9px; color:var(--ink-4); font-family:'JetBrains Mono',monospace; line-height:1; }
.ledger-day.is-today .ledger-day__num { color:var(--gold-2); font-weight:700; }
.ledger-day.is-today { color:var(--gold-2); }

/* Today: gold pill + inverted text */
.ledger-day.is-today {
  background: var(--gold-1, #bb9863);
  color: #2a1800 !important;
  border-radius: 3px;
  padding: 2px 4px;
  margin: -2px -4px;
  font-weight: 700;
}
.ledger-day.is-today .ledger-day__num { color: #2a1800 !important; font-weight: 700; }

/* Gold column line running down through ledger cells */
.ledger-cell.is-today {
  box-shadow: inset 1px 0 0 rgba(187,152,99,0.5), inset -1px 0 0 rgba(187,152,99,0.5);
  background: rgba(187,152,99,0.06);
}

/* Today column: full gold outline per cell (stacked = continuous column border) */
.ledger-cell.is-today {
  box-shadow:
    inset  1px  0   0 rgba(187,152,99,0.55),
    inset -1px  0   0 rgba(187,152,99,0.55),
    inset  0    1px 0 rgba(187,152,99,0.25),
    inset  0   -1px 0 rgba(187,152,99,0.25);
  background: rgba(187,152,99,0.06);
}

/* Pill cap: rounded top, square bottom — connects to cell border below */
.ledger-day.is-today {
  border-radius: 3px 3px 0 0;
  padding-bottom: 3px;
}

/* ── Today column: outer border only (no inner row dividers) ───────────── */
.ledger-cell.is-today {
  box-shadow:
    inset  1px 0 0 rgba(187,152,99,0.75),
    inset -1px 0 0 rgba(187,152,99,0.75) !important;
  background: rgba(187,152,99,0.07);
}
/* Top cap — first data row only */
.ledger-frow:first-child .ledger-cell.is-today,
.ledger-prow:first-child .ledger-cell.is-today {
  box-shadow:
    inset  1px  0   0 rgba(187,152,99,0.75),
    inset -1px  0   0 rgba(187,152,99,0.75),
    inset  0    1px 0 rgba(187,152,99,0.75) !important;
}
/* Bottom cap — last data row only */
.ledger-frow:last-child .ledger-cell.is-today,
.ledger-prow:last-child .ledger-cell.is-today {
  box-shadow:
    inset  1px  0   0 rgba(187,152,99,0.75),
    inset -1px  0   0 rgba(187,152,99,0.75),
    inset  0   -1px 0 rgba(187,152,99,0.75) !important;
}
/* Single row edge case */
.ledger-frow:only-child .ledger-cell.is-today,
.ledger-prow:only-child .ledger-cell.is-today {
  box-shadow:
    inset  1px  0   0 rgba(187,152,99,0.75),
    inset -1px  0   0 rgba(187,152,99,0.75),
    inset  0    1px 0 rgba(187,152,99,0.75),
    inset  0   -1px 0 rgba(187,152,99,0.75) !important;
}

/* ── Today column: single overlay spanning all data rows ─────────────────── */
.ledger-flat__rows {
  position: relative;
}
.ledger-col-today {
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(230px + var(--ti, 6) * (100% - 230px) / var(--dc, 7));
  width: calc((100% - 230px) / var(--dc, 7));
  border-left: 1px solid rgba(187,152,99,0.7);
  border-right: 1px solid rgba(187,152,99,0.7);
  background: rgba(187,152,99,0.05);
  pointer-events: none;
  z-index: 0;
}

/* Cell: gold side borders form the column outline */
.ledger-cell.is-today {
  background: rgba(187,152,99,0.06);
  box-shadow: inset 1px 0 0 rgba(187,152,99,0.75), inset -1px 0 0 rgba(187,152,99,0.75);
  position: relative;
  z-index: 1;
}
.ledger-frow:first-child .ledger-cell.is-today,
.ledger-prow:first-child .ledger-cell.is-today {
  box-shadow: inset 1px 0 0 rgba(187,152,99,0.75), inset -1px 0 0 rgba(187,152,99,0.75), inset 0 1px 0 rgba(187,152,99,0.75);
}
.ledger-frow:last-child .ledger-cell.is-today,
.ledger-prow:last-child .ledger-cell.is-today {
  box-shadow: inset 1px 0 0 rgba(187,152,99,0.75), inset -1px 0 0 rgba(187,152,99,0.75), inset 0 -1px 0 rgba(187,152,99,0.75);
}
.ledger-frow:only-child .ledger-cell.is-today,
.ledger-prow:only-child .ledger-cell.is-today {
  box-shadow: inset 1px 0 0 rgba(187,152,99,0.75), inset -1px 0 0 rgba(187,152,99,0.75), inset 0 1px 0 rgba(187,152,99,0.75), inset 0 -1px 0 rgba(187,152,99,0.75);
}

/* today pill: white text for accessibility */
.ledger-day.is-today { color: #fff !important; }
.ledger-day.is-today .ledger-day__num { color: #fff !important; }

/* today column overlay: positioning comes from JS (inline style) */
.ledger-col-today {
  position: absolute;
  top: 0; bottom: 0;
  border-left: 1px solid rgba(187,152,99,0.7);
  border-right: 1px solid rgba(187,152,99,0.7);
  background: rgba(187,152,99,0.05);
  pointer-events: none;
  z-index: 0;
}
