/* ════════════════════════════════════════════════════════════════
   Webbybrain — components (Untangle-themed by default)
   ════════════════════════════════════════════════════════════════ */
* { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0;
  background: var(--surface);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Body becomes Untangle-themed by default; other apps would set their own class */
body { /* effectively .app-untangle */
  --accent: #5E6F8C;
  --accent-soft: #E1E5EC;
  --accent-strong: #455673;
}

a { color: var(--accent); text-decoration: none; transition: color var(--duration) var(--ease); }
a:hover { color: var(--accent-strong); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }

h1, h2, h3 {
  font-family: var(--font-display);
  font-weight: 500;
  line-height: var(--leading-tight);
  letter-spacing: -0.01em;
  margin: 0 0 var(--sp-3);
  color: var(--ink);
}
h1 { font-size: var(--text-3xl); }
h2 { font-size: var(--text-2xl); margin-top: var(--sp-6); }
h3 { font-size: var(--text-xl); font-family: var(--font-body); font-weight: 700; }

p { margin: 0 0 var(--sp-3); }
em { font-style: italic; }
code { font-family: var(--font-mono); font-size: 0.9em; background: var(--surface-2); padding: 2px 6px; border-radius: var(--r-sm); }
pre { font-family: var(--font-mono); }

::selection { background: var(--accent-soft); color: var(--ink); }

/* ─── Header ─────────────────────────────────────────────────── */
.app-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-3) var(--sp-5);
  background: var(--surface);
  border-bottom: 1px solid var(--border-soft);
  position: sticky; top: 0; z-index: 10;
  backdrop-filter: saturate(140%) blur(6px);
}
.brand {
  display: flex; align-items: center; gap: var(--sp-2);
  font-family: var(--font-display); font-weight: 600;
  color: var(--ink); letter-spacing: -0.01em;
  font-size: var(--text-lg);
}
.brand-mark, .brand-mark-img {
  width: 32px; height: 32px;
  border-radius: var(--r-md);
  display: inline-grid; place-items: center;
}
.brand-mark {
  background: var(--accent); color: var(--ink-inverse);
  font-family: var(--font-display); font-weight: 700;
  font-size: 1.1rem; letter-spacing: 0;
}
.brand-mark-img { object-fit: cover; }
.app-nav {
  display: flex; gap: var(--sp-5);
  font-size: var(--text-sm);
}
.app-nav a {
  color: var(--ink-muted); font-weight: 400;
}
.app-nav a:hover { color: var(--ink); text-decoration: none; }
.user-pill {
  background: var(--surface-2); border: 1px solid var(--border);
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--r-pill);
  font-size: var(--text-xs);
  cursor: pointer; color: var(--ink-muted);
  transition: background var(--duration) var(--ease);
}
.user-pill:hover { background: var(--surface-3); }

/* ─── Layout ─────────────────────────────────────────────────── */
.view-root {
  max-width: 720px; margin: 0 auto;
  padding: var(--sp-6) var(--sp-5) var(--sp-8);
}
.boot-state, .placeholder, .status-msg {
  background: var(--surface-2); border: 1px solid var(--border);
  padding: var(--sp-4); border-radius: var(--r-md);
  color: var(--ink-muted);
  font-size: var(--text-sm);
}
.error-state {
  background: #F4E0E0; border: 1px solid #E0C0C0; color: #6B3838;
  padding: var(--sp-4); border-radius: var(--r-md);
}
.lede {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--ink-muted);
  line-height: var(--leading-loose);
  margin: 0 0 var(--sp-5);
}
.fineprint {
  color: var(--ink-soft); font-size: var(--text-xs);
  line-height: var(--leading-normal);
}

/* ─── Buttons ────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-5);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--surface);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: 700;
  cursor: pointer;
  transition: all var(--duration) var(--ease);
}
.btn:hover { background: var(--surface-2); border-color: var(--border-strong); }
.btn:active { transform: translateY(1px); }
.btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

.btn-primary {
  background: var(--accent); border-color: var(--accent);
  color: var(--ink-inverse);
}
.btn-primary:hover { background: var(--accent-strong); border-color: var(--accent-strong); }

.btn-icon {
  width: 48px; height: 48px; padding: 0; justify-content: center;
  font-size: 1.2rem;
}
.btn-icon.recording {
  background: #F4E0E0; border-color: #E0C0C0;
  animation: pulse 1.6s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.04); }
}
.btn-google {
  background: var(--surface);
  font-weight: 700;
}
.btn-ghost {
  background: transparent; border-color: transparent; color: var(--ink-muted);
}
.btn-ghost:hover { background: var(--surface-2); }

/* ─── Form fields ────────────────────────────────────────────── */
.field { display: block; margin: var(--sp-4) 0; }
.field span {
  display: block; margin-bottom: var(--sp-2);
  color: var(--ink-muted); font-size: var(--text-sm);
}
.field input, .field textarea, .field select {
  width: 100%; padding: var(--sp-3);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  font: inherit; font-family: var(--font-body);
  background: var(--surface); color: var(--ink);
  transition: border var(--duration) var(--ease);
}
.field input:focus, .field textarea:focus, .field select:focus {
  outline: none; border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.field textarea { resize: vertical; min-height: 100px; line-height: var(--leading-normal); }

/* ─── Login ──────────────────────────────────────────────────── */
.login-card {
  max-width: 480px; margin: var(--sp-8) auto;
  text-align: center;
  padding: var(--sp-6);
}
.login-card h1 {
  font-size: var(--text-3xl);
  margin: 0 0 var(--sp-3);
}
.login-card .btn { margin: var(--sp-5) 0; }
.webbybrain-foot {
  list-style: none; padding: 0; margin-top: var(--sp-7);
  color: var(--ink-soft); font-size: var(--text-xs);
  line-height: var(--leading-loose);
}

/* ─── Onboarding ─────────────────────────────────────────────── */
.onboarding { max-width: 560px; }
.setup-list {
  color: var(--ink-muted); line-height: var(--leading-loose);
  padding-left: var(--sp-5);
}
.setup-list code {
  background: var(--accent-soft); color: var(--accent-strong);
  padding: 1px 8px; border-radius: var(--r-sm);
}

/* ─── Home ──────────────────────────────────────────────────── */
.home h1 { margin-bottom: var(--sp-2); }
.capacity-banner {
  padding: var(--sp-4) var(--sp-5);
  border-radius: var(--r-md);
  margin: var(--sp-4) 0 var(--sp-6);
  border-left: 4px solid var(--ink-soft);
  background: var(--surface-2);
  font-size: var(--text-base);
  line-height: var(--leading-loose);
}
.capacity-banner.capacity-shutdown { border-left-color: var(--cap-shutdown); background: var(--cap-shutdown-soft); }
.capacity-banner.capacity-low      { border-left-color: var(--cap-low);      background: var(--cap-low-soft); }
.capacity-banner.capacity-medium   { border-left-color: var(--cap-medium);   background: var(--cap-medium-soft); }
.capacity-banner.capacity-high     { border-left-color: var(--cap-high);     background: var(--cap-high-soft); }

.tile-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-3);
}
.tile {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  color: var(--ink);
  font-weight: 700;
  transition: all var(--duration) var(--ease);
}
.tile:hover {
  background: var(--accent-soft);
  border-color: var(--accent);
  text-decoration: none;
  transform: translateY(-1px);
}
.tile-emoji { font-size: 1.4rem; }
.tile-primary {
  background: var(--accent-soft);
  border-color: var(--accent);
}
.open-sheet {
  margin-top: var(--sp-6);
  font-size: var(--text-xs);
  color: var(--ink-muted);
}

/* ─── Brain dump ─────────────────────────────────────────────── */
.brain-dump h1 { margin-bottom: var(--sp-2); }
.dump-input {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-4);
  transition: border var(--duration) var(--ease);
}
.dump-input:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.dump-input textarea {
  width: 100%; border: none; resize: vertical;
  padding: var(--sp-2);
  font: inherit; font-family: var(--font-body);
  font-size: var(--text-lg);
  line-height: var(--leading-loose);
  outline: none; background: transparent;
  color: var(--ink);
  min-height: 140px;
}
.dump-input textarea::placeholder { color: var(--ink-soft); }
.dump-controls {
  display: flex; gap: var(--sp-3);
  justify-content: flex-end; margin-top: var(--sp-3);
}

.routes-summary { margin: var(--sp-6) 0 var(--sp-4); }
.routes-summary h2 { margin: 0 0 var(--sp-1); }
.routes-summary .tone {
  color: var(--ink-soft); font-size: var(--text-sm);
  font-style: italic;
}

.fragment-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-5);
  margin-bottom: var(--sp-4);
}
.fragment-text {
  font-style: italic; color: var(--ink-muted);
  margin-bottom: var(--sp-4);
  padding-left: var(--sp-4);
  border-left: 3px solid var(--border);
}

.route-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--sp-3);
  align-items: center;
  padding: var(--sp-3); border-radius: var(--r-sm);
  margin-bottom: var(--sp-2);
  cursor: pointer;
  transition: background var(--duration) var(--ease);
}
.route-row:hover { background: var(--surface-2); }
.route-row.route-disconnected { opacity: 0.55; cursor: default; }
.route-row.route-disconnected:hover { background: transparent; }
.route-key {
  font-family: var(--font-mono); font-size: var(--text-xs);
  color: var(--accent);
}
.route-conf {
  font-size: var(--text-xs); color: var(--ink-soft);
  background: var(--surface-2); padding: 2px 8px;
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
}
.route-payload {
  grid-column: 2 / -1;
  background: var(--surface-2);
  border-radius: var(--r-sm);
  padding: var(--sp-3);
  font-size: var(--text-xs); color: var(--ink-muted);
  overflow: auto; max-height: 200px;
}
.route-cta {
  grid-column: 2 / -1;
  font-size: var(--text-xs); color: var(--accent-strong);
  font-style: italic;
}

.commit-btn { margin-top: var(--sp-5); }

/* ─── Tasks ──────────────────────────────────────────────────── */
.task-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-5);
  margin-bottom: var(--sp-3);
  border-left: 4px solid var(--border);
  transition: all var(--duration) var(--ease);
}
.task-card:hover { box-shadow: var(--shadow-sm); }
.task-urgent { border-left-color: var(--error); }
.task-high   { border-left-color: var(--warn); }
.task-medium { border-left-color: var(--accent); }
.task-low    { border-left-color: var(--ink-soft); }
.task-card h3 { margin: 0 0 var(--sp-1); font-size: var(--text-base); }
.task-meta {
  color: var(--ink-muted);
  font-size: var(--text-sm);
  margin: 0;
  font-family: var(--font-mono);
}
.task-notes { margin: var(--sp-2) 0 0; font-size: var(--text-sm); }

/* ─── Capacity ───────────────────────────────────────────────── */
.capacity h1 { margin-bottom: var(--sp-2); }
.capacity-tiers {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: var(--sp-2);
  margin: var(--sp-5) 0;
}
.capacity-tier {
  display: flex; flex-direction: column; align-items: center; gap: var(--sp-2);
  padding: var(--sp-5) var(--sp-3);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--surface);
  cursor: pointer; font: inherit;
  font-family: var(--font-body); font-weight: 700;
  text-transform: lowercase;
  transition: all var(--duration) var(--ease);
}
.capacity-tier:hover { transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.capacity-tier .tier-emoji { font-size: 1.8rem; }
.capacity-tier .tier-label { font-size: var(--text-sm); color: var(--ink-muted); }
.capacity-shutdown:hover { background: var(--cap-shutdown-soft); border-color: var(--cap-shutdown); }
.capacity-low:hover      { background: var(--cap-low-soft);      border-color: var(--cap-low); }
.capacity-medium:hover   { background: var(--cap-medium-soft);   border-color: var(--cap-medium); }
.capacity-high:hover     { background: var(--cap-high-soft);     border-color: var(--cap-high); }

@media (max-width: 540px) {
  .capacity-tiers { grid-template-columns: 1fr 1fr; }
}

/* ─── Settings ───────────────────────────────────────────────── */
.siblings-form .field input { font-family: var(--font-mono); font-size: var(--text-sm); }
.workspace-info {
  list-style: none; padding-left: 0;
  color: var(--ink-muted); font-size: var(--text-sm);
}
.workspace-info li { padding: var(--sp-2) 0; border-bottom: 1px solid var(--border-soft); }
.workspace-info li:last-child { border-bottom: 0; }
.workspace-info code {
  font-size: var(--text-xs); background: var(--surface-2);
  padding: 2px 8px; border-radius: var(--r-sm);
}

/* ─── Plan view (today) ──────────────────────────────────────── */
.plan-header {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: var(--sp-2);
}
.plan-date {
  font-family: var(--font-display); font-size: var(--text-3xl);
  color: var(--ink); font-weight: 500;
  letter-spacing: -0.01em;
}
.plan-capacity-pill {
  font-size: var(--text-sm); padding: var(--sp-1) var(--sp-3);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
}
.plan-capacity-pill.capacity-shutdown { background: var(--cap-shutdown-soft); color: #6B3838; }
.plan-capacity-pill.capacity-low      { background: var(--cap-low-soft);      color: #6B4F38; }
.plan-capacity-pill.capacity-medium   { background: var(--cap-medium-soft);   color: #5C5238; }
.plan-capacity-pill.capacity-high     { background: var(--cap-high-soft);     color: #3F5A3F; }

.plan-suggestion {
  font-style: italic;
  color: var(--ink-muted);
  font-family: var(--font-display);
  font-size: var(--text-lg);
  margin: var(--sp-3) 0 var(--sp-6);
}

.plan-list {
  list-style: none; padding: 0; margin: 0;
}
.plan-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--sp-4);
  align-items: center;
  padding: var(--sp-4);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  margin-bottom: var(--sp-2);
}
.plan-time {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--ink-muted);
  min-width: 60px;
}
.plan-title { font-weight: 700; }
.plan-meta { font-size: var(--text-xs); color: var(--ink-soft); }
.plan-actions { display: flex; gap: var(--sp-2); }

/* Plan load indicator (capacity-aware total) */
.plan-load {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-4);
  margin-bottom: var(--sp-4);
}
.plan-load-row {
  display: flex; justify-content: space-between; align-items: baseline;
  font-size: var(--text-base); color: var(--ink);
  margin-bottom: var(--sp-2);
}
.plan-load-row strong { font-family: var(--font-display); font-weight: 600; font-size: var(--text-lg); }
.plan-load-pct {
  font-family: var(--font-mono); font-size: var(--text-sm); color: var(--ink-muted);
}
.plan-load-bar {
  height: 6px; background: var(--surface-2); border-radius: var(--r-pill);
  overflow: hidden;
}
.plan-load-fill {
  height: 100%; border-radius: var(--r-pill);
  background: var(--ink-soft);
  transition: width var(--duration) var(--ease);
}
.plan-load.capacity-shutdown .plan-load-fill { background: var(--cap-shutdown); }
.plan-load.capacity-low      .plan-load-fill { background: var(--cap-low); }
.plan-load.capacity-medium   .plan-load-fill { background: var(--cap-medium); }
.plan-load.capacity-high     .plan-load-fill { background: var(--cap-high); }

/* Follow-up dump area */
.followup-area h3 {
  font-family: var(--font-display); font-weight: 500;
  font-size: var(--text-xl);
  color: var(--ink-muted);
}

.plan-rest-card {
  text-align: center;
  padding: var(--sp-7) var(--sp-5);
  background: var(--cap-shutdown-soft);
  border-radius: var(--r-lg);
  margin: var(--sp-5) 0;
}
.plan-rest-card h2 {
  font-family: var(--font-display);
  font-style: italic;
  color: #6B3838;
  margin: 0 0 var(--sp-3);
}
.plan-rest-card p {
  color: var(--ink-muted);
  max-width: 380px; margin: 0 auto;
  line-height: var(--leading-loose);
}

/* Webbybrain body-house alignment — Head · Untangle */
.brand-stack {
  display: inline-flex;
  flex-direction: column;
  line-height: 1;
  gap: 2px;
}
.brand-stack .brand-house {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 600;
  color: #6B7B8C;
  opacity: 0.85;
}
.brand-stack .brand-name {
  font-size: 18px;
  font-weight: 600;
  color: var(--ink, #2D2825);
  letter-spacing: -0.01em;
  font-family: 'Iowan Old Style', 'Charter', 'Georgia', serif;
}

/* Life admin view */
.admin .quick-add { background: var(--surface-2, #F2EBE0); border: 1px solid #E8DFD3; border-radius: 12px; padding: 12px 16px; margin-bottom: 24px; }
.admin .quick-add summary { font-weight: 600; cursor: pointer; padding: 4px 0; list-style: none; }
.admin .quick-add summary::-webkit-details-marker { display: none; }
.admin .quick-add-body { padding-top: 12px; display: flex; flex-direction: column; gap: 10px; }
.admin .quick-add-body input[type="text"], .admin .quick-add-body input[type="date"] { padding: 10px 12px; border-radius: 8px; border: 1px solid #E8DFD3; font-size: 16px; }
.quick-add-cats { display: flex; flex-wrap: wrap; gap: 6px; }
.qa-cat { padding: 8px 14px; border-radius: 999px; border: 1.5px solid #E8DFD3; background: #FAF6F1; font-size: 13px; cursor: pointer; transition: all 200ms; }
.qa-cat:hover { border-color: #6B7B8C; }
.qa-cat.selected { background: #6B7B8C; color: white; border-color: #6B7B8C; }
.qa-row { display: flex; gap: 10px; align-items: center; }
.qa-row input { flex: 1; }
.admin-group-heading { font-family: 'Iowan Old Style', serif; font-size: 18px; margin: 24px 0 8px; display: flex; align-items: baseline; gap: 8px; }
.admin-group-heading .count { font-size: 12px; color: #A89E92; font-weight: normal; }
.admin-group { display: flex; flex-direction: column; gap: 8px; }
.admin-card { padding: 12px 14px; background: white; border: 1px solid #E8DFD3; border-radius: 10px; }
.admin-card h3 { font-size: 15px; margin: 0 0 4px; font-weight: 500; }
.admin-card .task-meta { font-size: 12px; color: #7A7068; margin: 0; }
.admin-card.overdue { border-color: #c97064; background: #fbeae5; }
.overdue-tag { color: #c97064; font-weight: 600; }
.admin .empty-state { color: #A89E92; font-style: italic; text-align: center; padding: 40px 20px; }

/* Tasks view (and Life Admin via same shell) */
.tasks-view { max-width: 800px; margin: 0 auto; }
.tv-header { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 16px; gap: 12px; flex-wrap: wrap; }
.tv-filters { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 20px; }
.tv-filters input, .tv-filters select { padding: 8px 12px; border: 1px solid var(--border, #E8DFD3); border-radius: 8px; font-size: 14px; background: var(--surface, #FAF6F1); color: var(--ink, #2D2825); flex: 1 1 140px; min-width: 120px; }
.tv-filters input[type="search"] { flex: 2 1 200px; }

.task-card { padding: 14px 16px; background: white; border: 1px solid var(--border, #E8DFD3); border-radius: 12px; margin-bottom: 10px; box-shadow: 0 1px 2px rgba(45, 40, 37, 0.04); }
.task-card.task-urgent { border-left: 4px solid #c97064; }
.task-card.task-high { border-left: 4px solid #C9A663; }
.task-card.task-medium { border-left: 4px solid #6B7B8C; }
.task-card.task-low { border-left: 4px solid #A89E92; opacity: 0.85; }
.task-card.task-overdue { background: #fbeae5; border-color: #c97064; }
.task-card.task-done { opacity: 0.6; background: #f7f4ee; }
.task-card.task-done .task-title.strike { text-decoration: line-through; color: #7A7068; }

.task-card__header { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 8px; }
.task-title { flex: 1; font-size: 15px; font-weight: 500; margin: 0; line-height: 1.3; color: var(--ink, #2D2825); }

.task-check { width: 24px; height: 24px; min-width: 24px; border-radius: 6px; border: 1.5px solid var(--border, #E8DFD3); background: white; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 14px; color: #8AA17F; padding: 0; }
.task-check.checked { background: #8AA17F; color: white; border-color: #8AA17F; }
.task-check:hover { border-color: #8AA17F; }

.task-row-actions { display: flex; gap: 4px; flex-shrink: 0; }
.task-icon-btn { width: 28px; height: 28px; border-radius: 6px; border: 1px solid transparent; background: transparent; cursor: pointer; color: var(--ink-muted, #7A7068); font-size: 14px; padding: 0; line-height: 1; }
.task-icon-btn:hover { background: var(--surface-2, #F2EBE0); border-color: var(--border, #E8DFD3); }
.task-icon-btn.danger:hover { color: #c97064; background: #fbeae5; border-color: #c97064; }

.task-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.badge { display: inline-block; padding: 3px 10px; border-radius: 999px; font-size: 11px; font-weight: 500; line-height: 1.4; letter-spacing: 0.01em; }
.badge--neutral { background: #F2EBE0; color: #5C5048; }
.badge--cat { background: rgba(107, 123, 140, 0.12); color: #4A5C70; }
.badge--pri-urgent { background: #fbeae5; color: #c95a4d; }
.badge--pri-high { background: rgba(201, 166, 99, 0.18); color: #8d6e2c; }
.badge--pri-medium { background: rgba(107, 123, 140, 0.12); color: #4A5C70; }
.badge--pri-low { background: #F2EBE0; color: #7A7068; }
.badge--urgent { background: #c97064; color: white; }
.badge--low { background: rgba(138, 161, 127, 0.2); color: #4f6243; }
.badge--accent { background: rgba(159, 138, 171, 0.2); color: #645276; }

.task-notes { margin: 8px 0 0; font-size: 13px; color: var(--ink-muted, #7A7068); line-height: 1.5; }
.empty-state { text-align: center; padding: 40px 20px; color: var(--ink-soft, #A89E92); font-style: italic; }

/* Tasks/Admin modal */
.tv-modal { position: fixed; inset: 0; z-index: 100; display: flex; align-items: flex-end; }
@media (min-width: 600px) { .tv-modal { align-items: center; justify-content: center; } }
.tv-modal-backdrop { position: absolute; inset: 0; background: rgba(20,18,12,0.45); }
.tv-modal-card { position: relative; width: 100%; max-width: 520px; max-height: 92vh; overflow-y: auto; background: white; border-radius: 16px 16px 0 0; padding: 20px 22px; box-shadow: 0 -4px 30px rgba(0,0,0,0.18); }
@media (min-width: 600px) { .tv-modal-card { border-radius: 16px; margin: 20px; } }
.tv-modal-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
.tv-modal-head h2 { margin: 0; font-size: 20px; font-family: 'Iowan Old Style', serif; }
.tv-modal-close { background: transparent; border: none; cursor: pointer; font-size: 24px; padding: 4px 10px; color: var(--ink-muted, #7A7068); border-radius: 6px; }
.tv-modal-close:hover { background: var(--surface-2, #F2EBE0); color: var(--ink, #2D2825); }
.field-row { display: flex; gap: 10px; }
.field-row .field { flex: 1; min-width: 0; }
.tv-modal-actions { display: flex; gap: 10px; margin-top: 16px; }
.tv-modal-actions .btn { flex: 1; }
