/* ============================================================
   Lumi UI · Design System
   ------------------------------------------------------------
   Drop-in additive stylesheet. Load AFTER your existing
   style.css. All tokens and classes are prefixed `lui-` so
   nothing here clashes with what you already have.

   Theme switches via [data-theme="light"|"dark"] on <html>.
   Default is dark — matches existing default.
   ============================================================ */

/* ============================================================
   1. DESIGN TOKENS
   ============================================================ */
:root {
  /* --- Color (dark theme is default) --- */
  --lui-bg:             #0f1115;
  --lui-surface-1:      #171a21;
  --lui-surface-2:      #1d212a;
  --lui-surface-3:      #232833;

  --lui-border:         rgba(255, 255, 255, 0.06);
  --lui-border-strong:  rgba(255, 255, 255, 0.10);

  --lui-text:           #e6e8ee;
  --lui-text-primary:   #e6e8ee; /* alias of --lui-text — keeps `var(--lui-text-primary)` usages working */
  --lui-text-secondary: #a4abb8;
  --lui-text-muted:     #6c7382;

  /* Accent — one color, one job */
  --lui-accent:         #5eead4;
  --lui-accent-hover:   #4dd9c3;
  --lui-accent-soft:    rgba(94, 234, 212, 0.14);
  --lui-accent-fg:      #0a0c11; /* foreground on accent backgrounds */

  /* Semantic — one job per color */
  --lui-danger:         #f87171;
  --lui-danger-soft:    rgba(248, 113, 113, 0.14);
  --lui-warning:        #e0b15a;
  --lui-warning-soft:   rgba(224, 177, 90, 0.14);
  --lui-success:        #7dd3a8;
  --lui-success-soft:   rgba(125, 211, 168, 0.14);
  --lui-info:           #7dd3fc;
  --lui-info-soft:      rgba(125, 211, 252, 0.14);

  /* --- Typography --- */
  --lui-font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --lui-font-display: 'Plus Jakarta Sans', var(--lui-font-sans);
  --lui-font-mono: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;

  /* 6-step type scale (px, kept as numbers so consumers can derive line-heights) */
  --lui-fs-display: 28px;
  --lui-fs-title:   20px;
  --lui-fs-heading: 14px;
  --lui-fs-body:    13px;
  --lui-fs-caption: 12px;
  --lui-fs-micro:   11px;

  --lui-lh-tight:   1.2;
  --lui-lh-snug:    1.4;
  --lui-lh-normal:  1.55;
  --lui-lh-loose:   1.65;

  --lui-fw-regular: 400;
  --lui-fw-medium:  500;
  --lui-fw-semi:    600;
  --lui-fw-bold:    700;

  /* --- Spacing (4px base) --- */
  --lui-sp-1:  4px;
  --lui-sp-2:  8px;
  --lui-sp-3:  12px;
  --lui-sp-4:  16px;
  --lui-sp-5:  20px;
  --lui-sp-6:  24px;
  --lui-sp-7:  32px;
  --lui-sp-8:  40px;
  --lui-sp-9:  48px;
  --lui-sp-10: 64px;

  /* --- Radius --- */
  --lui-r-sm:  6px;
  --lui-r-md:  8px;
  --lui-r-lg:  12px;
  --lui-r-xl:  16px;
  --lui-r-full: 999px;

  /* --- Shadow --- */
  --lui-shadow-sm: 0 1px 2px rgba(0, 0, 0, .15);
  --lui-shadow:    0 4px 12px rgba(0, 0, 0, .22);
  --lui-shadow-md: 0 12px 32px rgba(0, 0, 0, .35);
  --lui-shadow-lg: 0 24px 60px rgba(0, 0, 0, .5);

  /* --- Motion --- */
  --lui-ease-out: cubic-bezier(.2, .7, .3, 1);
  --lui-dur-fast: 120ms;
  --lui-dur:      180ms;
  --lui-dur-slow: 280ms;

  /* --- Sizing --- */
  --lui-sidebar-w: 188px;
  --lui-topbar-h:  64px;
  --lui-content-max: 1280px;
  --lui-row-h:     48px;
  --lui-btn-h:     32px;
  --lui-input-h:   36px;

  /* --- Z-index scale --- */
  --lui-z-base:     1;
  --lui-z-sticky:   10;
  --lui-z-drawer:   50;
  --lui-z-modal:    60;
  --lui-z-palette:  70;
  --lui-z-toast:    80;
}

[data-theme="light"] {
  --lui-bg:             #f8f8f6;
  --lui-surface-1:      #ffffff;
  --lui-surface-2:      #f1f1ee;
  --lui-surface-3:      #e7e7e3;

  --lui-border:         rgba(0, 0, 0, 0.08);
  --lui-border-strong:  rgba(0, 0, 0, 0.14);

  --lui-text:           #1a1c22;
  --lui-text-primary:   #1a1c22; /* alias of --lui-text for light theme */
  --lui-text-secondary: #4d5563;
  --lui-text-muted:     #777f8b;

  --lui-accent:         #0d8c7d;
  --lui-accent-hover:   #0a6f63;
  --lui-accent-soft:    rgba(13, 140, 125, 0.10);
  --lui-accent-fg:      #ffffff;

  --lui-danger:         #c4453a;
  --lui-danger-soft:    rgba(196, 69, 58, 0.10);
  --lui-warning:        #b87a14;
  --lui-warning-soft:   rgba(184, 122, 20, 0.10);
  --lui-success:        #2e8056;
  --lui-success-soft:   rgba(46, 128, 86, 0.10);
  --lui-info:           #1670a8;
  --lui-info-soft:      rgba(22, 112, 168, 0.10);

  --lui-shadow-sm: 0 1px 2px rgba(0, 0, 0, .06);
  --lui-shadow:    0 4px 12px rgba(0, 0, 0, .08);
  --lui-shadow-md: 0 12px 32px rgba(0, 0, 0, .10);
  --lui-shadow-lg: 0 24px 60px rgba(0, 0, 0, .14);
}

/* ============================================================
   2. RESET & BASE (scoped — only applies inside .lui-app)
   ============================================================
   We scope under .lui-app so we don't conflict with existing
   styles. The migrated base template wraps content in
   <div class="lui-app">.
   ============================================================ */
.lui-app,
.lui-app * { box-sizing: border-box; }

.lui-app {
  font-family: var(--lui-font-sans);
  font-size: var(--lui-fs-body);
  line-height: var(--lui-lh-normal);
  color: var(--lui-text);
  background: var(--lui-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.lui-app h1, .lui-app h2, .lui-app h3, .lui-app h4, .lui-app h5, .lui-app h6 {
  font-family: var(--lui-font-display);
  font-weight: var(--lui-fw-bold);
  letter-spacing: -.01em;
  margin: 0;
}

.lui-app a { color: var(--lui-accent); text-decoration: none; }
.lui-app a:hover { color: var(--lui-accent-hover); }

.lui-app code, .lui-app pre { font-family: var(--lui-font-mono); }

/* ============================================================
   3. LAYOUT — sidebar + topbar + content
   ============================================================ */
/* Override legacy `body { display: flex }` whenever a migrated template
   is rendering. Without this, body's flex layout treats .lui-app as a
   content-hugging flex item and the content area never reaches the
   right edge of the viewport. The :has() selector scopes this fix to
   pages that actually use .lui-app, so legacy pages are unaffected. */
body:has(> .lui-app) {
  display: block;
}

.lui-app {
  display: flex;
  min-height: 100vh;
  width: 100%;
}

.lui-sidebar {
  width: var(--lui-sidebar-w);
  background: #0a0c11;
  border-right: 1px solid var(--lui-border);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  position: sticky;
  top: 0;
  height: 100vh;
}
[data-theme="light"] .lui-sidebar { background: #1a1c22; }

.lui-sidebar__brand {
  padding: 22px 18px 18px;
  color: #f1f5f9;
}
.lui-sidebar__brand-title {
  font-family: var(--lui-font-display);
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -.02em;
}
.lui-sidebar__brand-sub {
  font-size: 10px;
  color: #6c7382;
  margin-top: 2px;
}

.lui-sidebar__cmdk {
  margin: 0 12px 14px;
  display: flex;
  align-items: center;
  gap: 7px;
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  border-radius: var(--lui-r-md);
  padding: 6px 9px;
  font-size: var(--lui-fs-micro);
  color: var(--lui-text-muted);
  cursor: pointer;
  width: calc(100% - 24px);
  text-align: left;
  font-family: inherit;
}
.lui-sidebar__cmdk:hover { color: var(--lui-text-secondary); }
.lui-sidebar__cmdk-kbd {
  margin-left: auto;
  font-size: 9px;
  color: var(--lui-text-muted);
  background: rgba(255,255,255,.06);
  padding: 1px 5px;
  border-radius: var(--lui-r-sm);
  font-family: var(--lui-font-mono);
}
[data-theme="light"] .lui-sidebar__cmdk-kbd { background: rgba(255,255,255,.08); }

.lui-sidebar__nav { list-style: none; margin: 0; padding: 4px 8px; flex: 1; }
.lui-sidebar__nav li { margin: 0; }
.lui-sidebar__nav a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 10px;
  font-size: var(--lui-fs-body);
  font-weight: var(--lui-fw-medium);
  color: #a4abb8;
  background: transparent;
  border-radius: var(--lui-r-md);
  text-decoration: none;
  transition: background var(--lui-dur-fast), color var(--lui-dur-fast);
}
.lui-sidebar__nav a:hover { background: rgba(255,255,255,.04); color: #cbd5e1; }
.lui-sidebar__nav a.is-active {
  background: var(--lui-accent-soft);
  color: #fff;
  font-weight: var(--lui-fw-semi);
}
.lui-sidebar__nav a.is-active .lui-sidebar__nav-icon { color: var(--lui-accent); }
.lui-sidebar__nav-icon { width: 14px; text-align: center; color: #6c7382; font-size: 14px; flex-shrink: 0; }
.lui-sidebar__nav-badge {
  margin-left: auto;
  background: var(--lui-surface-2);
  color: var(--lui-text-secondary);
  font-size: 10px;
  font-weight: var(--lui-fw-semi);
  padding: 1px 6px;
  border-radius: var(--lui-r-full);
}
.lui-sidebar__nav-badge--danger { background: var(--lui-danger-soft); color: var(--lui-danger); }

.lui-sidebar__footer-nav {
  padding: 8px 10px;
  border-top: 1px solid var(--lui-border);
}
.lui-sidebar__user {
  padding: 10px 14px;
  border-top: 1px solid var(--lui-border);
  display: flex;
  align-items: center;
  gap: 8px;
}
.lui-sidebar__avatar {
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--lui-accent);
  color: var(--lui-accent-fg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
}

/* Main column */
.lui-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.lui-topbar {
  padding: 14px 28px;
  border-bottom: 1px solid var(--lui-border);
  background: var(--lui-bg);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.lui-topbar__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}
.lui-topbar__breadcrumb {
  font-size: var(--lui-fs-micro);
  color: var(--lui-text-muted);
  margin-bottom: 3px;
}
.lui-topbar__title {
  font-family: var(--lui-font-display);
  font-size: 22px;
  font-weight: var(--lui-fw-bold);
  letter-spacing: -.01em;
  color: var(--lui-text);
}
.lui-topbar__actions { display: flex; align-items: center; gap: 8px; }

.lui-tabs {
  display: flex;
  gap: 22px;
  font-size: var(--lui-fs-caption);
  margin-top: 2px;
}
.lui-tabs a {
  color: var(--lui-text-muted);
  text-decoration: none;
  padding: 6px 0;
  margin-bottom: -1px;
  border-bottom: 2px solid transparent;
  font-weight: var(--lui-fw-medium);
  transition: color var(--lui-dur-fast), border-color var(--lui-dur-fast);
}
.lui-tabs a:hover { color: var(--lui-text-secondary); }
.lui-tabs a.is-active {
  color: var(--lui-text);
  font-weight: var(--lui-fw-semi);
  border-bottom-color: var(--lui-accent);
}

.lui-content {
  flex: 1;
  padding: 24px 28px;
  overflow-y: auto;
  background: var(--lui-bg);
}
.lui-content--narrow { max-width: 920px; margin: 0 auto; }

/* ============================================================
   4. BUTTONS
   ============================================================ */
.lui-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  height: var(--lui-btn-h);
  padding: 0 14px;
  font-family: inherit;
  font-size: var(--lui-fs-body);
  font-weight: var(--lui-fw-semi);
  line-height: 1;
  border: 1px solid transparent;
  border-radius: var(--lui-r-md);
  cursor: pointer;
  transition: background var(--lui-dur-fast), border-color var(--lui-dur-fast), color var(--lui-dur-fast), transform var(--lui-dur-fast);
  text-decoration: none;
  white-space: nowrap;
  user-select: none;
}
.lui-btn:disabled, .lui-btn[aria-disabled="true"] {
  opacity: .5;
  pointer-events: none;
  cursor: not-allowed;
}
.lui-btn:focus-visible {
  outline: 2px solid var(--lui-accent);
  outline-offset: 2px;
}

/* Primary — the one true CTA */
/* Specificity bumped + !important on color so legacy a {color:var(--accent)}
   in style.css can't make the label match its background. */
.lui-app .lui-btn--primary,
.lui-btn.lui-btn--primary {
  background: var(--lui-accent);
  color: var(--lui-accent-fg) !important;
}
.lui-app .lui-btn--primary:hover,
.lui-btn.lui-btn--primary:hover { background: var(--lui-accent-hover); }
.lui-app .lui-btn--primary:active,
.lui-btn.lui-btn--primary:active { transform: translateY(1px); }

/* Secondary — outlined */
.lui-btn--secondary {
  background: transparent;
  border-color: var(--lui-border-strong);
  color: var(--lui-text);
}
.lui-btn--secondary:hover { background: var(--lui-surface-1); border-color: var(--lui-text-muted); }

/* Ghost — minimal */
.lui-btn--ghost {
  background: transparent;
  color: var(--lui-text-secondary);
}
.lui-btn--ghost:hover { background: var(--lui-surface-1); color: var(--lui-text); }

/* Danger — destructive */
.lui-btn--danger {
  background: var(--lui-danger-soft);
  color: var(--lui-danger);
  border-color: transparent;
}
.lui-btn--danger:hover { background: var(--lui-danger); color: #fff; }

/* Sizes */
.lui-btn--sm { height: 28px; padding: 0 11px; font-size: var(--lui-fs-caption); }
.lui-btn--lg { height: 40px; padding: 0 20px; font-size: var(--lui-fs-heading); }

/* Block — full width */
.lui-btn--block { width: 100%; }

/* Icon button */
.lui-btn--icon { width: var(--lui-btn-h); padding: 0; }
.lui-btn--icon.lui-btn--sm { width: 28px; }
.lui-btn--icon.lui-btn--lg { width: 40px; }

/* ============================================================
   5. CARDS
   ============================================================ */
.lui-card {
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  border-radius: var(--lui-r-lg);
  overflow: hidden;
}
.lui-card--padded { padding: var(--lui-sp-5) var(--lui-sp-6); }
.lui-card--interactive { cursor: pointer; transition: border-color var(--lui-dur-fast), transform var(--lui-dur-fast); }
.lui-card--interactive:hover { border-color: var(--lui-border-strong); }
.lui-card--interactive:active { transform: translateY(1px); }

.lui-card__head {
  padding: 14px 20px;
  border-bottom: 1px solid var(--lui-border);
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}
.lui-card__title {
  font-family: var(--lui-font-display);
  font-size: var(--lui-fs-heading);
  font-weight: var(--lui-fw-bold);
  color: var(--lui-text);
}
.lui-card__body { padding: var(--lui-sp-5) var(--lui-sp-6); }
.lui-card__body--flush { padding: 0; }

/* Hero card — for the "next action" hero on Today */
.lui-card--hero {
  background: linear-gradient(180deg, var(--lui-surface-2) 0%, var(--lui-surface-1) 100%);
  border-color: var(--lui-border-strong);
  padding: var(--lui-sp-6) var(--lui-sp-7);
}

/* ============================================================
   6. PILLS & BADGES
   ============================================================ */
.lui-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 9px;
  font-size: 10px;
  font-weight: var(--lui-fw-semi);
  letter-spacing: .04em;
  border-radius: var(--lui-r-sm);
  background: var(--lui-surface-2);
  color: var(--lui-text-secondary);
  text-transform: uppercase;
  white-space: nowrap;
}
.lui-pill--accent  { background: var(--lui-accent-soft);   color: var(--lui-accent); }
.lui-pill--danger  { background: var(--lui-danger-soft);   color: var(--lui-danger); }
.lui-pill--warning { background: var(--lui-warning-soft);  color: var(--lui-warning); }
.lui-pill--success { background: var(--lui-success-soft);  color: var(--lui-success); }
.lui-pill--info    { background: var(--lui-info-soft);     color: var(--lui-info); }

.lui-pill--no-upper { text-transform: none; letter-spacing: 0; }

/* Soft badge — non-uppercase, slightly larger, for ICP labels etc */
.lui-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 8px;
  font-size: var(--lui-fs-micro);
  font-weight: var(--lui-fw-semi);
  border-radius: var(--lui-r-sm);
  background: var(--lui-surface-2);
  color: var(--lui-text-secondary);
}
.lui-badge--accent  { background: var(--lui-accent-soft);   color: var(--lui-accent); }

/* Button-height badge — lines up with lui-btn in topbar action rows.
   Mirror the box model of .lui-btn (height + padding + box-sizing +
   border) so all three controls share the same baseline. */
.lui-badge--lg {
  height: var(--lui-btn-h);
  padding: 0 14px;
  font-size: var(--lui-fs-body);
  font-weight: var(--lui-fw-semi);
  border-radius: var(--lui-r-md);
  border: 1px solid transparent;
  box-sizing: border-box;
  line-height: 1;
}
.lui-badge--danger  { background: var(--lui-danger-soft);   color: var(--lui-danger); }
.lui-badge--warning { background: var(--lui-warning-soft);  color: var(--lui-warning); }
.lui-badge--success { background: var(--lui-success-soft);  color: var(--lui-success); }
.lui-badge--info    { background: var(--lui-info-soft);     color: var(--lui-info); }

/* ============================================================
   7. INPUTS & FORMS
   ============================================================ */
.lui-input,
.lui-select,
.lui-textarea {
  width: 100%;
  height: var(--lui-input-h);
  padding: 0 12px;
  font-family: inherit;
  font-size: var(--lui-fs-body);
  color: var(--lui-text);
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  border-radius: var(--lui-r-md);
  outline: none;
  transition: border-color var(--lui-dur-fast), background var(--lui-dur-fast);
}
.lui-textarea {
  height: auto;
  min-height: 96px;
  padding: 10px 12px;
  line-height: var(--lui-lh-loose);
  resize: vertical;
  font-family: inherit;
}
.lui-input::placeholder,
.lui-textarea::placeholder { color: var(--lui-text-muted); }
.lui-input:focus,
.lui-select:focus,
.lui-textarea:focus {
  border-color: var(--lui-accent);
  background: var(--lui-bg);
}
.lui-input:disabled,
.lui-select:disabled,
.lui-textarea:disabled {
  opacity: .5;
  cursor: not-allowed;
}

.lui-select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23a4abb8' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-position: right 10px center;
  background-repeat: no-repeat;
  padding-right: 30px;
}

.lui-field { display: block; margin-bottom: var(--lui-sp-4); }
.lui-field__label {
  display: block;
  margin-bottom: 6px;
  font-size: var(--lui-fs-caption);
  font-weight: var(--lui-fw-semi);
  color: var(--lui-text);
}
.lui-field__help {
  margin-top: 4px;
  font-size: var(--lui-fs-micro);
  color: var(--lui-text-muted);
}
.lui-field__error {
  margin-top: 4px;
  font-size: var(--lui-fs-micro);
  color: var(--lui-danger);
}

/* Search input (with leading icon) */
.lui-search {
  position: relative;
  display: inline-flex;
  align-items: center;
  width: 100%;
  max-width: 360px;
}
.lui-search::before {
  content: '';
  position: absolute;
  left: 10px;
  width: 14px;
  height: 14px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%236c7382' stroke-width='2' viewBox='0 0 24 24'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E") no-repeat center;
  pointer-events: none;
}
.lui-search .lui-input { padding-left: 32px; }

/* Segmented control */
.lui-seg {
  display: inline-flex;
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  border-radius: var(--lui-r-md);
  padding: 2px;
}
.lui-seg__btn {
  padding: 5px 12px;
  font-size: var(--lui-fs-micro);
  font-weight: var(--lui-fw-semi);
  background: transparent;
  color: var(--lui-text-muted);
  border: none;
  border-radius: var(--lui-r-sm);
  cursor: pointer;
  font-family: inherit;
  transition: background var(--lui-dur-fast), color var(--lui-dur-fast);
}
.lui-seg__btn.is-active {
  background: var(--lui-surface-2);
  color: var(--lui-text);
}

/* Filter chip */
.lui-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 11px;
  font-size: var(--lui-fs-micro);
  font-weight: var(--lui-fw-medium);
  background: transparent;
  color: var(--lui-text-muted);
  border: 1px solid transparent;
  border-radius: var(--lui-r-sm);
  cursor: pointer;
  font-family: inherit;
  transition: background var(--lui-dur-fast), color var(--lui-dur-fast), border-color var(--lui-dur-fast);
}
.lui-chip:hover { color: var(--lui-text-secondary); background: var(--lui-surface-1); }
.lui-chip.is-active {
  background: var(--lui-surface-2);
  color: var(--lui-text);
  border-color: var(--lui-border-strong);
}
.lui-chip__count { font-size: 10px; color: var(--lui-text-muted); font-weight: var(--lui-fw-semi); }
.lui-chip.is-active .lui-chip__count { color: var(--lui-text); }

/* Task-list row modifiers */
.lui-task { display: flex; gap: var(--lui-sp-4); align-items: flex-start; padding: 12px 0; border-top: 1px solid var(--lui-border); }
.lui-task:first-child { border-top: 0; }
.lui-task.is-focused { background: var(--lui-surface-1); }
.lui-task--completed { opacity: .55; }
.lui-task--completed .lui-task__title { text-decoration: line-through; }

/* Simple in-page overlay used by templates that have their own
   popup state (e.g. tasks page's connect/commenter/email/call
   popups). Toggled with the standard `hidden` attribute, not
   .is-open — keeps the template free of inline display tweaks. */
.lui-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .6);
  z-index: var(--lui-z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--lui-sp-5);
}
.lui-overlay[hidden] { display: none; }
.lui-overlay__card {
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border-strong);
  border-radius: var(--lui-r-xl);
  padding: var(--lui-sp-5);
  box-shadow: var(--lui-shadow-lg);
}

/* ============================================================
   Contacts page — table-like grid + pill search + more-filter
   popover. Scoped to .contacts-* so the patterns can be lifted
   into a shared component when we hit the second table screen.
   ============================================================ */
.contacts-search {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 240px;
  max-width: 320px;
  height: var(--lui-input-h);
  padding: 0 12px;
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  border-radius: var(--lui-r-full);
  transition: border-color var(--lui-dur-fast);
}
.contacts-search:focus-within {
  border-color: var(--lui-accent);
}
.contacts-search__icon { color: var(--lui-text-muted); flex-shrink: 0; }
.contacts-search__input {
  flex: 1;
  background: transparent;
  border: 0;
  outline: 0;
  color: var(--lui-text);
  font-family: inherit;
  font-size: var(--lui-fs-body);
}
.contacts-search__input::placeholder { color: var(--lui-text-muted); }
.contacts-search__clear {
  color: var(--lui-text-muted);
  text-decoration: none;
  padding: 0 4px;
  font-size: var(--lui-fs-caption);
}
.contacts-search__clear:hover { color: var(--lui-text); }

.contacts-more-filter { position: relative; }
.contacts-more-filter > summary {
  list-style: none;
  cursor: pointer;
}
.contacts-more-filter > summary::-webkit-details-marker { display: none; }
.contacts-more-filter__pop {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  z-index: var(--lui-z-drawer);
  min-width: 280px;
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border-strong);
  border-radius: var(--lui-r-md);
  box-shadow: var(--lui-shadow-md);
}

/* 8-column grid: select / contact / company / phone / fit / last / angle / action */
.contacts-thead,
.contacts-row {
  display: grid;
  grid-template-columns: 28px minmax(200px, 1.5fr) minmax(130px, 1fr) minmax(150px, 1fr) minmax(96px, .55fr) minmax(96px, .55fr) minmax(150px, 1.2fr) auto;
  gap: var(--lui-sp-4);
  align-items: center;
  padding: 12px var(--lui-sp-6);
}
.contacts-thead {
  padding-top: 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--lui-border);
}
.contacts-row { border-top: 1px solid var(--lui-border); }
.contacts-row:first-of-type { border-top: 0; }
.contacts-row.is-focused { background: var(--lui-surface-1); }
.contact-row--cooldown { opacity: .65; }

.contacts-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--lui-surface-2);
  color: var(--lui-text-secondary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--lui-fs-micro);
  font-weight: var(--lui-fw-semi);
  flex-shrink: 0;
}

@media (max-width: 1100px) {
  /* On narrower viewports the angle column collapses to keep things
     readable. Open button stays right-aligned via grid auto column. */
  /* angle hidden → 7 visible cols: select / contact / company / phone / fit / last / action */
  .contacts-thead,
  .contacts-row { grid-template-columns: 28px minmax(160px, 1.8fr) minmax(110px, 1fr) minmax(130px, 1fr) auto minmax(90px, .7fr) auto; }
  .contacts-col-angle { display: none; }
}

/* ============================================================
   Pipeline kanban — column-based deal board. SortableJS hooks
   on .kanban-column / .kanban-cards / .kanban-card / data-stage-id
   / data-deal-id are kept verbatim from the legacy markup.
   ============================================================ */
.lui-kanban {
  display: flex;
  gap: var(--lui-sp-4);
  overflow-x: auto;
  padding-bottom: var(--lui-sp-3);
  align-items: flex-start;
}
.lui-kanban__column {
  flex: 0 0 240px;
  min-width: 240px;
  background: transparent;
  border: 0;
  border-radius: 0;
  overflow: visible;
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 260px);
}
.lui-kanban__header {
  padding: var(--lui-sp-3) var(--lui-sp-4);
  background: transparent;
  border-bottom: 1px solid var(--lui-border);
}
.lui-kanban__stage-name {
  font-size: var(--lui-fs-micro);
  font-weight: var(--lui-fw-bold);
  color: var(--lui-text-secondary);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.lui-kanban__stage-count {
  font-size: var(--lui-fs-caption);
  font-weight: var(--lui-fw-semi);
  color: var(--lui-text-muted);
}
.lui-kanban__age {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.lui-kanban__age-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  display: inline-block;
}
.lui-kanban__age--success { color: var(--lui-text-muted); }
.lui-kanban__age--success .lui-kanban__age-dot { background: var(--lui-success); }
.lui-kanban__age--warning { color: var(--lui-warning); }
.lui-kanban__age--warning .lui-kanban__age-dot { background: var(--lui-warning); }
.lui-kanban__age--danger { color: var(--lui-danger); }
.lui-kanban__age--danger .lui-kanban__age-dot { background: var(--lui-danger); }
.lui-kanban__cards {
  flex: 1;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--lui-sp-2);
  overflow-y: auto;
  min-height: 120px;
}
.lui-kanban__card {
  /* Override lui-card padding — kanban cards are tighter */
  padding: 12px 14px;
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  cursor: pointer;
  transition: border-color var(--lui-dur-fast), transform var(--lui-dur-fast);
}
.lui-kanban__card:hover { border-color: var(--lui-border-strong); }
.lui-kanban__card:focus-visible {
  outline: 2px solid var(--lui-accent);
  outline-offset: 2px;
}

/* Owner avatar pill */
.lui-kanban__owner {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--lui-surface-2);
  color: var(--lui-text-secondary);
  font-size: 10px;
  font-weight: var(--lui-fw-semi);
  text-decoration: none;
  flex-shrink: 0;
}
.lui-kanban__owner:hover { background: var(--lui-surface-3); color: var(--lui-text); }

/* Hygiene popover — relative-positioned details inside the card */
.lui-kanban__hygiene { position: relative; }
.lui-kanban__hygiene > summary::-webkit-details-marker { display: none; }
.lui-kanban__hygiene-pop {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  z-index: var(--lui-z-sticky);
  min-width: 220px;
  padding: var(--lui-sp-3);
  box-shadow: var(--lui-shadow-md);
}

/* Disable legacy .kanban-card:hover transform on migrated pages —
   the hover transform was fighting Sortable's drag transform and
   making cards jitter / fail to follow the cursor. Scoped under
   .lui-app so legacy templates (if any still use the old board)
   keep their hover effect. */
.lui-app .kanban-card:hover { transform: none; box-shadow: none; }

/* Drag-drop visuals — Sortable applies these classes automatically. */
.kanban-card--ghost,
.lui-app .sortable-ghost {
  opacity: .35;
  background: var(--lui-accent-soft);
  border: 1px dashed var(--lui-accent);
}
.kanban-card--drag,
.lui-app .sortable-chosen {
  cursor: grabbing;
  box-shadow: var(--lui-shadow-lg);
}
.lui-app .sortable-drag {
  transform: rotate(1.5deg);
  box-shadow: var(--lui-shadow-lg);
  opacity: 1 !important;
}
.lui-kanban__card { cursor: grab; }
.lui-kanban__card:active { cursor: grabbing; }

/* ============================================================
   Deal detail — two-column layout, hero metrics, health score,
   activity timeline with semantic dot colours.
   ============================================================ */
.deal-detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: var(--lui-sp-6);
  align-items: start;
}
.deal-detail-main { min-width: 0; }
.deal-detail-side { min-width: 0; }
@media (max-width: 1100px) {
  .deal-detail-grid { grid-template-columns: 1fr; }
}

/* Health score circle */
.deal-health__score {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--lui-font-mono);
  font-weight: var(--lui-fw-bold);
  font-size: var(--lui-fs-heading);
  flex-shrink: 0;
  border: 2px solid;
}
.deal-health__score--success { background: var(--lui-success-soft); color: var(--lui-success); border-color: var(--lui-success); }
.deal-health__score--warning { background: var(--lui-warning-soft); color: var(--lui-warning); border-color: var(--lui-warning); }
.deal-health__score--danger  { background: var(--lui-danger-soft);  color: var(--lui-danger);  border-color: var(--lui-danger); }

/* Timeline tones — see section 15 for base layout. Type-specific
   modifiers below match the deal-detail design canvas:
   email=success / call=info / stage=warning / signal=danger / note+task=muted */

/* Move-stage popover in the topbar — plain button + JS popover, no
   <details>/<summary> so there's no element-type alignment weirdness. */
.deal-stage-picker { position: relative; display: inline-flex; }

/* ============================================================
   Compose — two-column layout, recipient chip, dropdown, rows.
   ============================================================ */
.compose-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: var(--lui-sp-6);
  align-items: start;
}
@media (max-width: 1100px) {
  .compose-grid { grid-template-columns: 1fr; }
}

/* Recipient chip — replaces the bare typeahead input once a contact is picked */
.compose-chip {
  display: flex;
  align-items: center;
  gap: var(--lui-sp-3);
  padding: 8px 12px;
  background: var(--lui-surface-2);
  border: 1px solid var(--lui-border);
  border-radius: var(--lui-r-full);
}
.compose-chip__avatar {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--lui-accent-soft);
  color: var(--lui-accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--lui-fs-micro);
  font-weight: var(--lui-fw-semi);
  flex-shrink: 0;
}

/* Compose dropdowns (contact / company typeahead) */
.compose-dropdown {
  position: absolute;
  top: 100%; left: 0; right: 0;
  z-index: var(--lui-z-sticky);
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border-strong);
  border-radius: var(--lui-r-md);
  max-height: 260px;
  overflow-y: auto;
  margin-top: 4px;
  box-shadow: var(--lui-shadow-md);
}
.compose-dropdown__item {
  padding: 10px 12px;
  cursor: pointer;
  border-bottom: 1px solid var(--lui-border);
  font-size: var(--lui-fs-body);
}
.compose-dropdown__item:last-child { border-bottom: 0; }
.compose-dropdown__item:hover { background: var(--lui-surface-2); }

/* Sidebar contact rows in the right rail */
.compose-context-row {
  display: flex;
  align-items: center;
  gap: var(--lui-sp-3);
  padding: 10px var(--lui-sp-4);
  cursor: pointer;
  border-bottom: 1px solid var(--lui-border);
}
.compose-context-row:last-child { border-bottom: 0; }
.compose-context-row:hover { background: var(--lui-surface-2); }

.compose-activity-row {
  display: flex;
  gap: var(--lui-sp-3);
  align-items: baseline;
  padding: 10px var(--lui-sp-4);
  border-bottom: 1px solid var(--lui-border);
}
.compose-activity-row:last-child { border-bottom: 0; }

/* ============================================================
   Cadence review — email preview reads like the email itself.
   Subject row sits at the top of an inset surface-2 block with a
   divider, body flows below with comfortable padding.
   ============================================================ */
.cadence-review__form { display: block; }
.cadence-review__email {
  background: var(--lui-surface-2);
  border: 1px solid var(--lui-border);
  border-radius: var(--lui-r-md);
  padding: 0;
  margin: 0;
}
.cadence-review__subject {
  display: flex;
  align-items: baseline;
  gap: var(--lui-sp-4);
  padding: 14px 18px;
  border-bottom: 1px solid var(--lui-border);
}
.cadence-review__subject label {
  flex-shrink: 0;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--lui-text-muted);
}
.cadence-review__subject-input {
  flex: 1;
  background: transparent;
  border: 0;
  outline: 0;
  color: var(--lui-text);
  font-family: var(--lui-font-sans);
  padding: 0;
  font-weight: var(--lui-fw-bold);
}
.cadence-review__body {
  width: 100%;
  background: transparent;
  border: 0;
  outline: 0;
  resize: vertical;
  padding: 16px 18px;
  color: var(--lui-text);
  font-family: var(--lui-font-sans);
  line-height: 1.65;
  min-height: 160px;
  display: block;
}

/* ============================================================
   Weekly brief — magazine layout
   Single column read-first article. The page extends base_v2 with
   `lui-content--narrow` so the surrounding chrome is already capped
   at 920px; .weekly-brief tightens further to 720px per spec.
   ============================================================ */
.weekly-brief {
  max-width: 720px;
  margin: 0 auto;
  font-family: var(--lui-font-sans);
}
.weekly-brief__header {
  border-bottom: 1px solid var(--lui-border);
  padding-bottom: var(--lui-sp-4);
}
.weekly-brief__headline {
  font-family: var(--lui-font-display);
  font-size: 36px;
  line-height: 1.15;
  font-weight: var(--lui-fw-bold);
  letter-spacing: -.02em;
  color: var(--lui-text);
  margin: 0 0 var(--lui-sp-3);
}
.weekly-brief__standfirst {
  font-size: var(--lui-fs-heading);
  color: var(--lui-text-secondary);
  line-height: 1.5;
  margin: 0;
}
.weekly-brief__h2 {
  font-family: var(--lui-font-display);
  font-size: var(--lui-fs-title);
  font-weight: var(--lui-fw-bold);
  color: var(--lui-text);
  margin: 0 0 var(--lui-sp-3);
  display: flex;
  align-items: baseline;
  gap: var(--lui-sp-3);
}
.weekly-brief__prose {
  font-size: var(--lui-fs-body);
  color: var(--lui-text-secondary);
  line-height: 1.7;
  white-space: pre-wrap;
}

.weekly-action-card {
  padding: var(--lui-sp-4) var(--lui-sp-5);
  border: 1px solid var(--lui-border);
  border-radius: var(--lui-r-md);
  margin-bottom: var(--lui-sp-3);
  background: var(--lui-surface-1);
}
.weekly-window-row {
  display: flex;
  align-items: center;
  gap: var(--lui-sp-3);
  padding: var(--lui-sp-3) 0;
  border-top: 1px solid var(--lui-border);
}
.weekly-window-row:first-of-type { border-top: 0; }

.weekly-matrix {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--lui-sp-3);
}
@media (max-width: 600px) {
  .weekly-matrix { grid-template-columns: 1fr; }
}
.weekly-matrix__cell {
  padding: var(--lui-sp-4);
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  border-radius: var(--lui-r-md);
}
.weekly-matrix__cell--priority { border-color: var(--lui-success); }
.weekly-matrix__cell--nurture  { border-color: var(--lui-warning); }
.weekly-matrix__title {
  font-size: var(--lui-fs-body);
  font-weight: var(--lui-fw-semi);
  color: var(--lui-text);
}

/* Daily digests — two-col dates sidebar + grouped signal cards */
.digest-grid {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: var(--lui-sp-5);
  align-items: start;
}
@media (max-width: 900px) {
  .digest-grid { grid-template-columns: 1fr; }
}
.digest-sidebar { min-width: 0; }
.digest-date-link {
  display: block;
  padding: 8px 10px;
  border-radius: var(--lui-r-sm);
  color: var(--lui-text-secondary);
  font-size: var(--lui-fs-caption);
  text-decoration: none;
}
.digest-date-link:hover { background: var(--lui-surface-2); color: var(--lui-text); }
.digest-date-link.is-active { background: var(--lui-accent-soft); color: var(--lui-accent); font-weight: var(--lui-fw-semi); }
.leftover-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  background: var(--lui-surface-2);
  border-radius: var(--lui-r-sm);
  color: var(--lui-text);
  text-decoration: none;
  font-size: var(--lui-fs-micro);
}
.leftover-chip:hover { background: var(--lui-surface-3); }
.signal-item {
  display: flex; gap: var(--lui-sp-3); align-items: flex-start;
  padding: 14px var(--lui-sp-5);
  border-top: 1px solid var(--lui-border);
}
.signal-item:first-child { border-top: 0; }
.signal-item:hover { background: var(--lui-surface-2); }

/* Outreach activity feed — row + expanded detail */
.outreach-row {
  display: flex;
  align-items: center;
  gap: var(--lui-sp-3);
  padding: 12px var(--lui-sp-6);
  cursor: pointer;
  border-top: 1px solid var(--lui-border);
}
.outreach-row:first-child,
.outreach-row:first-of-type { border-top: 0; }
.outreach-row:hover { background: var(--lui-surface-2); }
.outreach-detail {
  padding: 12px var(--lui-sp-6) 16px calc(var(--lui-sp-6) + 24px);
  border-top: 1px solid var(--lui-border);
  background: var(--lui-surface-2);
}

/* Cadences list — inline progress bar in the active table */
.cadences-progress {
  flex: 1;
  min-width: 60px;
  max-width: 120px;
  height: 6px;
  background: var(--lui-border);
  border-radius: 3px;
  overflow: hidden;
}
.cadences-progress__bar {
  height: 100%;
  background: var(--lui-accent);
  transition: width var(--lui-dur);
}
.deal-stage-picker__pop {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  z-index: var(--lui-z-drawer);
  min-width: 200px;
  padding: 4px;
  box-shadow: var(--lui-shadow-md);
}
.deal-stage-picker__item {
  display: block;
  width: 100%;
  text-align: left;
  padding: 8px 12px;
  background: transparent;
  border: 0;
  color: var(--lui-text);
  font-family: inherit;
  font-size: var(--lui-fs-caption);
  border-radius: var(--lui-r-sm);
  cursor: pointer;
}
.deal-stage-picker__item:hover { background: var(--lui-surface-2); }

/* Pipeline summary strip — big numbers on left, filters on right */
.pipeline-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--lui-sp-6);
  flex-wrap: wrap;
}
.pipeline-summary__stats {
  display: flex;
  gap: var(--lui-sp-8);
  flex-wrap: wrap;
}
.pipeline-summary__filters {
  display: flex;
  align-items: center;
  gap: var(--lui-sp-3);
  flex-wrap: wrap;
}

/* ============================================================
   8. TABLES
   ============================================================ */
.lui-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--lui-fs-body);
}
.lui-table thead tr {
  font-size: 11px;
  font-weight: var(--lui-fw-semi);
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--lui-text-muted);
}
.lui-table th {
  text-align: left;
  font-weight: var(--lui-fw-semi);
  padding: 12px var(--lui-sp-5);
}
.lui-table th:first-child,
.lui-table td:first-child { padding-left: var(--lui-sp-6); }
.lui-table th:last-child,
.lui-table td:last-child { padding-right: var(--lui-sp-6); }
.lui-table td {
  padding: var(--lui-sp-3) var(--lui-sp-5);
  vertical-align: middle;
  border-top: 1px solid var(--lui-border);
}
.lui-table tbody tr { transition: background var(--lui-dur-fast); }
.lui-table tbody tr:hover { background: var(--lui-surface-2); }
.lui-table tbody tr.is-selected { background: var(--lui-accent-soft); }

.lui-table--minimal th,
.lui-table--minimal td { padding-left: 0; padding-right: var(--lui-sp-4); }
.lui-table--minimal td { border-top-color: var(--lui-border); }

/* Avatar inside a table */
.lui-avatar {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--lui-surface-3);
  color: var(--lui-text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--lui-fs-micro);
  font-weight: var(--lui-fw-semi);
  flex-shrink: 0;
}
.lui-avatar--sm { width: 24px; height: 24px; font-size: 10px; }
.lui-avatar--lg { width: 40px; height: 40px; font-size: var(--lui-fs-heading); }

/* ============================================================
   9. EMPTY / LOADING / ERROR STATES
   ============================================================ */
.lui-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--lui-sp-9) var(--lui-sp-6);
  color: var(--lui-text-muted);
}
.lui-empty__icon {
  width: 48px; height: 48px;
  border-radius: var(--lui-r-lg);
  background: var(--lui-surface-2);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--lui-sp-4);
  color: var(--lui-text-muted);
}
.lui-empty__title {
  font-family: var(--lui-font-display);
  font-size: var(--lui-fs-heading);
  font-weight: var(--lui-fw-bold);
  color: var(--lui-text);
  margin-bottom: 6px;
}
.lui-empty__desc {
  max-width: 42ch;
  font-size: var(--lui-fs-caption);
  color: var(--lui-text-muted);
  margin-bottom: var(--lui-sp-5);
  line-height: var(--lui-lh-normal);
}

.lui-loading {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--lui-text-muted);
  font-size: var(--lui-fs-caption);
}
.lui-spinner {
  width: 14px; height: 14px;
  border: 2px solid var(--lui-border-strong);
  border-top-color: var(--lui-accent);
  border-radius: 50%;
  animation: lui-spin 700ms linear infinite;
}
@keyframes lui-spin { to { transform: rotate(360deg); } }

.lui-skeleton {
  background: linear-gradient(90deg, var(--lui-surface-2) 0%, var(--lui-surface-3) 50%, var(--lui-surface-2) 100%);
  background-size: 200% 100%;
  animation: lui-shimmer 1.4s ease-in-out infinite;
  border-radius: var(--lui-r-sm);
  height: 14px;
}
@keyframes lui-shimmer { to { background-position: -200% 0; } }

.lui-error {
  padding: var(--lui-sp-4);
  background: var(--lui-danger-soft);
  border: 1px solid var(--lui-danger);
  border-radius: var(--lui-r-md);
  color: var(--lui-danger);
  font-size: var(--lui-fs-caption);
}

/* ============================================================
   10. DRAWER (right-side panel for entity edits)
   ============================================================ */
.lui-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .5);
  z-index: var(--lui-z-drawer);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--lui-dur) var(--lui-ease-out);
}
.lui-drawer-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
}
.lui-drawer {
  position: fixed;
  top: 0; right: 0;
  height: 100vh;
  width: 440px;
  max-width: 100vw;
  background: var(--lui-surface-1);
  border-left: 1px solid var(--lui-border-strong);
  box-shadow: var(--lui-shadow-lg);
  z-index: calc(var(--lui-z-drawer) + 1);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform var(--lui-dur-slow) var(--lui-ease-out);
}
.lui-drawer.is-open { transform: translateX(0); }
.lui-drawer__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--lui-sp-4) var(--lui-sp-5);
  border-bottom: 1px solid var(--lui-border);
}
.lui-drawer__title {
  font-family: var(--lui-font-display);
  font-size: var(--lui-fs-title);
  font-weight: var(--lui-fw-bold);
  color: var(--lui-text);
}
.lui-drawer__close {
  background: transparent;
  border: none;
  color: var(--lui-text-muted);
  cursor: pointer;
  padding: 6px;
  border-radius: var(--lui-r-sm);
}
.lui-drawer__close:hover { background: var(--lui-surface-2); color: var(--lui-text); }
.lui-drawer__body {
  flex: 1;
  padding: var(--lui-sp-5);
  overflow-y: auto;
}
.lui-drawer__foot {
  padding: var(--lui-sp-4) var(--lui-sp-5);
  border-top: 1px solid var(--lui-border);
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}

/* ============================================================
   11. MODAL (centered, one-shot actions)
   ============================================================ */
.lui-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .5);
  z-index: var(--lui-z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--lui-sp-5);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--lui-dur) var(--lui-ease-out);
}
.lui-modal-overlay.is-open { opacity: 1; pointer-events: auto; }
.lui-modal {
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border-strong);
  border-radius: var(--lui-r-xl);
  max-width: 520px;
  width: 100%;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: var(--lui-shadow-lg);
  transform: translateY(8px) scale(.98);
  transition: transform var(--lui-dur) var(--lui-ease-out);
}
.lui-modal-overlay.is-open .lui-modal { transform: none; }
.lui-modal__head, .lui-modal__body, .lui-modal__foot { padding: var(--lui-sp-5); }
.lui-modal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--lui-border);
}
.lui-modal__body { flex: 1; overflow-y: auto; }
.lui-modal__foot { border-top: 1px solid var(--lui-border); display: flex; gap: 8px; justify-content: flex-end; }

/* ============================================================
   12. COMMAND PALETTE (⌘K)
   ============================================================ */
.lui-palette-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .55);
  backdrop-filter: blur(2px);
  z-index: var(--lui-z-palette);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 88px var(--lui-sp-5) 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--lui-dur-fast) var(--lui-ease-out);
}
.lui-palette-overlay.is-open { opacity: 1; pointer-events: auto; }
.lui-palette {
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border-strong);
  border-radius: var(--lui-r-lg);
  width: 100%;
  max-width: 560px;
  box-shadow: var(--lui-shadow-lg);
  overflow: hidden;
  transform: translateY(-8px);
  transition: transform var(--lui-dur-fast) var(--lui-ease-out);
}
.lui-palette-overlay.is-open .lui-palette { transform: none; }
.lui-palette__input {
  width: 100%;
  border: none;
  background: transparent;
  color: var(--lui-text);
  font-family: inherit;
  font-size: var(--lui-fs-heading);
  padding: 16px 20px;
  outline: none;
  border-bottom: 1px solid var(--lui-border);
}
.lui-palette__input::placeholder { color: var(--lui-text-muted); }
.lui-palette__results {
  max-height: 360px;
  overflow-y: auto;
  padding: 6px;
}
.lui-palette__group-label {
  padding: 8px 14px 4px;
  font-size: 10px;
  font-weight: var(--lui-fw-semi);
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--lui-text-muted);
}
.lui-palette__item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: var(--lui-r-sm);
  cursor: pointer;
  font-size: var(--lui-fs-body);
  color: var(--lui-text);
  text-decoration: none;
}
.lui-palette__item:hover,
.lui-palette__item.is-active { background: var(--lui-accent-soft); color: var(--lui-text); }
.lui-palette__item-icon { width: 18px; text-align: center; color: var(--lui-text-muted); flex-shrink: 0; }
.lui-palette__item-meta {
  margin-left: auto;
  font-size: var(--lui-fs-micro);
  color: var(--lui-text-muted);
}

/* ============================================================
   13. TOAST
   ============================================================ */
.lui-toast-container {
  position: fixed;
  top: var(--lui-sp-4);
  right: var(--lui-sp-4);
  z-index: var(--lui-z-toast);
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: 360px;
}
.lui-toast {
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border-strong);
  border-radius: var(--lui-r-md);
  padding: 12px 16px;
  box-shadow: var(--lui-shadow-md);
  font-size: var(--lui-fs-caption);
  color: var(--lui-text);
  display: flex;
  align-items: center;
  gap: 10px;
  animation: lui-toast-in var(--lui-dur) var(--lui-ease-out);
}
.lui-toast__icon { flex-shrink: 0; }
.lui-toast__message { flex: 1; }
.lui-toast__undo {
  background: transparent;
  border: none;
  color: var(--lui-accent);
  font-family: inherit;
  font-size: var(--lui-fs-caption);
  font-weight: var(--lui-fw-semi);
  cursor: pointer;
  padding: 0;
}
.lui-toast--success { border-left: 3px solid var(--lui-success); }
.lui-toast--danger  { border-left: 3px solid var(--lui-danger); }
.lui-toast--info    { border-left: 3px solid var(--lui-info); }
@keyframes lui-toast-in {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: none; }
}

/* ============================================================
   14. INLINE EDIT
   ============================================================ */
.lui-edit {
  display: inline-block;
  padding: 2px 6px;
  margin: -2px -6px;
  border-radius: var(--lui-r-sm);
  cursor: text;
  transition: background var(--lui-dur-fast);
}
.lui-edit:hover { background: var(--lui-surface-2); }
.lui-edit[contenteditable="true"] {
  background: var(--lui-bg);
  outline: 2px solid var(--lui-accent);
  outline-offset: 0;
  cursor: text;
}
.lui-edit__saved-tick {
  display: inline-block;
  margin-left: 4px;
  color: var(--lui-success);
  font-size: var(--lui-fs-micro);
  opacity: 0;
  transform: translateX(-4px);
  transition: opacity var(--lui-dur-fast), transform var(--lui-dur-fast);
}
.lui-edit.is-saved .lui-edit__saved-tick { opacity: 1; transform: none; }

/* ============================================================
   15. TIMELINE (for activity / deal detail)
   ============================================================ */
.lui-timeline { padding-left: 0; }
.lui-timeline__item {
  display: flex;
  gap: 14px;
  padding: 14px 0;
  border-top: 1px solid var(--lui-border);
  position: relative;
}
.lui-timeline__item:first-child { border-top: none; padding-top: 0; }
.lui-timeline__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--lui-text-muted);
  margin-top: 6px;
  flex-shrink: 0;
  position: relative;
}
.lui-timeline__dot--accent  { background: var(--lui-accent); }
.lui-timeline__dot--success { background: var(--lui-success); }
.lui-timeline__dot--info    { background: var(--lui-info); }
.lui-timeline__dot--warning { background: var(--lui-warning); }
.lui-timeline__dot--danger  { background: var(--lui-danger); }
/* Type-keyed tones — direct from `ev.type_label` on the deal page */
.lui-timeline__dot--email,
.lui-timeline__dot--email_sent,
.lui-timeline__dot--email_reply { background: var(--lui-success); }
.lui-timeline__dot--call,
.lui-timeline__dot--call_logged { background: var(--lui-info); }
.lui-timeline__dot--linkedin    { background: #0A66C2; }
.lui-timeline__dot--stage_change,
.lui-timeline__dot--stage       { background: var(--lui-warning); }
.lui-timeline__dot--signal      { background: var(--lui-danger); }
.lui-timeline__dot--task,
.lui-timeline__dot--note,
.lui-timeline__dot--created     { background: var(--lui-text-secondary); }
.lui-timeline__item:not(:last-child) .lui-timeline__dot::after {
  content: '';
  position: absolute;
  top: 12px;
  left: 50%;
  width: 1px;
  height: calc(100% + 24px);
  background: var(--lui-border);
  transform: translateX(-50%);
}
.lui-timeline__body { flex: 1; min-width: 0; }
.lui-timeline__title { font-size: var(--lui-fs-body); color: var(--lui-text); font-weight: var(--lui-fw-semi); }
.lui-timeline__meta  { font-size: var(--lui-fs-micro); color: var(--lui-text-muted); margin-top: 2px; }
.lui-timeline__text  { font-size: var(--lui-fs-caption); color: var(--lui-text-secondary); margin-top: 4px; line-height: var(--lui-lh-normal); }

/* ============================================================
   16. UTILITIES — minimal set, well-named
   ============================================================ */
.lui-flex     { display: flex; }
.lui-flex-col { flex-direction: column; }
.lui-flex-row { flex-direction: row; }
.lui-grid     { display: grid; }
.lui-block    { display: block; }
.lui-hidden   { display: none; }
.lui-items-center { align-items: center; }
.lui-items-baseline { align-items: baseline; }
.lui-justify-between { justify-content: space-between; }
.lui-justify-end { justify-content: flex-end; }
.lui-gap-1 { gap: var(--lui-sp-1); }
.lui-gap-2 { gap: var(--lui-sp-2); }
.lui-gap-3 { gap: var(--lui-sp-3); }
.lui-gap-4 { gap: var(--lui-sp-4); }
.lui-gap-5 { gap: var(--lui-sp-5); }
.lui-gap-6 { gap: var(--lui-sp-6); }
.lui-flex-1 { flex: 1; min-width: 0; }
.lui-flex-wrap { flex-wrap: wrap; }

.lui-mt-1 { margin-top: var(--lui-sp-1); }
.lui-mt-2 { margin-top: var(--lui-sp-2); }
.lui-mt-3 { margin-top: var(--lui-sp-3); }
.lui-mt-4 { margin-top: var(--lui-sp-4); }
.lui-mt-5 { margin-top: var(--lui-sp-5); }
.lui-mt-6 { margin-top: var(--lui-sp-6); }
.lui-mb-1 { margin-bottom: var(--lui-sp-1); }
.lui-mb-2 { margin-bottom: var(--lui-sp-2); }
.lui-mb-3 { margin-bottom: var(--lui-sp-3); }
.lui-mb-4 { margin-bottom: var(--lui-sp-4); }
.lui-mb-5 { margin-bottom: var(--lui-sp-5); }
.lui-mb-6 { margin-bottom: var(--lui-sp-6); }

.lui-text-muted { color: var(--lui-text-muted); }
.lui-text-secondary { color: var(--lui-text-secondary); }
.lui-text-danger { color: var(--lui-danger); }
.lui-text-warning { color: var(--lui-warning); }
.lui-text-success { color: var(--lui-success); }
.lui-text-info { color: var(--lui-info); }
.lui-text-accent { color: var(--lui-accent); }

.lui-fs-display { font-size: var(--lui-fs-display); }
.lui-fs-title   { font-size: var(--lui-fs-title); }
.lui-fs-heading { font-size: var(--lui-fs-heading); }
.lui-fs-body    { font-size: var(--lui-fs-body); }
.lui-fs-caption { font-size: var(--lui-fs-caption); }
.lui-fs-micro   { font-size: var(--lui-fs-micro); }

.lui-fw-regular { font-weight: var(--lui-fw-regular); }
.lui-fw-medium  { font-weight: var(--lui-fw-medium); }
.lui-fw-semi    { font-weight: var(--lui-fw-semi); }
.lui-fw-bold    { font-weight: var(--lui-fw-bold); }

.lui-font-display { font-family: var(--lui-font-display); }
.lui-font-mono    { font-family: var(--lui-font-mono); }

.lui-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Keyboard kbd */
.lui-kbd {
  display: inline-flex;
  align-items: center;
  font-family: var(--lui-font-mono);
  font-size: 10px;
  font-weight: var(--lui-fw-semi);
  background: var(--lui-surface-2);
  color: var(--lui-text-secondary);
  padding: 1px 6px;
  border-radius: var(--lui-r-sm);
  border: 1px solid var(--lui-border);
}

/* Screen reader only */
.lui-sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ============================================================
   16b. TRIAL CARDS — /trials list (mockup: Proposed_Trials)
   ============================================================ */
.lui-trial-card {
  position: relative;
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  border-left: 4px solid var(--lui-border-strong);
  border-radius: 8px;
  padding: 1.1rem 1.25rem 1rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: .75rem;
}
.lui-trial-card--high   { border-left-color: var(--lui-success); }
.lui-trial-card--medium { border-left-color: var(--lui-warning); }
.lui-trial-card--low    { border-left-color: var(--lui-danger); }
.lui-trial-card--neutral{ border-left-color: var(--lui-border-strong); }

.lui-trial-card__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  flex-wrap: wrap;
}
.lui-trial-card__title { min-width: 0; }
.lui-trial-card__meta {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  flex-wrap: wrap;
}
.lui-trial-card__day {
  display: inline-flex;
  align-items: baseline;
  white-space: nowrap;
}

.lui-trial-card__progress {
  height: 4px;
  background: var(--lui-surface-3);
  border-radius: 2px;
  overflow: hidden;
}
.lui-trial-card__progress-fill {
  height: 100%;
  border-radius: 2px;
  transition: width .3s ease;
}
.lui-trial-card__progress-fill--high    { background: var(--lui-success); }
.lui-trial-card__progress-fill--medium  { background: var(--lui-warning); }
.lui-trial-card__progress-fill--low     { background: var(--lui-danger); }
.lui-trial-card__progress-fill--neutral { background: var(--lui-border-strong); }

.lui-trial-card__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.lui-trial-card__next { min-width: 0; flex: 1; }

.lui-trial-pill {
  display: inline-flex;
  align-items: center;
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  padding: 4px 10px;
  border-radius: 4px;
  white-space: nowrap;
}
.lui-trial-pill--high    { background: var(--lui-success-soft); color: var(--lui-success); }
.lui-trial-pill--medium  { background: var(--lui-warning-soft); color: var(--lui-warning); }
.lui-trial-pill--low     { background: var(--lui-danger-soft);  color: var(--lui-danger); }
.lui-trial-pill--neutral { background: var(--lui-surface-3);    color: var(--lui-text-muted); }

/* ============================================================
   16c. ACTIVITY FEED — /outreach (mockup: Proposed_Activity)
   ============================================================ */
.lui-activity-row {
  display: flex;
  align-items: flex-start;
  gap: .85rem;
  padding: .85rem 1.1rem;
  border-bottom: 1px solid var(--lui-border);
  cursor: pointer;
  transition: background .12s ease;
}
.lui-activity-row:last-child { border-bottom: none; }
.lui-activity-row:hover { background: var(--lui-surface-2); }
.lui-activity-row__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--lui-success);
  margin-top: 7px;
  flex-shrink: 0;
}
.lui-activity-row__dot--email    { background: var(--lui-success); }
.lui-activity-row__dot--call     { background: var(--lui-accent); }
.lui-activity-row__dot--linkedin { background: var(--lui-info); }
.lui-activity-row__dot--meeting  { background: var(--lui-warning); }
.lui-activity-row__dot--note     { background: var(--lui-text-muted); }
.lui-activity-row__dot--other    { background: var(--lui-border-strong); }
.lui-activity-row__body { flex: 1; min-width: 0; }
.lui-activity-row__meta {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-shrink: 0;
  min-width: 80px;
  justify-content: flex-end;
  text-align: right;
}

.outreach-detail {
  padding: .85rem 1.1rem .85rem 2.6rem;
  border-bottom: 1px solid var(--lui-border);
  background: var(--lui-surface-2);
}

/* ============================================================
   16d. CALENDAR — /calendar (mockup: Proposed_Content)
   ============================================================ */
.lui-calendar {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--lui-border);
  border-radius: 8px;
  overflow: hidden;
  background: var(--lui-surface-1);
}
.lui-calendar__row {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  border-bottom: 1px solid var(--lui-border);
}
.lui-calendar__row:last-child { border-bottom: none; }
.lui-calendar__row--head {
  background: var(--lui-surface-2);
  border-bottom: 1px solid var(--lui-border);
}
.lui-calendar__head-cell {
  padding: .55rem .6rem;
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .1em;
  color: var(--lui-text-muted);
  border-right: 1px solid var(--lui-border);
  text-align: left;
}
.lui-calendar__head-cell:last-child { border-right: none; }
.lui-calendar__cell {
  min-height: 110px;
  padding: .55rem .55rem .65rem .55rem;
  border-right: 1px solid var(--lui-border);
  display: flex;
  flex-direction: column;
  gap: .3rem;
}
.lui-calendar__cell:last-child { border-right: none; }
.lui-calendar__cell--out { background: var(--lui-surface-2); opacity: .5; }
.lui-calendar__cell--today {
  background: var(--lui-success-soft);
  outline: 1px solid var(--lui-success);
  outline-offset: -1px;
}
.lui-calendar__cell-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: .15rem;
}
.lui-calendar__day-num {
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 12px;
  font-weight: 600;
  color: var(--lui-text-secondary);
}
.lui-calendar__cell--today .lui-calendar__day-num { color: var(--lui-success); }
.lui-calendar__day-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 10px;
  font-weight: 700;
  background: var(--lui-success);
  color: #0b1117;
  border-radius: 10px;
}

/* Calendar chips — one row per event in a day cell */
.lui-cal-chip {
  display: block;
  font-size: 11px;
  padding: 3px 7px;
  border-radius: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-decoration: none;
  border: 1px solid transparent;
  line-height: 1.35;
}
.lui-cal-chip--linkedin    { background: var(--lui-success-soft); color: var(--lui-success); border-color: var(--lui-success); }
.lui-cal-chip--email       { background: var(--lui-warning-soft); color: var(--lui-warning); border-color: var(--lui-warning); }
.lui-cal-chip--email_blast { background: var(--lui-warning-soft); color: var(--lui-warning); border-color: var(--lui-warning); }
.lui-cal-chip--webinar     { background: var(--lui-success-soft); color: var(--lui-success); border-color: var(--lui-success); }
.lui-cal-chip--blog        { background: var(--lui-info-soft);    color: var(--lui-info);    border-color: var(--lui-info); }
.lui-cal-chip--event       { background: var(--lui-accent-soft);  color: var(--lui-accent);  border-color: var(--lui-accent); }
.lui-cal-chip--other       { background: var(--lui-surface-3);    color: var(--lui-text-muted); border-color: var(--lui-border); }
.lui-cal-chip--marquee     { font-weight: 700; }

.lui-cal-chip__dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.lui-cal-chip__dot.lui-cal-chip--linkedin    { background: var(--lui-success); }
.lui-cal-chip__dot.lui-cal-chip--email       { background: var(--lui-warning); }
.lui-cal-chip__dot.lui-cal-chip--email_blast { background: var(--lui-warning); }
.lui-cal-chip__dot.lui-cal-chip--webinar     { background: var(--lui-success); }
.lui-cal-chip__dot.lui-cal-chip--blog        { background: var(--lui-info); }
.lui-cal-chip__dot.lui-cal-chip--event       { background: var(--lui-accent); }
.lui-cal-chip__dot.lui-cal-chip--other       { background: var(--lui-text-muted); }

.lui-cal-tag {
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .06em;
  padding: 3px 8px;
  border-radius: 4px;
  text-transform: uppercase;
  white-space: nowrap;
  align-self: center;
}
.lui-cal-tag--linkedin    { background: var(--lui-success-soft); color: var(--lui-success); }
.lui-cal-tag--email       { background: var(--lui-warning-soft); color: var(--lui-warning); }
.lui-cal-tag--email_blast { background: var(--lui-warning-soft); color: var(--lui-warning); }
.lui-cal-tag--webinar     { background: var(--lui-success-soft); color: var(--lui-success); }
.lui-cal-tag--blog        { background: var(--lui-info-soft);    color: var(--lui-info); }
.lui-cal-tag--event       { background: var(--lui-accent-soft);  color: var(--lui-accent); }
.lui-cal-tag--other       { background: var(--lui-surface-3);    color: var(--lui-text-muted); }

/* Layer palette (Why-unify proposal: 4 semantic categorical colours).
   Meetings = amber, Content = blue, Cadence = teal, Tasks = indigo.
   Background saturation bumped vs initial draft so chips are legible
   on both light and dark themes. Used by chips, dots, tags, and the
   right-rail toggle indicators. */
.lui-cal-chip--layer-meeting { background: rgba(251,191,36,.20); color: #B45309; border-color: rgba(251,191,36,.55); }
.lui-cal-chip--layer-content { background: rgba( 96,165,250,.20); color: #1D4ED8; border-color: rgba( 96,165,250,.55); }
.lui-cal-chip--layer-cadence { background: rgba( 45,212,191,.20); color: #0D9488; border-color: rgba( 45,212,191,.55); }
.lui-cal-chip--layer-task    { background: rgba(129,140,248,.22); color: #4338CA; border-color: rgba(129,140,248,.55); }

[data-theme="dark"] .lui-cal-chip--layer-meeting { color: #FBBF24; }
[data-theme="dark"] .lui-cal-chip--layer-content { color: #60A5FA; }
[data-theme="dark"] .lui-cal-chip--layer-cadence { color: #2DD4BF; }
[data-theme="dark"] .lui-cal-chip--layer-task    { color: #A5B4FC; }

.lui-cal-chip__dot.lui-cal-chip--layer-meeting { background: #FBBF24; }
.lui-cal-chip__dot.lui-cal-chip--layer-content { background: #60A5FA; }
.lui-cal-chip__dot.lui-cal-chip--layer-cadence { background: #2DD4BF; }
.lui-cal-chip__dot.lui-cal-chip--layer-task    { background: #818CF8; }

.lui-cal-tag--layer-meeting { background: rgba(251,191,36,.20); color: #B45309; }
.lui-cal-tag--layer-content { background: rgba( 96,165,250,.20); color: #1D4ED8; }
.lui-cal-tag--layer-cadence { background: rgba( 45,212,191,.20); color: #0D9488; }
.lui-cal-tag--layer-task    { background: rgba(129,140,248,.22); color: #4338CA; }
[data-theme="dark"] .lui-cal-tag--layer-meeting { color: #FBBF24; }
[data-theme="dark"] .lui-cal-tag--layer-content { color: #60A5FA; }
[data-theme="dark"] .lui-cal-tag--layer-cadence { color: #2DD4BF; }
[data-theme="dark"] .lui-cal-tag--layer-task    { color: #A5B4FC; }

/* ============================================================
   17b. Asset library - file rows (Phase D.3.b)
   ============================================================ */
.lui-asset-list {
  display: flex;
  flex-direction: column;
  gap: .35rem;
}
.lui-asset-row {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) auto;
  align-items: center;
  gap: .65rem;
  padding: .55rem .75rem;
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  border-radius: 6px;
  color: var(--lui-text);
}
.lui-asset-row:hover { background: var(--lui-surface-2); }
.lui-asset-row__icon {
  font-size: 18px;
  line-height: 1;
  text-align: center;
}
.lui-asset-row__body { min-width: 0; }
.lui-asset-row__name {
  font-size: 13px;
  font-weight: 600;
  color: var(--lui-text);
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.lui-asset-row__meta {
  font-size: 11px;
  color: var(--lui-text-muted);
  line-height: 1.25;
  margin-top: 2px;
}
.lui-asset-row__actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}

/* ============================================================
   17a. Comment generator - tone chips + result cards (E.2)
   ============================================================ */
.lui-tone-chip {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .4rem .85rem;
  background: var(--lui-surface-1);
  color: var(--lui-text);
  border: 1px solid var(--lui-border);
  border-radius: 18px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: background .12s ease, border-color .12s ease;
  user-select: none;
}
.lui-tone-chip:hover { background: var(--lui-surface-2); }
.lui-tone-chip.is-selected {
  background: rgba(45,212,191,.20);
  color: #0D9488;
  border-color: rgba(45,212,191,.55);
  font-weight: 600;
}
[data-theme="dark"] .lui-tone-chip.is-selected { color: #2DD4BF; }
.lui-tone-chip.is-disabled-max { opacity: .5; cursor: not-allowed; }

.lui-commenter-cards {
  display: flex;
  flex-direction: column;
  gap: .65rem;
}
.lui-commenter-card {
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  border-radius: 8px;
  padding: .85rem 1rem;
  display: flex;
  flex-direction: column;
  gap: .55rem;
}
.lui-commenter-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  flex-wrap: wrap;
}
.lui-commenter-card__tone {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: .2rem .55rem;
  border-radius: 4px;
  background: rgba(45,212,191,.20);
  color: #0D9488;
}
[data-theme="dark"] .lui-commenter-card__tone { color: #2DD4BF; }
.lui-commenter-card__actions {
  display: flex;
  gap: .3rem;
  align-items: center;
}
.lui-commenter-card__body {
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--lui-text);
  white-space: pre-wrap;
}
.lui-commenter-card__rationale {
  font-size: 11.5px;
  color: var(--lui-text-muted);
  font-style: italic;
  padding-top: .5rem;
  border-top: 1px solid var(--lui-border);
  line-height: 1.45;
}

/* ============================================================
   17. Content Studio - kanban board + 'New from...' source cards
   ============================================================ */
.lui-content-board {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .75rem;
  align-items: start;
}
.lui-content-col {
  background: var(--lui-surface-2);
  border: 1px solid var(--lui-border);
  border-radius: 8px;
  min-height: 280px;
  display: flex;
  flex-direction: column;
}
.lui-content-col__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .65rem .85rem;
  border-bottom: 1px solid var(--lui-border);
}
.lui-content-col__title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--lui-text-muted);
}
.lui-content-col__count {
  font-size: 12px;
  font-weight: 700;
  color: var(--lui-text-muted);
  background: var(--lui-surface-3);
  padding: 1px 8px;
  border-radius: 999px;
}
.lui-content-col__body {
  padding: .5rem;
  display: flex;
  flex-direction: column;
  gap: .4rem;
}
.lui-content-col__empty {
  font-size: 12px;
  color: var(--lui-text-muted);
  text-align: center;
  padding: 1.25rem .75rem;
  border: 1px dashed var(--lui-border);
  border-radius: 6px;
  line-height: 1.45;
}
.lui-content-card {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: .6rem .7rem;
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  border-radius: 6px;
  text-decoration: none;
  color: var(--lui-text);
  transition: background .12s ease;
}
.lui-content-card:hover { background: var(--lui-surface-2); }
.lui-content-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}
.lui-content-card__channel {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #1D4ED8;
  background: rgba(96,165,250,.18);
  padding: 1px 6px;
  border-radius: 3px;
}
[data-theme="dark"] .lui-content-card__channel { color: #60A5FA; }
.lui-content-card__when {
  font-size: 10px;
  color: var(--lui-text-muted);
  font-variant-numeric: tabular-nums;
}
.lui-content-card__title {
  font-size: 12.5px;
  font-weight: 600;
  line-height: 1.35;
  color: var(--lui-text);
  overflow-wrap: anywhere;
}
.lui-content-card__meta {
  font-size: 10.5px;
  color: var(--lui-text-muted);
}

/* "New from..." source cards in the right rail.
   Compact: 30px icon + title + optional 1-line metadata. No verbose
   descriptions - the title alone should be enough context. */
.lui-content-source {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: .6rem;
  align-items: center;
  padding: .6rem .75rem;
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  border-radius: 6px;
  text-decoration: none;
  color: var(--lui-text);
  transition: background .12s ease;
}
.lui-content-source:hover { background: var(--lui-surface-2); }
.lui-content-source--soon { opacity: .55; }
.lui-content-source__icon {
  width: 32px;
  height: 32px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  line-height: 1;
}
.lui-content-source__body { min-width: 0; }
.lui-content-source__title {
  font-size: 13px;
  font-weight: 700;
  color: var(--lui-text);
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.lui-content-source__meta {
  font-size: 11px;
  color: var(--lui-text-muted);
  line-height: 1.3;
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.lui-content-source__badge {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--lui-text-muted);
  background: var(--lui-surface-3);
  padding: 1px 6px;
  border-radius: 3px;
  margin-left: 6px;
  vertical-align: middle;
}


/* '+ New' picker cards inside the calendar drawer. Single vertical
   column of full-width cards; each card has a 44px icon on the left
   and title+description on the right, with the content area locked
   to min-width:0 so text wraps cleanly inside the 440px drawer.
   Layer-colour accent on the left border. */
.lui-cal-picker-grid {
  display: flex;
  flex-direction: column;
  gap: .55rem;
}
.lui-cal-picker {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: .85rem;
  align-items: start;
  padding: .9rem 1rem;
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  border-left: 3px solid var(--accent, var(--lui-border));
  border-radius: 8px;
  text-decoration: none;
  color: var(--lui-text);
  cursor: pointer;
  transition: background .12s ease;
}
.lui-cal-picker:hover { background: var(--lui-surface-2); }
.lui-cal-picker__icon {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  line-height: 1;
}
.lui-cal-picker__body {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.lui-cal-picker__title {
  font-size: 14px;
  font-weight: 700;
  color: var(--lui-text);
  line-height: 1.2;
}
.lui-cal-picker__desc {
  font-size: 12px;
  color: var(--lui-text-muted);
  line-height: 1.4;
  overflow-wrap: anywhere;
}

/* Right rail for the unified calendar — layer toggles + today's agenda.
   Built defensively against narrow viewports: explicit colors instead of
   color:inherit, generous min-width on labels, grid (not flex) for the
   toggle row so the colour dot, label, and count never compete for space. */
.lui-cal-rail {
  width: 280px;
  flex: 0 0 280px;
  position: sticky;
  top: 1rem;
}
.lui-cal-rail__heading {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--lui-text-muted);
  margin: 0 0 .55rem;
}
.lui-cal-rail__toggle {
  display: grid;
  grid-template-columns: 14px 1fr auto auto;
  align-items: center;
  gap: .6rem;
  padding: .55rem .75rem;
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  border-radius: 8px;
  text-decoration: none;
  color: var(--lui-text);  /* explicit so it's never invisible */
  font-size: 13px;
  line-height: 1.2;
  margin-bottom: .35rem;
}
.lui-cal-rail__toggle:hover { background: var(--lui-surface-2); }
.lui-cal-rail__toggle--off { opacity: .5; }
.lui-cal-rail__toggle__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: block;
}
.lui-cal-rail__toggle__label {
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}
.lui-cal-rail__toggle__count {
  font-size: 12px;
  color: var(--lui-text-muted);
  font-variant-numeric: tabular-nums;
  font-weight: 600;
}
.lui-cal-rail__toggle__check {
  width: 14px;
  text-align: center;
  color: var(--lui-success);
  font-weight: 700;
  font-size: 12px;
}

.lui-cal-rail__agenda-item {
  display: block;
  padding: .55rem .75rem;
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  border-left-width: 3px;
  border-radius: 6px;
  text-decoration: none;
  color: var(--lui-text);
  margin-bottom: .4rem;
}
.lui-cal-rail__agenda-item:hover { background: var(--lui-surface-2); }
.lui-cal-rail__agenda-item--meeting { border-left-color: #FBBF24; }
.lui-cal-rail__agenda-item--content { border-left-color: #60A5FA; }
.lui-cal-rail__agenda-item--cadence { border-left-color: #2DD4BF; }
.lui-cal-rail__agenda-item--task    { border-left-color: #818CF8; }
.lui-cal-rail__agenda-time {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--lui-text-muted);
}
.lui-cal-rail__agenda-title {
  font-size: 13px;
  font-weight: 600;
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.lui-cal-rail__agenda-meta {
  font-size: 11px;
  color: var(--lui-text-muted);
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Week view — 5-column Mon-Fri grid with rich event cards.
   Built for the Why-unify mockup: each event is a full-width card
   in its day's column with the time + title + optional detail,
   instead of the tiny truncated chips of the month grid. */
.lui-week {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 0;
  border-top: 1px solid var(--lui-border);
  border-left: 1px solid var(--lui-border);
}
.lui-week__col {
  border-right: 1px solid var(--lui-border);
  border-bottom: 1px solid var(--lui-border);
  min-height: 360px;
  display: flex;
  flex-direction: column;
}
.lui-week__head {
  padding: .55rem .65rem;
  border-bottom: 1px solid var(--lui-border);
  background: var(--lui-surface-2);
}
.lui-week__col--today .lui-week__head { background: var(--lui-surface-3); }
.lui-week__head-day {
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--lui-text-muted);
}
.lui-week__head-date {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--lui-text);
  margin-top: 2px;
}
.lui-week__col--today .lui-week__head-date { color: var(--lui-success); }
.lui-week__events {
  padding: .45rem;
  display: flex;
  flex-direction: column;
  gap: .35rem;
  flex: 1;
}
.lui-week-event {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: .4rem .5rem;
  border: 1px solid transparent;
  border-radius: 6px;
  text-decoration: none;
  line-height: 1.3;
  min-width: 0;
}
.lui-week-event__time {
  font-size: .65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  opacity: .85;
}
.lui-week-event__title {
  font-size: .78rem;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.lui-week-event__detail {
  font-size: .68rem;
  opacity: .75;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ============================================================
   16e. ORG CHART — /account-map (mockup: Proposed_Account_Map)
   ============================================================ */
.lui-orgchart__row {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  justify-content: center;
  align-items: flex-start;
  padding: 1.5rem 0;
  position: relative;
}
.lui-orgchart__row + .lui-orgchart__row { border-top: 1px dashed var(--lui-border); }

.lui-orgchart__node {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .3rem;
  min-width: 110px;
  max-width: 150px;
  text-align: center;
}

.lui-orgchart__avatar {
  position: relative;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .04em;
  color: var(--lui-text-primary);
  background: var(--lui-surface-2);
  border: 2px solid var(--lui-border);
  box-shadow: 0 0 0 4px var(--lui-surface-1) inset;
}
.lui-orgchart__node--champion .lui-orgchart__avatar {
  border-color: var(--lui-warning);
  background: var(--lui-warning-soft);
  color: var(--lui-warning);
}
.lui-orgchart__node--engaged .lui-orgchart__avatar {
  border-color: var(--lui-success);
  background: var(--lui-success-soft);
  color: var(--lui-success);
}
.lui-orgchart__node--gap .lui-orgchart__avatar {
  border-style: dashed;
  border-color: var(--lui-danger);
  background: transparent;
  color: var(--lui-danger);
}
.lui-orgchart__node--unknown .lui-orgchart__avatar {
  border-color: var(--lui-border-strong);
  background: var(--lui-surface-2);
  color: var(--lui-text-muted);
}

.lui-orgchart__star {
  position: absolute;
  top: -4px;
  left: -4px;
  width: 18px;
  height: 18px;
  background: var(--lui-warning);
  color: var(--lui-surface-1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  line-height: 1;
}

.lui-orgchart__name {
  font-size: 13px;
  font-weight: 600;
  color: var(--lui-text-primary);
  margin-top: 4px;
  line-height: 1.2;
}
.lui-orgchart__title {
  font-size: 11px;
  color: var(--lui-text-muted);
  line-height: 1.2;
}
.lui-orgchart__nocontact {
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .08em;
  color: var(--lui-danger);
  margin-top: 4px;
}

/* ============================================================
   16f. LIST BUILDER — /list-builder (mockup: Proposed_List_Builder)
   ============================================================ */
.lb-sentence {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .55rem .65rem;
  font-size: 16px;
  line-height: 1.6;
}
.lb-connector {
  font-size: 14px;
  color: var(--lui-text-muted);
}
.lb-chip {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .35rem .7rem;
  background: var(--lui-surface-2);
  border: 1px solid var(--lui-border);
  border-radius: 6px;
  font-size: 14px;
  font-weight: 500;
  color: var(--lui-text-primary);
  cursor: pointer;
  list-style: none;
  transition: border-color .12s ease, background .12s ease;
}
.lb-chip::-webkit-details-marker { display: none; }
.lb-chip:hover { border-color: var(--lui-border-strong); }
.lb-chip--filled, .lb-chip--accent.lb-chip--filled {
  background: var(--lui-accent-soft);
  border-color: var(--lui-accent);
  color: var(--lui-accent);
}
.lb-chip__x {
  background: none;
  border: none;
  color: inherit;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  padding: 0;
  opacity: .7;
}
.lb-chip__x:hover { opacity: 1; }
.lb-add-filter {
  font-size: 13px;
  color: var(--lui-text-muted);
}

/* Popover body for each chip's picker — anchored under <details> */
.lb-pop { position: relative; display: inline-block; }
.lb-pop[open] > .lb-chip { background: var(--lui-accent-soft); border-color: var(--lui-accent); color: var(--lui-accent); }
.lb-pop__body {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  width: 320px;
  max-width: 90vw;
  z-index: 20;
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border-strong);
  border-radius: var(--lui-r-lg);
  box-shadow: 0 18px 40px rgba(0,0,0,.45), 0 4px 12px rgba(0,0,0,.25);
  padding: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.lb-pop__body--wide { width: 420px; }

.lb-pop__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  padding: .65rem .9rem;
  background: var(--lui-surface-2);
  border-bottom: 1px solid var(--lui-border);
}
.lb-pop__title {
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--lui-text-muted);
}
.lb-pop__clear {
  background: none;
  border: none;
  padding: 0;
  font-size: 12px;
  color: var(--lui-text-muted);
  text-decoration: underline;
  cursor: pointer;
}
.lb-pop__clear:hover { color: var(--lui-text-primary); }

.lb-pop__search {
  margin: .65rem .9rem 0;
  width: calc(100% - 1.8rem);
}

.lb-pop__list {
  display: flex;
  flex-direction: column;
  padding: .35rem;
  max-height: 280px;
  overflow-y: auto;
}
.lb-pop__list--grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

.lb-pop__row {
  display: flex;
  align-items: center;
  gap: .55rem;
  padding: .4rem .55rem;
  border-radius: 6px;
  font-size: 13px;
  color: var(--lui-text-primary);
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.lb-pop__row:hover { background: var(--lui-surface-2); }
.lb-pop__row input[type="checkbox"],
.lb-pop__row input[type="radio"] {
  accent-color: var(--lui-accent);
  width: 14px;
  height: 14px;
  cursor: pointer;
  flex-shrink: 0;
}
.lb-pop__row > span {
  overflow: hidden;
  text-overflow: ellipsis;
}

.lb-pop__foot {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: .5rem;
  padding: .65rem .9rem;
  border-top: 1px solid var(--lui-border);
  background: var(--lui-surface-2);
}

/* ============================================================
   16g. WIN/LOSS — /insights/win-loss (mockup: Proposed_Win_Loss)
   ============================================================ */
.wl-page { max-width: 760px; }

.wl-hero {
  font-family: var(--lui-font-display, 'Plus Jakarta Sans', system-ui, sans-serif);
  font-size: 30px;
  line-height: 1.2;
  font-weight: 800;
  letter-spacing: -.01em;
  color: var(--lui-text-primary);
  margin: 0 0 1rem;
  max-width: 620px;
}
@media (min-width: 900px) {
  .wl-hero { font-size: 36px; }
}

.wl-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}
@media (max-width: 720px) {
  .wl-grid { grid-template-columns: 1fr; gap: 1.25rem; }
}

.wl-pattern {
  display: flex;
  align-items: flex-start;
  gap: .65rem;
  padding: .65rem .75rem;
  background: var(--lui-surface-2);
  border: 1px solid var(--lui-border);
  border-radius: 8px;
}
.wl-pattern__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-top: 7px;
  flex-shrink: 0;
}
.wl-pattern--win .wl-pattern__dot { background: var(--lui-success); }
.wl-pattern--loss .wl-pattern__dot { background: var(--lui-danger); }

.wl-actions {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--lui-border);
}
.wl-action {
  display: flex;
  gap: 1.25rem;
  padding: 1.1rem 0;
  border-bottom: 1px solid var(--lui-border);
}
.wl-action__num {
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 13px;
  font-weight: 700;
  color: var(--lui-text-muted);
  width: 36px;
  flex-shrink: 0;
  padding-top: 2px;
}
.wl-action__body { flex: 1; min-width: 0; }
.wl-action__foot {
  margin-top: .75rem;
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;
}

/* ============================================================
   16h. COMPANY WORKSPACE — /company/{name} (Proposed_Company)
   ============================================================ */
.company-props {
  position: relative;
}
.company-props__grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 1.25rem;
}
@media (max-width: 900px) {
  .company-props__grid { grid-template-columns: repeat(3, 1fr); gap: 1rem 1.25rem; }
}
@media (max-width: 560px) {
  .company-props__grid { grid-template-columns: repeat(2, 1fr); }
}
.company-props__cell { min-width: 0; }
.company-props__label {
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--lui-text-muted);
  margin-bottom: .25rem;
}
.company-props__value {
  font-size: 13px;
  font-weight: 500;
  color: var(--lui-text);
}
.company-props__hint {
  position: absolute;
  top: var(--lui-sp-5);
  right: var(--lui-sp-6);
  font-size: 11px;
  color: var(--lui-text-muted);
}
@media (max-width: 900px) {
  .company-props__hint { display: none; }
}

.company-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 1.25rem;
}
@media (max-width: 1080px) {
  .company-grid { grid-template-columns: 1fr; }
}
.company-grid__main { min-width: 0; }
.company-grid__rail { min-width: 0; }

.company-suggests {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .55rem;
}
.company-suggests li {
  position: relative;
  padding-left: 1.1rem;
  font-size: 13px;
  line-height: 1.55;
  color: var(--lui-text);
}
.company-suggests li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .55rem;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--lui-accent);
}

.company-activity {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.company-activity__item {
  display: flex;
  gap: .85rem;
  padding: .75rem 0;
  border-bottom: 1px solid var(--lui-border);
}
.company-activity__item:last-child { border-bottom: none; }
.company-activity__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--lui-text-muted);
  margin-top: 7px;
  flex-shrink: 0;
}
.company-activity__dot--email    { background: var(--lui-success); }
.company-activity__dot--call     { background: var(--lui-accent); }
.company-activity__dot--linkedin { background: var(--lui-info); }
.company-activity__dot--meeting  { background: var(--lui-warning); }
.company-activity__dot--signal   { background: var(--lui-info); }
.company-activity__dot--stage    { background: var(--lui-accent); }
.company-activity__dot--other    { background: var(--lui-text-muted); }
.company-activity__body { min-width: 0; flex: 1; }

/* Buying committee mini-row (right rail) */
.committee-row {
  display: flex;
  align-items: center;
  gap: .65rem;
  padding: .35rem 0;
}
.committee-row__avatar {
  position: relative;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
  background: var(--lui-surface-2);
  border: 2px solid var(--lui-border);
  flex-shrink: 0;
}
.committee-row__avatar--champion {
  border-color: var(--lui-warning);
  background: var(--lui-warning-soft);
  color: var(--lui-warning);
}
.committee-row__avatar--engaged {
  border-color: var(--lui-success);
  background: var(--lui-success-soft);
  color: var(--lui-success);
}
.committee-row__avatar--gap {
  border-style: dashed;
  border-color: var(--lui-danger);
  background: transparent;
  color: var(--lui-danger);
}
.committee-row__avatar--unknown {
  color: var(--lui-text-muted);
}
.committee-row__star {
  position: absolute;
  top: -3px;
  left: -3px;
  width: 14px;
  height: 14px;
  background: var(--lui-warning);
  color: var(--lui-surface-1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 8px;
  line-height: 1;
}
.committee-row__body { min-width: 0; flex: 1; }

/* ============================================================
   16i. CONTACT WORKSPACE — /contacts/{id} (Proposed_Contact)
   ============================================================ */
.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 1.25rem;
}
@media (max-width: 1080px) {
  .contact-grid { grid-template-columns: 1fr; }
}
.contact-grid__main { min-width: 0; }
.contact-grid__rail { min-width: 0; }

.contact-header {
  display: flex;
  gap: 1.25rem;
  align-items: flex-start;
}
.contact-header__avatar {
  position: relative;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: .04em;
  background: var(--lui-surface-2);
  border: 2px solid var(--lui-border);
  color: var(--lui-text-muted);
  flex-shrink: 0;
}
.contact-header__avatar--champion {
  border-color: var(--lui-warning);
  background: var(--lui-warning-soft);
  color: var(--lui-warning);
}
.contact-header__avatar--engaged {
  border-color: var(--lui-success);
  background: var(--lui-success-soft);
  color: var(--lui-success);
}
.contact-header__avatar--unknown {
  background: var(--lui-surface-2);
  color: var(--lui-text-muted);
}
.contact-header__star {
  position: absolute;
  top: -4px;
  left: -4px;
  width: 22px;
  height: 22px;
  background: var(--lui-warning);
  color: var(--lui-surface-1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  line-height: 1;
}
.contact-header__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: .25rem;
}
.contact-contact-line {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;
  padding-top: .85rem;
  border-top: 1px solid var(--lui-border);
}

.contact-details {
  margin: 0;
  display: grid;
  grid-template-columns: 1fr 1.25fr;
  gap: .55rem .85rem;
  font-size: 13px;
  line-height: 1.4;
}
.contact-details dt {
  color: var(--lui-text-muted);
}
.contact-details dd {
  margin: 0;
  color: var(--lui-text);
  text-align: right;
}

/* ============================================================
   16j. INBOUND INBOX — /inbound (Proposed_Inbound)
   ============================================================ */
.inbox-group-head {
  display: flex;
  align-items: center;
  gap: .55rem;
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding-bottom: .75rem;
  margin-bottom: 1rem;
}
.inbox-group-head--danger  { color: var(--lui-danger); }
.inbox-group-head--warning { color: var(--lui-warning); }
.inbox-group-head--muted   { color: var(--lui-text-muted); }
.inbox-group-head__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  font-size: 10px;
  background: currentColor;
  color: var(--lui-surface-1);
  border-radius: 10px;
  filter: brightness(1);
}

.inbox-card {
  background: var(--lui-surface-1);
  border: 1px solid var(--lui-border);
  border-radius: 10px;
  padding: 1rem 1.1rem;
  display: flex;
  flex-direction: column;
  gap: .75rem;
}
.inbox-card__head {
  display: flex;
  align-items: flex-start;
  gap: .85rem;
}
.inbox-card__avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
  background: var(--lui-surface-2);
  border: 1px solid var(--lui-border);
  color: var(--lui-text-muted);
  flex-shrink: 0;
}
.inbox-card__avatar--email,
.inbox-card__avatar--linkedin {
  border-color: var(--lui-danger);
  background: var(--lui-danger-soft);
  color: var(--lui-danger);
}
.inbox-card__avatar--inbound_form,
.inbox-card__avatar--meeting {
  border-color: var(--lui-success);
  background: var(--lui-success-soft);
  color: var(--lui-success);
}

.inbox-card__title-block { min-width: 0; flex: 1; }
.inbox-card__title-line {
  display: flex;
  align-items: center;
  gap: .45rem;
  flex-wrap: wrap;
  font-size: 13px;
}
.inbox-card__src {
  display: inline-flex;
  align-items: center;
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  padding: 2px 8px;
  border-radius: 4px;
  background: var(--lui-surface-2);
  color: var(--lui-text-muted);
  white-space: nowrap;
}
.inbox-card__src--email    { background: var(--lui-danger-soft);  color: var(--lui-danger); }
.inbox-card__src--inbound_form,
.inbox-card__src--meeting  { background: var(--lui-success-soft); color: var(--lui-success); }
.inbox-card__src--linkedin { background: var(--lui-info-soft);    color: var(--lui-info); }

.inbox-card__meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: .5rem;
  flex-shrink: 0;
}
.inbox-card__actions {
  display: flex;
  gap: .35rem;
  align-items: center;
}

.inbox-card__quote {
  padding: .7rem .9rem;
  background: var(--lui-surface-2);
  border-radius: 8px;
  font-size: 13px;
  line-height: 1.5;
  color: var(--lui-text-secondary);
  font-style: italic;
}

.inbox-card__context {
  font-size: 12px;
  color: var(--lui-accent);
}

/* ============================================================
   16k. RESEARCH VIEW — /research/view/{id} (Proposed_Research)
   ============================================================ */
.research-page {
  display: grid;
  grid-template-columns: 180px minmax(0, 720px);
  gap: 3rem;
  align-items: start;
}
@media (max-width: 900px) {
  .research-page { grid-template-columns: 1fr; gap: 1.5rem; }
  .research-toc { position: static !important; }
}

.research-toc {
  position: sticky;
  top: 24px;
  align-self: start;
}
.research-toc__nav {
  display: flex;
  flex-direction: column;
  gap: .35rem;
}
.research-toc__nav a {
  display: block;
  padding: .35rem .65rem;
  border-left: 2px solid transparent;
  color: var(--lui-text-muted);
  font-size: 13px;
  text-decoration: none;
  transition: color .12s ease, border-color .12s ease;
}
.research-toc__nav a:hover { color: var(--lui-text); }
.research-toc__nav a.is-active {
  color: var(--lui-text);
  border-left-color: var(--lui-accent);
  font-weight: 600;
}

.research-main { min-width: 0; }

.research-hero { padding-bottom: 1.5rem; border-bottom: 1px solid var(--lui-border); }
.research-score {
  width: 96px;
  height: 96px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background:
    conic-gradient(var(--lui-accent) calc(var(--score, 0) * 36deg), var(--lui-surface-3) 0deg);
  position: relative;
}
.research-score::before {
  content: "";
  position: absolute;
  inset: 6px;
  border-radius: 50%;
  background: var(--lui-surface-1);
}
.research-score__num {
  position: relative;
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 30px;
  font-weight: 700;
  color: var(--lui-text);
}
.research-score--strong   { --score: 8.5; }
.research-score--strong   .research-score__num { color: var(--lui-success); }
.research-score--moderate { --score: 5.5; }
.research-score--moderate .research-score__num { color: var(--lui-warning); }
.research-score--low      { --score: 2.5; }
.research-score--low      .research-score__num { color: var(--lui-danger); }

.research-headline {
  font-family: var(--lui-font-display, 'Plus Jakarta Sans', system-ui, sans-serif);
  font-size: 28px;
  line-height: 1.2;
  font-weight: 800;
  letter-spacing: -.01em;
  color: var(--lui-text);
  margin: 0;
}
@media (min-width: 900px) {
  .research-headline { font-size: 32px; }
}

.research-section {
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--lui-border);
}
.research-section:last-child { border-bottom: none; }
.research-section__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  margin-bottom: .85rem;
}
.research-section__title {
  font-family: var(--lui-font-display, 'Plus Jakarta Sans', system-ui, sans-serif);
  font-size: 18px;
  font-weight: 700;
  color: var(--lui-text);
  margin: 0;
}
.research-section__body {
  font-size: 14px;
  line-height: 1.7;
  color: var(--lui-text-secondary);
  margin: 0;
  max-width: 660px;
}
.research-section__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .55rem;
  max-width: 660px;
}
.research-section__list li {
  position: relative;
  padding-left: 1.2rem;
  font-size: 14px;
  line-height: 1.55;
  color: var(--lui-text-secondary);
}
.research-section__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .55rem;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--lui-accent);
}

.research-opener {
  margin: 0;
  padding: 1.1rem 1.25rem;
  background: var(--lui-surface-2);
  border: 1px solid var(--lui-border);
  border-radius: 10px;
  font-size: 15px;
  line-height: 1.6;
  font-style: italic;
  color: var(--lui-text);
}

.research-sources {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  counter-reset: src;
}
.research-sources__item {
  font-size: 13px;
  color: var(--lui-text-secondary);
  line-height: 1.45;
}
.research-sources__num {
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  color: var(--lui-text-muted);
  margin-right: .5rem;
}
.research-sources__label { color: var(--lui-text); font-weight: 500; }
.research-sources__detail,
.research-sources__when { color: var(--lui-text-muted); }

/* ============================================================
   16l. REVENUE — /pipeline/revenue (Proposed_Revenue)
   ============================================================ */
.revenue-hero {
  font-family: var(--lui-font-display, 'Plus Jakarta Sans', system-ui, sans-serif);
  font-size: 22px;
  line-height: 1.35;
  font-weight: 700;
  color: var(--lui-text);
}
@media (min-width: 900px) {
  .revenue-hero { font-size: 26px; }
}
.revenue-hero strong { color: var(--lui-accent); }

.revenue-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.25rem;
}
@media (max-width: 900px) {
  .revenue-kpis { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
}
@media (max-width: 480px) {
  .revenue-kpis { grid-template-columns: 1fr; }
}
.revenue-kpi { min-width: 0; }
.revenue-kpi__value {
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 24px;
  font-weight: 700;
  color: var(--lui-text);
  line-height: 1.1;
}
.revenue-kpi__unit {
  font-size: 13px;
  font-weight: 500;
  color: var(--lui-text-muted);
}
.revenue-kpi__label {
  margin-top: .35rem;
  font-size: 12px;
  color: var(--lui-text-muted);
}

.revenue-charts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}
@media (max-width: 900px) {
  .revenue-charts { grid-template-columns: 1fr; }
}
/* Chart.js with maintainAspectRatio:false sizes to the parent. Without a
   bounded parent height the canvas grows on each layout pass, producing
   an effectively infinite-tall card. Lock the wrapper height here. */
.revenue-chart-wrap {
  position: relative;
  height: 220px;
  width: 100%;
}
.revenue-chart-wrap > canvas {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
}

/* By-stage rows. One row per non-closed stage. Layout:
   Name + count badge on top, value bar middle, value/win-rate bottom.
   Grid keeps the bars vertically aligned across rows. */
.revenue-stages {
  display: grid;
  grid-template-columns: minmax(0, 220px) minmax(0, 1fr) minmax(160px, max-content);
  column-gap: 1.5rem;
  row-gap: 0;
}
@media (max-width: 720px) {
  .revenue-stages { grid-template-columns: 1fr; }
}
.revenue-stage {
  display: contents;
  color: inherit;
  text-decoration: none;
}
.revenue-stage__head,
.revenue-stage__bar,
.revenue-stage__meta {
  padding: .75rem 0;
  border-bottom: 1px solid var(--lui-border);
  align-self: center;
  transition: background .12s ease;
}
.revenue-stage:last-child > * { border-bottom: none; }
.revenue-stage:hover > * { background: var(--lui-surface-2); }

.revenue-stage__head {
  display: flex;
  align-items: center;
  gap: .55rem;
  padding-left: .75rem;
  padding-right: .25rem;
  border-radius: 6px 0 0 6px;
}
.revenue-stage__name {
  font-weight: 600;
  font-size: 14px;
  color: var(--lui-text);
}
.revenue-stage__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 7px;
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 11px;
  font-weight: 700;
  background: var(--lui-surface-3);
  color: var(--lui-text-secondary);
  border-radius: 11px;
}

.revenue-stage__bar {
  position: relative;
  height: 28px;
  padding: 0;
  margin: .75rem 0;
}
.revenue-stage__bar-fill {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  background: var(--lui-accent-soft);
  border-left: 2px solid var(--lui-accent);
  border-radius: 4px;
  min-width: 4px;
  transition: width .35s ease;
}

.revenue-stage__meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: .15rem;
  padding-right: .75rem;
  border-radius: 0 6px 6px 0;
}

@media (max-width: 720px) {
  .revenue-stage__head, .revenue-stage__bar, .revenue-stage__meta {
    padding-left: .25rem; padding-right: .25rem;
    border-radius: 0;
  }
  .revenue-stage__bar { margin: 0 0 .25rem; }
  .revenue-stage__meta { align-items: flex-start; padding-bottom: 1rem; }
}

/* ============================================================
   16m. SIGNALS — /digests (Proposed_Signals)
   ============================================================ */
.signal-card { padding: 0; }
.signal-card__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--lui-border);
  flex-wrap: wrap;
}
.signal-card__company { min-width: 0; flex: 1; }
.signal-card__actions {
  display: flex;
  gap: .5rem;
  flex-shrink: 0;
  flex-wrap: wrap;
}
.signal-card__rows {
  display: flex;
  flex-direction: column;
}
.signal-row {
  display: flex;
  gap: 1rem;
  padding: .85rem 1.25rem;
  border-top: 1px solid var(--lui-border);
  align-items: flex-start;
}
.signal-row:first-child { border-top: none; }

.signal-row__strength {
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  padding: 4px 8px;
  border-radius: 4px;
  flex-shrink: 0;
  min-width: 44px;
  text-align: center;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 2px;
}
.signal-row__strength--high    { background: var(--lui-danger-soft);  color: var(--lui-danger); }
.signal-row__strength--medium  { background: var(--lui-warning-soft); color: var(--lui-warning); }
.signal-row__strength--low     { background: var(--lui-surface-3);    color: var(--lui-text-muted); }

.signal-row__body { flex: 1; min-width: 0; }
.signal-row__dismiss {
  background: none;
  border: none;
  color: var(--lui-text-muted);
  font-size: 12px;
  cursor: pointer;
  padding: 4px 8px;
  flex-shrink: 0;
}
.signal-row__dismiss:hover {
  color: var(--lui-text);
  text-decoration: underline;
}

/* ============================================================
   16n. SETTER DESK — /setter-desk (Proposed_Setter_Desk)
   ============================================================ */
.setter-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 1.25rem;
}
@media (max-width: 1080px) {
  .setter-grid { grid-template-columns: 1fr; }
}
.setter-main, .setter-rail { min-width: 0; }
.setter-rail > section { position: relative; }

/* Identity strip */
.setter-identity {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}
.setter-identity__avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--lui-warning-soft);
  color: var(--lui-warning);
  border: 2px solid var(--lui-warning);
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 18px;
  font-weight: 700;
  flex-shrink: 0;
}
.setter-identity__body { flex: 1; min-width: 0; }
.setter-why {
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid var(--lui-border);
}

/* Talking points */
.setter-talking {
  list-style: none;
  margin: 0;
  padding: 0;
  counter-reset: tp;
  display: flex;
  flex-direction: column;
  gap: .8rem;
}
.setter-talking li {
  counter-increment: tp;
  position: relative;
  padding-left: 2rem;
  font-size: 14px;
  line-height: 1.55;
}
.setter-talking li::before {
  content: "#" counter(tp);
  position: absolute;
  left: 0;
  top: 1px;
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 12px;
  font-weight: 700;
  color: var(--lui-text-muted);
  width: 1.6rem;
}

/* Qualification checklist */
.setter-qual {
  display: flex;
  flex-direction: column;
  gap: .6rem;
}
.setter-qual__row {
  display: flex;
  gap: .85rem;
  padding: .75rem .85rem;
  background: var(--lui-surface-2);
  border: 1px solid var(--lui-border);
  border-radius: 8px;
  cursor: pointer;
  transition: border-color .12s ease, background .12s ease;
}
.setter-qual__row:hover { border-color: var(--lui-border-strong); }
.setter-qual__row.is-ticked {
  background: var(--lui-success-soft);
  border-color: var(--lui-success);
}
.setter-qual__row input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--lui-success);
  margin-top: 1px;
  flex-shrink: 0;
  cursor: pointer;
}
.setter-qual__body { min-width: 0; flex: 1; }

/* BDM picker + slots */
.setter-slots {
  display: flex;
  gap: .55rem;
  overflow-x: auto;
  padding-bottom: .25rem;
}
.setter-slot-col {
  display: flex;
  flex-direction: column;
  gap: .35rem;
  flex: 0 0 auto;
  min-width: 62px;
}
.setter-slot-col__head {
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--lui-text-muted);
  padding: .15rem 0;
}
.setter-slot {
  font-family: var(--lui-font-mono, ui-monospace, monospace);
  font-size: 12px;
  padding: .45rem .35rem;
  background: var(--lui-surface-2);
  border: 1px solid var(--lui-border);
  border-radius: 6px;
  color: var(--lui-text);
  cursor: pointer;
  transition: border-color .12s ease, background .12s ease;
}
.setter-slot:hover { border-color: var(--lui-border-strong); }
.setter-slot.is-picked {
  background: var(--lui-accent);
  color: var(--lui-accent-fg);
  border-color: var(--lui-accent);
}

/* Preview list (what BDM will see) */
.setter-preview-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .35rem;
}
.setter-preview-list li {
  position: relative;
  padding-left: 1rem;
  font-size: 13px;
  line-height: 1.5;
  color: var(--lui-text-secondary);
}
.setter-preview-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--lui-success);
  font-weight: 700;
}

/* ============================================================
   17. REDUCED MOTION — respect users
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  .lui-app *, .lui-app *::before, .lui-app *::after {
    transition-duration: 0ms !important;
    animation-duration: 0ms !important;
  }
}
