/* KOVA · Primitive styles · v1
   Reads from tokens.css. Atoms → molecules → organisms.
   No gold, sans-only, 8-px grid, Linear-led calm. */

/* ============================================================
   ATOMS
   ============================================================ */

/* Button */
.k-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  height: 32px;
  padding: 0 14px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--ink-2);
  border-radius: var(--r-sm);
  font: inherit;
  font-size: var(--t-body-sm);
  font-weight: var(--w-medium);
  letter-spacing: -0.005em;
  cursor: pointer;
  transition: background var(--m-1) var(--ease-out),
              border-color var(--m-1) var(--ease-out),
              color var(--m-1) var(--ease-out);
  white-space: nowrap;
}
.k-btn:hover  { background: var(--surface-2); border-color: var(--line-strong); }
.k-btn:active { background: var(--surface-3); }
.k-btn[disabled],
.k-btn.is-disabled { opacity: 0.45; cursor: not-allowed; }

.k-btn-primary {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--accent-ink);
}
.k-btn-primary:hover  { background: var(--ink-2); border-color: var(--ink-2); }
.k-btn-primary:active { background: #000; }

.k-btn-accent {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--accent-ink);
}
.k-btn-accent:hover  { background: var(--accent-2); border-color: var(--accent-2); }

.k-btn-ghost {
  background: transparent;
  border-color: transparent;
  color: var(--ink-2);
}
.k-btn-ghost:hover { background: var(--surface-2); border-color: var(--line-2); }

.k-btn-approve {
  background: var(--success-soft);
  color: var(--success);
  border-color: var(--success-line);
}
.k-btn-approve:hover { background: #DDEEE3; }

.k-btn-reject {
  background: transparent;
  color: var(--danger);
  border-color: var(--danger-line);
}
.k-btn-reject:hover { background: var(--danger-soft); }

.k-btn-sm { height: 26px; padding: 0 10px; font-size: var(--t-meta); gap: var(--s-1); }
.k-btn-lg { height: 40px; padding: 0 20px; font-size: var(--t-body); }

/* IconBtn */
.k-iconbtn {
  width: 32px; height: 32px;
  display: grid; place-items: center;
  border: 1px solid transparent;
  background: transparent;
  color: var(--ink-3);
  border-radius: var(--r-sm);
  cursor: pointer;
  transition: background var(--m-1) var(--ease-out);
  position: relative;
}
.k-iconbtn:hover { background: var(--surface-2); }
.k-iconbtn .k-dot {
  position: absolute; top: 8px; right: 8px;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
  border: 1.5px solid var(--surface);
}

/* Input */
.k-input {
  display: flex; align-items: center; gap: var(--s-2);
  height: 32px;
  padding: 0 12px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  font: inherit;
  font-size: var(--t-body-sm);
  color: var(--ink);
  transition: border-color var(--m-2) var(--ease-out),
              box-shadow var(--m-2) var(--ease-out);
}
.k-input:hover  { border-color: var(--line-strong); }
.k-input:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(46,91,255,0.12);
}
.k-input.is-error {
  border-color: var(--danger);
  box-shadow: 0 0 0 3px rgba(185,28,28,0.10);
}
.k-input.is-disabled {
  background: var(--surface-2);
  color: var(--mute-2);
  cursor: not-allowed;
}
.k-input input {
  flex: 1; border: 0; outline: 0; background: transparent;
  font: inherit; color: inherit; min-width: 0;
}
.k-input-aff { font-size: var(--t-meta); color: var(--mute); }

/* Textarea */
.k-textarea {
  width: 100%;
  min-height: 88px;
  padding: 10px 12px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  font: inherit; font-size: var(--t-body-sm);
  color: var(--ink); resize: vertical;
}

/* Chip */
.k-chip {
  display: inline-flex; align-items: center; gap: var(--s-1);
  height: 22px;
  padding: 0 10px;
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: var(--r-pill);
  font-size: var(--t-meta);
  font-weight: var(--w-medium);
  color: var(--ink-2);
  letter-spacing: 0;
}
.k-chip-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; opacity: 0.85; }

.k-chip-success { color: var(--success); background: var(--success-soft); border-color: var(--success-line); }
.k-chip-warn    { color: var(--warn);    background: var(--warn-soft);    border-color: var(--warn-line); }
.k-chip-danger  { color: var(--danger);  background: var(--danger-soft);  border-color: var(--danger-line); }
.k-chip-info    { color: var(--info);    background: var(--info-soft);    border-color: var(--info-line); }
.k-chip-accent  { color: var(--accent);  background: var(--accent-soft);  border-color: rgba(46,91,255,0.18); }
.k-chip-solid   { color: var(--accent-ink); background: var(--ink); border-color: var(--ink); }
.k-chip-mute    { color: var(--mute); }

/* StatusDot */
.k-status-dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--mute-2);
}
.k-status-dot.is-success { background: var(--success); }
.k-status-dot.is-warn    { background: var(--warn); }
.k-status-dot.is-danger  { background: var(--danger); }
.k-status-dot.is-info    { background: var(--info); }

/* Kbd */
.k-kbd {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--mute);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 1px 5px;
  background: var(--surface-2);
  letter-spacing: 0;
}

/* Avatar — neutral graphite, NO gold */
.k-avatar {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4B5563, #1F2329);
  color: #fff;
  display: grid; place-items: center;
  font-weight: var(--w-semibold);
  font-size: 11px;
  letter-spacing: 0.02em;
}

/* Spinner */
.k-spin {
  width: 14px; height: 14px;
  border: 1.5px solid var(--line);
  border-top-color: var(--ink);
  border-radius: 50%;
  animation: k-spin 720ms linear infinite;
  display: inline-block;
}
@keyframes k-spin { to { transform: rotate(360deg); } }

/* Skeleton */
.k-skel {
  background: linear-gradient(90deg,
    var(--line-2) 0%,
    var(--surface-2) 50%,
    var(--line-2) 100%);
  background-size: 200% 100%;
  animation: k-skel 1.6s linear infinite;
  border-radius: var(--r-xs);
}
@keyframes k-skel {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Checkbox */
.k-check {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-size: var(--t-body-sm);
  color: var(--ink-2);
  cursor: pointer;
  user-select: none;
}
.k-check-box {
  width: 16px; height: 16px;
  border: 1.5px solid var(--line-strong);
  border-radius: 4px;
  background: var(--surface);
  display: grid; place-items: center;
  transition: border-color var(--m-1) var(--ease-out),
              background var(--m-1) var(--ease-out);
  flex-shrink: 0;
}
.k-check:hover .k-check-box { border-color: var(--ink-3); }
.k-check.is-checked .k-check-box {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.k-check.is-checked .k-check-box::after {
  content: "✓"; font-size: 10px; font-weight: 700; line-height: 1; color: #fff;
}
.k-check.is-disabled { opacity: 0.45; cursor: not-allowed; }

/* Switch */
.k-switch {
  position: relative;
  width: 32px; height: 18px;
  background: var(--line-strong);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: background var(--m-2) var(--ease-out);
  flex-shrink: 0;
}
.k-switch::after {
  content: "";
  position: absolute;
  top: 2px; left: 2px;
  width: 14px; height: 14px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 1px 2px rgba(0,0,0,0.18);
  transition: transform var(--m-2) var(--ease-out);
}
.k-switch.is-on { background: var(--accent); }
.k-switch.is-on::after { transform: translateX(14px); }
.k-switch.is-disabled { opacity: 0.45; cursor: not-allowed; }

/* Notification row */
.k-notif {
  display: flex; align-items: flex-start; gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  border-bottom: 1px solid var(--line-2);
  font-size: var(--t-body-sm);
  cursor: pointer;
  transition: background var(--m-1) var(--ease-out);
}
.k-notif:last-child { border-bottom: 0; }
.k-notif:hover { background: var(--surface-2); }
.k-notif-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--m-mod, var(--accent));
  margin-top: 7px; flex-shrink: 0;
}
.k-notif.is-read .k-notif-dot { background: var(--mute-2); opacity: 0.5; }
.k-notif-body { flex: 1; min-width: 0; }
.k-notif-title { color: var(--ink); }
.k-notif-meta  { font-size: var(--t-meta); color: var(--mute); margin-top: 2px; }

/* Empty / restricted / error states (organism-level layouts) */
.k-empty {
  display: flex; flex-direction: column; align-items: center;
  padding: 48px 24px;
  text-align: center;
  color: var(--mute);
}
.k-empty-mark {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--surface-2);
  border: 1px solid var(--line);
  display: grid; place-items: center;
  color: var(--mute);
  margin-bottom: 14px;
}
.k-empty-title { font-size: var(--t-h3); color: var(--ink); font-weight: var(--w-semibold); }
.k-empty-body  { font-size: var(--t-body-sm); margin-top: 6px; max-width: 360px; line-height: 1.55; }
.k-empty-cta   { margin-top: 16px; }

.k-locked {
  position: relative;
  border: 1px dashed var(--line);
  border-radius: var(--r-lg);
  padding: 20px 22px;
  background: repeating-linear-gradient(
    -45deg,
    var(--surface-2) 0 8px,
    var(--bg) 8px 16px
  );
  color: var(--mute);
}
.k-locked-badge {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-size: var(--t-eyebrow);
  font-weight: var(--w-semibold);
  letter-spacing: var(--tr-eyebrow);
  text-transform: uppercase;
  color: var(--mute);
}
.k-locked-badge::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--mute-2);
}


/* ============================================================
   MOLECULES
   ============================================================ */

/* Field */
.k-field { display: flex; flex-direction: column; gap: var(--s-1); }
.k-field-label {
  font-size: var(--t-eyebrow);
  font-weight: var(--w-semibold);
  letter-spacing: var(--tr-eyebrow);
  text-transform: uppercase;
  color: var(--mute);
}
.k-field-help { font-size: var(--t-meta); color: var(--mute); }
.k-field-help.is-error { color: var(--danger); }

/* Tabs */
.k-tabs {
  display: flex;
  gap: 2px;
  border-bottom: 1px solid var(--line);
}
.k-tab {
  position: relative;
  padding: 10px 14px;
  font-size: var(--t-body-sm);
  font-weight: var(--w-medium);
  color: var(--mute);
  cursor: pointer;
}
.k-tab:hover { color: var(--ink); }
.k-tab.is-active { color: var(--ink); font-weight: var(--w-semibold); }
.k-tab.is-active::after {
  content: ""; position: absolute;
  left: 8px; right: 8px; bottom: -1px;
  height: 2px; border-radius: 2px;
  background: var(--m-mod, var(--ink));
}
.k-tab-count {
  margin-left: 6px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--mute-2);
  font-variant-numeric: tabular-nums;
}

/* Segmented control */
.k-seg {
  display: inline-flex;
  padding: 3px;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
}
.k-seg button {
  height: 26px;
  padding: 0 12px;
  border: 0;
  background: transparent;
  font: inherit;
  font-size: var(--t-meta);
  font-weight: var(--w-medium);
  color: var(--mute);
  border-radius: 5px;
  cursor: pointer;
  transition: background var(--m-2) var(--ease-out), color var(--m-2) var(--ease-out);
}
.k-seg button:hover { color: var(--ink); }
.k-seg button.is-on {
  background: var(--surface);
  color: var(--ink);
  box-shadow: var(--z-1);
}

/* Search */
.k-search {
  display: flex; align-items: center; gap: var(--s-2);
  height: 32px; padding: 0 12px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  font-size: var(--t-body-sm);
  color: var(--mute);
  min-width: 280px;
  max-width: 480px;
  flex: 1;
}
.k-search .k-kbd { margin-left: auto; }

/* Crumb */
.k-crumb {
  font-size: var(--t-meta);
  color: var(--mute);
  letter-spacing: 0.02em;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.k-crumb-sep { color: var(--mute-2); }

/* KPI tile */
.k-kpi {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: var(--s-4) var(--s-5);
  display: flex; flex-direction: column; gap: var(--s-1);
  min-height: 92px;
  box-shadow: var(--z-1);
}
.k-kpi-label {
  font-size: var(--t-eyebrow);
  font-weight: var(--w-semibold);
  letter-spacing: var(--tr-eyebrow);
  text-transform: uppercase;
  color: var(--mute);
}
.k-kpi-value {
  font-size: 26px;
  line-height: 1.1;
  font-weight: var(--w-semibold);
  letter-spacing: var(--tr-tight);
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.k-kpi-foot { font-size: var(--t-meta); color: var(--mute); display: flex; align-items: center; gap: var(--s-1); }
.k-kpi-trend.up   { color: var(--success); }
.k-kpi-trend.down { color: var(--danger); }

/* Confidence meter */
.k-conf { display: inline-flex; align-items: center; gap: var(--s-2); font-size: var(--t-meta); color: var(--mute); }
.k-conf-bars { display: inline-flex; gap: 2px; }
.k-conf-bars span {
  width: 4px; height: 12px;
  border-radius: 1px;
  background: var(--line-strong);
}
.k-conf-bars span.on {
  background: var(--m-mod, var(--accent));
}

/* Approval timeline step */
.k-tl { position: relative; padding-left: 20px; }
.k-tl::before {
  content: ""; position: absolute;
  left: 5px; top: 4px; bottom: 4px;
  width: 1px; background: var(--line);
}
.k-tl-step { position: relative; padding: 0 0 14px 0; }
.k-tl-step::before {
  content: ""; position: absolute;
  left: -16px; top: 4px;
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--bg);
  border: 1.5px solid var(--mute-2);
}
.k-tl-step.is-done::before { background: var(--success); border-color: var(--success); }
.k-tl-step.is-now::before {
  border-color: var(--m-mod, var(--accent));
  box-shadow: 0 0 0 3px rgba(46,91,255,0.18);
}
.k-tl-who  { font-size: var(--t-body-sm); color: var(--ink); }
.k-tl-meta { font-size: var(--t-meta); color: var(--mute); margin-top: 2px; }


/* ============================================================
   ORGANISMS
   ============================================================ */

/* Card · base */
.k-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: var(--z-1);
  padding: var(--s-5) var(--s-6);
}
.k-card-flat   { box-shadow: none; }
.k-card-tight  { padding: var(--s-3) var(--s-4); }

/* StatusBadge (organism — semantic with icon) */
.k-status-badge {
  display: inline-flex; align-items: center; gap: var(--s-2);
  height: 22px; padding: 0 10px;
  border-radius: var(--r-pill);
  font-size: var(--t-meta);
  font-weight: var(--w-semibold);
  letter-spacing: 0.02em;
}
.k-status-badge .k-status-dot { width: 6px; height: 6px; }
.k-status-badge.is-verified {
  color: var(--success); background: var(--success-soft); border: 1px solid var(--success-line);
}
.k-status-badge.is-pending {
  color: var(--warn); background: var(--warn-soft); border: 1px solid var(--warn-line);
}
.k-status-badge.is-failed {
  color: var(--danger); background: var(--danger-soft); border: 1px solid var(--danger-line);
}
.k-status-badge.is-drift {
  color: var(--mute); background: var(--surface-2); border: 1px solid var(--line);
}

/* VerificationLayer (organism — provenance row at top of DecisionCard) */
.k-verify {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-size: var(--t-meta);
  font-weight: var(--w-semibold);
  letter-spacing: 0.04em;
  color: var(--success);
}
.k-verify::before {
  content: "";
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--success-soft);
  border: 1px solid var(--success-line);
  background-image: radial-gradient(circle, var(--success) 2.5px, transparent 3px);
}

/* RunBadge — molecule pointer to a Run */
.k-run-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--mute);
  letter-spacing: 0;
}

/* DecisionCard (the signature organism) */
.k-decision {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: var(--z-2);
  position: relative;
  padding: var(--s-5) var(--s-6) var(--s-4);
  overflow: hidden;
}
.k-decision::before {
  /* 2-px module stripe — encodes provenance */
  content: ""; position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 2px;
  background: var(--m-mod, var(--ink));
}
.k-decision-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: var(--s-4); margin-bottom: var(--s-3);
}
.k-decision-head-meta {
  display: inline-flex; align-items: center; gap: var(--s-3); flex-wrap: wrap;
}
.k-decision-title {
  font-size: var(--t-h1); line-height: var(--lh-h1);
  font-weight: var(--w-semibold);
  letter-spacing: var(--tr-tight);
  color: var(--ink);
  margin: var(--s-2) 0 0;
}
.k-decision-reason {
  font-size: var(--t-body);
  color: var(--ink-2);
  line-height: 1.55;
  margin: var(--s-3) 0;
  max-width: 64ch;
}
.k-decision-stats {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--line-2);
  margin-top: var(--s-3);
}
.k-decision-stat {
  padding: var(--s-3) var(--s-4) 0 0;
  border-right: 1px solid var(--line-2);
}
.k-decision-stat:last-child { border-right: 0; padding-right: 0; }
.k-decision-stat-label {
  font-size: var(--t-eyebrow);
  font-weight: var(--w-semibold);
  letter-spacing: var(--tr-eyebrow);
  text-transform: uppercase;
  color: var(--mute);
}
.k-decision-stat-value {
  font-size: 19px;
  font-weight: var(--w-semibold);
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
  margin-top: 4px;
  color: var(--ink);
}
.k-decision-stat-value.is-success { color: var(--success); }
.k-decision-stat-value.is-danger  { color: var(--danger); }
.k-decision-foot {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: var(--s-4);
  padding-top: var(--s-3);
  border-top: 1px solid var(--line-2);
  gap: var(--s-4);
}
.k-decision-foot-left  { display: flex; align-items: center; gap: var(--s-2); flex-wrap: wrap; }
.k-decision-foot-right { display: flex; align-items: center; gap: var(--s-2); }


/* ============================================================
   SHELL — TopBar · Rail · PageHead
   ============================================================ */
.k-shell {
  position: absolute; inset: 0;
  display: grid;
  grid-template-rows: var(--top-h) 1fr;
  grid-template-columns: var(--rail-w) 1fr;
  background: var(--bg);
}
.k-shell-top  { grid-column: 1 / -1; }
.k-shell-rail { grid-row: 2; }
/* Vertical scroll when a page is taller than the viewport. Most module
   pages (HOME, /approvals, /vault, /price, /orbit) stack DecisionCards
   and overflow on smaller viewports. Pages that manage their own
   internal scroll (e.g. KRAFT studio chat thread, MONITOR run table)
   still work because they declare `height: 100%` and never push the
   shell past its grid-cell height — the shell scrollbar stays idle. */
.k-shell-main { grid-row: 2; overflow-y: auto; overflow-x: hidden; padding: var(--s-6) var(--s-7); }

.k-topbar {
  display: flex; align-items: center; gap: var(--s-4);
  padding: 0 var(--s-5);
  border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,0.86);
  backdrop-filter: blur(6px);
}
.k-brand {
  display: flex; align-items: center; gap: var(--s-2);
  width: calc(var(--rail-w) - var(--s-5));
}
.k-brand-mark {
  width: 26px; height: 26px;
  border-radius: 6px;
  background: var(--ink);
  color: #fff;
  display: grid; place-items: center;
  font-weight: var(--w-bold);
  font-size: 13px;
  letter-spacing: -0.02em;
}
.k-brand-name {
  font-weight: var(--w-semibold);
  font-size: var(--t-body-sm);
  letter-spacing: 0.04em;
  color: var(--ink);
}
.k-brand-tenant { font-size: var(--t-meta); color: var(--mute); }

.k-rail {
  border-right: 1px solid var(--line);
  background: var(--bg);
  padding: var(--s-3) var(--s-2);
  display: flex; flex-direction: column;
  gap: 1px;
}
.k-rail-section {
  font-size: var(--t-eyebrow);
  font-weight: var(--w-semibold);
  letter-spacing: var(--tr-eyebrow);
  text-transform: uppercase;
  color: var(--mute-2);
  padding: var(--s-4) var(--s-3) var(--s-1);
}
.k-nav {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 10px;
  border-radius: var(--r-sm);
  font-size: var(--t-body-sm);
  font-weight: var(--w-medium);
  color: var(--ink-3);
  position: relative;
  cursor: pointer;
  transition: background var(--m-1) var(--ease-out), color var(--m-1) var(--ease-out);
}
.k-nav:hover { background: var(--surface-2); color: var(--ink); }
.k-nav.is-active {
  background: var(--surface);
  color: var(--ink);
  box-shadow: var(--z-1);
}
.k-nav.is-active::before {
  content: ""; position: absolute;
  left: -10px; top: 12px; bottom: 12px;
  width: 2px; border-radius: 2px;
  background: var(--m-mod, var(--ink));
}
.k-nav-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--m-mod, var(--mute-2));
  flex-shrink: 0;
}
.k-nav-count {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--mute);
  font-variant-numeric: tabular-nums;
}

.k-pagehead {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: var(--s-6);
  margin-bottom: var(--s-6);
}
.k-pagehead-actions { display: flex; align-items: center; gap: var(--s-2); }


/* ============================================================
   AVATAR MENU — dropdown from top bar avatar
   ============================================================ */
.k-avatar-menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 260px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: var(--z-3);
  padding: 12px 0;
  z-index: 30;
  animation: k-fade-down var(--m-2) var(--ease-out);
}
@keyframes k-fade-down {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.k-avatar-menu-head {
  display: flex; align-items: center; gap: 10px;
  padding: 4px 16px 12px;
}
.k-avatar-menu-chip {
  margin: 0 16px;
  padding: 8px 10px;
  background: var(--success-soft);
  border: 1px solid var(--success-line);
  border-radius: var(--r-sm);
  display: flex; align-items: center; gap: 8px;
  font-size: var(--t-meta);
  color: var(--success);
  font-weight: var(--w-medium);
}
.k-avatar-menu-sep {
  height: 1px;
  background: var(--line-2);
  margin: 10px 0;
}
.k-avatar-menu-item {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%;
  padding: 8px 16px;
  border: 0;
  background: transparent;
  font: inherit;
  font-size: var(--t-body-sm);
  color: var(--ink-2);
  cursor: pointer;
  text-align: left;
  transition: background var(--m-1) var(--ease-out);
}
.k-avatar-menu-item:hover { background: var(--surface-2); color: var(--ink); }
.k-avatar-menu-item.is-danger { color: var(--danger); }
.k-avatar-menu-item.is-danger:hover { background: var(--danger-soft); }


/* ============================================================
   FLOW INDICATOR — bottom-left pill showing CEO journey stage
   Helps demos · removable in prod
   ============================================================ */
.k-flow-indicator {
  position: fixed;
  bottom: 16px;
  left: 16px;
  z-index: 70;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px 6px 8px;
  background: rgba(11,13,16,0.92);
  color: #ECEEF1;
  border-radius: 999px;
  font-size: 11px;
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
  box-shadow: var(--z-3);
  user-select: none;
}
.k-flow-step {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 2px 8px;
  border-radius: 999px;
  color: rgba(255,255,255,0.5);
  font-weight: 500;
}
.k-flow-step.is-on {
  background: rgba(255,255,255,0.12);
  color: #fff;
}
.k-flow-step.is-done {
  color: rgba(255,255,255,0.7);
}
.k-flow-sep {
  color: rgba(255,255,255,0.28);
}
