/* ============================================================
   Computer × Trust Fund — editorial restyle
   System: warm cream surfaces + restrained type + Trust Fund accent
   deck's serif-display + small-caps mono editorial grid.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600&family=Inter+Tight:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --font-display: 'Fraunces', 'Tiempos Headline', Georgia, serif;
  --font-body:    'Inter Tight', 'Inter', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  /* Type scale — editorial, generous */
  --t-meta:   11px;          /* mono caps labels */
  --t-micro:  12px;
  --t-body:   14.5px;
  --t-lede:   16px;
  --t-h3:     20px;
  --t-h2:     28px;
  --t-h1:     46px;          /* serif page titles */
  --t-anchor: 64px;          /* oversized serif numerals */

  --lh-display: 1.04;
  --lh-body: 1.55;

  --tracking-meta: 0.14em;
  --tracking-caps: 0.06em;

  /* Spacing — baseline 8 */
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 20px;
  --s-6: 24px;
  --s-8: 32px;
  --s-10: 40px;
  --s-12: 48px;
  --s-16: 64px;
  --s-20: 80px;

  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 10px;
  --radius-full: 999px;

  --transition: 200ms cubic-bezier(0.2, 0.7, 0.2, 1);
}

/* Light = canonical */
:root,
[data-theme='light'] {
  --paper:        #EFECE5;   /* warm cream — sampled from deck */
  --paper-2:      #E6E2D9;   /* slightly darker for inset */
  --paper-3:      #DCD7CC;
  --ink:          #14130F;
  --ink-2:        #2B2A26;
  --muted:        #6B685F;
  --faint:        #9C9890;
  --hair:         #D6D1C5;   /* hairline rule */
  --hair-soft:    #E2DED3;

  --accent:       #C8E45C;   /* signature lime */
  --accent-deep:  #98B83C;
  --accent-ink:   #1E2410;

  --urgent:       #C44545;
  --urgent-soft:  #EFD7D2;
  --warn:         #A6741E;
  --warn-soft:    #E9DCC0;
  --ok:           #4F7A2E;

  /* Source dots — desaturated, editorial */
  --src-granola:  #8B7BCC;
  --src-gmail:    #C25450;
  --src-slack:    #7A5BB5;
  --src-whatsapp: #5F9560;
  --src-gcal:     #4F77B5;
  --src-linkedin: #4A82B5;
  --src-attio:    #3F8580;
  --src-substack: #C67A3A;
}

/* Dark — kept usable but light is the brand */
[data-theme='dark'] {
  --paper:        #15140F;
  --paper-2:      #1C1B16;
  --paper-3:      #25241D;
  --ink:          #EFECE2;
  --ink-2:        #DCD8CB;
  --muted:        #8E8B80;
  --faint:        #5F5C53;
  --hair:         #2D2C25;
  --hair-soft:    #232219;
  --accent:       #C8E45C;
  --accent-deep:  #A8C44A;
  --accent-ink:   #14130F;
}

/* ===== Reset ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; scroll-behavior: smooth; }
body {
  min-height: 100dvh;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: var(--t-body);
  line-height: var(--lh-body);
  font-feature-settings: 'ss01', 'cv11';
}
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
ul, ol { list-style: none; }
img { display: block; max-width: 100%; }

/* ===== Layout shell ===== */
.app {
  display: grid;
  grid-template-columns: 232px 1fr;
  min-height: 100dvh;
}

/* ===== Sidebar — editorial, no cards ===== */
.sidebar {
  padding: var(--s-8) var(--s-6) var(--s-6);
  border-right: 1px solid var(--hair);
  display: flex;
  flex-direction: column;
  gap: var(--s-8);
  background: var(--paper);
  position: sticky;
  top: 0;
  height: 100dvh;
  overflow-y: auto;
}

.brand {
  display: flex;
  align-items: center;
  padding-bottom: var(--s-2);
}
.brand-logo {
  display: block;
  height: 28px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
  object-position: left center;
}
[data-theme="dark"] .brand-logo {
  filter: invert(1) brightness(1.05);
}

.nav { display: flex; flex-direction: column; gap: var(--s-6); }
.nav-section { display: flex; flex-direction: column; gap: var(--s-1); }
.nav-label {
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--faint);
  padding: 0 0 var(--s-3);
}
.nav-item {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: 6px 0;
  font-size: var(--t-body);
  color: var(--ink-2);
  border: 0;
  background: none;
  text-align: left;
  cursor: pointer;
  transition: color var(--transition);
  position: relative;
}
.nav-item .count {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  color: var(--faint);
  letter-spacing: 0.02em;
}
.nav-item:hover { color: var(--ink); }
.nav-item:hover .count { color: var(--muted); }
.nav-item.active {
  color: var(--ink);
  font-weight: 600;
}
.nav-item.active::before {
  content: "";
  position: absolute;
  left: -24px;
  top: 50%;
  transform: translateY(-50%);
  width: 12px;
  height: 1px;
  background: var(--ink);
}
.nav-item svg { width: 14px; height: 14px; opacity: 0.55; flex-shrink: 0; }
.nav-item.active svg { opacity: 0.9; }

/* source dots in connected list */
.src-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.src-dot.granola  { background: var(--src-granola); }
.src-dot.gmail    { background: var(--src-gmail); }
.src-dot.slack    { background: var(--src-slack); }
.src-dot.whatsapp { background: var(--src-whatsapp); }
.src-dot.gcal     { background: var(--src-gcal); }
.src-dot.linkedin { background: var(--src-linkedin); }
.src-dot.attio    { background: var(--src-attio); }
.src-dot.substack { background: var(--src-substack); }

/* Profile card — lime accent */
.profile {
  margin-top: auto;
  padding: var(--s-5);
  background: var(--accent);
  color: var(--accent-ink);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  gap: var(--s-3);
  position: relative;
  overflow: hidden;
}
.profile::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, transparent 60%, rgba(255,255,255,0.35) 100%);
  pointer-events: none;
}
.avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--accent-ink);
  color: var(--accent);
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 15px;
  font-style: italic;
  flex-shrink: 0;
}
.profile-meta { display: flex; flex-direction: column; min-width: 0; }
.profile-name {
  font-weight: 600;
  font-size: 13.5px;
  color: var(--accent-ink);
}
.profile-sub {
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--accent-ink);
  opacity: 0.75;
  margin-top: 2px;
}

/* ===== Main ===== */
.main {
  padding: var(--s-10) var(--s-16) var(--s-16);
  max-width: 1200px;
}
@media (max-width: 1280px) {
  .main { padding: var(--s-10) var(--s-10) var(--s-16); }
}

/* Topbar — minimal, no card */
.topbar {
  display: flex;
  align-items: center;
  gap: var(--s-6);
  padding-bottom: var(--s-8);
  margin-bottom: var(--s-10);
  border-bottom: 1px solid var(--hair);
}
.crumb {
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: var(--s-2);
}
.crumb-muted { color: var(--faint); }
.crumb-muted::before { content: "/"; margin-right: var(--s-2); color: var(--faint); }

.search {
  position: relative;
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: var(--s-2);
  padding: 8px 12px;
  background: transparent;
  border: 1px solid var(--hair);
  border-radius: var(--radius-full);
  min-width: 280px;
  color: var(--muted);
  font-size: var(--t-micro);
  transition: border-color var(--transition);
}
.search:hover { border-color: var(--hair-soft); }
.search:focus-within { border-color: var(--ink); }
.search svg { width: 13px; height: 13px; opacity: 0.6; flex-shrink: 0; }
.search input {
  flex: 1;
  min-width: 0;
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
  border: 0;
  outline: 0;
  padding: 0;
  margin: 0;
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: var(--t-micro);
  letter-spacing: 0;
  line-height: 1.4;
}
.search input::placeholder { color: var(--muted); opacity: 1; }
.search input::-webkit-search-decoration,
.search input::-webkit-search-cancel-button { -webkit-appearance: none; }
.search kbd {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--faint);
  border: 0;
  background: none;
  padding: 0;
}

.topbar-actions { display: flex; align-items: center; gap: var(--s-2); }
.icon-btn {
  width: 32px; height: 32px;
  display: grid; place-items: center;
  border-radius: 50%;
  color: var(--muted);
  transition: color var(--transition), background var(--transition);
}
.icon-btn:hover { color: var(--ink); background: var(--hair-soft); }
.icon-btn svg { width: 14px; height: 14px; }
.icon-btn .pulse {
  position: absolute;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent-deep);
  transform: translate(8px, -8px);
}

/* ===== Page head — editorial ===== */
.page-head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--s-8);
  align-items: end;
  margin-bottom: var(--s-12);
}
.kicker {
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--muted);
  margin-bottom: var(--s-4);
}
.page-head h1 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--t-h1);
  line-height: var(--lh-display);
  letter-spacing: -0.025em;
  color: var(--ink);
  margin-top: var(--s-2);
}
.page-head h1 em { font-style: italic; font-weight: 400; }

/* Source page H1 with inline brand logo */
.src-h1 {
  display: inline-flex;
  align-items: baseline;
  gap: 0.32em;
}
.src-h1-logo {
  height: 0.72em;
  width: auto;
  align-self: center;
  /* nudge optical alignment with the serif cap-height */
  transform: translateY(0.02em);
  flex-shrink: 0;
  display: inline-block;
}

.run-card {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: var(--s-4) var(--s-5);
  border: 1px solid var(--hair);
  border-radius: var(--radius-md);
  background: transparent;
  font-size: 12.5px;
  min-width: 200px;
  align-self: end;
}
.run-card-row {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--ink-2);
}
.run-card .run-card-meta {
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--faint);
  display: block;
}
.pulse {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent-deep);
  display: inline-block;
  box-shadow: 0 0 0 0 rgba(168, 196, 74, 0.6);
  animation: pulse 2.4s ease-out infinite;
}
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(168, 196, 74, 0.55); }
  70% { box-shadow: 0 0 0 8px rgba(168, 196, 74, 0); }
  100% { box-shadow: 0 0 0 0 rgba(168, 196, 74, 0); }
}
.lede {
  max-width: 56ch;
  margin-top: var(--s-5);
  font-size: var(--t-lede);
  color: var(--muted);
  line-height: 1.5;
}

/* ===== Stats — no boxes, anchor numerals ===== */
.stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-12);
  padding: var(--s-8) 0;
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
  margin-bottom: var(--s-12);
}
.stats.stats-3 { grid-template-columns: repeat(3, 1fr); }
.stat {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  align-items: flex-start;
}
.stat .stat-label { order: 1; }
.stat .stat-num   { order: 2; }
.stat .stat-trend { order: 3; }
.stat-label {
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--muted);
}
.stat-num {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 52px;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--ink);
  display: flex;
  align-items: baseline;
  gap: var(--s-3);
}
.stat-num small {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--muted);
  letter-spacing: 0;
}
.stat-trend {
  font-family: var(--font-mono);
  font-size: var(--t-micro);
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 6px;
}
.stat-trend .up { color: var(--ok); }
.stat-trend .urgent { color: var(--urgent); }

/* ===== Filter bar ===== */
.filterbar {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin-bottom: var(--s-6);
  flex-wrap: wrap;
}
.filters {
  display: flex;
  gap: var(--s-2);
  flex-wrap: wrap;
}
.tabs {
  display: inline-flex;
  gap: 2px;
  padding: 3px;
  background: var(--paper-2);
  border-radius: var(--radius-full);
  border: 1px solid var(--hair);
}
.tab {
  padding: 6px 14px;
  border-radius: var(--radius-full);
  font-size: 12.5px;
  font-weight: 500;
  color: var(--muted);
  transition: color var(--transition), background var(--transition);
}
.tab:hover { color: var(--ink); }
.tab.active {
  background: var(--ink);
  color: var(--paper);
}
.chip {
  padding: 5px 10px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--muted);
  border: 1px solid var(--hair);
  border-radius: var(--radius-full);
  background: transparent;
}
.chip:hover { color: var(--ink); border-color: var(--ink); }
.chip.primary {
  border-color: var(--ink);
  color: var(--ink);
  background: var(--accent);
}
.chip.primary svg { width: 11px; height: 11px; }
.footer-note {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--faint);
}

/* ===== Tasks — editorial list, oversized serif anchor numbers ===== */
.tasks { display: flex; flex-direction: column; }
.task {
  display: grid;
  grid-template-columns: 100px 1fr 280px;
  gap: var(--s-8);
  padding: var(--s-8) 0;
  border-top: 1px solid var(--hair);
  position: relative;
}
.task:last-child { border-bottom: 1px solid var(--hair); }
.task.urgent .rank-num { color: var(--urgent); }

.rank { display: flex; flex-direction: column; gap: var(--s-3); }
.rank-num {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--t-anchor);
  line-height: 0.9;
  letter-spacing: -0.04em;
  color: var(--ink);
  font-variant-numeric: lining-nums;
}
/* (removed: legacy ::before prefixed Nº; new ranked rows render the number alone) */
.rank-bar {
  height: 2px;
  background: var(--hair);
  border-radius: 2px;
  position: relative;
  overflow: hidden;
  max-width: 60px;
}
.rank-bar::after {
  content: "";
  position: absolute; inset: 0;
  width: var(--rank-fill, 100%);
  background: var(--ink);
}
.task.urgent .rank-bar::after { background: var(--urgent); }
.confidence {
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--faint);
}

.task-body { display: flex; flex-direction: column; gap: var(--s-3); min-width: 0; }
.task-head { display: flex; align-items: center; gap: var(--s-3); flex-wrap: wrap; }
.task-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--t-h3);
  line-height: 1.25;
  letter-spacing: -0.012em;
  color: var(--ink);
}
.badge {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  padding: 3px 7px;
  border-radius: 3px;
  background: var(--paper-3);
  color: var(--ink-2);
}
.badge.urgent, .badge.badge-urgent { background: var(--urgent-soft); color: var(--urgent); }
.badge.warn, .badge.badge-warn { background: var(--warn-soft); color: var(--warn); }
.badge.ok, .badge.badge-ok { background: #DCEACA; color: var(--ok); }

.badge-source[data-src="granola"]  { color: var(--src-granola); }
.badge-source[data-src="gmail"]    { color: var(--src-gmail); }
.badge-source[data-src="slack"]    { color: var(--src-slack); }
.badge-source[data-src="whatsapp"] { color: var(--src-whatsapp); }
.badge-source[data-src="gcal"],
.badge-source[data-src="calendar"] { color: var(--src-gcal); }
.badge-source[data-src="linkedin"] { color: var(--src-linkedin); }
.badge-source[data-src="attio"]    { color: var(--src-attio); }
.badge-source[data-src="substack"] { color: var(--src-substack); }
.src-dot[data-src="granola"]  { background: var(--src-granola); }
.src-dot[data-src="gmail"]    { background: var(--src-gmail); }
.src-dot[data-src="slack"]    { background: var(--src-slack); }
.src-dot[data-src="whatsapp"] { background: var(--src-whatsapp); }
.src-dot[data-src="gcal"],
.src-dot[data-src="calendar"] { background: var(--src-gcal); }
.src-dot[data-src="linkedin"] { background: var(--src-linkedin); }
.src-dot[data-src="attio"]    { background: var(--src-attio); }
.src-dot[data-src="substack"] { background: var(--src-substack); }

.task-context {
  font-size: var(--t-body);
  color: var(--ink-2);
  line-height: 1.55;
  max-width: 60ch;
}
.task-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-4);
  margin-top: var(--s-1);
}
.meta-row { display: flex; align-items: baseline; gap: var(--s-2); }
.meta-label {
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--faint);
}
.meta-val { font-size: 12.5px; color: var(--ink-2); }

.badge-source {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--muted);
}

/* Draft — paper inset */
.draft {
  background: var(--paper-2);
  border: 1px solid var(--hair);
  border-radius: var(--radius-md);
  padding: var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  font-size: 13px;
  align-self: start;
}
.draft-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--faint);
}
.draft-actions { display: flex; gap: var(--s-2); margin-top: var(--s-2); }
.btn-primary, .btn-ghost {
  padding: 7px 14px;
  font-size: 12px;
  font-weight: 500;
  font-family: var(--font-body);
  border-radius: var(--radius-full);
  transition: background var(--transition), color var(--transition), border-color var(--transition);
  cursor: pointer;
  border: 1px solid transparent;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.btn-primary {
  background: var(--ink);
  color: var(--paper);
}
.btn-primary:hover { background: var(--ink-2); }
.btn-ghost {
  border-color: var(--hair);
  color: var(--ink-2);
  background: transparent;
}
.btn-ghost:hover { border-color: var(--ink); color: var(--ink); }
.task-actions { display: flex; gap: var(--s-2); flex-wrap: wrap; }

.te-src {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--muted);
}

/* ===== Workflows — editorial list ===== */
.wf-list { display: flex; flex-direction: column; }
.wf {
  padding: var(--s-8) 0;
  border-top: 1px solid var(--hair);
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}
.wf:last-child { border-bottom: 1px solid var(--hair); }
.wf-head {
  display: grid;
  grid-template-columns: 40px 1fr auto auto;
  gap: var(--s-4);
  align-items: center;
}
.wf-head > div:nth-child(2) {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.wf-head h3 {
  font-family: var(--font-display);
  font-size: var(--t-h3);
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.wf-icon {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--paper-2);
  display: grid;
  place-items: center;
  color: var(--ink-2);
  border: 1px solid var(--hair);
}
.wf-icon svg { width: 14px; height: 14px; }
.wf-meta {
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--muted);
  line-height: 1.4;
}
.wf-status {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  padding: 3px 8px;
  border-radius: 3px;
  background: var(--paper-3);
  color: var(--ink-2);
}
.wf-status.ok { background: #DCEACA; color: var(--ok); }
.wf-status.warn { background: var(--warn-soft); color: var(--warn); }

.wf-body {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: var(--s-4);
  align-items: start;
}
.wf-body > p {
  grid-column: 2;
  font-size: var(--t-body);
  color: var(--ink-2);
  line-height: 1.55;
  max-width: 70ch;
}
.wf-body code {
  font-family: var(--font-mono);
  font-size: 12.5px;
  padding: 1px 6px;
  background: var(--paper-3);
  border-radius: 3px;
  color: var(--ink);
}
.wf-runs {
  grid-column: 2;
  display: flex;
  align-items: flex-end;
  gap: 3px;
  margin-top: var(--s-2);
}
.wf-runs .wf-run {
  flex: 0 0 8px;
  height: 16px;
  background: var(--hair);
  border-radius: 1px;
}
.wf-runs .wf-run.ok { background: var(--ink); }
.wf-runs .wf-run.warn { background: var(--warn); }
.wf-runs .wf-run.fail { background: var(--urgent); }
.wf-run-label {
  margin-left: var(--s-3);
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--faint);
  align-self: center;
}
.run-card-meta {
  font-size: 12.5px;
  color: var(--ink-2);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.switch {
  display: inline-block;
  width: 32px; height: 18px;
  border-radius: var(--radius-full);
  background: var(--paper-3);
  position: relative;
  cursor: pointer;
  transition: background var(--transition);
  border: 1px solid var(--hair);
  flex-shrink: 0;
}
.switch input { display: none; }
.switch span {
  position: absolute;
  top: 2px; left: 2px;
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--paper);
  transition: transform var(--transition);
  box-shadow: 0 1px 2px rgba(0,0,0,0.12);
}
.switch:has(input:checked) {
  background: var(--ink);
  border-color: var(--ink);
}
.switch:has(input:checked) span { transform: translateX(14px); }

/* ===== Threads — two-column grid, like a press review ===== */
.thread-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-6) var(--s-10);
}
@media (max-width: 1100px) { .thread-grid { grid-template-columns: 1fr; } }

.thread {
  padding: var(--s-6) 0;
  border-top: 1px solid var(--hair);
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}
.thread-head {
  display: flex;
  align-items: baseline;
  gap: var(--s-3);
  justify-content: space-between;
}
.thread-head > div:first-child {
  display: flex;
  align-items: baseline;
  gap: var(--s-3);
}
.thread-avatar { display: none !important; }
.thread-head h3, .thread-head strong {
  font-family: var(--font-display);
  font-size: 19px;
  font-weight: 500;
  letter-spacing: -0.012em;
  color: var(--ink);
  line-height: 1.25;
}
.thread-sub {
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--faint);
}
.thread-state {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  padding: 3px 8px;
  border-radius: 3px;
  background: var(--paper-3);
  color: var(--ink-2);
  white-space: nowrap;
}
.thread-state.urgent { background: var(--urgent-soft); color: var(--urgent); }
.thread-state.warn { background: var(--warn-soft); color: var(--warn); }
.thread-state.ok { background: #DCEACA; color: var(--ok); }

.thread-events {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  border-left: 1px solid var(--hair);
  padding-left: var(--s-4);
  margin-left: 4px;
}
.thread-events li {
  position: relative;
  font-size: 13px;
  color: var(--ink-2);
  line-height: 1.5;
  padding: 3px 0;
}
.thread-events li::before {
  content: "";
  position: absolute;
  left: -19px;
  top: 12px;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--hair);
}
.thread-events li:last-child::before { background: var(--accent-deep); }
.te-src {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--muted);
  margin-right: 6px;
}
.te-src[data-src="granola"]  { color: var(--src-granola); }
.te-src[data-src="gmail"]    { color: var(--src-gmail); }
.te-src[data-src="slack"]    { color: var(--src-slack); }
.te-src[data-src="whatsapp"] { color: var(--src-whatsapp); }
.te-src[data-src="calendar"],
.te-src[data-src="gcal"]     { color: var(--src-gcal); }
.te-src[data-src="linkedin"] { color: var(--src-linkedin); }
.te-src[data-src="attio"]    { color: var(--src-attio); }
.te-src[data-src="substack"] { color: var(--src-substack); }
.thread-foot {
  display: flex;
  gap: var(--s-2);
  padding-top: var(--s-2);
}

/* ===== Calendar ===== */
.cal-nav {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--muted);
  align-self: end;
}
.cal-nav .cal-week { padding: 0 var(--s-3); }
.cal-nav button { color: var(--muted); padding: 4px; width: 26px; height: 26px; }
.cal-nav button:hover { color: var(--ink); background: var(--hair-soft); }
.cal-nav svg { width: 11px; height: 11px; }

.cal {
  display: flex;
  flex-direction: column;
}
.cal[hidden], .cal-month[hidden] { display: none !important; }
.cal-day {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--s-8);
  padding: var(--s-6) 0;
  border-top: 1px solid var(--hair);
}
.cal-day:last-child { border-bottom: 1px solid var(--hair); }
.cal-day.today {}
.cal-day-head {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 4px;
}
.cal-dow {
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--faint);
}
.cal-dom {
  font-family: var(--font-display);
  font-size: 38px;
  font-weight: 400;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--ink);
}
.cal-day.today .cal-dom { color: var(--accent-deep); font-style: italic; }
.cal-tag {
  margin-top: var(--s-2);
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--accent-deep);
}
.cal-events { display: flex; flex-direction: column; gap: var(--s-3); }
.cal-event {
  display: grid;
  grid-template-columns: 64px 1fr 1.3fr;
  gap: var(--s-5);
  padding: var(--s-3) 0;
  border-top: 1px solid var(--hair-soft);
  align-items: start;
}
.cal-event:first-child { border-top: 0; padding-top: 0; }
.cal-event.focus .cal-title { color: var(--ink); }
.cal-event.focus::before {
  /* skipping, use accent dot in time */
}
.cal-time {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-2);
  letter-spacing: 0.02em;
}
.cal-event.focus .cal-time { color: var(--accent-deep); }
.cal-event.focus .cal-time::before {
  content: "● ";
  color: var(--accent-deep);
}
.cal-body { min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.cal-title {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.3;
  color: var(--ink);
}
.cal-meta { font-size: 12.5px; color: var(--muted); line-height: 1.4; }
.cal-brief {
  font-size: 12.5px;
  color: var(--ink-2);
  line-height: 1.5;
  padding: var(--s-3);
  background: var(--paper-2);
  border-radius: var(--radius-sm);
  border-left: 2px solid var(--accent);
}
.cal-empty {
  font-size: 12px;
  color: var(--faint);
  font-style: italic;
  padding: var(--s-2) 0;
}
.cal-day.past .cal-dom { color: var(--muted); }
.cal-day.past .cal-title { color: var(--ink-2); }
.cal-day.past .cal-brief { opacity: 0.7; }
.cal-tag.muted { color: var(--muted); }

/* Calendar toolbar (toggle + nav) */
.cal-toolbar {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--s-3);
}
.cal-toggle {
  display: inline-flex;
  background: var(--paper-2);
  border: 1px solid var(--hair);
  border-radius: 999px;
  padding: 3px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
}
.cal-toggle-btn {
  background: transparent;
  border: 0;
  color: var(--muted);
  padding: 6px 14px;
  border-radius: 999px;
  cursor: pointer;
  font: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  transition: color 120ms ease, background 120ms ease;
}
.cal-toggle-btn:hover { color: var(--ink); }
.cal-toggle-btn.active {
  background: var(--ink);
  color: var(--paper);
}

/* List-view month dividers */
.cal-month-divider {
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--faint);
  padding: var(--s-6) 0 var(--s-2);
  border-top: 1px solid var(--hair);
}
.cal-month-divider:first-child { border-top: 0; padding-top: 0; }
.cal-list .cal-day { border-top: 1px solid var(--hair-soft); }
.cal-list .cal-day:last-child { border-bottom: 1px solid var(--hair); }

/* ===== Month grid view ===== */
.cal-month {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  margin-top: var(--s-2);
}
.cal-month-dows {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--faint);
  padding-bottom: var(--s-2);
  border-bottom: 1px solid var(--hair);
}
.cal-month-dows span {
  padding: 4px 8px;
}
.cal-month-dows span:nth-child(n+6) { color: var(--muted); }
.cal-month-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  grid-auto-rows: minmax(120px, auto);
  border-left: 1px solid var(--hair);
  border-top: 1px solid var(--hair);
}
.cal-cell {
  border-right: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
  padding: 8px 8px 10px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
  background: var(--paper);
  position: relative;
}
.cal-cell.out { background: transparent; border-right-color: transparent; border-bottom-color: transparent; }
.cal-cell.weekend { background: color-mix(in oklab, var(--paper) 70%, var(--paper-2)); }
.cal-cell.past .cal-cell-num { color: var(--faint); }
.cal-cell.today { background: color-mix(in oklab, var(--accent) 14%, var(--paper)); }
.cal-cell.today .cal-cell-num {
  color: var(--accent-deep);
  font-style: italic;
}
.cal-cell-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 6px;
}
.cal-cell-num {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.cal-cell-today {
  font-family: var(--font-mono);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--accent-deep);
}
.cal-cell-events {
  display: flex;
  flex-direction: column;
  gap: 3px;
  list-style: none;
  padding: 0;
  margin: 0;
  min-width: 0;
}
.cal-pill {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 4px;
  align-items: baseline;
  font-size: 11px;
  line-height: 1.25;
  padding: 2px 4px 2px 6px;
  border-radius: 3px;
  border-left: 2px solid var(--muted);
  background: var(--paper-2);
  min-width: 0;
  cursor: default;
}
.cal-pill-time {
  font-family: var(--font-mono);
  font-size: 9.5px;
  color: var(--ink-2);
  letter-spacing: 0.02em;
}
.cal-pill-title {
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}
.cal-pill.kind-focus {
  background: color-mix(in oklab, var(--accent) 22%, var(--paper));
  border-left-color: var(--accent-deep);
}
.cal-pill.kind-focus .cal-pill-time { color: var(--accent-deep); }
.cal-pill.kind-ext {
  background: var(--paper-2);
  border-left-color: var(--ink-2);
}
.cal-pill.kind-int {
  background: color-mix(in oklab, var(--paper-2) 70%, var(--paper-3));
  border-left-color: var(--muted);
}
.cal-pill.kind-personal {
  background: var(--paper);
  border-left-color: var(--hair-strong, var(--muted));
  color: var(--muted);
}
.cal-pill.kind-personal .cal-pill-title { color: var(--muted); font-style: italic; }
.cal-pill-more {
  font-family: var(--font-mono);
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--faint);
  padding: 2px 4px 0 6px;
}
.cal-cell.past .cal-pill { opacity: 0.55; }
.cal-cell.past .cal-pill.kind-focus { opacity: 0.7; }

.cal-month-legend {
  display: flex;
  gap: var(--s-5);
  flex-wrap: wrap;
  margin-top: var(--s-4);
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--muted);
}
.cal-month-legend span { display: inline-flex; align-items: center; gap: 6px; }
.cal-month-legend .dot { width: 9px; height: 9px; border-radius: 2px; display: inline-block; }
.cal-month-legend .dot-focus { background: var(--accent); }
.cal-month-legend .dot-ext { background: var(--paper-3); border: 1px solid var(--ink-2); }
.cal-month-legend .dot-int { background: var(--paper-3); }
.cal-month-legend .dot-personal { background: var(--paper); border: 1px solid var(--hair); }

@media (max-width: 1100px) {
  .cal-pill-title { font-size: 10.5px; }
  .cal-month-grid { grid-auto-rows: minmax(96px, auto); }
}

/* ===== Source drill-downs ===== */
.src-stat-strip {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  padding: 0 0 0 var(--s-8);
  border-left: 1px solid var(--hair);
  min-width: 180px;
}
.src-stat-strip > div {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.src-stat-strip > div {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.src-stat-strip strong {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 30px;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--ink);
}
.src-stat-strip span {
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--muted);
}

.src-list { display: flex; flex-direction: column; }
.src-row {
  display: grid;
  grid-template-columns: 100px 1fr auto;
  gap: var(--s-8);
  padding: var(--s-6) 0;
  border-top: 1px solid var(--hair);
  align-items: start;
}
.src-row > .btn-ghost { align-self: start; }
.src-row:last-child { border-bottom: 1px solid var(--hair); }
.src-time {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--faint);
  padding-top: 4px;
}
.src-row-body { min-width: 0; display: flex; flex-direction: column; gap: var(--s-2); }
.src-row-body strong,
.src-row-body h4 {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ink);
  line-height: 1.3;
}
.src-row-body p { font-size: 13.5px; color: var(--ink-2); line-height: 1.5; }
.src-tags {
  display: flex;
  gap: var(--s-2);
  flex-wrap: wrap;
  align-content: flex-start;
}
.tag {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  padding: 3px 8px;
  border-radius: 3px;
  background: var(--paper-3);
  color: var(--ink-2);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.tag .src-dot { width: 5px; height: 5px; }
.topic {
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-meta);
  color: var(--muted);
}
.dot { display: none; } /* small dot separator unused */
.small { font-size: 12px; color: var(--muted); }

/* ===== Hide non-active views ===== */
.view[hidden] { display: none; }

/* ===== Responsive ===== */
@media (max-width: 1024px) {
  .app { grid-template-columns: 200px 1fr; }
  .main { padding: var(--s-8); }
  .task { grid-template-columns: 80px 1fr; }
  .task .draft { grid-column: 1 / -1; margin-left: 88px; }
  .stats, .src-stat-strip { grid-template-columns: repeat(2, 1fr); gap: var(--s-6); }
  .wf-head { grid-template-columns: 32px 1fr; row-gap: var(--s-2); }
  .wf-head .wf-status, .wf-head .switch { grid-column: 2; justify-self: start; }
  .wf-body, .wf-body > p, .wf-runs { grid-column: 1 / -1; grid-template-columns: 1fr; margin-left: 0; }
  .src-row { grid-template-columns: 70px 1fr; }
  .src-tags { grid-column: 2; }
  .cal-day { grid-template-columns: 1fr; gap: var(--s-3); }
  .cal-event { grid-template-columns: 56px 1fr; }
  .cal-event .cal-brief { grid-column: 2; }
  .page-head { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .app { grid-template-columns: 1fr; }
  .sidebar { display: none; }
  .search { display: none; }
}

/* ============================ CONTACTS (lightweight CMS) ============================ */
.contacts-pane[hidden] { display: none; }

.contacts-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-4);
  padding: var(--s-4) 0 var(--s-3);
  border-bottom: 1px solid var(--hair);
  margin-bottom: var(--s-2);
}
.contacts-tabs {
  display: flex;
  align-items: center;
  gap: 0;
  padding: 4px;
  background: var(--paper-2);
  border: 1px solid var(--hair);
  border-radius: var(--radius-full);
}
.contacts-tabs .tab {
  appearance: none;
  background: transparent;
  border: 0;
  color: var(--muted);
  font: inherit;
  font-size: 13.5px;
  padding: 6px 14px;
  border-radius: var(--radius-full);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.contacts-tabs .tab .tab-count {
  color: var(--muted);
  font-size: 12px;
}
.contacts-tabs .tab.active {
  background: var(--ink);
  color: var(--paper);
}
.contacts-tabs .tab.active .tab-count { color: var(--paper); opacity: 0.7; }

.contacts-search {
  display: flex;
  align-items: center;
}
.contacts-search input {
  appearance: none;
  background: var(--paper-2);
  border: 1px solid var(--hair);
  border-radius: var(--radius-full);
  color: var(--ink);
  font: inherit;
  font-size: 13.5px;
  padding: 7px 14px;
  width: 260px;
  outline: none;
}
.contacts-search input:focus { border-color: var(--ink); }
.contacts-search input::placeholder { color: var(--muted); }

/* Table */
.contacts-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  margin-top: var(--s-2);
}
.contacts-table thead th {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: var(--t-meta);
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--muted);
  text-align: left;
  padding: var(--s-3) var(--s-4);
  border-bottom: 1px solid var(--hair);
}
.contacts-table thead th.num { text-align: right; }
.contacts-table tbody tr {
  cursor: pointer;
  border-bottom: 1px solid var(--hair-soft);
  transition: background-color 80ms ease;
}
.contacts-table tbody tr:hover { background: var(--paper-2); }
.contacts-table tbody td {
  padding: var(--s-4);
  color: var(--ink);
  vertical-align: middle;
}
.contacts-table tbody td.num { text-align: right; font-variant-numeric: tabular-nums; color: var(--muted); }
.contacts-table .c-name {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 500;
}
.contacts-table .c-avatar {
  width: 28px;
  height: 28px;
  border-radius: var(--radius-full);
  background: var(--paper-3);
  color: var(--ink-2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  flex-shrink: 0;
}
.contacts-table .c-company { color: var(--ink-2); }
.contacts-table .c-role { color: var(--muted); }
.contacts-table .c-last { color: var(--muted); font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.02em; }

/* Status pills */
.c-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  background: var(--paper-2);
  border: 1px solid var(--hair);
  color: var(--ink-2);
  white-space: nowrap;
}
.c-status::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: var(--radius-full);
  background: var(--muted);
}
.c-status.is-active::before { background: var(--accent-deep); }
.c-status.is-closing::before { background: var(--accent-deep); }
.c-status.is-prospect::before { background: #8AB4F8; }
.c-status.is-internal::before { background: var(--muted); }
.c-status.is-warning::before { background: #D98E3C; }

/* Detail view */
.contact-breadcrumb {
  padding: var(--s-4) 0 var(--s-2);
}
.contact-back {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
}
.contact-back:hover { color: var(--ink); }

.contact-detail {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: var(--s-10);
  padding-top: var(--s-2);
  border-top: 1px solid var(--hair);
  margin-top: var(--s-2);
}

.contact-header {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding-top: var(--s-6);
}
.contact-header .c-avatar-lg {
  width: 64px;
  height: 64px;
  border-radius: var(--radius-full);
  background: var(--paper-3);
  color: var(--ink-2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 18px;
  letter-spacing: 0.04em;
}
.contact-header h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 32px;
  line-height: var(--lh-display);
  color: var(--ink);
  margin: 0;
}
.contact-header .c-affil {
  font-size: var(--t-body);
  color: var(--ink-2);
}
.contact-header .c-meta {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  margin-top: var(--s-3);
  padding-top: var(--s-4);
  border-top: 1px solid var(--hair-soft);
}
.contact-header .c-meta-row {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: var(--s-3);
  font-size: 13.5px;
  align-items: baseline;
}
.contact-header .c-meta-label {
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--muted);
}
.contact-header .c-meta-value { color: var(--ink); }
.contact-header .c-notes {
  margin-top: var(--s-4);
  padding-top: var(--s-4);
  border-top: 1px solid var(--hair-soft);
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--ink-2);
}

/* Timeline */
.contact-timeline {
  padding-top: var(--s-6);
}
.contact-timeline-head {
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: var(--s-5);
}
.email-row {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--s-5);
  padding: var(--s-5) var(--s-3);
  margin: 0 calc(var(--s-3) * -1);
  border-top: 1px solid var(--hair-soft);
  text-decoration: none;
  color: inherit;
  border-radius: 4px;
  transition: background 140ms ease;
}
a.email-row { cursor: pointer; }
a.email-row:hover { background: var(--paper-2); }
a.email-row:hover .email-open { opacity: 1; }
.email-row:first-of-type { border-top: 1px solid var(--hair); }
.email-open {
  margin-left: 8px;
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--muted);
  opacity: 0;
  transition: opacity 140ms ease;
}
.email-time {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.02em;
  color: var(--muted);
  padding-top: 2px;
}
.email-body { display: flex; flex-direction: column; gap: 4px; }
.email-dir {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 2px;
}
.email-dir.in { color: var(--accent-deep); }
.email-dir.out { color: var(--ink-2); }
.email-subject {
  font-size: 15px;
  color: var(--ink);
  font-weight: 500;
}
.email-snippet {
  font-size: 13.5px;
  color: var(--ink-2);
  line-height: 1.55;
  margin-top: 2px;
}
.email-meta {
  font-size: 12px;
  color: var(--muted);
  margin-top: 4px;
}

.contacts-empty {
  padding: var(--s-10) 0;
  text-align: center;
  color: var(--muted);
  font-size: 13.5px;
}

@media (max-width: 1100px) {
  .contact-detail { grid-template-columns: 1fr; gap: var(--s-6); }
}

/* ============================================================
   Sources accordion (footer-style sidebar group)
   ============================================================ */
.sources-section { margin-top: var(--s-4); }
.sources-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0;
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--faint);
  background: none;
  border: 0;
  cursor: pointer;
  transition: color var(--transition);
}
.sources-toggle:hover { color: var(--muted); }
.sources-chev { transition: transform var(--transition); opacity: 0.6; }
.sources-toggle.open .sources-chev { transform: rotate(90deg); }
.sources-list {
  display: flex;
  flex-direction: column;
  gap: var(--s-1);
  margin-top: var(--s-3);
}
.sources-list[hidden] { display: none !important; }

/* ============================================================
   Tasks · Toolbar (add form + view toggle)
   ============================================================ */
.tasks-toolbar {
  display: flex;
  align-items: center;
  gap: var(--s-4);
  margin-bottom: var(--s-4);
  flex-wrap: wrap;
}
.task-add {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  flex: 1;
  min-width: 300px;
  padding: 6px 10px 6px 12px;
  background: var(--paper-2);
  border: 1px solid var(--hair);
  border-radius: var(--radius-md);
  transition: border-color var(--transition);
}
.task-add:focus-within { border-color: var(--ink); background: var(--paper); }
.task-add-prefix {
  font-family: var(--font-mono);
  color: var(--muted);
  font-size: 14px;
}
.task-add input[type="text"] {
  flex: 1;
  font: inherit;
  font-size: 14px;
  color: var(--ink);
  background: none;
  border: 0;
  outline: none;
  padding: 6px 0;
}
.task-add input[type="text"]::placeholder { color: var(--muted); }
.task-add input[type="date"] {
  font: inherit;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted);
  background: none;
  border: 0;
  border-left: 1px solid var(--hair);
  padding-left: var(--s-2);
  outline: none;
  cursor: pointer;
}
.task-add input[type="date"]::-webkit-calendar-picker-indicator {
  filter: invert(0.5);
  cursor: pointer;
}
.task-add-btn {
  padding: 6px 14px;
  font-size: 12px;
  border-radius: var(--radius-sm);
}
.tasks-view-toggle {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 3px;
  background: var(--paper-2);
  border: 1px solid var(--hair);
  border-radius: var(--radius-md);
}

/* ============================================================
   Tasks · List view rows
   ============================================================ */
.tasks-pane { display: block; }
.tasks-pane[hidden] { display: none !important; }
.tasks-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  overflow: visible;
}
.task-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--s-3);
  padding: var(--s-4) var(--s-5);
  background: var(--paper);
  transition: background var(--transition);
  align-items: start;
}
.task-row:hover { background: var(--paper-2); }
.task-row.done { opacity: 0.6; }
.task-row.done .task-row-title { text-decoration: line-through; color: var(--muted); }

.task-check {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1.5px solid var(--hair);
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  color: transparent;
  transition: all var(--transition);
  margin-top: 2px;
  flex-shrink: 0;
}
.task-check:hover {
  border-color: var(--accent-deep);
  color: var(--accent-deep);
  background: rgba(200, 228, 92, 0.12);
}
.task-row.done .task-check {
  background: var(--accent-deep);
  border-color: var(--accent-deep);
  color: var(--paper);
}

.task-row-body { display: flex; flex-direction: column; gap: var(--s-2); min-width: 0; }
.task-row-meta {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  flex-wrap: wrap;
}
.task-origin {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  flex-shrink: 0;
}
.task-origin.auto {
  background: rgba(143, 124, 204, 0.16);
  color: var(--src-granola);
}
.task-origin.manual {
  background: var(--paper-3);
  color: var(--muted);
}
.task-col {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: var(--radius-sm);
  background: var(--paper-3);
  color: var(--muted);
}
.task-col.col-doing { background: rgba(200, 228, 92, 0.25); color: var(--accent-ink); }
.task-col.col-waiting { background: rgba(166, 116, 30, 0.16); color: var(--warn); }
.task-due {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--muted);
  border: 1px solid var(--hair);
}
.task-due.overdue { color: var(--urgent); border-color: var(--urgent-soft); background: var(--urgent-soft); }
.task-due.due-today { color: var(--warn); border-color: var(--warn-soft); background: var(--warn-soft); font-weight: 500; }
.task-due.due-soon { color: var(--ink-2); border-color: var(--hair); }
.task-src {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--muted);
}
.task-src .src-dot { width: 6px; height: 6px; }

.task-row-title {
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  line-height: 1.4;
}
.task-row-notes {
  font-size: 13.5px;
  color: var(--muted);
  line-height: 1.5;
}
.task-row-contact {
  display: flex;
  align-items: center;
  gap: var(--s-2);
}
.task-contact {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  color: var(--ink-2);
  border: 1px solid var(--hair);
  background: var(--paper);
  padding: 3px 9px 3px 4px;
  border-radius: var(--radius-full);
  transition: all var(--transition);
}
.task-contact:hover { border-color: var(--ink); background: var(--paper-2); }
.c-avatar.tiny {
  width: 18px;
  height: 18px;
  font-size: 9px;
  border-radius: 50%;
  background: var(--paper-3);
  color: var(--ink);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
  font-weight: 500;
}

.task-row-actions {
  display: flex;
  flex-direction: column;
  gap: 4px;
  opacity: 0;
  transition: opacity var(--transition);
}
.task-row:hover .task-row-actions { opacity: 1; }
.task-mini {
  width: 24px;
  height: 24px;
  border-radius: var(--radius-sm);
  color: var(--muted);
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid var(--hair);
  transition: all var(--transition);
}
.task-mini:hover { color: var(--ink); border-color: var(--ink); background: var(--paper-2); }

.task-empty {
  padding: var(--s-10);
  text-align: center;
  color: var(--muted);
  font-size: 14px;
  background: var(--paper);
  border: 1px dashed var(--hair);
  border-radius: var(--radius-md);
}

/* ============================================================
   Tasks · Kanban
   ============================================================ */
.kanban {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-3);
  align-items: start;
}
.kanban-col {
  background: var(--paper-2);
  border: 1px solid var(--hair);
  border-radius: var(--radius-md);
  padding: var(--s-3);
  min-height: 280px;
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.kanban-col header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 4px;
}
.kanban-title {
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--ink);
  font-weight: 500;
}
.kanban-count {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  padding: 1px 6px;
  background: var(--paper-3);
  border-radius: var(--radius-sm);
}
.kanban-list {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  min-height: 60px;
  border-radius: var(--radius-sm);
  transition: background var(--transition);
}
.kanban-list.drop-over { background: rgba(200, 228, 92, 0.16); }
.kanban-card {
  background: var(--paper);
  border: 1px solid var(--hair);
  border-radius: var(--radius-sm);
  padding: var(--s-3);
  cursor: grab;
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  transition: border-color var(--transition), box-shadow var(--transition);
}
.kanban-card:hover { border-color: var(--ink-2); }
.kanban-card.dragging { opacity: 0.45; cursor: grabbing; }
.kanban-card-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.kanban-card-title {
  font-size: 13.5px;
  line-height: 1.4;
  color: var(--ink);
  font-weight: 500;
}
.kanban-card-contact {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11.5px;
  color: var(--muted);
  margin-top: 2px;
}
.kanban-card-contact:hover { color: var(--ink); }

/* ============================================================
   Today view
   ============================================================ */
.today-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-6);
}
.today-grid .today-block:first-child { grid-column: 1 / -1; }
.today-block {
  background: var(--paper-2);
  border: 1px solid var(--hair);
  border-radius: var(--radius-md);
  padding: var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.today-block-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-3);
}
.today-block-head h2 {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -0.01em;
}
.today-block-count {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--muted);
  background: var(--paper);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--hair);
}
.today-block-sub {
  font-size: 13px;
  color: var(--muted);
  margin-top: -4px;
}
.today-meetings,
.today-waiting,
.today-urgent {
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: var(--hair);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.today-empty {
  padding: var(--s-5);
  text-align: center;
  color: var(--muted);
  font-size: 13.5px;
  background: var(--paper);
  font-style: italic;
}
.today-meeting {
  display: grid;
  grid-template-columns: 70px 1fr;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: var(--paper);
  align-items: baseline;
}
.today-meeting.kind-focus { border-left: 2px solid var(--accent-deep); }
.today-meeting.kind-personal { border-left: 2px solid var(--src-substack); }
.today-meeting-time {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.02em;
  color: var(--ink);
  font-weight: 500;
}
.today-meeting-title {
  font-size: 14px;
  color: var(--ink);
  font-weight: 500;
}
.today-meeting-meta {
  font-size: 12.5px;
  color: var(--muted);
  margin-top: 2px;
}

.today-waiting-row { background: var(--paper); }
.today-waiting-link {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  align-items: center;
  transition: background var(--transition);
}
.today-waiting-link:hover { background: var(--paper-2); }
.today-waiting-name {
  font-size: 14px;
  color: var(--ink);
  font-weight: 500;
}
.today-waiting-co { color: var(--muted); font-weight: 400; font-size: 12.5px; }
.today-waiting-subj {
  font-size: 12.5px;
  color: var(--muted);
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.today-waiting-days {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--urgent);
  background: var(--urgent-soft);
  padding: 3px 8px;
  border-radius: var(--radius-sm);
}

.today-urgent-row {
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: var(--paper);
  align-items: baseline;
}
.today-urgent-due {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--muted);
}
.today-urgent-due.overdue { color: var(--urgent); }
.today-urgent-due.due-today { color: var(--warn); font-weight: 500; }
.today-urgent-title {
  font-size: 14px;
  color: var(--ink);
  font-weight: 500;
}
.today-urgent-c {
  display: inline-block;
  font-size: 12px;
  color: var(--muted);
  margin-top: 4px;
  border-bottom: 1px solid var(--hair);
}
.today-urgent-c:hover { color: var(--ink); border-color: var(--ink); }

@media (max-width: 1100px) {
  .today-grid { grid-template-columns: 1fr; }
  .kanban { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
  .kanban { grid-template-columns: 1fr; }
}

/* ============================================================
   Contacts · stage chip, waiting chip, open tasks chip, filters
   ============================================================ */
.contacts-filters {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  flex-wrap: wrap;
}
.contacts-stage {
  font: inherit;
  font-size: 12.5px;
  color: var(--ink);
  background: var(--paper-2);
  border: 1px solid var(--hair);
  padding: 6px 28px 6px 10px;
  border-radius: var(--radius-sm);
  outline: none;
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236B685F' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat: no-repeat;
  background-position: right 8px center;
  background-size: 14px;
}
.contacts-stage:focus { border-color: var(--ink); }
.contacts-search-input {
  font: inherit;
  font-size: 12.5px;
  color: var(--ink);
  background: var(--paper-2);
  border: 1px solid var(--hair);
  padding: 6px 10px;
  border-radius: var(--radius-sm);
  outline: none;
  min-width: 160px;
}
.contacts-search-input:focus { border-color: var(--ink); background: var(--paper); }
.contacts-search-input::placeholder { color: var(--muted); }

.stage-chip {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--ink-2);
  background: var(--paper-3);
  padding: 2px 7px;
  border-radius: var(--radius-sm);
}
.waiting-chip {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--urgent);
  background: var(--urgent-soft);
  padding: 1px 6px;
  border-radius: var(--radius-sm);
  margin-left: var(--s-2);
  font-weight: 500;
}
.open-tasks-chip {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--accent-ink);
  background: rgba(200, 228, 92, 0.35);
  padding: 1px 8px;
  border-radius: var(--radius-full);
  min-width: 22px;
  text-align: center;
}
.c-faint { color: var(--faint); font-family: var(--font-mono); font-size: 12px; }

/* Contact detail: tasks block above email timeline */
.contact-tasks-block {
  margin-bottom: var(--s-6);
  padding-bottom: var(--s-5);
  border-bottom: 1px solid var(--hair);
}
.contact-tasks-head {
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: var(--s-3);
}
.contact-tasks-empty {
  font-size: 13px;
  color: var(--muted);
  font-style: italic;
}
.contact-task-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--s-3);
  align-items: center;
  padding: var(--s-2) 0;
  border-bottom: 1px dashed var(--hair-soft);
  transition: background var(--transition);
}
.contact-task-row:hover { background: var(--paper-2); padding-left: 6px; padding-right: 6px; border-radius: var(--radius-sm); }
.contact-task-row:last-child { border-bottom: 0; }
.contact-task-bullet {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent-deep);
}
.contact-task-bullet.waiting { background: var(--warn); }
.contact-task-title {
  font-size: 13.5px;
  color: var(--ink);
}
.contact-task-due {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: var(--tracking-meta);
  text-transform: uppercase;
  color: var(--muted);
  padding: 2px 7px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--hair);
}
.contact-task-due.overdue { color: var(--urgent); border-color: var(--urgent-soft); background: var(--urgent-soft); }
.contact-task-due.due-today { color: var(--warn); border-color: var(--warn-soft); background: var(--warn-soft); }

@media (max-width: 720px) {
  .tasks-toolbar { flex-direction: column; align-items: stretch; }
  .task-add { min-width: 0; }
  .task-row { grid-template-columns: auto 1fr; }
  .task-row-actions { grid-column: 2; flex-direction: row; opacity: 1; justify-content: flex-end; }
}

/* ============================================================
   Tasks · Greeting + stat tiles (restored hero treatment)
   ============================================================ */
.greeting {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(36px, 4.4vw, 56px);
  line-height: 1.04;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: var(--s-3) 0 var(--s-4);
}
.greeting em {
  font-style: italic;
  font-weight: 500;
  color: var(--ink);
}
.lede b { font-weight: 600; color: var(--ink); }

.stat-tiles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-6);
  padding: var(--s-6) 0;
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
  margin: var(--s-6) 0;
}
.stat { display: flex; flex-direction: column; gap: var(--s-2); }
.stat-tiles .stat-label { order: 1; }
.stat-tiles .stat-num   { order: 2; }
.stat-tiles .stat-sub   { order: 3; }
.stat-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}
.stat-num {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 64px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.stat-sub {
  font-size: 13px;
  color: var(--muted);
}

/* ============================================================
   Tasks · Filterbar right cluster + sort + manual-add details
   ============================================================ */
.filterbar-right {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin-left: auto;
}
/* legacy .sort-control wrapper styles — superseded by .sort-trigger below */
.sort-control { display: inline-block; }
.sort-control svg { color: inherit; }
.sort-control select {
  font: inherit;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  background: transparent;
  border: 0;
  color: var(--ink);
  cursor: pointer;
  padding-right: 14px;
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%236B685F' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat: no-repeat;
  background-position: right 0 center;
}

.task-add-wrap {
  margin-bottom: var(--s-5);
  border: 1px dashed var(--hair);
  border-radius: var(--radius-md);
  background: color-mix(in oklab, var(--paper) 70%, transparent);
}
.task-add-wrap summary {
  list-style: none;
  cursor: pointer;
  padding: 10px var(--s-4);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  user-select: none;
}
.task-add-wrap summary::-webkit-details-marker { display: none; }
.task-add-wrap summary:hover { color: var(--ink); }
.task-add-wrap[open] summary { border-bottom: 1px solid var(--hair); }
.task-add-wrap .task-add {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
}
.task-add-wrap input[type="text"] {
  flex: 1;
  background: transparent;
  border: 0;
  font: inherit;
  color: var(--ink);
  outline: none;
  padding: 6px 0;
}
.task-add-wrap input[type="date"] {
  background: transparent;
  border: 1px solid var(--hair);
  border-radius: var(--radius-sm);
  padding: 5px 8px;
  font: inherit;
  font-size: 12.5px;
  color: var(--ink);
}

/* ============================================================
   Tasks · Ranked card rows (restored hero treatment)
   ============================================================ */
#tasks-list-host {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}
.ranked-row {
  display: grid;
  grid-template-columns: 92px 1fr auto;
  gap: var(--s-5);
  align-items: start;
  padding: var(--s-6) 0;
  border-bottom: 1px solid var(--hair);
}
.ranked-row:first-child { padding-top: var(--s-4); }
.ranked-row:last-child { border-bottom: 0; }
.ranked-row.done { opacity: 0.45; }
.ranked-row.done .ranked-title { text-decoration: line-through; }

.rank-num {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  font-family: var(--font-display);
  line-height: 1;
}
.rank-no {
  font-size: 11px;
  font-style: italic;
  color: var(--muted);
  font-family: var(--font-mono);
  letter-spacing: 0.06em;
}
.rank-digits {
  font-size: 56px;
  font-weight: 400;
  letter-spacing: -0.04em;
  color: var(--ink);
  padding-bottom: 2px;
  border-bottom: 2px solid currentColor;
}
.rank-num.pri-high   .rank-digits { color: #C25450; }
.rank-num.pri-medium .rank-digits { color: var(--ink); }
.rank-num.pri-low    .rank-digits { color: var(--muted); }

.ranked-body { min-width: 0; }
.ranked-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--s-3);
  margin-bottom: var(--s-3);
}
.pri-badge {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 3px;
}
.pri-badge.pri-high   { background: color-mix(in oklab, #C25450 18%, transparent); color: #A8403D; }
.pri-badge.pri-medium { background: color-mix(in oklab, var(--accent) 30%, transparent); color: var(--accent-ink); }
.pri-badge.pri-low    { background: var(--paper-2); color: var(--muted); }

.meta-src, .meta-ctx, .meta-conf {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}
.meta-src .src-dot {
  width: 7px; height: 7px;
}

.ranked-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 22px;
  line-height: 1.25;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 0 0 var(--s-2);
}
.ranked-notes {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-2);
  margin: 0 0 var(--s-3);
  max-width: 64ch;
}
.ranked-contact {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 10px 4px 4px;
  background: var(--paper-2);
  border: 1px solid var(--hair);
  border-radius: var(--radius-full);
  font-size: 12.5px;
  color: var(--ink-2);
  text-decoration: none;
}
.ranked-contact:hover { background: var(--paper-3); color: var(--ink); }

.ranked-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  opacity: 0.75;
  transition: opacity var(--transition);
}
.ranked-row:hover .ranked-actions { opacity: 1; }
.ranked-actions [data-action="delete"] {
  color: var(--muted);
}
.ranked-actions [data-action="delete"]:hover {
  color: #B03A2E;
  border-color: #B03A2E;
  background: rgba(176, 58, 46, 0.06);
}

/* ===== Nº prefix above rank digits ===== */
.rank-num { position: relative; }
.rank-no {
  display: block;
  font-family: var(--font-display, 'Fraunces', Georgia, serif);
  font-style: italic;
  font-size: 11px;
  line-height: 1;
  color: var(--muted, #6B685F);
  letter-spacing: 0.02em;
  margin-bottom: 2px;
  font-weight: 400;
}
.rank-num.pri-high .rank-no { color: #C25450; opacity: 0.75; }

/* ===== Computer-drafted email card inside ranked row ===== */
.draft {
  margin-top: 14px;
  padding: 14px 16px 12px;
  border: 1px solid var(--hair, #D6D1C5);
  border-radius: 6px;
  background: rgba(251, 250, 245, 0.6);
}
.draft-head {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono, 'JetBrains Mono', ui-monospace, monospace);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted, #6B685F);
  margin-bottom: 8px;
}
.draft-head svg { flex: none; opacity: 0.7; }
.draft-body {
  font-family: var(--font-display, 'Fraunces', Georgia, serif);
  font-style: italic;
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink, #14130F);
  margin: 0 0 12px;
  max-width: 64ch;
}
.draft-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.btn-primary {
  display: inline-flex;
  align-items: center;
  padding: 7px 16px;
  font-family: var(--font-body, 'Inter Tight', system-ui, sans-serif);
  font-size: 12.5px;
  font-weight: 500;
  letter-spacing: 0.01em;
  color: var(--ink, #14130F);
  background: var(--paper, #F5F1E8);
  border: 1px solid var(--ink, #14130F);
  border-radius: 999px;
  cursor: pointer;
  transition: background 140ms ease, transform 140ms ease;
}
.btn-primary:hover { background: rgba(20, 19, 15, 0.06); }
.btn-primary:active { transform: translateY(1px); }

/* ===== @-mention autocomplete for task add ===== */
.task-add { position: relative; }
.task-add-suggest {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  max-width: 420px;
  background: var(--paper, #F5F1E8);
  border: 1px solid var(--hair, rgba(20,19,15,0.14));
  border-radius: 10px;
  box-shadow: 0 8px 24px rgba(20,19,15,0.10);
  list-style: none;
  margin: 0;
  padding: 4px;
  max-height: 260px;
  overflow-y: auto;
  z-index: 50;
  display: none;
}
.task-add-suggest[data-open="true"] { display: block; }
.task-add-suggest li {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 10px;
  border-radius: 6px;
  cursor: pointer;
  font-family: var(--font-body, 'Inter Tight', system-ui, sans-serif);
  font-size: 13px;
  color: var(--ink, #14130F);
}
.task-add-suggest li.active,
.task-add-suggest li:hover { background: rgba(20,19,15,0.06); }
.task-add-suggest .sg-avatar {
  width: 22px; height: 22px;
  border-radius: 999px;
  background: var(--ink, #14130F);
  color: #EFECE5;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 600; letter-spacing: 0.02em;
  flex-shrink: 0;
}
.task-add-suggest .sg-name { font-weight: 500; }
.task-add-suggest .sg-co {
  color: var(--muted, rgba(20,19,15,0.55));
  font-size: 12px;
  margin-left: auto;
  padding-left: 8px;
}
.task-add-suggest .sg-empty {
  padding: 10px;
  color: var(--muted, rgba(20,19,15,0.55));
  font-size: 12.5px;
  font-style: italic;
  cursor: default;
}
.task-add-suggest .sg-empty:hover { background: transparent; }

/* ===== Editable draft body ===== */
.draft-body[contenteditable="true"] {
  outline: none;
  caret-color: var(--ink, #14130F);
  border-radius: 4px;
  transition: background 140ms ease;
}
.draft-body[contenteditable="true"]:focus {
  background: rgba(20,19,15,0.04);
  box-shadow: inset 0 0 0 1px var(--hair, rgba(20,19,15,0.14));
}
.draft-edit-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 3px;
  margin: -3px 4px -3px -3px;
  background: transparent;
  border: 0;
  border-radius: 4px;
  color: var(--muted, rgba(20,19,15,0.55));
  cursor: pointer;
  transition: background 140ms ease, color 140ms ease;
}
.draft-edit-btn:hover {
  background: rgba(20,19,15,0.06);
  color: var(--ink, #14130F);
}

/* ===== Custom Sort dropdown ===== */
.sort-control { position: relative; }
.sort-trigger {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 12px 6px 11px;
  font-family: var(--font-mono, 'Geist Mono', monospace);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--ink, #14130F);
  background: var(--paper, #F5F1E8);
  border: 1px solid var(--hair, rgba(20,19,15,0.14));
  border-radius: 999px;
  cursor: pointer;
  transition: background 140ms ease, border-color 140ms ease;
}
.sort-trigger:hover { background: rgba(20,19,15,0.04); border-color: rgba(20,19,15,0.28); }
.sort-trigger .sort-label { color: var(--muted, rgba(20,19,15,0.55)); text-transform: uppercase; }
.sort-trigger .sort-value { text-transform: uppercase; }
.sort-trigger .sort-chev { opacity: 0.55; transition: transform 160ms ease; margin-left: 2px; }
.sort-control.open .sort-trigger { background: rgba(20,19,15,0.05); border-color: var(--ink, #14130F); }
.sort-control.open .sort-trigger .sort-chev { transform: rotate(180deg); }
.sort-menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 220px;
  background: var(--paper, #F5F1E8);
  border: 1px solid var(--hair, rgba(20,19,15,0.14));
  border-radius: 10px;
  box-shadow: 0 12px 32px rgba(20,19,15,0.12);
  list-style: none;
  margin: 0;
  padding: 5px;
  z-index: 60;
  display: none;
}
.sort-control.open .sort-menu { display: block; }
.sort-menu li {
  display: flex;
  align-items: center;
  padding: 9px 32px 9px 12px;
  border-radius: 6px;
  font-family: var(--font-body, 'Inter Tight', system-ui, sans-serif);
  font-size: 13px;
  color: var(--ink, #14130F);
  cursor: pointer;
  position: relative;
}
.sort-menu li:hover { background: rgba(20,19,15,0.05); }
.sort-menu li.active { background: rgba(20,19,15,0.07); }
.sort-menu li.active::after {
  content: '✓';
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 12px;
  color: var(--ink, #14130F);
}
.sort-menu .sort-hint {
  font-family: var(--font-mono, 'Geist Mono', monospace);
  font-size: 10.5px;
  letter-spacing: 0.04em;
  color: var(--muted, rgba(20,19,15,0.55));
  text-transform: uppercase;
}

/* ===== Kanban card delete button ===== */
.kanban-card { position: relative; }
.kanban-card-del {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  font-size: 14px;
  line-height: 1;
  color: var(--muted, rgba(20,19,15,0.55));
  background: transparent;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  opacity: 0.55;
  transition: opacity 140ms ease, background 140ms ease, color 140ms ease;
  z-index: 2;
}
.kanban-card:hover .kanban-card-del { opacity: 1; }
.kanban-card-del:hover {
  background: rgba(176, 58, 46, 0.10);
  color: #B03A2E;
  opacity: 1;
}
.kanban-card-del:focus-visible { opacity: 1; outline: 1px solid var(--ink, #14130F); outline-offset: 1px; }
.btn-ghost {
  display: inline-flex;
  align-items: center;
  padding: 7px 14px;
  font-family: var(--font-body, 'Inter Tight', system-ui, sans-serif);
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ink, #14130F);
  background: transparent;
  border: 1px solid var(--hair, #D6D1C5);
  border-radius: 999px;
  cursor: pointer;
  transition: background 140ms ease, border-color 140ms ease;
}
.btn-ghost:hover {
  background: rgba(20, 19, 15, 0.04);
  border-color: #B6B0A2;
}

/* ===== Global search dropdown ===== */
.search-results {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  min-width: 380px;
  max-height: 440px;
  overflow-y: auto;
  background: var(--paper);
  border: 1px solid var(--hair);
  border-radius: 10px;
  box-shadow: 0 12px 32px rgba(20, 19, 15, 0.12);
  list-style: none;
  margin: 0;
  padding: 5px;
  z-index: 80;
  display: none;
}
#global-search.open .search-results { display: block; }
.search-results li[data-idx] {
  display: flex;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 6px;
  cursor: pointer;
  align-items: center;
  font-size: 13px;
  color: var(--ink);
}
.search-results li.active,
.search-results li[data-idx]:hover {
  background: rgba(20, 19, 15, 0.06);
}
.sr-head {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 10px 10px 4px;
}
.sr-avatar {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background: var(--ink);
  color: #EFECE5;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10.5px;
  font-weight: 600;
  flex-shrink: 0;
}
.sr-icon {
  width: 26px;
  height: 26px;
  border-radius: 6px;
  background: var(--paper-2, #F5F1E6);
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 12px;
}
.sr-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-width: 0;
}
.sr-title {
  color: var(--ink);
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sr-sub {
  color: var(--muted);
  font-size: 11.5px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sr-kind {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  flex-shrink: 0;
}
.sr-empty {
  padding: 14px 12px;
  color: var(--muted);
  font-style: italic;
  font-size: 12.5px;
}
.search-results mark {
  background: rgba(212, 168, 88, 0.35);
  color: inherit;
  padding: 0 1px;
  border-radius: 2px;
}

/* ===== Notifications panel ===== */
.notif-wrap { position: relative; }
.notif-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 360px;
  max-height: 440px;
  overflow-y: auto;
  background: var(--paper);
  border: 1px solid var(--hair);
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(20, 19, 15, 0.14);
  z-index: 90;
  padding: 4px;
}
.notif-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px 6px;
}
.notif-kicker {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}
.notif-mark-read {
  background: none;
  border: none;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 4px;
}
.notif-mark-read:hover { color: var(--ink); background: rgba(20,19,15,0.05); }
.notif-list { list-style: none; margin: 0; padding: 0; }
.notif-item {
  display: flex;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 8px;
  cursor: pointer;
  align-items: flex-start;
  border-top: 1px solid var(--hair);
}
.notif-item:first-child { border-top: none; }
.notif-item:hover { background: rgba(20, 19, 15, 0.05); }
.notif-item.read { opacity: 0.55; }
.notif-icon {
  width: 24px; height: 24px;
  border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px;
  flex-shrink: 0;
  background: var(--paper-2, #F5F1E6);
  color: var(--ink);
}
.notif-kind-task    { background: rgba(60, 110, 70, 0.18); color: #2D5A37; }
.notif-kind-draft   { background: rgba(212, 168, 88, 0.28); color: #7A5A14; }
.notif-kind-signal  { background: rgba(58, 102, 162, 0.18); color: #2A4F88; }
.notif-kind-cal     { background: rgba(120, 80, 160, 0.18); color: #5C3D8A; }
.notif-kind-granola { background: rgba(176, 58, 46, 0.16); color: #8A2E22; }
.notif-kind-attio   { background: rgba(20, 19, 15, 0.10); color: var(--ink); }
.notif-body { flex: 1; min-width: 0; }
.notif-text {
  font-size: 13px; line-height: 1.35; color: var(--ink);
}
.notif-time {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin-top: 3px;
}

/* ===== Source row hover + expanded ===== */
.src-row { cursor: default; transition: background var(--transition); }
.src-row .btn-ghost { cursor: pointer; }
.src-row.expanded {
  background: rgba(20, 19, 15, 0.04);
  outline: 1px solid var(--hair);
}
