
    /* ─────────────────  TOKENS  ───────────────── */
    :root[data-theme="dark"] {
      --bg:            #0b0d0c;
      --bg-1:          #101312;
      --bg-2:          #14181a;          /* card */
      --bg-3:          #181d1f;          /* inset */
      --bg-hover:      #1a2120;
      --line:          #1f2624;
      --line-strong:   #2a3331;
      --text:          #e8ecea;
      --text-2:        #b6bdba;
      --text-3:        #7d8784;
      --text-4:        #555d5b;
      --accent:        oklch(0.74 0.14 245);
      --accent-ink:    #07101e;
      --accent-soft:   color-mix(in oklab, var(--accent) 14%, transparent);
      --accent-line:   color-mix(in oklab, var(--accent) 38%, transparent);
      --accent-glow:   color-mix(in oklab, var(--accent) 28%, transparent);
      --danger:        oklch(0.70 0.17 25);
      --danger-soft:   color-mix(in oklab, var(--danger) 16%, transparent);
      --danger-line:   rgba(239,93,82,.34);
      --warn:          oklch(0.78 0.15 75);
      --good:          #10b981;
      --brand-cyan:    #06b6d4;
      --brand-blue:    #3b82f6;
      --brand-violet:  #8b5cf6;
      --radius:        12px;
      --shadow-sm:     0 1px 0 rgba(255,255,255,0.02) inset, 0 1px 2px rgba(0,0,0,0.4);
      --shadow-md:     0 1px 0 rgba(255,255,255,0.03) inset, 0 8px 24px -12px rgba(0,0,0,0.7);
      --shadow-lg:     0 24px 60px -20px rgba(0,0,0,0.85), 0 8px 16px -8px rgba(0,0,0,0.6);
      --ring:          0 0 0 3px color-mix(in oklab, var(--accent) 22%, transparent);
      --modal-scrim:   rgba(2,5,4,0.72);
    }
    :root[data-theme="light"] {
      --bg:            #f6f5f1;          /* warm paper */
      --bg-1:          #fbfaf6;
      --bg-2:          #ffffff;          /* card */
      --bg-3:          #f1efe8;          /* inset */
      --bg-hover:      #f0eee6;
      --line:          #e6e3d8;
      --line-strong:   #d3cebf;
      --text:          #1b1f1d;
      --text-2:        #4b524f;
      --text-3:        #767d79;
      --text-4:        #9aa19d;
      --accent:        oklch(0.52 0.16 252);
      --accent-ink:    #ffffff;
      --accent-soft:   color-mix(in oklab, var(--accent) 10%, transparent);
      --accent-line:   color-mix(in oklab, var(--accent) 30%, transparent);
      --accent-glow:   color-mix(in oklab, var(--accent) 22%, transparent);
      --danger:        oklch(0.55 0.18 25);
      --danger-soft:   color-mix(in oklab, var(--danger) 10%, transparent);
      --danger-line:   rgba(214,69,59,.26);
      --warn:          oklch(0.62 0.15 65);
      --shadow-sm:     0 1px 2px rgba(20,30,25,0.05);
      --shadow-md:     0 1px 2px rgba(20,30,25,0.04), 0 8px 24px -16px rgba(20,30,25,0.18);
      --shadow-lg:     0 24px 60px -28px rgba(20,30,25,0.28), 0 8px 16px -8px rgba(20,30,25,0.10);
      --ring:          0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent);
      --modal-scrim:   rgba(20,25,22,0.32);
      --brand-cyan:    #06b6d4;
      --brand-blue:    #3b82f6;
      --brand-violet:  #8b5cf6;
      --good:          #10b981;
    }

    /* ─── DESIGN PRIMITIVES (from design-merge/tokens.css) ─── */
    .brandmark { display: inline-flex; gap: 3px; align-items: center; }
    .brandmark i { width: 4px; height: 17px; border-radius: 2px; display: block; }
    .brandmark i:nth-child(1) { background: var(--brand-cyan); }
    .brandmark i:nth-child(2) { background: var(--brand-blue); }
    .brandmark i:nth-child(3) { background: var(--brand-violet); }

    /* cv-flash: brief highlight pulse applied when cvHome routes user to a specific
       Settings row (e.g. clicking Fireflies card on connect-state hero). Auto-removed
       after ~5.5s by JS; keep 3-pulse animation roughly aligned with that. */
    .cv-flash { animation: cv-flash-pulse 1.8s ease-out 3; box-shadow: 0 0 0 2px var(--accent), 0 0 28px var(--accent-glow); border-radius: 12px; position: relative; z-index: 2; }
    @keyframes cv-flash-pulse { 0%,100% { box-shadow: 0 0 0 2px var(--accent), 0 0 28px var(--accent-glow); } 50% { box-shadow: 0 0 0 4px var(--accent), 0 0 44px var(--accent-glow); } }

    .btn {
      font-family: inherit; font-size: 13px; font-weight: 600;
      border-radius: 9px; padding: 10px 16px;
      border: 1px solid var(--line-strong);
      background: var(--bg-2); color: var(--text-2); cursor: pointer;
      transition: transform .14s cubic-bezier(.2,.7,.3,1.4),
                  border-color .16s, color .16s, background .16s;
      white-space: nowrap;
    }
    .btn:hover { border-color: var(--accent-line); color: var(--text); }
    .btn:active { transform: scale(.97); }
    .btn-primary {
      background: var(--accent); color: var(--accent-ink);
      border-color: transparent;
      box-shadow: 0 8px 20px -10px var(--accent-glow);
    }
    .btn-primary:hover { filter: brightness(1.07); color: var(--accent-ink); }
    .btn-danger {
      color: var(--danger); border-color: var(--danger-line);
      background: transparent;
    }
    .btn-danger:hover { background: var(--danger-soft); color: var(--danger); }

    .input {
      width: 100%; padding: 11px 13px;
      border: 1px solid var(--line-strong); border-radius: 9px;
      background: var(--bg-3); color: var(--text);
      font-family: inherit; font-size: 14px; outline: none;
      transition: border-color .16s, box-shadow .16s;
    }
    .input::placeholder { color: var(--text-4); }
    .input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
    textarea.input { resize: vertical; min-height: 88px; line-height: 1.55; }

    .lock {
      display: inline-flex; align-items: center; gap: 5px;
      font-size: 10px; font-weight: 700; letter-spacing: .04em;
      text-transform: uppercase; color: var(--warn);
      background: rgba(233,162,60,.12);
      border: 1px solid rgba(233,162,60,.3);
      border-radius: 999px; padding: 3px 8px;
    }

    .meter {
      height: 7px; border-radius: 999px;
      background: var(--bg-3); overflow: hidden;
    }
    .meter > span {
      display: block; height: 100%; border-radius: 999px;
      background: var(--accent);
    }

    .eyebrow {
      font-size: 11px; font-weight: 700;
      letter-spacing: .09em; text-transform: uppercase;
      color: var(--text-3);
    }

    * { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }
    html, body {
      height: 100%; width: 100%;
      font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'Segoe UI', sans-serif;
      font-size: 14px; line-height: 1.5;
      color: var(--text); background: var(--bg);
      overflow: hidden;
      font-feature-settings: "cv11","ss01","ss03";
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      transition: background 240ms ease, color 240ms ease;
    }
    body { display: flex; flex-direction: column; padding-top: env(safe-area-inset-top); padding-bottom: env(safe-area-inset-bottom); position: relative; }
    .mono { font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace; font-feature-settings: "ss01"; }

    /* page background — subtle radial wash, more visible in dark */
    body::before {
      content: ""; position: fixed; inset: 0;
      background:
        radial-gradient(900px 480px at 80% -10%, color-mix(in oklab, var(--accent) 8%, transparent), transparent 60%),
        radial-gradient(700px 420px at -10% 110%, color-mix(in oklab, var(--accent) 5%, transparent), transparent 65%);
      pointer-events: none; z-index: 0;
      transition: opacity 240ms ease;
    }
    :root[data-theme="light"] body::before { opacity: 0.55; }

    #mainView { position: relative; z-index: 1; display: flex; flex-direction: column; height: 100%; }

    /* ─────────────────  HEADER  ───────────────── */
    .header {
      background: color-mix(in oklab, var(--bg-1) 90%, transparent);
      backdrop-filter: saturate(140%) blur(10px);
      -webkit-backdrop-filter: saturate(140%) blur(10px);
      padding: 12px 16px; display: flex; align-items: center; gap: 12px;
      flex-shrink: 0; border-bottom: 1px solid var(--line);
    }
    .brand { display: flex; align-items: center; min-width: 0; position: relative; }
    .brand-name {
      display: inline-flex; align-items: center; gap: 5px;
      font-size: 15px; font-weight: 700; color: var(--text); letter-spacing: -0.015em;
      margin: 0;
    }
    .brand-mark {
      display: inline-flex; align-items: center; justify-content: center;
      flex-shrink: 0;
    }
    .brand-mark svg { width: 18px; height: 18px; display: block; }
    .header h1 {
      font-size: 15px; font-weight: 700; color: var(--text); letter-spacing: -0.015em;
    }
    .status-pill {
      display: inline-flex; align-items: center; gap: 8px;
      padding: 4px 10px 4px 8px;
      border: 1px solid var(--line); border-radius: 999px;
      background: var(--bg-2);
      font-size: 11px; font-weight: 600; color: var(--text-3);
      letter-spacing: 0.01em;
    }
    .dot {
      position: relative; width: 8px; height: 8px; border-radius: 50%;
      background: var(--text-4); flex-shrink: 0;
      transition: background 200ms ease, box-shadow 200ms ease;
    }
    .dot.live      { background: var(--accent);  box-shadow: 0 0 0 3px var(--accent-glow); }
    .dot.connecting{ background: var(--warn);    box-shadow: 0 0 0 3px color-mix(in oklab, var(--warn) 28%, transparent); }
    .dot.error     { background: var(--danger);  box-shadow: 0 0 0 3px color-mix(in oklab, var(--danger) 28%, transparent); }
    .dot.analyzing { background: var(--accent);  box-shadow: 0 0 0 3px var(--accent-glow); }
    .dot.live::after, .dot.connecting::after, .dot.analyzing::after {
      content: ""; position: absolute; inset: -3px; border-radius: 50%;
      border: 1px solid currentColor; color: var(--accent); opacity: 0.6;
      animation: ring 1.8s ease-out infinite;
    }
    .dot.connecting::after { color: var(--warn); animation-duration: 1.1s; }
    @keyframes ring { 0%{transform:scale(0.6);opacity:.7} 100%{transform:scale(2.2);opacity:0} }

    .header-btns { margin-left: auto; display: flex; gap: 6px; align-items: center; }
    .hbtn {
      padding: 7px 13px; border: 1px solid var(--line-strong); border-radius: 8px;
      background: var(--bg-2); color: var(--text-2);
      font-family: inherit; font-size: 12px; font-weight: 600; letter-spacing: 0.005em;
      white-space: nowrap;
      cursor: pointer;
      transition: transform 140ms cubic-bezier(.2,.7,.3,1.4), background 160ms ease, border-color 160ms ease, color 160ms ease, box-shadow 160ms ease;
    }
    .hbtn:hover { border-color: var(--accent-line); color: var(--text); }
    .hbtn:active { transform: scale(0.96); }
    .hbtn .hbtn-plus { display: inline-block; font-size: 1.35em; font-weight: 800; color: var(--accent); line-height: 1; vertical-align: -1px; margin-right: 2px; }
    .nt-key-list { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
    .nt-key-row { display: flex; align-items: center; gap: 8px; padding: 8px 10px; border: 1px solid var(--line); border-radius: 6px; background: var(--bg-3); cursor: pointer; user-select: none; }
    .nt-key-row:hover { border-color: var(--accent-line); }
    .nt-key-row input { margin: 0; cursor: pointer; }
    .nt-key-row .nt-key-name { flex: 1; font-size: 13px; color: var(--text); }
    .nt-key-row .nt-key-default-tag { font-size: 10px; color: var(--accent); font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; }
    .key-default-label { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--text-3); margin: 4px 0 6px; cursor: pointer; user-select: none; }
    .key-default-label input { margin: 0; cursor: pointer; }
    .key-default-label.is-default { color: var(--accent); font-weight: 600; }
    .hbtn:focus-visible { outline: none; box-shadow: var(--ring); }
    /* ─────────────────  EMPTY-STATE INLINE ACTION BUTTONS  ───────────────── */
    .empty-copy { display: flex; flex-direction: column; gap: 6px; }
    .empty-line {
      display: flex; flex-wrap: wrap; align-items: center;
      gap: 4px; row-gap: 6px;
      font-size: 13px; color: var(--text-2); line-height: 1.5;
    }
    .empty-line-text { white-space: pre-wrap; }
    .hbtn.hbtn--inline {
      padding: 4px 9px;
      font-size: 12px;
      border-radius: 6px;
      vertical-align: middle;
      display: inline-flex; align-items: center; gap: 3px;
    }
    .hbtn.hbtn--inline::before { display: none; }
    .hbtn.hbtn--inline .hbtn-plus { font-size: 1.25em; margin-right: 1px; }
    .hbtn.hbtn--inline .hbtn--inline-gear {
      width: 11px; height: 11px; display: block;
    }
    @media(max-width:600px){
      .hbtn.hbtn--inline { padding: 6px 10px; font-size: 10px; border-radius: 5px; min-height: 32px; }
      .hbtn.hbtn--inline .hbtn--inline-gear { width: 10px; height: 10px; }
      .empty-line { font-size: 12px; }
    }
    .hbtn.active-btn {
      background: var(--accent-soft); color: var(--accent);
      border-color: var(--accent-line);
    }
    .hbtn.danger-active {
      background: var(--danger); color: #fff;
      border-color: var(--danger);
    }
    .hbtn.icon { padding: 6px 9px; font-size: 14px; }
    .icon-btn {
      width: 30px; height: 30px; display: grid; place-items: center;
      padding: 0; border: 1px solid var(--line-strong); border-radius: 8px;
      background: var(--bg-2); color: var(--text-2); cursor: pointer;
      transition: transform 140ms cubic-bezier(.2,.7,.3,1.4), background 160ms ease, border-color 160ms ease, color 160ms ease;
    }
    .icon-btn:hover { color: var(--text); border-color: var(--accent-line); }
    .icon-btn:active { transform: scale(0.93); }
    .icon-btn svg { width: 14px; height: 14px; display: block; }

    /* ─────────────────  STATUS + STATS  ───────────────── */
    .status-bar {
      padding: 7px 16px; font-size: 11px; color: var(--text-3);
      background: var(--bg-1); border-bottom: 1px solid var(--line); flex-shrink: 0;
      letter-spacing: 0.005em;
      display: flex; align-items: center; gap: 8px;
    }
    .status-bar #statusIcon { display: none; flex-shrink: 0; }
    .status-bar.is-loading { color: var(--accent); }
    .status-bar.is-loading #statusIcon { display: inline-flex; align-items: center; }
    .hourglass {
      display: inline-block; width: 12px; height: 14px; position: relative;
      animation: hgFlip 1.6s cubic-bezier(.55,.05,.45,.95) infinite;
    }
    .hourglass::before, .hourglass::after {
      content: ""; position: absolute; left: 0; right: 0;
      border-left: 6px solid transparent; border-right: 6px solid transparent;
    }
    .hourglass::before {
      top: 0; border-top: 7px solid currentColor;
    }
    .hourglass::after {
      bottom: 0; border-bottom: 7px solid currentColor;
    }
    @keyframes hgFlip {
      0%, 45%   { transform: rotate(0deg); }
      55%, 100% { transform: rotate(180deg); }
    }
    .status-bar .hg-sand {
      display: inline-block; width: 4px; height: 4px;
      border-radius: 50%; background: currentColor;
      margin-left: 4px; opacity: 0.7;
      animation: hgSand 1.6s ease-in-out infinite;
    }
    @keyframes hgSand {
      0%, 100% { transform: translateY(-2px); opacity: 0.3; }
      50%      { transform: translateY(2px);  opacity: 1; }
    }

    /* History button — pinned top-right of chat/auto-analysis tab content */
    .history-fab {
      position: absolute; top: 12px; right: 16px; z-index: 6;
      display: none; align-items: center; gap: 7px;
      padding: 7px 12px 7px 10px;
      background: var(--bg-1); color: var(--text-2);
      border: 1px solid var(--line-strong); border-radius: 999px;
      font-family: inherit; font-size: 11px; font-weight: 700;
      letter-spacing: 0.04em; text-transform: uppercase;
      cursor: pointer;
      box-shadow: var(--shadow-md);
      backdrop-filter: blur(8px);
      transition: color 160ms ease, border-color 160ms ease, background 160ms ease, transform 140ms cubic-bezier(.2,.7,.3,1.4);
    }
    .history-fab.visible { display: inline-flex; }
    .history-fab:hover { color: var(--accent); border-color: var(--accent-line); background: var(--accent-soft); }
    .history-fab:active { transform: scale(0.95); }
    .history-fab svg { width: 12px; height: 12px; }
    .history-fab .h-count {
      background: var(--accent); color: var(--accent-ink);
      padding: 1px 7px; border-radius: 999px;
      font-size: 10px; font-weight: 800;
      font-variant-numeric: tabular-nums;
    }

    /* Context usage pill — sits LEFT of history fab (history fab is the rightmost anchor).
       Width allowance: history-fab is up to ~130px including the count badge, plus 8px gap. */
    .ctx-pill {
      position: absolute; top: 12px; right: calc(16px + 130px + 8px); z-index: 6;
      display: none; align-items: center; gap: 6px;
      padding: 7px 10px;
      background: var(--bg-1); color: var(--text-3);
      border: 1px solid var(--line-strong); border-radius: 999px;
      font-family: inherit; font-size: 10px; font-weight: 700;
      letter-spacing: 0.02em;
      cursor: pointer;
      box-shadow: var(--shadow-md);
      backdrop-filter: blur(8px);
      transition: color 160ms ease, border-color 160ms ease, background 160ms ease, transform 140ms cubic-bezier(.2,.7,.3,1.4);
    }
    .ctx-pill.visible { display: inline-flex; }
    .ctx-pill:hover { color: var(--text); border-color: var(--accent-line); }
    .ctx-pill:active { transform: scale(0.95); }
    .ctx-bar-track {
      width: 40px; height: 5px; border-radius: 999px;
      background: var(--bg-3); overflow: hidden;
    }
    .ctx-bar-fill {
      height: 100%; border-radius: 999px;
      background: var(--accent);
      transition: width 400ms ease, background 400ms ease;
    }
    .ctx-pill.warn .ctx-bar-fill { background: var(--warn); }
    .ctx-pill.danger .ctx-bar-fill { background: var(--danger); }
    .ctx-pill.warn { color: var(--warn); border-color: color-mix(in oklab, var(--warn) 40%, transparent); }
    .ctx-pill.danger { color: var(--danger); border-color: color-mix(in oklab, var(--danger) 40%, transparent); }

    /* History modal */
    .history-modal {
      position: absolute; inset: 0; z-index: 200;
      background: var(--modal-scrim);
      display: none; align-items: stretch; justify-content: center;
      animation: pageIn 180ms cubic-bezier(.2,.7,.2,1);
    }
    .history-modal.open { display: flex; }
    .history-sheet {
      margin: auto; width: min(640px, calc(100% - 24px));
      max-height: calc(100% - 48px);
      background: var(--bg-1); border: 1px solid var(--line);
      border-radius: 14px; box-shadow: var(--shadow-lg);
      display: flex; flex-direction: column; overflow: hidden;
    }
    .history-head {
      display: flex; align-items: center; gap: 10px;
      padding: 14px 16px; border-bottom: 1px solid var(--line);
      background: var(--bg-2);
    }
    .history-head h3 { font-size: 14px; font-weight: 700; color: var(--text); flex: 1; letter-spacing: -0.005em; }
    .history-head .h-meta { font-size: 11px; color: var(--text-3); }
    .history-close {
      background: transparent; border: 1px solid var(--line-strong);
      width: 28px; height: 28px; border-radius: 7px;
      color: var(--text-2); cursor: pointer;
      display: grid; place-items: center; font-size: 14px;
    }
    .history-close:hover { color: var(--danger); border-color: var(--danger); }
    .history-body { flex: 1; overflow-y: auto; padding: 14px 16px; }
    .history-empty { color: var(--text-3); text-align: center; padding: 40px 20px; font-size: 13px; }
    .h-item {
      background: var(--bg-2); border: 1px solid var(--line);
      border-radius: 10px; padding: 12px 14px; margin-bottom: 10px;
      cursor: pointer;
      transition: border-color 160ms ease, transform 140ms cubic-bezier(.2,.7,.3,1.4);
    }
    .h-item:hover { border-color: var(--accent-line); transform: translateY(-1px); }
    .h-item-top {
      display: flex; align-items: center; gap: 8px;
      margin-bottom: 6px;
    }
    .h-item-kind {
      font-size: 10px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase;
      color: var(--accent); padding: 2px 8px;
      background: var(--accent-soft); border: 1px solid var(--accent-line);
      border-radius: 999px;
    }
    .h-item-time { font-size: 10px; color: var(--text-4); font-family: 'JetBrains Mono', monospace; margin-left: auto; }
    .h-item-preview {
      font-size: 13px; color: var(--text-2); line-height: 1.5;
      display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
      overflow: hidden;
    }
    .h-item-detail {
      display: none;
      font-size: 14px; color: var(--text); line-height: 1.65;
      padding-top: 10px; margin-top: 8px;
      border-top: 1px dashed var(--line);
      white-space: pre-wrap;
    }
    .h-item.expanded .h-item-detail { display: block; }
    .h-item.expanded .h-item-preview { display: none; }

    /* When history fab is visible, push tab content slightly so they don't collide.
       Only apply at widths where the controls have room — at narrow widths the
       fab sits above the controls naturally. */
    @media(min-width:560px){
      .content-pane-wrap.has-fab .auto-analysis-controls { padding-right: 110px; }
    }
    .content-pane-wrap.has-fab .content-area { padding-top: 14px; }

    /* Scroll-to-latest pill (chat) — centered above the bottom bar so it never blends with Send */
    .scroll-to-latest {
      position: absolute; left: 50%; right: auto; bottom: 12px;
      transform: translateX(-50%) translateY(8px);
      display: inline-flex; align-items: center; gap: 5px;
      padding: 5px 12px 5px 10px;
      background: color-mix(in oklab, var(--bg-1) 92%, transparent);
      color: var(--accent);
      border: 1px solid var(--accent-line);
      border-radius: 999px;
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
      font-family: inherit; font-size: 11px; font-weight: 700;
      letter-spacing: 0.01em; cursor: pointer;
      box-shadow:
        0 0 0 1px color-mix(in oklab, var(--accent) 20%, transparent),
        0 18px 36px -14px rgba(0,0,0,0.6),
        0 6px 16px -8px var(--accent-glow);
      opacity: 0; pointer-events: none;
      transition: opacity 200ms ease, transform 220ms cubic-bezier(.2,.7,.3,1.4), filter 160ms ease, background 160ms ease;
      z-index: 5;
    }
    .scroll-to-latest.visible {
      opacity: 1; pointer-events: auto;
      transform: translateX(-50%) translateY(0);
    }
    .scroll-to-latest:hover {
      filter: brightness(1.04);
      background: color-mix(in oklab, var(--accent-soft) 80%, var(--bg-1));
      transform: translateX(-50%) translateY(-2px);
    }
    .scroll-to-latest:active { transform: translateX(-50%) translateY(0) scale(0.96); }
    .scroll-to-latest svg { width: 12px; height: 12px; transition: transform 200ms cubic-bezier(.2,.7,.3,1.4); }
    .scroll-to-latest.is-up svg { transform: rotate(180deg); }
    .scroll-to-latest .stl-pulse {
      width: 5px; height: 5px; border-radius: 50%;
      background: currentColor; opacity: 0.9;
      animation: stlPulse 1.2s ease-in-out infinite;
    }
    @keyframes stlPulse {
      0%, 100% { transform: scale(0.7); opacity: 0.5; }
      50%      { transform: scale(1.1); opacity: 1; }
    }

    /* Jump-to-top pill — CENTERED at top on desktop (≥600px viewport, where the
       gap between the brand and the right-anchored ctx-pill+history-fab leaves
       room to center). On phones <600px the centered position would collide
       with those pills, so the mobile media-query below switches to left-anchor. */
    .jump-to-top {
      position: absolute; left: 50%; right: auto; top: 12px;
      transform: translateX(-50%) translateY(-8px);
      display: inline-flex; align-items: center; gap: 6px;
      padding: 5px 12px 5px 10px;
      background: color-mix(in oklab, var(--bg-1) 92%, transparent);
      color: var(--accent);
      border: 1px solid var(--accent-line);
      border-radius: 999px;
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
      font-family: inherit; font-size: 11px; font-weight: 700;
      letter-spacing: 0.01em; cursor: pointer;
      box-shadow:
        0 0 0 1px color-mix(in oklab, var(--accent) 20%, transparent),
        0 18px 36px -14px rgba(0,0,0,0.6),
        0 6px 16px -8px var(--accent-glow);
      opacity: 0; pointer-events: none;
      transition: opacity 200ms ease, transform 220ms cubic-bezier(.2,.7,.3,1.4), filter 160ms ease, background 160ms ease;
      z-index: 5;
    }
    .jump-to-top.visible {
      opacity: 1; pointer-events: auto;
      transform: translateX(-50%) translateY(0);
    }
    .jump-to-top:hover {
      filter: brightness(1.04);
      background: color-mix(in oklab, var(--accent-soft) 80%, var(--bg-1));
      transform: translateX(-50%) translateY(2px);
    }
    .jump-to-top:active { transform: translateX(-50%) translateY(0) scale(0.96); }
    .jump-to-top svg { width: 12px; height: 12px; }

    /* Mobile (<600px): switch Top to LEFT-anchor so it can't collide with the
       right-side pills. All 4 transform variants are overridden to drop the
       translateX(-50%) centering. */
    @media(max-width:600px){
      .jump-to-top { left: 16px; transform: translateY(-8px); }
      .jump-to-top.visible { transform: translateY(0); }
      .jump-to-top:hover { transform: translateY(2px); }
      .jump-to-top:active { transform: translateY(0) scale(0.96); }
    }

    /* Narrow-screen tightening — small phones: drop button labels to icon-only so the
       three top pills (Top / ctx / History) never collide. */
    @media(max-width:480px){
      .jump-to-top { left: 10px; padding: 5px 10px 5px 8px; }
      .jump-to-top span { display: none; }
      /* 128px allowance covers history-fab even with a 3-digit count badge. */
      .ctx-pill { right: calc(10px + 128px + 6px); padding: 6px 8px; }
      .ctx-pill .ctx-bar-track { width: 28px; }
      .history-fab { right: 10px; padding: 6px 10px 6px 9px; }
    }
    .stats-bar {
      display: flex; gap: 18px; padding: 10px 16px;
      border-bottom: 1px solid var(--line); flex-shrink: 0; background: var(--bg-1);
      align-items: center;
    }
    .stat-pill { font-size: 12px; color: var(--text-3); display: inline-flex; align-items: baseline; gap: 5px; }
    .stat-pill .val {
      color: var(--accent); font-weight: 700; font-variant-numeric: tabular-nums;
      font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 13px;
    }
    .stat-pill.muted { color: var(--text-4); }

    /* ─────────────────  TABS  ───────────────── */
    .tabs {
      display: flex; flex-shrink: 0; background: var(--bg);
      border-bottom: 1px solid var(--line);
      position: relative;
    }
    .tab {
      flex: 1; padding: 15px 10px; text-align: center;
      font-size: 12px; font-weight: 600; color: var(--text-3);
      cursor: pointer;
      border-bottom: 2.5px solid transparent;
      transition: color 180ms ease, border-color 180ms ease;
      letter-spacing: 0.01em;
    }
    .tab:hover { color: var(--text-2); }
    .tab.active { color: var(--text); border-bottom-color: var(--accent); }

    /* Data Rooms pill — quiet purple-blue tone matching the tab font, with more
       horizontal padding for prominence. R5 restyle: subtle gradient + thin border
       so it reads as a "different mode" without shouting like the prior bright pill. */
    .tab-spacer { flex: 1; }
    .tab.data-rooms {
      flex: 1;
      padding: 12px 20px !important;
      text-align: center;
      background: linear-gradient(135deg, rgba(59, 130, 246, 0.10) 0%, rgba(139, 92, 246, 0.10) 100%);
      border: 1px solid rgba(139, 92, 246, 0.30);
      border-bottom: 1px solid rgba(139, 92, 246, 0.30);
      border-radius: 6px;
      color: #c7baf5;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      font-weight: 600 !important;
      font-size: 11px !important;
      cursor: pointer;
      position: relative;
      box-shadow: none;
      transition: background 160ms ease, border-color 160ms ease, color 160ms ease, box-shadow 160ms ease;
    }
    .tab.data-rooms::after { display: none !important; }
    .tab.data-rooms:hover {
      background: linear-gradient(135deg, rgba(59, 130, 246, 0.18) 0%, rgba(139, 92, 246, 0.18) 100%);
      border-color: rgba(139, 92, 246, 0.50);
      color: #e8defc;
      box-shadow: 0 0 12px rgba(139, 92, 246, 0.20);
    }
    .tab.data-rooms:active { filter: brightness(0.95); }
    .tab.data-rooms:focus-visible {
      outline: 2px solid rgba(139, 92, 246, 0.60);
      outline-offset: 2px;
    }
    .tab.data-rooms.active {
      border-bottom-color: rgba(139, 92, 246, 0.30);
    }

    /* ─────────────────  DR LAYER — LANDING + OVERLAYS  ─────────────────
       All classes prefixed with cap-dr- to avoid colliding with production. */

    /* Landing overlay (first-visit only) */
    .cap-dr-landing {
      position: fixed; inset: 0; z-index: 9000;
      background: var(--bg);
      display: none;
      align-items: center; justify-content: center;
      padding: 32px 24px;
      animation: capDrFade 220ms ease;
    }
    .cap-dr-landing.is-open { display: flex; }
    .cap-dr-landing-inner {
      width: 100%; max-width: 920px;
      display: flex; flex-direction: column; gap: 28px;
    }
    .cap-dr-landing-title {
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 22px; font-weight: 600; color: var(--text);
      letter-spacing: 0.01em; margin: 0; text-align: center;
    }
    .cap-dr-landing-sub {
      font-size: 12px; color: var(--text-3); text-align: center;
      letter-spacing: 0.06em; text-transform: uppercase; margin: 0;
    }
    .cap-dr-landing-cards {
      display: grid; grid-template-columns: 1fr 1fr; gap: 18px;
    }
    @media (max-width: 640px) {
      .cap-dr-landing-cards { grid-template-columns: 1fr; }
    }
    .cap-dr-landing-card {
      background: linear-gradient(155deg, var(--bg-2) 0%, var(--bg-1) 100%);
      border: 1px solid var(--line);
      border-radius: 10px;
      padding: 22px 20px;
      cursor: pointer;
      display: flex; flex-direction: column; gap: 12px;
      min-height: 200px;
      transition: border-color 160ms ease, background 160ms ease;
    }
    .cap-dr-landing-card:hover {
      border-color: var(--accent-line);
      background: linear-gradient(155deg, var(--bg-2) 0%, var(--bg-hover) 100%);
    }
    .cap-dr-landing-card.dr {
      background: linear-gradient(155deg, rgba(6, 182, 212, 0.10) 0%, var(--bg-1) 100%);
      border-color: rgba(6, 182, 212, 0.30);
    }
    .cap-dr-landing-card.dr:hover {
      background: linear-gradient(155deg, rgba(6, 182, 212, 0.18) 0%, var(--bg-hover) 100%);
      border-color: rgba(6, 182, 212, 0.55);
    }
    .cap-dr-landing-glyph {
      width: 32px; height: 32px; color: var(--accent);
      display: inline-flex; align-items: center; justify-content: center;
    }
    .cap-dr-landing-card.dr .cap-dr-landing-glyph { color: #22d3ee; font-size: 26px; line-height: 1; }
    .cap-dr-landing-card-title {
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 16px; font-weight: 600; color: var(--text); margin: 0;
    }
    .cap-dr-landing-card-desc {
      font-size: 12px; color: var(--text-2); margin: 0; line-height: 1.55;
    }
    .cap-dr-landing-cta {
      margin-top: auto; font-size: 11px; letter-spacing: 0.06em;
      text-transform: uppercase; color: var(--text-3);
      display: inline-flex; align-items: center; gap: 6px;
    }
    .cap-dr-landing-skip {
      position: absolute; bottom: 18px; right: 22px;
      font-size: 11px; color: var(--text-3); cursor: pointer;
      letter-spacing: 0.04em;
      background: none; border: none; padding: 6px 8px;
    }
    .cap-dr-landing-skip:hover { color: var(--text-2); }

    /* DR inline overlay (inside #mainView) — DRA palette ported via overrides */
    .cap-dr-overlay {
      /* DRA palette overrides (spec section 10) */
      --cap-dr-bg:              #000;
      --cap-dr-bg-soft:         #0a0a0a;
      --cap-dr-fg:              #fff;
      --cap-dr-fg-dim:          #aaa;
      --cap-dr-fg-dimmer:       #777;
      --cap-dr-card-bg:         #111;
      --cap-dr-card-border:     #333;
      --cap-dr-card-border-hover:#666;
      --cap-dr-addctx-bg:       #0d0d10;
      --cap-dr-addctx-border:   #2a2a30;
      --cap-dr-accent-blue:     #3b82f6;
      --cap-dr-accent-blue-strong:#2563eb;
      --cap-dr-accent-blue-hover:#1d4ed8;
      --cap-dr-accent-blue-active:#1e40af;

      position: absolute; inset: 0; z-index: 80;
      background: var(--cap-dr-bg);
      color: var(--cap-dr-fg);
      transform: translateY(8px); opacity: 0;
      pointer-events: none;
      transition: opacity 200ms ease, transform 200ms ease;
      display: flex; flex-direction: column;
      overflow: hidden;
    }
    .cap-dr-overlay.is-open { transform: translateY(0); opacity: 1; pointer-events: auto; }
    .cap-dr-overlay-header {
      flex: 0 0 auto;
      display: flex; align-items: center; justify-content: space-between;
      padding: 11px 16px;
      border-bottom: 1px solid var(--cap-dr-card-border);
      background: linear-gradient(90deg, var(--cap-dr-bg) 0%, var(--cap-dr-bg-soft) 100%);
    }
    .cap-dr-overlay-title {
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 22px; font-weight: 700; color: var(--cap-dr-fg);
      letter-spacing: 0.08em; text-transform: uppercase;
      display: flex; align-items: center; gap: 12px;
    }
    .cap-dr-count {
      font-size: 11px; color: var(--cap-dr-fg-dim); font-weight: 500;
      padding: 3px 9px; background: var(--cap-dr-card-bg);
      border: 1px solid var(--cap-dr-card-border);
      border-radius: 999px;
      font-family: 'Roboto Mono', ui-monospace, monospace;
      letter-spacing: 0.04em;
    }
    .cap-dr-hub-hero { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
    .cap-dr-hub-hero-text { min-width: 0; }
    .cap-dr-hub-hero .cap-dr-histbtn { flex-shrink: 0; margin-top: 2px; }
    .cap-dr-histbtn {
      display: inline-flex; align-items: center; gap: 8px;
      font-family: 'Inter', system-ui, sans-serif; font-size: 13px; font-weight: 600;
      color: var(--cap-dr-fg-dim); background: var(--cap-dr-card-bg, #161a20);
      border: 1px solid var(--cap-dr-card-border, #2a3340); border-radius: 10px;
      padding: 8px 12px; cursor: pointer; transition: color .15s, border-color .15s;
    }
    .cap-dr-histbtn:hover { color: var(--cap-dr-fg); border-color: var(--cap-dr-card-border-hover, #3a4656); }
    .cap-dr-histbtn svg { width: 15px; height: 15px; }
    .cap-dr-histbtn-badge { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 10px; color: var(--cap-dr-accent-blue, #4f97f2); background: rgba(79,151,242,.12); border: 1px solid rgba(79,151,242,.4); border-radius: 6px; padding: 1px 6px; }
    .cap-dr-histpop {
      position: fixed; width: 430px; max-width: calc(100vw - 40px); max-height: 70vh;
      display: flex; flex-direction: column; z-index: 200;
      background: linear-gradient(180deg, #111419, #0e1116);
      border: 1px solid #3a4656; border-radius: 15px; box-shadow: 0 30px 80px -30px #000;
      overflow: hidden; opacity: 0; transform: translateY(-6px); pointer-events: none; transition: .16s;
      font-family: 'Inter', system-ui, sans-serif;
    }
    .cap-dr-histpop.open { opacity: 1; transform: none; pointer-events: auto; }
    .cap-dr-histpop .hp-h { padding: 15px 17px 12px; border-bottom: 1px solid #1d242e; display: flex; align-items: center; gap: 9px; }
    .cap-dr-histpop .hp-ti { font-size: 14.5px; font-weight: 700; color: #eef1f4; }
    .cap-dr-histpop .hp-c { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: #5a6470; margin-left: auto; }
    .cap-dr-histpop .hp-scroll { overflow: auto; padding: 8px; }
    .cap-dr-histpop .hp-empty { padding: 30px 18px; text-align: center; color: #5a6470; font-size: 13px; line-height: 1.6; }
    .cap-dr-histpop .hp-item { display: flex; gap: 11px; padding: 11px; border-radius: 11px; cursor: pointer; }
    .cap-dr-histpop .hp-item:hover { background: #161a20; }
    .cap-dr-histpop .hp-ic { width: 34px; height: 34px; border-radius: 9px; flex-shrink: 0; display: grid; place-items: center; font-size: 14px; }
    .cap-dr-histpop .hp-ic.all { background: linear-gradient(140deg, #4f97f2, #8b5cf6); color: #fff; }
    .cap-dr-histpop .hp-ic.proj { background: #0c0f14; border: 1px solid #2a3340; }
    .cap-dr-histpop .hp-m { flex: 1; min-width: 0; }
    .cap-dr-histpop .hp-q { font-size: 13px; font-weight: 600; color: #eef1f4; line-height: 1.35; overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
    .cap-dr-histpop .hp-src { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 7px; }
    .cap-dr-histpop .hp-chip { font-family: 'JetBrains Mono', monospace; font-size: 9.5px; color: #aeb6c2; background: #161a20; border: 1px solid #2a3340; border-radius: 5px; padding: 2px 6px; display: flex; gap: 4px; align-items: center; }
    .cap-dr-histpop .hp-t { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: #5a6470; margin-top: 6px; }

    .cap-dr-overlay-x {
      background: transparent; border: 1px solid #555; color: var(--cap-dr-fg-dim);
      width: 30px; height: 30px; border-radius: 4px; cursor: pointer;
      display: inline-flex; align-items: center; justify-content: center;
      font-size: 14px; line-height: 1;
      transition: background 150ms ease, color 150ms ease, border-color 150ms ease;
    }
    .cap-dr-overlay-x:hover {
      background: var(--cap-dr-fg); color: var(--cap-dr-bg); border-color: var(--cap-dr-fg);
    }
    /* Hub header top-right chrome (theme / settings / account) — mirrors the main app header */
    .cap-dr-overlay-hdr-actions { display: flex; align-items: center; gap: 8px; }
    .cap-dr-hdr-icon {
      background: transparent; border: 1px solid var(--cap-dr-card-border);
      color: var(--cap-dr-fg-dim);
      width: 30px; height: 30px; border-radius: 7px; cursor: pointer;
      display: inline-flex; align-items: center; justify-content: center;
      transition: background 150ms ease, color 150ms ease, border-color 150ms ease;
    }
    .cap-dr-hdr-icon:hover { background: var(--cap-dr-card-bg); color: var(--cap-dr-fg); border-color: var(--cap-dr-fg); }
    .cap-dr-hdr-icon:active { transform: scale(0.93); }
    .cap-dr-hdr-icon svg { width: 15px; height: 15px; display: block; }
    .cap-dr-hdr-acct {
      display: inline-flex; align-items: center; gap: 7px;
      background: transparent; border: 1px solid var(--cap-dr-card-border);
      color: var(--cap-dr-fg); cursor: pointer;
      height: 30px; padding: 0 10px; border-radius: 7px;
      font: inherit; font-size: 12px; max-width: 220px;
      transition: background 150ms ease, border-color 150ms ease;
    }
    .cap-dr-hdr-acct:hover { background: var(--cap-dr-card-bg); border-color: var(--cap-dr-fg); }
    .cap-dr-hdr-acct .hub-av {
      width: 20px; height: 20px; border-radius: 50%; flex-shrink: 0;
      display: inline-flex; align-items: center; justify-content: center;
      background: #34d39e; color: #0b0d0c; font-size: 11px; font-weight: 700;
    }
    .cap-dr-hdr-acct .hub-em { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .cap-dr-hdr-acct.signin { background: #34d39e; color: #0b0d0c; border-color: #34d39e; font-weight: 600; }
    .cap-dr-hdr-acct.signin:hover { background: #2bbf8c; border-color: #2bbf8c; }

    /* ─── Hub-side app switcher (mirrors cvHome appsw so user can hop back to Call Analyst from the Hub) ─── */
    .cap-dr-overlay-left {
      display: flex; align-items: center; gap: 12px;
      position: relative;
      min-width: 0;
    }
    .hub-appsw {
      display: flex; align-items: center; gap: 9px;
      padding: 6px 9px;
      border-radius: 10px;
      border: 1px solid transparent;
      background: transparent;
      cursor: pointer;
      font: inherit;
      color: var(--cap-dr-fg);
      transition: background 150ms ease, border-color 150ms ease;
    }
    .hub-appsw:hover { background: var(--cap-dr-card-bg); border-color: var(--cap-dr-card-border); }
    .hub-appsw[aria-expanded="true"] { background: var(--cap-dr-card-bg); border-color: var(--cap-dr-card-border); }
    /* Bug 3 (corrected): match the VISIBLE home brand = #cvHome .cvbrandmark + .cvnm:
       ascending bars 9/15/12 + Inter 14.5px/700/-0.01em. (The static .brand-name is
       hidden; the live wordmark is .cvnm. Earlier I wrongly used equal bars + 16px.) */
    .hub-brandmark { display: inline-flex; gap: 2px; align-items: flex-end; }
    .hub-brandmark i { display: block; width: 3px; height: 15px; border-radius: 2px; }
    .hub-brandmark i:nth-child(1) { height: 9px;  background: var(--brand-cyan); }
    .hub-brandmark i:nth-child(2) { height: 15px; background: var(--brand-blue); }
    .hub-brandmark i:nth-child(3) { height: 12px; background: var(--brand-violet); }
    .hub-swname {
      font-weight: 700; font-size: 14.5px; letter-spacing: -0.01em;
      color: var(--cap-dr-fg);
      font-family: 'Inter', -apple-system, system-ui, sans-serif;
    }
    .hub-chev { width: 13px; height: 13px; color: var(--cap-dr-fg-dim); transition: transform .2s, color .15s; flex-shrink: 0; display: inline-flex; }
    .hub-appsw:hover .hub-chev { color: var(--cap-dr-fg); }
    .hub-appsw[aria-expanded="true"] .hub-chev { transform: rotate(180deg); }

    .hub-appmenu {
      position: absolute;
      top: calc(100% + 6px);
      left: 0;
      z-index: 50;
      min-width: 268px;
      padding: 8px;
      display: none;
      background: var(--cap-dr-bg-soft, #0a0a0a);
      border: 1px solid var(--cap-dr-card-border);
      border-radius: 12px;
      box-shadow: 0 18px 44px -16px rgba(0,0,0,0.55), 0 4px 14px -6px rgba(0,0,0,0.35);
      backdrop-filter: blur(8px);
    }
    .hub-appmenu[data-open="1"] { display: block; animation: hubAppMenuIn .16s cubic-bezier(.2,.8,.2,1); }
    @keyframes hubAppMenuIn { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }
    .hub-appmenu-h {
      font-size: 10px; font-weight: 700; letter-spacing: 0.11em; text-transform: uppercase;
      color: var(--cap-dr-fg-dimmer); padding: 8px 10px 7px;
    }
    .hub-mitem {
      display: flex; align-items: center; gap: 10px; width: 100%;
      padding: 9px 10px; border-radius: 8px;
      background: transparent; border: 0;
      color: var(--cap-dr-fg);
      cursor: pointer; font: inherit; text-align: left;
    }
    .hub-mitem:hover { background: var(--cap-dr-card-bg); }
    .hub-mitem.hub-cur { background: rgba(59,130,246,0.10); }
    .hub-mitem.hub-cur:hover { background: rgba(59,130,246,0.16); }
    .hub-mic {
      display: inline-flex; align-items: center; justify-content: center;
      width: 28px; height: 28px; border-radius: 7px;
      background: var(--cap-dr-card-bg);
      border: 1px solid var(--cap-dr-card-border);
      color: var(--cap-dr-fg-dim);
      flex-shrink: 0;
    }
    .hub-mic svg { width: 14px; height: 14px; }
    .hub-mitem.hub-cur .hub-mic { color: var(--cap-dr-accent-blue); border-color: var(--cap-dr-accent-blue); }
    /* Item 4: per-app colored icon chips so each app is visually distinct and
       jives with the brand palette — Call Analyst blue, Projects Hub violet. */
    .hub-mitem[data-cv-go="home"] .hub-mic, .hub-mitem[data-detail-go="home"] .hub-mic {
      color: #3b82f6; background: rgba(59,130,246,0.14); border-color: rgba(59,130,246,0.40);
    }
    .hub-mitem[data-cv-go="hub"] .hub-mic, .hub-mitem[data-detail-go="hub"] .hub-mic {
      color: #8b5cf6; background: rgba(139,92,246,0.14); border-color: rgba(139,92,246,0.40);
    }
    .hub-tx { display: flex; flex-direction: column; flex: 1; min-width: 0; }
    .hub-tx .hub-t { font-size: 13.5px; font-weight: 700; color: var(--cap-dr-fg); letter-spacing: -0.01em; }
    .hub-tx .hub-s { font-size: 11.5px; color: var(--cap-dr-fg-dimmer); margin-top: 1px; }
    .hub-check { color: var(--cap-dr-accent-blue); font-weight: 700; font-size: 14px; margin-left: 6px; }

    .cap-dr-overlay-body {
      flex: 1; overflow-y: auto; padding: 20px 24px 28px;
      -webkit-overflow-scrolling: touch;
    }
    .cap-dr-section-h {
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 14px; font-weight: 500;
      text-transform: uppercase; letter-spacing: 0.1em;
      color: var(--cap-dr-fg-dim); margin: 0 0 12px;
    }
    /* R13.4: Projects Hub hero + bar + chips + count + empty */
    .cap-dr-hub-hero { margin-bottom: 18px; }
    .cap-dr-hub-hero h1 {
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 24px; font-weight: 800;
      letter-spacing: -0.02em; color: var(--cap-dr-fg); margin: 0;
    }
    .cap-dr-hub-hero p {
      font-size: 13px; color: var(--cap-dr-fg-dim); margin: 5px 0 0;
      font-family: 'Roboto Mono', ui-monospace, monospace;
    }
    .cap-dr-hubbar {
      display: flex; align-items: center; gap: 10px;
      margin-bottom: 14px; flex-wrap: wrap;
    }
    .cap-dr-hubsearch { position: relative; flex: 1; min-width: 220px; }
    .cap-dr-hubsearch svg {
      position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
      width: 14px; height: 14px; color: var(--cap-dr-fg-dimmer);
    }
    .cap-dr-hubsearch input {
      width: 100%; padding: 10px 13px 10px 34px;
      border: 1px solid var(--cap-dr-card-border); border-radius: 6px;
      background: var(--cap-dr-card-bg); color: var(--cap-dr-fg);
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 13px; outline: none;
    }
    .cap-dr-hubsearch input:focus {
      border-color: var(--cap-dr-accent-blue);
      box-shadow: 0 0 0 3px rgba(59,130,246,0.18);
    }
    .cap-dr-fchips { display: flex; gap: 6px; flex-wrap: wrap; }
    .cap-dr-fchip {
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 11px; font-weight: 600;
      color: var(--cap-dr-fg-dim);
      background: var(--cap-dr-card-bg);
      border: 1px solid var(--cap-dr-card-border);
      border-radius: 999px; padding: 7px 12px;
      cursor: pointer; white-space: nowrap;
      letter-spacing: 0.04em; text-transform: uppercase;
      transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
    }
    .cap-dr-fchip:hover { color: var(--cap-dr-fg); border-color: var(--cap-dr-card-border-hover); }
    .cap-dr-fchip.on {
      color: var(--cap-dr-accent-blue);
      background: rgba(59,130,246,0.12);
      border-color: var(--cap-dr-accent-blue);
    }
    .cap-dr-fchip-add { border-style: dashed; color: var(--cap-dr-fg-dimmer); }
    .cap-dr-fchip-dot {
      display: inline-block; width: 8px; height: 8px;
      border-radius: 50%; margin-right: 6px; vertical-align: -1px;
    }
    .cap-dr-newproj-btn {
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 12px; font-weight: 700;
      letter-spacing: 0.06em; text-transform: uppercase;
      background: var(--cap-dr-accent-blue-strong); color: #fff;
      border: 0; border-radius: 6px; padding: 9px 14px;
      cursor: pointer;
      transition: background 0.15s ease;
    }
    .cap-dr-newproj-btn:hover { background: var(--cap-dr-accent-blue-hover); }
    .cap-dr-hubcount-row {
      display: flex; align-items: center; justify-content: space-between; gap: 10px;
    }
    .cap-dr-hubcount {
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 11px; color: var(--cap-dr-fg-dimmer); margin-bottom: 10px;
    }
    .cap-dr-hidden-btn {
      display: inline-flex; align-items: center; gap: 6px; margin-bottom: 10px;
      font-family: 'Roboto Mono', ui-monospace, monospace; font-size: 11px;
      color: var(--cap-dr-fg-dim); background: transparent;
      border: 1px solid var(--cap-dr-card-border); border-radius: 6px;
      padding: 5px 10px; cursor: pointer;
      transition: color .15s ease, border-color .15s ease;
    }
    .cap-dr-hidden-btn[hidden] { display: none; }
    .cap-dr-hidden-btn:hover { color: var(--cap-dr-fg); border-color: var(--cap-dr-card-border-hover); }
    .cap-dr-hidden-btn svg { width: 13px; height: 13px; }
    .cap-dr-hidden-cnt {
      font-size: 10px; font-weight: 700; background: var(--cap-dr-bg-soft);
      border: 1px solid var(--cap-dr-card-border); border-radius: 999px; padding: 1px 6px;
    }
    .cap-dr-hub-empty {
      padding: 40px 20px; text-align: center;
      color: var(--cap-dr-fg-dimmer); font-size: 13px;
      font-family: 'Roboto Mono', ui-monospace, monospace;
    }
    .cap-dr-hub-empty[hidden] { display: none; }
    /* R13.4: modal scrim + dialog (label manager, new project) */
    .cap-dr-scrim {
      position: fixed; inset: 0;
      background: rgba(0,0,0,0.72);
      backdrop-filter: blur(5px);
      z-index: 200;
      display: none;
      align-items: center; justify-content: center;
      padding: 20px;
    }
    .cap-dr-scrim.open { display: flex; }
    :root[data-theme="light"] .cap-dr-scrim { background: rgba(20,25,22,0.4); }
    .cap-dr-modal {
      width: 100%; max-width: 440px;
      background: var(--cap-dr-card-bg);
      border: 1px solid var(--cap-dr-card-border);
      border-radius: 8px;
      padding: 20px;
      color: var(--cap-dr-fg);
      box-shadow: 0 16px 40px rgba(0,0,0,0.5);
    }
    .cap-dr-modal h3 {
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 16px; font-weight: 700;
      letter-spacing: -0.01em; margin: 0 0 4px;
    }
    .cap-dr-modal-sub {
      font-size: 12px; color: var(--cap-dr-fg-dim); margin-bottom: 14px;
      font-family: 'Roboto Mono', ui-monospace, monospace;
    }
    .cap-dr-mfield { margin-bottom: 12px; }
    .cap-dr-mfield label {
      display: block;
      font-size: 11px; color: var(--cap-dr-fg-dim);
      margin-bottom: 5px; font-weight: 600;
      font-family: 'Source Code Pro', ui-monospace, monospace;
      letter-spacing: 0.04em; text-transform: uppercase;
    }
    .cap-dr-mfield input {
      width: 100%; padding: 10px 12px;
      border: 1px solid var(--cap-dr-card-border); border-radius: 6px;
      background: var(--cap-dr-bg-soft); color: var(--cap-dr-fg);
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 13px; outline: none; box-sizing: border-box;
    }
    .cap-dr-mfield input:focus {
      border-color: var(--cap-dr-accent-blue);
      box-shadow: 0 0 0 3px rgba(59,130,246,0.18);
    }
    .cap-dr-swatches { display: flex; gap: 9px; flex-wrap: wrap; max-width: 350px; }
    /* custom color: native picker disguised as a rainbow swatch */
    .cap-dr-swatch-custom {
      width: 26px; height: 26px; border-radius: 50%; cursor: pointer; position: relative;
      background: conic-gradient(#ef4444, #f59e0b, #84cc16, #10b981, #0ea5e9, #8b5cf6, #ec4899, #ef4444);
      box-shadow: 0 0 0 2px var(--cap-dr-card-bg), 0 0 0 3px transparent;
      transition: box-shadow 0.15s ease;
      display: inline-block;
    }
    .cap-dr-swatch-custom.is-on { box-shadow: 0 0 0 2px var(--cap-dr-card-bg), 0 0 0 4px var(--cap-dr-fg); }
    .cap-dr-swatch-custom input { position: absolute; inset: 0; opacity: 0; width: 100%; height: 100%; cursor: pointer; }
    .cap-dr-swatch {
      width: 26px; height: 26px; border-radius: 50%;
      border: 0; cursor: pointer; padding: 0;
      box-shadow: 0 0 0 2px var(--cap-dr-card-bg), 0 0 0 3px transparent;
      transition: box-shadow 0.15s ease;
    }
    .cap-dr-swatch[data-c="#06b6d4"] { background: #06b6d4; }
    .cap-dr-swatch[data-c="#8b5cf6"] { background: #8b5cf6; }
    .cap-dr-swatch[data-c="#10b981"] { background: #10b981; }
    .cap-dr-swatch[data-c="#f59e0b"] { background: #f59e0b; }
    .cap-dr-swatch[data-c="#ec4899"] { background: #ec4899; }
    .cap-dr-swatch[data-c="#4f97f2"] { background: #4f97f2; }
    .cap-dr-swatch.is-on {
      box-shadow: 0 0 0 2px var(--cap-dr-card-bg), 0 0 0 4px var(--cap-dr-fg);
    }
    .cap-dr-modal-actions {
      display: flex; gap: 8px; margin-top: 16px;
    }
    .cap-dr-modal-btn {
      flex: 1; padding: 9px 14px;
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 12px; font-weight: 700;
      letter-spacing: 0.06em; text-transform: uppercase;
      border: 1px solid var(--cap-dr-card-border);
      border-radius: 6px;
      background: transparent; color: var(--cap-dr-fg);
      cursor: pointer;
      transition: background 0.15s ease, border-color 0.15s ease;
    }
    .cap-dr-modal-btn:hover { background: var(--cap-dr-bg-soft); }
    .cap-dr-modal-btn-primary {
      background: var(--cap-dr-accent-blue-strong);
      color: #fff; border-color: var(--cap-dr-accent-blue-strong);
    }
    .cap-dr-modal-btn-primary:hover { background: var(--cap-dr-accent-blue-hover); }
    /* R13.4: inline label dots on hub cards */
    .cap-dr-hclabel {
      display: inline-block; width: 8px; height: 8px;
      border-radius: 50%; margin-right: 5px; vertical-align: -1px;
    }
    .cap-dr-card-labels {
      display: inline-flex; align-items: center; gap: 8px;
      flex-wrap: wrap;
    }
    /* Ask-all mega CTA — DRA's flat #2563eb block */
    .cap-dr-ask-all {
      display: flex; align-items: center; justify-content: center; gap: 12px;
      width: 100%;
      padding: 16px 24px;
      margin-bottom: 16px;
      border: none; border-radius: 6px;
      background: var(--cap-dr-accent-blue-strong);
      color: #fff;
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 15px; font-weight: 600;
      text-transform: uppercase; letter-spacing: 0.08em;
      cursor: pointer; text-align: center;
      box-shadow: 0 1px 0 rgba(0,0,0,0.2), inset 0 1px 0 rgba(255,255,255,0.1);
      transition: background 0.15s ease, transform 0.1s ease, box-shadow 0.15s ease;
    }
    .cap-dr-ask-all:hover {
      background: var(--cap-dr-accent-blue-hover);
      box-shadow: 0 2px 6px rgba(37,99,235,0.35);
    }
    .cap-dr-ask-all:active {
      background: var(--cap-dr-accent-blue-active);
      transform: translateY(1px);
    }
    .cap-dr-ask-all-icon { font-size: 18px; color: #fff; }
    .cap-dr-ask-all-hint {
      font-weight: 400; font-size: 11px;
      color: rgba(255,255,255,0.75);
      text-transform: none; letter-spacing: 0;
      margin-left: 4px;
      font-family: 'Roboto Mono', ui-monospace, monospace;
    }
    .cap-dr-grid {
      display: grid; gap: 12px;
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
    @media (max-width: 1100px) { .cap-dr-grid { grid-template-columns: repeat(3, 1fr); } }
    @media (max-width: 820px)  { .cap-dr-grid { grid-template-columns: repeat(2, 1fr); } }
    @media (max-width: 520px)  { .cap-dr-grid { grid-template-columns: 1fr; } }
    .cap-dr-card {
      position: relative;
      background: var(--cap-dr-card-bg);
      border: 1px solid var(--cap-dr-card-border);
      border-radius: 6px;
      padding: 12px 14px 12px 16px;
      cursor: pointer;
      display: flex; flex-direction: column; gap: 8px;
      min-height: 140px;
      text-align: left;
      color: var(--cap-dr-fg);
      transition: border-color 0.15s ease, transform 0.15s ease, background 0.15s ease;
    }
    .cap-dr-card::before {
      content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
      background: var(--cap-dr-sector, var(--cap-dr-accent-blue));
      border-radius: 6px 0 0 6px;
    }
    .cap-dr-card:hover {
      border-color: var(--cap-dr-card-border-hover);
      transform: translateY(-2px);
    }
    /* Hover-revealed card actions: a footer action ROW at the BOTTOM of the card so
       the buttons never overlap the title / description / meta text. Collapsed (no
       height, faded out) until the card is hovered or focused. */
    .cap-dr-card-actions {
      margin-top: auto;
      display: flex; gap: 8px; justify-content: flex-end; align-items: center;
      padding-top: 0; margin-bottom: -2px;
      border-top: 1px solid transparent;
      max-height: 0; opacity: 0; overflow: hidden;
      transition: max-height .16s ease, opacity .14s ease, padding-top .16s ease, border-color .16s ease;
    }
    .cap-dr-card:hover .cap-dr-card-actions,
    .cap-dr-card:focus-within .cap-dr-card-actions {
      max-height: 48px; opacity: 1; padding-top: 8px;
      border-top-color: var(--cap-dr-card-border);
    }
    .cap-dr-card-act {
      width: 30px; height: 26px; border-radius: 7px;
      border: 1px solid var(--cap-dr-card-border); background: var(--cap-dr-bg, #0d1015);
      color: var(--cap-dr-fg-dim, #7e8794); font-size: 12px; line-height: 1;
      display: grid; place-items: center; cursor: pointer; padding: 0;
      transition: color .14s, border-color .14s, background .14s;
    }
    .cap-dr-card-act svg { width: 14px; height: 14px; display: block; }
    .cap-dr-card-archive:hover { color: #fff; background: #3b5573; border-color: #3b5573; }
    .cap-dr-card-trash:hover { color: #fff; background: #b4434a; border-color: #b4434a; }
    .cap-dr-card-act:focus-visible { opacity: 1; outline: 2px solid var(--cap-dr-accent-blue, #4f97f2); outline-offset: 1px; }
    .cap-dr-card-head {
      display: flex; align-items: flex-start; justify-content: space-between; gap: 8px;
    }
    .cap-dr-card-name {
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 13px; font-weight: 600; color: var(--cap-dr-fg); margin: 0;
      letter-spacing: 0.04em;
      flex: 1; min-width: 0; word-break: break-word;
    }
    .cap-dr-card-files {
      flex: 0 0 auto;
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 10px; font-weight: 600; color: var(--cap-dr-fg-dim);
      padding: 2px 8px; border: 1px solid var(--cap-dr-card-border); border-radius: 999px;
      background: var(--cap-dr-bg-soft);
      letter-spacing: 0.04em; white-space: nowrap;
    }
    .cap-dr-card-desc {
      font-size: 11px; color: var(--cap-dr-fg-dim); line-height: 1.5; margin: 0;
      display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
      overflow: hidden;
      font-family: 'Roboto Mono', ui-monospace, monospace;
    }
    .cap-dr-card-meta {
      margin-top: auto;
      display: flex; align-items: center; justify-content: space-between; gap: 8px;
      padding-top: 6px;
      border-top: 1px dashed var(--cap-dr-card-border);
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 10px; color: var(--cap-dr-fg-dim); letter-spacing: 0.04em;
    }
    /* R13.4: sector tag retired (labels replace it) */
    .cap-dr-card.empty {
      border-style: dashed; background: transparent; cursor: pointer;
      color: var(--cap-dr-fg-dimmer);
      grid-column: 1 / -1;
      display: flex; align-items: center; gap: 10px;
      padding: 11px 16px; min-height: 0;
    }
    .cap-dr-card.empty .cap-dr-card-head { margin: 0; }
    .cap-dr-card.empty .cap-dr-card-name { font-size: 13px; margin: 0; }
    .cap-dr-card.empty .cap-dr-card-desc { margin: 0; font-size: 12px; opacity: .8; }
    .cap-dr-card.empty .cap-dr-card-meta { margin-left: auto; }
    .cap-dr-card.empty::before { background: var(--cap-dr-card-border); }
    .cap-dr-card.empty:hover {
      border-color: var(--cap-dr-card-border-hover);
      transform: translateY(-2px);
    }
    .cap-dr-card.empty .cap-dr-card-name { color: var(--cap-dr-fg-dim); }

    /* Project detail inline overlay — DRA palette + sources-list pattern */
    .cap-dr-detail {
      /* Inherit DRA palette overrides from .cap-dr-overlay scope */
      --cap-dr-bg:              #000;
      --cap-dr-bg-soft:         #0a0a0a;
      --cap-dr-fg:              #fff;
      --cap-dr-fg-dim:          #aaa;
      --cap-dr-fg-dimmer:       #777;
      --cap-dr-card-bg:         #111;
      --cap-dr-card-border:     #333;
      --cap-dr-card-border-hover:#666;
      --cap-dr-addctx-bg:       #0d0d10;
      --cap-dr-addctx-border:   #2a2a30;
      --cap-dr-accent-blue:     #3b82f6;
      --cap-dr-accent-blue-strong:#2563eb;

      position: absolute; inset: 0; z-index: 85;
      background: var(--cap-dr-bg);
      color: var(--cap-dr-fg);
      transform: translateY(8px); opacity: 0;
      pointer-events: none;
      transition: opacity 200ms ease, transform 200ms ease;
      display: flex; flex-direction: column;
      overflow: hidden;
    }
    .cap-dr-detail.is-open { transform: translateY(0); opacity: 1; pointer-events: auto; }
    .cap-dr-detail-header {
      flex: 0 0 auto;
      display: flex; align-items: center; gap: 10px;
      padding: 18px 24px 14px;
      border-bottom: 1px solid var(--cap-dr-card-border);
      background: linear-gradient(90deg, var(--cap-dr-bg) 0%, var(--cap-dr-bg-soft) 100%);
    }
    .cap-dr-detail-back, .cap-dr-detail-x {
      background: transparent; border: 1px solid #555; color: var(--cap-dr-fg-dim);
      width: 38px; height: 38px; border-radius: 4px; cursor: pointer;
      display: inline-flex; align-items: center; justify-content: center;
      font-size: 14px; line-height: 1;
      transition: background 150ms ease, color 150ms ease, border-color 150ms ease;
    }
    .cap-dr-detail-back:hover, .cap-dr-detail-x:hover {
      background: var(--cap-dr-fg); color: var(--cap-dr-bg); border-color: var(--cap-dr-fg);
    }
    /* R7: labeled pill shared style (overrides 38x38 square above) */
    .cap-dr-detail-pill {
      width: auto; height: auto;
      display: inline-flex; align-items: center; gap: 6px;
      padding: 6px 12px;
      background: transparent;
      border: 1px solid var(--cap-dr-card-border);
      border-radius: 999px;
      color: var(--cap-dr-fg);
      font-family: 'Source Code Pro', monospace;
      font-size: 12px; font-weight: 600;
      letter-spacing: 0.02em;
      cursor: pointer;
      transition: background .15s, border-color .15s, color .15s;
      white-space: nowrap;
      flex-shrink: 0;
    }
    .cap-dr-detail-pill:hover {
      background: rgba(59,130,246,0.12);
      border-color: var(--cap-dr-accent-blue);
      color: var(--cap-dr-fg);
    }
    .cap-dr-detail-pill:focus-visible {
      outline: 2px solid var(--cap-dr-accent-blue);
      outline-offset: 2px;
    }
    .cap-dr-detail-pill--exit { margin-left: auto; }
    /* Item 4: make the project-detail top-left brand identical to the Projects Hub
       switcher (ascending bars + Inter 14.5px), so it stays consistent across the
       hub list and an individual project. Doubles as the back-to-hub control. */
    .cap-dr-detail-left { position: relative; display: inline-flex; align-items: center; flex-shrink: 0; }
    .cap-dr-detail-hubbrand {
      display: inline-flex; align-items: center; gap: 9px;
      padding: 6px 9px; border-radius: 10px;
      border: 1px solid transparent; background: transparent;
      cursor: pointer; font: inherit; color: var(--cap-dr-fg);
      transition: background 150ms ease, border-color 150ms ease;
    }
    .cap-dr-detail-hubbrand:hover { background: var(--cap-dr-card-bg); border-color: var(--cap-dr-card-border); }
    .cap-dr-detail-hubname {
      font-weight: 700; font-size: 14.5px; letter-spacing: -0.01em;
      color: var(--cap-dr-fg);
      font-family: 'Inter', -apple-system, system-ui, sans-serif;
    }
    @media (max-width: 459px) {
      .cap-dr-detail-pill { font-size: 11px; padding: 5px 10px; }
      .cap-dr-detail-pill-text { display: none; }
    }
    @media (prefers-reduced-motion: reduce) {
      .cap-dr-detail-pill { transition: none; }
    }
    .cap-dr-detail-title {
      flex: 1;
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 18px; font-weight: 700; color: var(--cap-dr-fg); margin: 0;
      letter-spacing: 0.04em;
    }
    /* R13.4: header label pill (replaces sector tag, color driven by --cap-dr-label-color) */
    .cap-dr-detail-label {
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase;
      padding: 3px 9px; border-radius: 999px;
      background: color-mix(in srgb, var(--cap-dr-label-color, var(--cap-dr-accent-blue)) 14%, transparent);
      border: 1px solid color-mix(in srgb, var(--cap-dr-label-color, var(--cap-dr-accent-blue)) 38%, transparent);
      color: var(--cap-dr-label-color, var(--cap-dr-accent-blue));
      font-weight: 600;
      display: inline-flex; align-items: center; gap: 6px;
    }
    .cap-dr-detail-label[hidden] { display: none; }
    .cap-dr-detail-body {
      flex: 1; overflow-y: auto; padding: 20px 24px 80px;
      -webkit-overflow-scrolling: touch;
      display: none; /* legacy body retired by IT5 icon-rail */
    }
    /* ──────────── R13.4 C2 STACKED WORKSPACE ──────────── */
    /* .pdbody is a 2-col grid: chat (1fr) + always-visible tools column (440px) */
    .cap-dr-stage.pdbody {
      flex: 1; min-height: 0;
      display: grid;
      grid-template-columns: 1fr 440px;
      grid-template-rows: minmax(0, 1fr);
      overflow: hidden;
      position: relative;
    }
    .cap-dr-chat-wrap {
      min-width: 0; min-height: 0; display: flex; flex-direction: column;
      position: relative;
      background: var(--cap-dr-bg);
      /* R12: layer pre-promote — keep for message append flash protection */
      will-change: filter;
      transform: translateZ(0);
    }
    .cap-dr-chat-scope {
      padding: 10px 22px; border-bottom: 1px solid var(--cap-dr-card-border);
      color: var(--cap-dr-accent-blue); font-size: 12px; letter-spacing: 0.04em;
      display: flex; align-items: center; gap: 10px; flex-shrink: 0;
      background: var(--cap-dr-bg-soft);
      font-family: 'Roboto Mono', ui-monospace, monospace;
    }
    .cap-dr-chat-scope-dot { width:6px; height:6px; border-radius:50%; background: var(--cap-dr-accent-blue); }
    .cap-dr-chat-scope-meta { color: var(--cap-dr-fg-dimmer); margin-left: auto; font-size: 11px; }
    .cap-dr-chat-messages {
      flex: 1; min-height: 0; overflow-y: auto;
      padding: 20px 22px 12px; display: flex; flex-direction: column; gap: 14px;
    }
    .cap-dr-message { display: flex; gap: 10px; max-width: 78%; }
    .cap-dr-message.ai   { align-self: flex-start; }
    .cap-dr-message.user { align-self: flex-end; flex-direction: row-reverse; }
    .cap-dr-message-avatar {
      width: 28px; height: 28px; border-radius: 50%;
      background: var(--cap-dr-accent-blue); color: #fff;
      display: flex; align-items: center; justify-content: center;
      font-family: 'Source Code Pro', monospace; font-weight: 700; font-size: 13px;
      flex-shrink: 0;
    }
    .cap-dr-message.user .cap-dr-message-avatar {
      background: var(--cap-dr-bg-soft); color: var(--cap-dr-fg-dim);
      border: 1px solid var(--cap-dr-card-border);
    }
    .cap-dr-message-bubble {
      padding: 10px 14px; border-radius: 6px; font-size: 13.5px; line-height: 1.6;
      word-wrap: break-word;
      font-family: 'Roboto Mono', ui-monospace, monospace;
      white-space: pre-wrap;
    }
    .cap-dr-message.ai   .cap-dr-message-bubble {
      background: #0e1a2e; border-left: 2px solid var(--cap-dr-accent-blue); color: #e5e7eb;
    }
    .cap-dr-message.user .cap-dr-message-bubble {
      background: var(--cap-dr-bg-soft); border: 1px solid var(--cap-dr-card-border); color: var(--cap-dr-fg);
    }
    .cap-dr-message-bubble.is-thinking { opacity: 0.65; font-style: italic; }
    /* AI answers use the main chat's markdown formatting (md-content), not
       the mono/pre-wrap raw-text look */
    .cap-dr-message.ai .cap-dr-message-bubble.md-content {
      white-space: normal;
      font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
      font-size: 13.5px;
    }
    .cap-dr-message-bubble.md-content > :first-child { margin-top: 0; }
    .cap-dr-message-bubble.md-content > :last-child { margin-bottom: 0; }
    .cap-dr-chat-composer {
      padding: 12px 22px 16px; border-top: 1px solid var(--cap-dr-card-border);
      background: var(--cap-dr-bg-soft); flex-shrink: 0;
      display: flex; gap: 10px; align-items: flex-end;
    }
    .cap-dr-chat-composer textarea {
      flex: 1; min-height: 42px; max-height: 120px; resize: none; line-height: 1.45;
      background: var(--cap-dr-card-bg); border: 1px solid var(--cap-dr-card-border);
      color: var(--cap-dr-fg); border-radius: 4px; padding: 9px 10px;
      font-family: inherit; font-size: 14px;
    }
    .cap-dr-chat-composer textarea:focus {
      outline: none; border-color: var(--cap-dr-accent-blue);
    }
    .cap-dr-chat-tools { display: flex; gap: 6px; }
    .cap-dr-chat-tool-btn {
      width: 38px; height: 38px; display: flex; align-items: center; justify-content: center;
      border: 1px solid var(--cap-dr-card-border); border-radius: 4px;
      color: var(--cap-dr-fg-dim); transition: all .2s; background: transparent;
      cursor: pointer;
    }
    .cap-dr-chat-tool-btn:hover { color: var(--cap-dr-fg); border-color: var(--cap-dr-card-border-hover); background: var(--cap-dr-card-bg); }
    /* Dictation active state — mirrors the Call Analyst .voice-btn.recording look */
    .cap-dr-chat-tool-btn.recording {
      background: #dc2626; color: #fff; border-color: #dc2626;
      animation: voice-pulse 1.2s ease-in-out infinite;
    }
    @media (prefers-reduced-motion: reduce) {
      .cap-dr-chat-tool-btn.recording { animation: none; box-shadow: 0 0 0 3px rgba(220,38,38,0.35); }
    }
    .cap-dr-chat-send {
      background: var(--cap-dr-accent-blue-strong); color: #fff;
      padding: 9px 18px; border-radius: 4px; height: 38px;
      font-family: 'Source Code Pro', monospace; font-size: 13px; font-weight: 600;
      letter-spacing: 0.06em; transition: background .2s; border: 0; cursor: pointer;
    }
    .cap-dr-chat-send:hover { background: var(--cap-dr-accent-blue-hover); }
    .cap-dr-chat-send:disabled { opacity: 0.55; cursor: not-allowed; }
    /* R13.4: C2 stacked .pdtools column — always visible, scrollable */
    .pdtools {
      min-width: 0; min-height: 0;
      display: flex; flex-direction: column;
      background: var(--cap-dr-bg-soft);
      border-left: 1px solid var(--cap-dr-card-border);
      overflow: hidden;
    }
    .pdpanel-stack {
      flex: 1; min-height: 0;
      overflow-y: auto;
      padding: 14px 15px;
      -webkit-overflow-scrolling: touch;
    }
    /* Each pdpanel is a section; in C2 they're stacked top-to-bottom, no borders/cards */
    .pdpanel {
      display: block; margin-bottom: 22px;
      background: transparent;
    }
    .pdpanel:last-child { margin-bottom: 0; }
    .pdpanel .stack-h {
      display: flex; align-items: center; gap: 8px;
      margin-bottom: 11px;
    }
    .pdpanel .stack-h h4 {
      font-family: 'Source Code Pro', monospace;
      font-size: 11px; font-weight: 700; letter-spacing: 0.07em;
      text-transform: uppercase; color: var(--cap-dr-fg-dim);
      white-space: nowrap; margin: 0;
    }
    .pdpanel .stack-h .cnt {
      font-family: 'Roboto Mono', monospace;
      font-size: 10px; color: var(--cap-dr-fg-dimmer);
      background: var(--cap-dr-card-bg);
      border: 1px solid var(--cap-dr-card-border);
      border-radius: 999px; padding: 1px 7px;
    }
    .pdpanel .stack-h .stack-hint {
      font-family: 'Roboto Mono', monospace;
      font-size: 10px; color: var(--cap-dr-fg-dimmer);
      letter-spacing: 0.02em; white-space: nowrap;
      overflow: hidden; text-overflow: ellipsis;
    }
    /* Pre-mounted slot — in C2 stacked mode, all slots are always active */
    .cap-dr-panel-body-slot {
      display: block;
      box-sizing: border-box;
      contain: layout style;
    }
    /* R13.4: C2 compact source rows — port from project.css L201-204 */
    .pdpanel[data-tool="sources"] .cap-dr-source-row {
      padding: 8px 11px; margin-bottom: 5px;
    }
    .pdpanel[data-tool="sources"] .cap-dr-src-snippet {
      display: none;
    }
    .pdpanel[data-tool="sources"] .cap-dr-src-full {
      display: none;
    }
    .pdpanel[data-tool="sources"] .cap-dr-source-row[data-expanded="true"] .cap-dr-src-snippet,
    .pdpanel[data-tool="sources"] .cap-dr-source-row[data-expanded="true"] .cap-dr-src-full {
      display: block;
    }
    .pdpanel[data-tool="sources"] .cap-dr-src-actions {
      display: none; opacity: 1; margin-top: 8px;
    }
    .pdpanel[data-tool="sources"] .cap-dr-source-row:hover .cap-dr-src-actions,
    .pdpanel[data-tool="sources"] .cap-dr-source-row[data-expanded="true"] .cap-dr-src-actions {
      display: flex;
    }
    /* Pinned: green left-border accent (replaces overlapping floating pinflag) */
    .pdpanel[data-tool="sources"] .cap-dr-source-row.is-pinned {
      border-left: 2px solid #10b981;
    }
    /* Stacked mobile: hide tools under 900px, chat full-width */
    @media (max-width: 900px) {
      .cap-dr-stage.pdbody {
        grid-template-columns: 1fr;
      }
      .pdtools { display: none; }
    }
    @media (prefers-reduced-motion: reduce) {
      .cap-dr-chat-wrap { transition: none; }
    }
    .cap-dr-detail-summary {
      padding: 14px 16px;
      border: 1px solid var(--cap-dr-card-border);
      border-left: 3px solid var(--cap-dr-fg);
      border-radius: 4px;
      background: var(--cap-dr-card-bg);
      color: var(--cap-dr-fg); font-size: 13px;
      line-height: 1.6; margin-bottom: 18px;
      font-family: 'Roboto Mono', ui-monospace, monospace;
    }
    .cap-dr-detail-section { margin-bottom: 20px; }
    .cap-dr-detail-h {
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 14px; font-weight: 500; letter-spacing: 0.1em;
      text-transform: uppercase; color: var(--cap-dr-fg-dim);
      margin: 0 0 12px;
    }

    /* Sources list — DRA spec section 7 */
    .cap-dr-sources-list {
      border: 1px solid var(--cap-dr-addctx-border);
      border-radius: 4px;
      overflow: hidden;
    }
    .cap-dr-source-row {
      padding: 10px 14px;
      border-bottom: 1px solid var(--cap-dr-addctx-border);
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 11px;
      background: transparent;
      cursor: pointer;
      transition: background 140ms ease;
    }
    .cap-dr-source-row:last-child { border-bottom: none; }
    .cap-dr-source-row:hover { background: var(--cap-dr-bg-soft); }
    .cap-dr-source-row-head {
      display: grid;
      grid-template-columns: 90px 1fr 80px 90px;
      gap: 10px; align-items: center;
      margin-bottom: 4px;
    }
    @media (max-width: 640px) {
      .cap-dr-source-row-head {
        grid-template-columns: 80px 1fr 70px;
      }
      .cap-dr-source-row-head .cap-dr-src-date { display: none; }
    }
    .cap-dr-src-type {
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 9px; font-weight: 600;
      text-transform: uppercase; letter-spacing: 0.06em;
      padding: 2px 6px; border-radius: 3px;
      text-align: center; white-space: nowrap;
      border: 1px solid currentColor;
    }
    .cap-dr-src-type.transcript {
      color: #3b82f6;
      background: rgba(59,130,246,0.08);
      border-color: rgba(59,130,246,0.3);
    }
    .cap-dr-src-type.deck {
      color: #ec4899;
      background: rgba(236,72,153,0.08);
      border-color: rgba(236,72,153,0.3);
    }
    .cap-dr-src-type.model {
      color: #06b6d4;
      background: rgba(6,182,212,0.08);
      border-color: rgba(6,182,212,0.3);
    }
    .cap-dr-src-type.update {
      color: #f59e0b;
      background: rgba(245,158,11,0.08);
      border-color: rgba(245,158,11,0.3);
    }
    .cap-dr-src-type.memo {
      color: #14b8a6;
      background: rgba(20,184,166,0.08);
      border-color: rgba(20,184,166,0.3);
    }
    .cap-dr-src-title {
      font-weight: 600; color: var(--cap-dr-fg);
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 12px; letter-spacing: 0.02em;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .cap-dr-src-date {
      font-size: 10px; color: var(--cap-dr-fg-dim);
      letter-spacing: 0.04em; text-align: right;
      white-space: nowrap;
    }
    .cap-dr-src-examine {
      font-size: 10px; color: var(--cap-dr-fg-dim);
      letter-spacing: 0.04em; text-align: right;
      opacity: 0; transition: opacity 150ms ease;
      white-space: nowrap;
    }
    .cap-dr-source-row:hover .cap-dr-src-examine { opacity: 1; }
    .cap-dr-source-row[data-expanded="true"] .cap-dr-src-examine { opacity: 1; color: var(--cap-dr-accent-blue); }
    .cap-dr-src-snippet {
      color: var(--cap-dr-fg-dim);
      font-size: 11px; line-height: 1.5;
      margin: 4px 0 0;
      padding-left: 100px;
      display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
      overflow: hidden;
    }
    @media (max-width: 640px) {
      .cap-dr-src-snippet { padding-left: 0; }
    }
    .cap-dr-src-full {
      display: none;
      margin-top: 10px;
      padding: 10px 12px;
      background: var(--cap-dr-bg-soft);
      border: 1px solid var(--cap-dr-card-border);
      border-radius: 4px;
      font-size: 12px; line-height: 1.6; color: var(--cap-dr-fg);
      font-family: 'Roboto Mono', ui-monospace, monospace;
    }
    .cap-dr-source-row[data-expanded="true"] .cap-dr-src-full { display: block; }
    .cap-dr-source-expand-placeholder {
      display: none;
      color: #777;
      font-size: 12px;
      padding: 12px 0;
      font-family: 'Roboto Mono', ui-monospace, monospace;
    }
    .cap-dr-source-row[data-expanded="true"] .cap-dr-source-expand-placeholder { display: block; }
    .cap-dr-src-full-turn {
      margin-bottom: 8px; padding-bottom: 8px;
      border-bottom: 1px dashed var(--cap-dr-card-border);
    }
    .cap-dr-src-full-turn:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
    .cap-dr-src-full-speaker {
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 10px; font-weight: 600;
      color: var(--cap-dr-accent-blue);
      letter-spacing: 0.06em; text-transform: uppercase;
      margin-bottom: 3px;
    }

    .cap-dr-detail-grid2 {
      display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
    }
    @media (max-width: 720px) { .cap-dr-detail-grid2 { grid-template-columns: 1fr; } }
    .cap-dr-note-row {
      padding: 8px 12px;
      border: 1px solid var(--cap-dr-addctx-border);
      border-radius: 4px;
      background: var(--cap-dr-card-bg);
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 11px; color: var(--cap-dr-fg-dim);
      margin-bottom: 6px; line-height: 1.5;
    }
    /* Project-scope pill (legacy — no longer rendered) */
    .cap-dr-scope-pill {
      flex: 0 0 auto;
      background: rgba(59, 130, 246, 0.14);
      color: var(--cap-dr-accent-blue);
      border: 1px solid rgba(59, 130, 246, 0.3);
      padding: 5px 10px;
      border-radius: 999px;
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 11px;
      font-weight: 600;
      letter-spacing: 0.04em;
      white-space: nowrap;
      max-width: 40%;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    /* DR pill internal pieces — glyph + label + badge */
    .cap-dr-pill-glyph {
      display: inline-block;
      margin-right: 4px;
    }
    .cap-dr-pill-label {
      display: inline-block;
    }
    .cap-dr-pill-badge {
      display: inline-block;
      margin-left: 6px;
      font-size: 10px;
      font-weight: 600;
      padding: 1px 6px;
      border-radius: 999px;
      background: rgba(139, 92, 246, 0.18);
      color: #c7baf5;
      letter-spacing: 0.02em;
      line-height: 1.4;
    }
    .tab.data-rooms:hover .cap-dr-pill-badge {
      background: rgba(139, 92, 246, 0.28);
      color: #e8defc;
    }
    /* Narrow-phone DR pill: hide label, keep glyph + badge.
       Production .tabs forces padding:13px 12px !important so we match. */
    @media (max-width: 460px) {
      .tab.data-rooms {
        padding: 6px 10px !important;
        font-size: 11px;
      }
      .tab.data-rooms .cap-dr-pill-label {
        display: none;
      }
    }
    /* Narrow-phone detail header: shrink, allow title to ellipsize */
    .cap-dr-detail-title { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .cap-dr-detail-label { flex-shrink: 0; }
    @media (max-width: 480px) {
      .cap-dr-detail-title { font-size: 13px; }
      .cap-dr-detail-label { display: none; }
    }
    /* Task A (#3): on mobile, make the Projects Hub top-right account chip MATCH the
       Call Analyst header (.cvacct) — avatar-only, no email overflowing the bar.
       Mirror cviconbtn/cvacct sizing so theme + settings + account read identically
       across both surfaces at phone width. Desktop keeps the email label. */
    @media (max-width: 600px) {
      .cap-dr-overlay-hdr-actions { gap: 6px; }
      .cap-dr-hdr-acct { max-width: none; padding: 0; width: 30px; justify-content: center; }
      .cap-dr-hdr-acct .hub-em { display: none; }
      .cap-dr-hdr-acct.signin { width: auto; padding: 0 10px; }
    }
    /* Reset for landing cards / DR pill when rendered as <button> so they don't
       inherit default UA button chrome on top of our cap-dr- styles. */
    button.cap-dr-landing-card {
      font: inherit; text-align: left; color: inherit;
    }
    /* Old polish R2 button reset for keyboard accessibility — font properties stripped to let R5 typography win (.tab.data-rooms sets 11px/600/0.1em-letter-spacing with !important) */

    /* ───── WORKSPACE AFFORDANCES (per DRA-WORKSPACE-SPEC) ─────
       Lifted CSS where possible from DRA styles.css:
       .add-context-trigger, .add-context-body, .add-ctx-drop,
       .ctx-entry-actions, .sources-empty.
    */

    /* Active scope line above sources list */
    .cap-dr-scope-line {
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 11px;
      font-style: italic;
      color: var(--cap-dr-fg-dim);
      margin: 0 2px 8px;
      letter-spacing: 0.02em;
    }
    .cap-dr-scope-line strong {
      font-style: normal; font-weight: 600;
      color: var(--cap-dr-fg);
    }

    /* Section heads — same shape across Files/Notes */
    .cap-dr-section-head {
      display: flex; align-items: center; justify-content: space-between;
      gap: 8px;
      padding: 8px 0;
      border-bottom: 1px solid var(--cap-dr-addctx-border);
      margin-bottom: 10px;
    }
    .cap-dr-section-head h3 {
      margin: 0;
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 13px; font-weight: 600;
      color: var(--cap-dr-fg);
      letter-spacing: 0.04em;
      display: inline-flex; align-items: center; gap: 8px;
    }
    .cap-dr-section-count {
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 10px; color: var(--cap-dr-fg-dimmer);
      padding: 1px 8px; border-radius: 999px;
      background: var(--cap-dr-bg-soft);
      border: 1px solid var(--cap-dr-addctx-border);
      font-weight: 500;
    }
    .cap-dr-section-add-btn {
      background: var(--cap-dr-card-bg);
      color: var(--cap-dr-fg-dim);
      border: 1px solid var(--cap-dr-card-border);
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 11px;
      padding: 5px 12px;
      border-radius: 4px;
      cursor: pointer;
      letter-spacing: 0.04em;
      transition: color 0.15s ease, border-color 0.15s ease;
    }
    .cap-dr-section-add-btn:hover {
      color: var(--cap-dr-fg);
      border-color: var(--cap-dr-fg-dim);
    }

    /* Empty-state placeholders */
    .cap-dr-empty {
      padding: 18px 14px;
      text-align: center;
      font-size: 12px;
      font-style: italic;
      color: var(--cap-dr-fg-dim);
      background: var(--cap-dr-bg-soft);
      border: 1px dashed var(--cap-dr-addctx-border);
      border-radius: 6px;
      font-family: 'Roboto Mono', ui-monospace, monospace;
    }

    /* Source row action cluster (hover-reveal pin / hide / remove).
       Pattern lifted from DRA .ctx-entry-actions (styles.css 1853-1876). */
    .cap-dr-source-row { position: relative; }
    .cap-dr-src-actions {
      position: absolute;
      right: 14px; top: 8px;
      display: flex; gap: 4px;
      opacity: 0;
      transition: opacity 0.15s ease;
      pointer-events: none;
    }
    .cap-dr-source-row:hover .cap-dr-src-actions,
    .cap-dr-source-row:focus-within .cap-dr-src-actions {
      opacity: 1;
      pointer-events: auto;
    }
    .cap-dr-src-actions button {
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 11px; line-height: 1;
      padding: 3px 7px;
      background: var(--cap-dr-bg-soft);
      color: var(--cap-dr-fg-dim);
      border: 1px solid var(--cap-dr-card-border);
      border-radius: 3px;
      cursor: pointer;
      transition: color 0.12s ease, border-color 0.12s ease;
    }
    .cap-dr-src-actions button:hover {
      color: var(--cap-dr-fg);
      border-color: var(--cap-dr-fg);
    }
    .cap-dr-src-actions button[data-action="remove"]:hover {
      color: #f43f5e; border-color: #f43f5e;
    }
    .cap-dr-src-actions button[data-action="hide"]:hover {
      color: #f59e0b; border-color: #f59e0b;
    }
    .cap-dr-src-actions button[data-action="pin"]:hover {
      color: #10b981; border-color: #10b981;
    }
    /* Pinned / hidden visual states */
    .cap-dr-source-row.is-pinned {
      border-left: 2px solid #10b981;
    }
    .cap-dr-source-row.is-pinned::after {
      content: "pinned";
      position: absolute; left: 6px; bottom: 4px;
      font-size: 8px; letter-spacing: 0.08em; text-transform: uppercase;
      color: #10b981; font-weight: 600;
    }
    .cap-dr-source-row.is-hidden {
      opacity: 0.4;
    }
    .cap-dr-source-row.is-hidden .cap-dr-src-title {
      text-decoration: line-through;
    }
    .cap-dr-source-row.is-removed { display: none; }

    /* P1 #6: touch / coarse-pointer devices always show the action cluster */
    @media (hover: none), (pointer: coarse) {
      .cap-dr-src-actions {
        opacity: 1;
        pointer-events: auto;
      }
    }

    /* P1 #3: "Show N removed" recovery panel */
    .cap-dr-removed-wrap {
      margin-top: 10px;
      padding-top: 8px;
      border-top: 1px dashed var(--cap-dr-card-border);
    }
    .cap-dr-removed-toggle {
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 11px;
      background: transparent;
      color: var(--cap-dr-fg-dim);
      border: 0;
      padding: 4px 0;
      cursor: pointer;
      letter-spacing: 0.04em;
    }
    .cap-dr-removed-toggle:hover {
      color: var(--cap-dr-fg);
      text-decoration: underline;
    }
    .cap-dr-removed-panel {
      margin-top: 6px;
      padding: 6px 8px;
      background: var(--cap-dr-bg-soft);
      border: 1px solid var(--cap-dr-card-border);
      border-radius: 4px;
    }
    .cap-dr-removed-row {
      display: flex;
      gap: 8px;
      align-items: center;
      padding: 4px 0;
      font-size: 12px;
    }
    .cap-dr-removed-row .cap-dr-src-title {
      flex: 1;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .cap-dr-removed-restore {
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 11px;
      padding: 3px 8px;
      background: var(--cap-dr-bg-soft);
      color: var(--cap-dr-fg-dim);
      border: 1px solid var(--cap-dr-card-border);
      border-radius: 3px;
      cursor: pointer;
    }
    .cap-dr-removed-restore:hover {
      color: #10b981;
      border-color: #10b981;
    }

    /* Add Context strip — collapsed-by-default trigger row.
       Lifted from DRA .add-context-section (compact variant). */
    .cap-dr-addctx {
      background: var(--cap-dr-addctx-bg);
      border: 1px solid var(--cap-dr-addctx-border);
      border-radius: 6px;
      margin-top: 8px;
      margin-bottom: 18px;
      display: flex; flex-direction: column;
      opacity: 0.92;
      transition: opacity 0.15s ease, box-shadow 0.15s ease;
    }
    .cap-dr-addctx.drag-pulse {
      background: rgba(59,130,246,0.12);
      box-shadow: inset 0 0 0 1px rgba(59,130,246,0.5);
      opacity: 1;
    }
    .cap-dr-addctx-trigger {
      display: flex; align-items: center; gap: 8px;
      min-height: 32px;
      padding: 6px 12px;
      background: transparent;
      border: none;
      color: var(--cap-dr-fg);
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 12px;
      font-weight: 500;
      letter-spacing: 0.04em;
      cursor: pointer;
      text-align: left;
      width: 100%;
    }
    .cap-dr-addctx-trigger:hover {
      background: var(--cap-dr-addctx-border);
    }
    .cap-dr-addctx-trigger:active {
      transform: translateY(1px);
    }
    .cap-dr-addctx-trigger-label {
      font-weight: 500;
    }
    .cap-dr-addctx-trigger-hint {
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 10px;
      color: var(--cap-dr-fg-dim);
      letter-spacing: 0.02em;
      margin-left: auto;
    }
    .cap-dr-addctx-trigger-chevron {
      font-size: 11px;
      color: var(--cap-dr-fg-dim);
      transition: transform 0.18s ease;
      margin-left: 6px;
    }
    .cap-dr-addctx[data-collapsed="false"] .cap-dr-addctx-trigger-chevron {
      transform: rotate(180deg);
    }
    .cap-dr-addctx-body {
      max-height: 0;
      overflow: hidden;
      opacity: 0;
      padding: 0 16px;
      transition: max-height 0.25s ease, opacity 0.18s ease, padding 0.18s ease;
    }
    .cap-dr-addctx[data-collapsed="false"] .cap-dr-addctx-body {
      max-height: 4000px;
      opacity: 1;
      padding: 4px 16px 12px;
      overflow: visible;
    }
    .cap-dr-addctx-drop {
      border: 2px dashed var(--cap-dr-card-border);
      border-radius: 8px;
      padding: 18px;
      text-align: center;
      cursor: pointer;
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 12px;
      color: var(--cap-dr-fg-dim);
      transition: border-color 0.15s ease, background 0.15s ease;
      margin-bottom: 10px;
    }
    .cap-dr-addctx-drop.dragging,
    .cap-dr-files-dropzone.dragging {
      border-color: var(--cap-dr-accent-blue);
      background: rgba(59,130,246,0.08);
      color: var(--cap-dr-fg);
    }
    .cap-dr-addctx-drop strong { color: var(--cap-dr-fg); }
    .cap-dr-addctx-drop .drop-hint {
      display: block;
      margin-top: 4px;
      font-size: 11px;
      color: var(--cap-dr-fg-dimmer);
    }
    .cap-dr-addctx-input {
      width: 100%;
      min-height: 84px;
      resize: vertical;
      padding: 10px 12px;
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 13px;
      background: var(--cap-dr-bg-soft);
      border: 1px solid var(--cap-dr-card-border);
      color: var(--cap-dr-fg);
      border-radius: 4px;
      box-sizing: border-box;
    }
    .cap-dr-addctx-input:focus {
      outline: none;
      border-color: var(--cap-dr-fg-dim);
    }
    .cap-dr-addctx-actions {
      display: flex; gap: 8px; align-items: center;
      margin-top: 8px;
    }
    .cap-dr-addctx-save {
      background: var(--cap-dr-accent-blue-strong);
      color: #fff;
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-weight: 600;
      padding: 7px 16px;
      border-radius: 4px;
      border: none;
      cursor: pointer;
      letter-spacing: 0.04em;
      font-size: 12px;
    }
    .cap-dr-addctx-save:hover { background: var(--cap-dr-accent-blue-hover); }
    .cap-dr-addctx-clear {
      background: var(--cap-dr-card-bg);
      color: var(--cap-dr-fg-dim);
      border: 1px solid var(--cap-dr-card-border);
      padding: 7px 14px;
      border-radius: 4px;
      cursor: pointer;
      font-family: 'Source Code Pro', ui-monospace, monospace;
      font-size: 12px;
      letter-spacing: 0.04em;
    }
    .cap-dr-addctx-clear:hover { color: var(--cap-dr-fg); border-color: var(--cap-dr-fg-dim); }
    .cap-dr-addctx-summary {
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 11px;
      color: var(--cap-dr-fg-dim);
      margin-top: 8px;
    }
    .cap-dr-addctx-list {
      margin-top: 8px;
      max-height: 300px;
      overflow-y: auto;
      border-top: 1px solid var(--cap-dr-addctx-border);
      padding-top: 8px;
      display: flex; flex-direction: column; gap: 6px;
    }
    .cap-dr-addctx-item {
      background: var(--cap-dr-card-bg);
      border: 1px solid var(--cap-dr-card-border);
      border-radius: 4px;
      padding: 8px 10px;
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 12px;
      color: var(--cap-dr-fg);
      white-space: pre-wrap;
      position: relative;
    }
    .cap-dr-addctx-item-meta {
      font-size: 10px;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: var(--cap-dr-fg-dimmer);
      margin-bottom: 4px;
    }
    .cap-dr-addctx-item .cap-dr-row-del {
      position: absolute; top: 6px; right: 6px;
      opacity: 0; transition: opacity 0.15s ease;
    }
    .cap-dr-addctx-item:hover .cap-dr-row-del { opacity: 1; }

    /* Notes section */
    .cap-dr-notes-list {
      display: flex; flex-direction: column; gap: 6px;
    }
    .cap-dr-note-card {
      background: var(--cap-dr-card-bg);
      border: 1px solid var(--cap-dr-card-border);
      border-radius: 4px;
      padding: 8px 10px;
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 12px;
      color: var(--cap-dr-fg);
      white-space: pre-wrap;
      position: relative;
      line-height: 1.55;
    }
    .cap-dr-note-meta {
      font-size: 10px;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: var(--cap-dr-fg-dimmer);
      margin-bottom: 4px;
    }
    .cap-dr-note-card .cap-dr-row-del {
      position: absolute; top: 6px; right: 6px;
      opacity: 0; transition: opacity 0.15s ease;
    }
    .cap-dr-note-card:hover .cap-dr-row-del { opacity: 1; }
    .cap-dr-composer {
      background: var(--cap-dr-addctx-bg);
      border: 1px solid var(--cap-dr-addctx-border);
      border-radius: 6px;
      padding: 10px 12px;
      margin-bottom: 10px;
      display: flex; flex-direction: column; gap: 8px;
    }
    .cap-dr-composer textarea,
    .cap-dr-composer input {
      width: 100%;
      box-sizing: border-box;
      background: var(--cap-dr-bg-soft);
      border: 1px solid var(--cap-dr-card-border);
      color: var(--cap-dr-fg);
      padding: 8px 12px;
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 13px;
      border-radius: 4px;
    }
    .cap-dr-composer textarea { min-height: 60px; resize: vertical; }
    .cap-dr-composer textarea:focus,
    .cap-dr-composer input:focus {
      outline: none; border-color: var(--cap-dr-fg-dim);
    }
    .cap-dr-composer-actions {
      display: flex; gap: 8px; align-items: center;
    }
    .cap-dr-composer-hint {
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 10px;
      color: var(--cap-dr-fg-dimmer);
      margin-left: auto;
      letter-spacing: 0.02em;
    }

    /* Row delete (×) button, shared */
    .cap-dr-row-del {
      background: transparent;
      border: 1px solid var(--cap-dr-card-border);
      color: var(--cap-dr-fg-dim);
      border-radius: 3px;
      font-size: 11px;
      line-height: 1;
      padding: 2px 6px;
      cursor: pointer;
    }
    .cap-dr-row-del:hover {
      color: #f43f5e; border-color: #f43f5e;
    }

    /* Files section */
    .cap-dr-files-dropzone {
      border: 2px dashed var(--cap-dr-card-border);
      border-radius: 8px;
      padding: 18px;
      text-align: center;
      cursor: pointer;
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 12px;
      color: var(--cap-dr-fg-dim);
      margin-bottom: 10px;
      transition: border-color 0.15s ease, background 0.15s ease;
    }
    .cap-dr-files-dropzone strong { color: var(--cap-dr-fg); }
    .cap-dr-files-dropzone .drop-hint {
      display: block;
      margin-top: 4px;
      font-size: 11px;
      color: var(--cap-dr-fg-dimmer);
    }
    .cap-dr-files-list {
      list-style: none; padding: 0; margin: 0;
      display: flex; flex-direction: column; gap: 4px;
    }
    .cap-dr-file-row {
      display: grid;
      grid-template-columns: 1fr 70px 1fr 28px;
      gap: 8px; align-items: center;
      padding: 6px 10px;
      background: var(--cap-dr-card-bg);
      border: 1px solid var(--cap-dr-card-border);
      border-radius: 4px;
      font-family: 'Roboto Mono', ui-monospace, monospace;
      font-size: 11px;
      color: var(--cap-dr-fg);
    }
    .cap-dr-file-row .cap-dr-file-name {
      color: var(--cap-dr-fg); font-weight: 600;
      overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    }
    .cap-dr-file-row .cap-dr-file-size,
    .cap-dr-file-row .cap-dr-file-status {
      color: var(--cap-dr-fg-dim); font-size: 10px;
    }

    /* Drag-pulse on the whole detail overlay during window-drop */
    .cap-dr-detail.drag-pulse {
      box-shadow: inset 0 0 0 2px rgba(59,130,246,0.45);
    }
    /* ───── END WORKSPACE AFFORDANCES ───── */

    @keyframes capDrFade { from { opacity: 0; } to { opacity: 1; } }
    @media (prefers-reduced-motion: reduce) {
      .cap-dr-overlay, .cap-dr-detail, .cap-dr-landing,
      .cap-dr-overlay.is-open, .cap-dr-detail.is-open, .cap-dr-landing.is-open {
        animation: none !important;
        transition: none !important;
      }
    }
    /* ── END DR LAYER ── */

    /* ─── R10: DATA ROOMS LIGHT-MODE PALETTE ─── */
    /* Single source of truth: <html data-theme="light"> from the main app theme toggle.
       All cap-dr- surfaces re-color via CSS variable cascade — no JS needed. */

    :root[data-theme="light"] .cap-dr-overlay,
    :root[data-theme="light"] .cap-dr-detail {
      --cap-dr-bg:                #fbfaf6;
      --cap-dr-bg-soft:           #f1efe8;
      --cap-dr-fg:                #1b1f1d;
      --cap-dr-fg-dim:            #4b524f;
      --cap-dr-fg-dimmer:         #767d79;
      --cap-dr-card-bg:           #ffffff;
      --cap-dr-card-border:       #e6e3d8;
      --cap-dr-card-border-hover: #b8b3a1;
      --cap-dr-addctx-bg:         #f4f3ee;
      --cap-dr-addctx-border:     #dfddd0;
      --cap-dr-accent-blue:       #2563eb;
      --cap-dr-accent-blue-strong:#1d4ed8;
      --cap-dr-accent-blue-hover: #1e40af;
      --cap-dr-accent-blue-active:#1e3a8a;
    }

    /* Landing card .dr — bump cyan alphas for visibility on warm-paper bg */
    :root[data-theme="light"] .cap-dr-landing-card.dr {
      background: linear-gradient(155deg, rgba(6,182,212,0.16) 0%, var(--bg-1) 100%);
      border-color: rgba(6,182,212,0.55);
    }
    :root[data-theme="light"] .cap-dr-landing-card.dr:hover {
      background: linear-gradient(155deg, rgba(6,182,212,0.26) 0%, var(--bg-hover) 100%);
      border-color: rgba(6,182,212,0.75);
    }
    :root[data-theme="light"] .cap-dr-landing-card.dr .cap-dr-landing-glyph { color: #0891b2; }

    /* Borders that were hardcoded mid-gray — re-use the token */
    :root[data-theme="light"] .cap-dr-overlay-x,
    :root[data-theme="light"] .cap-dr-detail-back,
    :root[data-theme="light"] .cap-dr-detail-x { border-color: var(--cap-dr-card-border); }

    /* Ask-all CTA — shadow lighter on warm paper */
    :root[data-theme="light"] .cap-dr-ask-all {
      box-shadow: 0 1px 2px rgba(20,30,25,0.10), inset 0 1px 0 rgba(255,255,255,0.15);
    }
    :root[data-theme="light"] .cap-dr-ask-all:hover {
      box-shadow: 0 4px 12px rgba(37,99,235,0.28);
    }

    /* R11: chat-scope tokenized at source (B6) — no light override needed */

    /* AI chat bubble — blue-tinted bg flips from #0e1a2e to #eaf2ff */
    :root[data-theme="light"] .cap-dr-message.ai .cap-dr-message-bubble {
      background: #eaf2ff;
      color: #0f172a;
    }

    /* R13.4: detail-pill hover tint — softer on light */
    :root[data-theme="light"] .cap-dr-detail-pill:hover { background: rgba(59,130,246,0.10); }

    /* Source-type type-tags — text darker, fills slightly stronger for legibility on white */
    :root[data-theme="light"] .cap-dr-src-type.transcript { color: #1d4ed8; background: rgba(59,130,246,0.10); border-color: rgba(59,130,246,0.45); }
    :root[data-theme="light"] .cap-dr-src-type.deck       { color: #be185d; background: rgba(236,72,153,0.10); border-color: rgba(236,72,153,0.45); }
    :root[data-theme="light"] .cap-dr-src-type.model      { color: #0e7490; background: rgba(6,182,212,0.10); border-color: rgba(6,182,212,0.45); }
    :root[data-theme="light"] .cap-dr-src-type.update     { color: #b45309; background: rgba(245,158,11,0.10); border-color: rgba(245,158,11,0.45); }
    :root[data-theme="light"] .cap-dr-src-type.memo       { color: #0f766e; background: rgba(20,184,166,0.10); border-color: rgba(20,184,166,0.45); }

    /* Stragglers — placeholder text */
    :root[data-theme="light"] .cap-dr-source-expand-placeholder { color: var(--cap-dr-fg-dimmer); }

    /* Legacy scope-pill (safety: not rendered today, but covers ghost render paths) */
    :root[data-theme="light"] .cap-dr-scope-pill { background: rgba(59,130,246,0.12); border-color: rgba(59,130,246,0.45); }

    /* Semantic action colors — darken one tier for AA on light */
    :root[data-theme="light"] .cap-dr-src-actions button[data-action="remove"]:hover,
    :root[data-theme="light"] .cap-dr-row-del:hover { color: #e11d48; border-color: #e11d48; }
    :root[data-theme="light"] .cap-dr-src-actions button[data-action="hide"]:hover { color: #d97706; border-color: #d97706; }
    :root[data-theme="light"] .cap-dr-src-actions button[data-action="pin"]:hover,
    :root[data-theme="light"] .cap-dr-removed-restore:hover { color: #059669; border-color: #059669; }
    :root[data-theme="light"] .cap-dr-source-row.is-pinned { border-left-color: #059669; }
    :root[data-theme="light"] .cap-dr-source-row.is-pinned::after { color: #059669; }

    /* Drag-pulse states */
    :root[data-theme="light"] .cap-dr-addctx.drag-pulse {
      background: rgba(59,130,246,0.10);
      box-shadow: inset 0 0 0 1px rgba(59,130,246,0.65);
    }
    :root[data-theme="light"] .cap-dr-addctx-drop.dragging,
    :root[data-theme="light"] .cap-dr-files-dropzone.dragging {
      background: rgba(59,130,246,0.10);
    }
    :root[data-theme="light"] .cap-dr-detail.drag-pulse {
      box-shadow: inset 0 0 0 2px rgba(59,130,246,0.55);
    }

    /* ─── R10: DR PILL LIGHT-MODE (Mark ask #1) ─── */
    /* Dark pill uses 0.10 alpha gradient + 0.30 border — invisible on warm-paper bg.
       Bump alphas + darken text so the pill reads as a clear, prominent "different mode" affordance. */
    :root[data-theme="light"] .tab.data-rooms {
      background: linear-gradient(135deg, rgba(59, 130, 246, 0.18) 0%, rgba(139, 92, 246, 0.18) 100%);
      border: 1px solid rgba(139, 92, 246, 0.55);
      border-bottom: 1px solid rgba(139, 92, 246, 0.55);
      color: #4f378b;
    }
    :root[data-theme="light"] .tab.data-rooms:hover {
      background: linear-gradient(135deg, rgba(59, 130, 246, 0.28) 0%, rgba(139, 92, 246, 0.28) 100%);
      border-color: rgba(139, 92, 246, 0.75);
      color: #3b2774;
      box-shadow: 0 0 12px rgba(139, 92, 246, 0.18);
    }
    :root[data-theme="light"] .tab.data-rooms:focus-visible {
      outline-color: rgba(139, 92, 246, 0.75);
    }
    :root[data-theme="light"] .tab.data-rooms.active {
      border-bottom-color: rgba(139, 92, 246, 0.55);
    }
    :root[data-theme="light"] .tab.data-rooms .cap-dr-pill-badge {
      background: rgba(139, 92, 246, 0.20);
      color: #5b3ebc;
    }
    :root[data-theme="light"] .tab.data-rooms:hover .cap-dr-pill-badge {
      background: rgba(139, 92, 246, 0.32);
      color: #4f378b;
    }
    /* ─── END R10 ─── */

    /* ─────────────────  CONTENT  ───────────────── */
    .content-area { flex: 1; overflow-y: auto; padding: 14px 16px 18px; min-height: 0; -webkit-overflow-scrolling: touch; position: relative; }
    /* When inside scrolling content-area, the fab needs to be sticky-style — pin to viewport top of pane */
    .content-pane-wrap { flex: 1; position: relative; display: flex; flex-direction: column; min-height: 0; }

    .empty-state {
      display: flex; align-items: center; justify-content: center; height: 100%;
      color: var(--text-3); font-size: 14px; flex-direction: column; gap: 12px;
      text-align: center; padding: 32px;
    }
    .empty-state .glyph {
      width: 56px; height: 56px; border-radius: 14px;
      background: var(--bg-2); border: 1px solid var(--line);
      display: grid; place-items: center; color: var(--text-4);
      box-shadow: var(--shadow-sm);
    }
    .empty-state .glyph svg { width: 24px; height: 24px; }
    .empty-state .lead { color: var(--text-2); font-weight: 600; }

    /* Transcript lines */
    .t-line { margin-bottom: 14px; }
    .t-line .t-speaker {
      font-size: 11px; font-weight: 700; color: var(--accent);
      margin-bottom: 3px; letter-spacing: 0.02em; text-transform: uppercase;
      display: inline-flex; align-items: baseline; gap: 8px;
    }
    .t-line .t-text { font-size: 14px; color: var(--text); line-height: 1.6; }
    .t-line .t-time { font-size: 10px; color: var(--text-4); font-family: 'JetBrains Mono', ui-monospace, monospace; font-weight: 500; letter-spacing: 0; text-transform: none; }

    /* Session chip */
    .session-header {
      display: flex; align-items: center; justify-content: space-between;
      padding: 10px 12px; margin: 6px 0 14px;
      background: var(--bg-2);
      border: 1px solid var(--line); border-radius: 10px;
      box-shadow: var(--shadow-sm);
      position: relative; overflow: hidden;
    }
    .session-header::before {
      content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
      background: var(--accent);
    }
    .session-header:first-child { margin-top: 0; }
    .session-info { display: flex; flex-direction: column; gap: 2px; min-width: 0; flex: 1; padding-left: 8px; }
    .session-title { font-size: 13px; font-weight: 700; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; letter-spacing: -0.005em; }
    .session-meta { font-size: 11px; color: var(--text-3); }
    .session-clear-btn {
      background: transparent; border: 1px solid transparent; color: var(--text-3);
      font-size: 14px; cursor: pointer; padding: 5px 9px; border-radius: 7px;
      transition: color 160ms ease, background 160ms ease;
    }
    .session-clear-btn:hover { color: var(--danger); background: var(--danger-soft); }
    .session-divider { border: none; border-top: 1px dashed var(--line); margin: 18px 0; }

    /* Generic cards */
    .a-entry {
      background: var(--bg-2); border: 1px solid var(--line); border-radius: 12px;
      padding: 14px; margin-bottom: 10px; box-shadow: var(--shadow-sm);
    }
    .a-entry .a-meta { font-size: 11px; color: var(--text-3); margin-bottom: 8px; }
    .a-entry .a-content { font-size: 14px; line-height: 1.6; color: var(--text); white-space: pre-wrap; }

    /* Chat — editorial layout (matches reference app) */
    .chat-q {
      font-size: 14px; color: var(--text-3); font-weight: 500;
      padding: 0 0 14px 0; margin: 0 0 18px 0;
      border-bottom: 1px solid var(--line);
      display: flex; gap: 10px; align-items: flex-start;
    }
    .chat-q::before {
      content: "Q"; flex-shrink: 0;
      width: 22px; height: 22px; border-radius: 6px;
      display: grid; place-items: center;
      background: var(--accent-soft); color: var(--accent);
      font-size: 10px; font-weight: 800; letter-spacing: 0.05em;
      border: 1px solid var(--accent-line);
      margin-top: 1px;
    }
    .chat-q .q-text { flex: 1; padding-top: 3px; }
    .chat-a {
      background: transparent; border: none;
      border-radius: 0; padding: 0;
      margin: 0 0 28px 0;
      box-shadow: none;
    }
    .chat-a.streaming { border: none; box-shadow: none; }

    /* ─────────────────  BOTTOM BAR  (B7 fix: merged base + premium, dropped nested backdrop-filter, trimmed transition) ───────────────── */
    .bottom-bar {
      flex-shrink: 0; border-top: none;
      background: color-mix(in oklab, var(--bg) 60%, transparent);
      backdrop-filter: saturate(180%) blur(18px);
      padding: 10px 12px; display: flex; gap: 8px;
      padding-bottom: max(10px, env(safe-area-inset-bottom));
      position: relative;
    }
    .bottom-bar::before {
      content: ""; position: absolute; left: 0; right: 0; top: 0; height: 1px;
      background: linear-gradient(90deg, transparent, var(--line-strong), transparent);
    }
    .bottom-bar input {
      flex: 1; padding: 11px 14px;
      border: 1px solid var(--line-strong); border-radius: 10px;
      background: color-mix(in oklab, var(--bg-2) 80%, transparent); color: var(--text);
      font-family: inherit; font-size: 14px; outline: none;
      transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
    }
    .bottom-bar input:focus { border-color: var(--accent); box-shadow: var(--ring); }
    .bottom-bar input::placeholder { color: var(--text-4); }

    .send-btn {
      padding: 11px 20px; background: var(--accent); color: #fff;
      border: none; border-radius: 10px; font-size: 13px; font-weight: 700;
      cursor: pointer; letter-spacing: 0.04em; font-family: inherit;
      text-shadow: 0 1px 2px rgba(0,0,0,0.3);
      transition: background 150ms ease, border-color 150ms ease;
      box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.2),
        0 0 0 1px color-mix(in oklab, var(--accent) 50%, transparent),
        0 10px 24px -10px var(--accent-glow);
    }
    .send-btn:hover { filter: brightness(1.06); }
    .send-btn:active { transform: scale(0.96); }
    .send-btn:disabled { background: var(--bg-3); color: var(--text-4); box-shadow: none; cursor: not-allowed; }

    /* Quick model selector: small box next to Send. Hidden by default;
       unhidden by initModelQuickSelects() on internal (non-consumer) builds. */
    .model-quick-select {
      height: 38px; max-width: 112px; padding: 0 6px;
      background: var(--bg-3); color: var(--text-2);
      border: 1px solid var(--line); border-radius: 10px;
      font-size: 12px; font-family: inherit; cursor: pointer;
      align-self: center; flex-shrink: 0;
    }
    .model-quick-select:focus { outline: none; border-color: var(--accent); }

    /* Voice-input button: small round white pill to the right of Send, mirrors
       the iOS-style dictation control from the user reference. align-self:center
       keeps the round mic centered on Send's vertical axis (Send is a stretched
       flex child, voice-btn has a fixed 38px height). */
    .voice-btn {
      flex-shrink: 0; align-self: center;
      width: 38px; height: 38px; padding: 0;
      background: #fff; color: #0b0d0c;
      border: 1px solid rgba(0,0,0,0.12); border-radius: 50%;
      cursor: pointer;
      display: inline-flex; align-items: center; justify-content: center;
      box-shadow: 0 1px 3px rgba(0,0,0,0.18), 0 2px 8px -2px rgba(0,0,0,0.12);
      transition: transform 140ms cubic-bezier(.2,.7,.3,1.4),
                  background 160ms ease, box-shadow 160ms ease, color 160ms ease;
    }
    .voice-btn svg { width: 18px; height: 18px; }
    .voice-btn:hover { background: #f4f4f5; }
    .voice-btn:active { transform: scale(0.92); }
    .voice-btn:focus-visible { outline: none; box-shadow: 0 0 0 2px var(--accent), 0 1px 3px rgba(0,0,0,0.18); }
    .voice-btn.recording {
      background: #dc2626; color: #fff;
      animation: voice-pulse 1.2s ease-in-out infinite;
    }
    .voice-btn[disabled] { opacity: 0.4; cursor: not-allowed; }
    @keyframes voice-pulse {
      0%, 100% { box-shadow: 0 0 0 0 rgba(220,38,38,0.55), 0 1px 3px rgba(0,0,0,0.18); }
      50%      { box-shadow: 0 0 0 8px rgba(220,38,38,0),    0 1px 3px rgba(0,0,0,0.18); }
    }
    @media (prefers-reduced-motion: reduce) {
      .voice-btn.recording { animation: none; box-shadow: 0 0 0 3px rgba(220,38,38,0.35), 0 1px 3px rgba(0,0,0,0.18); }
    }

    .mat-btn {
      padding: 0; width: 42px; height: 42px;
      border: 1px solid var(--line-strong); border-radius: 10px;
      background: var(--bg-2); color: var(--text-3);
      cursor: pointer; flex-shrink: 0;
      display: grid; place-items: center;
      transition: color 160ms ease, border-color 160ms ease, transform 140ms cubic-bezier(.2,.7,.3,1.4);
    }
    .mat-btn:hover { color: var(--accent); border-color: var(--accent-line); }
    .mat-btn:active { transform: scale(0.93); }
    .mat-btn svg { width: 16px; height: 16px; }

    /* Auto-Analysis grid: 2-up on phones, 3-up before stretching to 6-in-a-row.
       Reads break-before-squish so labels stay legible. */
    .auto-analysis-controls {
      display: grid; gap: 8px; padding: 4px 0 12px;
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    @media(min-width:560px){
      .auto-analysis-controls { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    }
    @media(min-width:980px){
      .auto-analysis-controls { grid-template-columns: repeat(6, minmax(0, 1fr)); }
    }
    .aa-btn {
      --aa-c: var(--accent);
      --aa-soft: color-mix(in oklab, var(--aa-c) 12%, transparent);
      --aa-line: color-mix(in oklab, var(--aa-c) 35%, transparent);
      --aa-glow: color-mix(in oklab, var(--aa-c) 28%, transparent);
      display: flex; align-items: center; gap: 8px;
      padding: 10px 14px; border: 1px solid var(--line); border-radius: 10px;
      background: var(--bg-2); color: var(--text);
      font-family: inherit; font-size: 12px; font-weight: 600;
      cursor: pointer; text-align: left;
      min-width: 0;
      position: relative; overflow: hidden;
      transition: transform 140ms cubic-bezier(.2,.7,.3,1.4), border-color 200ms ease, background 200ms ease, color 200ms ease, box-shadow 200ms ease;
      box-shadow: var(--shadow-sm);
    }
    .auto-analysis-panel { display: flex; flex-direction: column; gap: 8px; height: 100%; }
    /* Per-category color tokens */
    .aa-btn[data-aa="summary"] { --aa-c: oklch(0.72 0.13 245); }
    .aa-btn[data-aa="risks"]   { --aa-c: oklch(0.70 0.18 25);  }
    .aa-btn[data-aa="actions"] { --aa-c: oklch(0.72 0.16 155); }
    .aa-btn[data-aa="numbers"] { --aa-c: oklch(0.78 0.15 75);  }
    .aa-btn[data-aa="dd"]      { --aa-c: oklch(0.70 0.16 295); }
    .aa-btn[data-aa="deal"]    { --aa-c: oklch(0.74 0.13 195); }
    :root[data-theme="light"] .aa-btn[data-aa="summary"] { --aa-c: oklch(0.52 0.16 252); }
    :root[data-theme="light"] .aa-btn[data-aa="risks"]   { --aa-c: oklch(0.55 0.19 25);  }
    :root[data-theme="light"] .aa-btn[data-aa="actions"] { --aa-c: oklch(0.52 0.15 155); }
    :root[data-theme="light"] .aa-btn[data-aa="numbers"] { --aa-c: oklch(0.62 0.15 65);  }
    :root[data-theme="light"] .aa-btn[data-aa="dd"]      { --aa-c: oklch(0.52 0.18 295); }
    :root[data-theme="light"] .aa-btn[data-aa="deal"]    { --aa-c: oklch(0.55 0.13 195); }
    /* Tinted icon chip per category */
    .aa-btn .aa-icon {
      width: 24px; height: 24px; border-radius: 7px;
      display: inline-flex; align-items: center; justify-content: center;
      background: var(--aa-soft);
      color: var(--aa-c);
      border: 1px solid var(--aa-line);
      flex-shrink: 0;
      transition: background 220ms ease, color 220ms ease, border-color 220ms ease, transform 220ms ease, box-shadow 220ms ease;
    }
    .aa-btn .aa-icon svg { width: 13px; height: 13px; }
    /* Hover — tile lifts and stroke takes the category color */
    .aa-btn:hover {
      border-color: var(--aa-line);
      box-shadow: 0 8px 22px -14px var(--aa-glow), var(--shadow-sm);
    }
    /* Loading — tile fully tinted, ring around icon */
    .aa-btn.loading {
      border-color: var(--aa-line);
      background: var(--aa-soft);
      pointer-events: none;
      box-shadow: 0 0 0 1px var(--aa-line), 0 12px 30px -14px var(--aa-glow);
    }
    .aa-btn.loading .aa-icon {
      background: var(--aa-c); color: var(--aa-c);
      box-shadow: 0 0 0 3px var(--aa-glow), 0 0 18px var(--aa-glow);
    }
    .aa-btn.loading .aa-icon svg { animation: spin 1s linear infinite; color: var(--accent-ink); }
    /* Has-result — saturated stroke, soft fill, icon stays lit */
    .aa-btn.has-result {
      border-color: var(--aa-c);
      background: var(--aa-soft);
      color: var(--text);
      box-shadow: 0 0 0 1px var(--aa-line) inset, 0 6px 18px -12px var(--aa-glow);
    }
    .aa-btn.has-result .aa-icon {
      background: var(--aa-c); color: var(--accent-ink);
      border-color: var(--aa-c);
      box-shadow: 0 0 0 2px var(--aa-glow);
    }
    .aa-btn.has-result .aa-icon svg { color: var(--accent-ink); }
    /* Active (currently displayed) — outlined ring + subtle scan-line */
    .aa-btn.active {
      border-color: var(--aa-c);
      background: linear-gradient(180deg, var(--aa-soft), color-mix(in oklab, var(--aa-c) 6%, transparent));
      box-shadow:
        0 0 0 1px var(--aa-c),
        0 1px 0 color-mix(in oklab, var(--aa-c) 35%, transparent) inset,
        0 14px 32px -14px var(--aa-glow);
      transform: translateY(-1px);
    }
    .aa-btn.active .aa-icon {
      background: var(--aa-c); color: var(--accent-ink);
      border-color: var(--aa-c);
      box-shadow: 0 0 0 3px var(--aa-glow), 0 0 14px var(--aa-glow);
    }
    .aa-btn.active .aa-icon svg { color: var(--accent-ink); }

    /* ─────────────────  MOBILE HEADER  ───────────────── */
    @media(max-width:600px){
      .header { padding: 8px 10px; gap: 6px; }
      .header h1 { font-size: 13px; }
      .brand-mark svg { width: 14px; height: 14px; }
      .brand-name { gap: 4px; }
      .status-pill { display: none; }
      .header-btns { gap: 4px; }
      .hbtn { padding: 5px 8px; font-size: 10px; border-radius: 6px; }
      .icon-btn { width: 26px; height: 26px; border-radius: 6px; }
      .icon-btn svg { width: 12px; height: 12px; }
      .status-bar { padding: 5px 12px; font-size: 10px; }
      .stats-bar { padding: 5px 12px; gap: 8px; }
      .stat-pill { font-size: 10px; }
      .tabs .tab { padding: 8px 4px; font-size: 11px; }
      .bottom-bar { padding: 8px 10px; gap: 6px; }
      .bottom-bar input { padding: 8px 10px; font-size: 13px; }
      .send-btn { padding: 8px 14px; font-size: 13px; }
      .voice-btn { width: 34px; height: 34px; }
      .voice-btn svg { width: 16px; height: 16px; }
    }
    .aa-btn:active { transform: scale(0.97); }
    @keyframes spin { to { transform: rotate(360deg); } }
    .aa-btn .aa-label { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .aa-btn .aa-check {
      width: 16px; height: 16px; border-radius: 50%;
      background: var(--aa-c); color: var(--accent-ink);
      display: none; align-items: center; justify-content: center;
      flex-shrink: 0; opacity: 0;
      transform: scale(0.6);
      transition: opacity 220ms ease, transform 320ms cubic-bezier(.2,.7,.3,1.6);
      box-shadow: 0 0 0 2px var(--aa-glow);
    }
    .aa-btn.has-result .aa-check, .aa-btn.active .aa-check {
      display: inline-flex; opacity: 1; transform: scale(1);
    }
    .aa-btn .aa-check svg { width: 9px; height: 9px; }
    .aa-results { flex: 1; overflow-y: auto; }

    /* ─────────────────  FULL-PAGE (settings)  ───────────────── */
    .page {
      display: none; flex-direction: column; position: absolute; inset: 0;
      background: var(--bg); z-index: 100;
      animation: pageIn 220ms cubic-bezier(.2,.7,.2,1);
    }
    .page.open { display: flex; }
    @keyframes pageIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
    .page-header {
      display: flex; align-items: center; gap: 12px;
      padding: 14px 16px;
      background: color-mix(in oklab, var(--bg-1) 90%, transparent);
      backdrop-filter: blur(10px);
      border-bottom: 1px solid var(--line);
      flex-shrink: 0; padding-top: max(14px, env(safe-area-inset-top));
    }
    .page-header h2 { font-size: 17px; font-weight: 700; color: var(--text); letter-spacing: -0.01em; }
    .page-back {
      background: transparent; border: 1px solid var(--line-strong);
      width: 32px; height: 32px; border-radius: 8px;
      color: var(--text-2); cursor: pointer;
      display: grid; place-items: center;
      transition: color 160ms ease, border-color 160ms ease, background 160ms ease;
    }
    .page-back:hover { color: var(--accent); border-color: var(--accent-line); background: var(--accent-soft); }
    .page-back svg { width: 14px; height: 14px; }
    .page-body { flex: 1; overflow-y: auto; padding: 22px 18px; padding-bottom: max(20px, env(safe-area-inset-bottom)); max-width: 720px; width: 100%; margin: 0 auto; }

    .settings-section { margin-bottom: 30px; }
    .settings-section h3 {
      font-size: 11px; font-weight: 700; text-transform: uppercase;
      letter-spacing: 0.08em; color: var(--text-3); margin-bottom: 12px;
    }

    .key-card, .preset-card {
      background: var(--bg-2); border: 1px solid var(--line);
      border-radius: 12px; padding: 16px; margin-bottom: 10px;
      box-shadow: var(--shadow-sm);
      transition: border-color 160ms ease, transform 140ms cubic-bezier(.2,.7,.3,1.4);
    }
    .key-card-top, .preset-top {
      display: flex; align-items: center; justify-content: space-between;
      margin-bottom: 8px; gap: 10px;
    }
    .key-card-label, .preset-name { font-size: 15px; font-weight: 600; color: var(--text); letter-spacing: -0.005em; }
    .preset-name { font-size: 16px; font-weight: 700; }

    .provider-badge, .preset-badge {
      font-size: 10px; font-weight: 700; padding: 3px 9px;
      border-radius: 999px; text-transform: uppercase; letter-spacing: 0.06em;
      background: var(--accent-soft); color: var(--accent);
      border: 1px solid var(--accent-line);
    }

    .key-display {
      font-family: 'JetBrains Mono', ui-monospace, monospace;
      font-size: 12px; color: var(--text-3);
      padding: 9px 12px; background: var(--bg-3); border-radius: 8px;
      margin-bottom: 10px; border: 1px solid var(--line);
      letter-spacing: 0;
    }
    .key-remove {
      background: transparent; border: 1px solid color-mix(in oklab, var(--danger) 35%, var(--line));
      color: var(--danger); font-size: 13px; padding: 7px 14px;
      border-radius: 8px; cursor: pointer; font-weight: 600; font-family: inherit;
      transition: background 160ms ease;
    }
    .key-remove:hover { background: var(--danger-soft); }

    .preset-card.active-preset { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), var(--shadow-sm); }
    .preset-keys-list { font-size: 13px; color: var(--text-3); line-height: 1.7; margin-bottom: 10px; }
    .preset-actions { display: flex; gap: 8px; flex-wrap: wrap; }
    .preset-actions button {
      padding: 7px 14px; border-radius: 8px;
      font-size: 13px; font-weight: 600; font-family: inherit;
      cursor: pointer; border: 1px solid var(--line-strong);
      background: transparent; color: var(--text-2);
      transition: all 160ms ease;
    }
    .preset-actions button:hover { background: var(--bg-hover); color: var(--text); }
    .preset-actions .use-btn { border-color: var(--accent-line); color: var(--accent); }
    .preset-actions .use-btn:hover { background: var(--accent-soft); }

    /* Inputs */
    .s-input {
      width: 100%; padding: 13px 15px;
      border: 1px solid var(--line-strong); border-radius: 10px;
      background: var(--bg-2); color: var(--text);
      font-family: inherit; font-size: 15px; outline: none;
      margin-bottom: 10px;
      transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
    }
    .s-input:focus { border-color: var(--accent); box-shadow: var(--ring); }
    .s-input::placeholder { color: var(--text-4); }
    textarea.s-input { resize: vertical; min-height: 96px; line-height: 1.55; }
    select.s-input { -webkit-appearance: none; appearance: none; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' fill='none' stroke='%237d8784' stroke-width='1.5' stroke-linecap='round'/></svg>"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 38px; }

    .drop-zone { position: relative; }
    .drop-zone .drop-overlay {
      display: none; position: absolute; inset: 0;
      border: 2px dashed var(--accent); border-radius: 10px;
      background: var(--accent-soft); z-index: 2; pointer-events: none;
      align-items: center; justify-content: center;
      color: var(--accent); font-size: 14px; font-weight: 600;
    }
    .drop-zone.dragging .drop-overlay { display: flex; }

    .drop-file-btn {
      background: transparent; border: 1px solid var(--line-strong);
      border-radius: 8px; color: var(--text-3);
      font-family: inherit; font-size: 13px; font-weight: 500;
      padding: 7px 14px; cursor: pointer; margin-bottom: 12px;
      transition: all 160ms ease;
    }
    .drop-file-btn:hover { border-color: var(--accent-line); color: var(--accent); }
    .file-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
    .file-chips:empty { display: none; }
    .file-chip {
      display: inline-flex; align-items: center; gap: 4px;
      padding: 4px 8px 4px 6px; border-radius: 6px;
      background: var(--accent-soft); border: 1px solid var(--accent-line);
      font-size: 11px; font-weight: 600; color: var(--accent);
      max-width: 160px;
    }
    .file-chip .chip-icon { flex-shrink: 0; font-size: 12px; }
    .file-chip .chip-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .file-chip .chip-x {
      flex-shrink: 0; background: none; border: none; color: var(--text-3);
      font-size: 14px; line-height: 1; cursor: pointer; padding: 0 0 0 2px;
      transition: color 120ms ease;
    }
    .file-chip .chip-x:hover { color: var(--danger); }

    .action-btn {
      display: flex; align-items: center; justify-content: center; gap: 8px;
      width: 100%; padding: 14px; border: 1.5px dashed var(--line-strong);
      border-radius: 10px; background: transparent; color: var(--text-3);
      font-family: inherit; font-size: 14px; font-weight: 600;
      cursor: pointer; margin-bottom: 10px;
      transition: all 160ms ease;
    }
    .action-btn:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }

    .save-btn {
      width: 100%; padding: 13px;
      background: var(--accent); color: var(--accent-ink);
      border: none; border-radius: 10px;
      font-family: inherit; font-size: 14px; font-weight: 700; letter-spacing: 0.01em;
      cursor: pointer; margin-top: 6px;
      transition: transform 140ms cubic-bezier(.2,.7,.3,1.4), filter 160ms ease;
      box-shadow: 0 8px 18px -10px var(--accent-glow);
    }
    .save-btn:hover { filter: brightness(1.06); }
    .save-btn:active { transform: scale(0.98); }

    .danger-btn {
      width: 100%; padding: 13px;
      background: transparent; color: var(--danger);
      border: 1px solid color-mix(in oklab, var(--danger) 35%, var(--line));
      border-radius: 10px; font-family: inherit;
      font-size: 14px; font-weight: 600; cursor: pointer; margin-top: 10px;
      transition: background 160ms ease;
    }
    .danger-btn:hover { background: var(--danger-soft); }

    /* ─────────────────  MODAL  ───────────────── */
    .modal-overlay {
      display: none; position: fixed; inset: 0;
      background: var(--modal-scrim); backdrop-filter: blur(4px);
      z-index: 200; align-items: center; justify-content: center; padding: 20px;
      animation: fadeIn 180ms ease;
    }
    .modal-overlay.open { display: flex; }
    @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
    .modal {
      background: var(--bg-2); border: 1px solid var(--line);
      border-radius: 16px; padding: 24px; width: 100%; max-width: 420px;
      box-shadow: var(--shadow-lg);
      animation: modalIn 220ms cubic-bezier(.2,.7,.2,1);
    }
    @keyframes modalIn { from { opacity: 0; transform: translateY(8px) scale(0.98); } to { opacity: 1; transform: none; } }
    .modal h3 { font-size: 18px; font-weight: 700; color: var(--text); margin-bottom: 16px; letter-spacing: -0.01em; }
    .modal-actions { display: flex; gap: 10px; margin-top: 20px; }
    .modal-actions button {
      flex: 1; padding: 13px; border-radius: 10px;
      font-family: inherit; font-size: 14px; font-weight: 700; cursor: pointer;
      border: 1px solid transparent;
      transition: filter 160ms ease, background 160ms ease;
    }
    .modal-cancel { background: var(--bg-3); color: var(--text-2); border-color: var(--line); }
    .modal-cancel:hover { background: var(--bg-hover); }
    .modal-confirm { background: var(--accent); color: var(--accent-ink); }
    .modal-confirm:hover { filter: brightness(1.06); }

    /* ─────────────────  CALL CARDS (Live + Old)  ───────────────── */
    .live-section { margin-bottom: 18px; }
    .live-section-label {
      font-size: 10px; font-weight: 700; text-transform: uppercase;
      letter-spacing: 0.1em; color: var(--accent); margin-bottom: 10px;
      display: flex; align-items: center; gap: 8px;
    }
    .live-section-label::before {
      content: ""; display: inline-block;
      width: 7px; height: 7px; border-radius: 50%;
      background: var(--accent);
      box-shadow: 0 0 0 3px var(--accent-glow);
      animation: pulse 1.8s ease-in-out infinite;
    }
    @keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.5} }

    .live-call-card {
      background: var(--accent-soft);
      border: 1.5px solid var(--accent-line);
      border-radius: 12px; padding: 16px 18px; margin-bottom: 10px;
      cursor: pointer; position: relative;
      transition: transform 140ms cubic-bezier(.2,.7,.3,1.4), border-color 160ms ease, background 160ms ease;
    }
    .live-call-card:hover { border-color: var(--accent); background: color-mix(in oklab, var(--accent) 14%, transparent); }
    .live-call-card:active { transform: scale(0.99); }
    .live-call-card .lc-title { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 4px; letter-spacing: -0.005em; }
    .live-call-card .lc-meta { font-size: 12px; color: var(--accent); font-weight: 500; }
    .live-call-card .lc-badge {
      display: inline-block; background: var(--accent); color: var(--accent-ink);
      font-size: 9px; font-weight: 800; padding: 3px 8px;
      border-radius: 999px; text-transform: uppercase; letter-spacing: 0.08em;
      margin-bottom: 8px;
    }

    .old-calls-section { margin-top: 4px; }
    .old-calls-toggle {
      width: 100%; padding: 12px 16px;
      background: var(--bg-2); border: 1px solid var(--line);
      border-radius: 10px; color: var(--text-2);
      font-family: inherit; font-size: 13px; font-weight: 600;
      cursor: pointer; text-align: left;
      display: flex; align-items: center; justify-content: space-between;
      transition: background 160ms ease, border-color 160ms ease;
    }
    .old-calls-toggle:hover { background: var(--bg-hover); border-color: var(--line-strong); }
    .old-calls-toggle .toggle-arrow { transition: transform 220ms cubic-bezier(.2,.7,.2,1); display: inline-block; }
    .old-calls-toggle.expanded .toggle-arrow { transform: rotate(180deg); }
    .old-calls-list { margin-top: 10px; }

    .old-call-item {
      background: var(--bg-2); border: 1px solid var(--line);
      border-radius: 10px; padding: 11px 13px; margin-bottom: 6px;
      cursor: pointer; display: flex; align-items: center; gap: 11px;
      transition: border-color 160ms ease, background 160ms ease, transform 140ms cubic-bezier(.2,.7,.3,1.4);
    }
    .old-call-item:hover { border-color: var(--accent-line); background: var(--bg-hover); }
    .old-call-item:active { transform: scale(0.99); }
    .old-call-item .oc-icon {
      flex-shrink: 0; color: var(--text-4);
      width: 18px; height: 18px; display: grid; place-items: center;
    }
    .old-call-item .oc-icon svg { width: 16px; height: 16px; }
    .old-call-item .oc-info { flex: 1; min-width: 0; }
    .old-call-item .oc-title { font-size: 13px; color: var(--text); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; letter-spacing: -0.005em; }
    .old-call-item .oc-meta { font-size: 11px; color: var(--text-3); margin-top: 2px; font-family: 'JetBrains Mono', ui-monospace, monospace; }
    .old-calls-loading { text-align: center; padding: 16px; color: var(--text-3); font-size: 13px; }
    .loading-indicator {
      font-size: 11px; color: var(--text-3); padding: 6px 2px 2px;
      display: inline-flex; align-items: center; gap: 6px;
    }
    .loading-indicator::before {
      content: ""; width: 8px; height: 8px; border-radius: 50%;
      background: var(--accent); animation: pulse 1.4s ease-in-out infinite;
    }

    .search-bar-wrap { padding: 0 0 10px 0; display: flex; flex-direction: column; gap: 4px; }
    .search-bar-input {
      width: 100%; padding: 11px 14px;
      border: 1px solid var(--line-strong); border-radius: 10px;
      background: var(--bg-2); color: var(--text);
      font-family: inherit; font-size: 13px; outline: none;
      transition: border-color 160ms ease, box-shadow 160ms ease;
    }
    .search-bar-input:focus { border-color: var(--accent); box-shadow: var(--ring); }
    .search-bar-input::placeholder { color: var(--text-4); }
    .search-count { font-size: 11px; color: var(--text-3); padding: 0 2px; font-family: 'JetBrains Mono', ui-monospace, monospace; }

    .edit-name-btn {
      opacity: 0; transition: opacity 160ms ease;
      background: transparent; border: none; color: var(--text-4);
      cursor: pointer; font-size: 12px; padding: 0 2px; flex-shrink: 0;
    }
    .edit-name-btn:hover { color: var(--accent); }
    .old-call-item:hover .edit-name-btn, .live-call-card:hover .edit-name-btn { opacity: 1; }
    .edit-name-input {
      background: var(--bg-2); border: 1px solid var(--accent);
      border-radius: 6px; color: var(--text);
      font-family: inherit; font-size: 14px; padding: 5px 9px;
      outline: none; min-width: 240px; max-width: 460px;
      box-shadow: var(--ring);
    }
    .local-label { font-size: 10px; color: var(--text-3); margin-left: 4px; font-style: italic; }
    .call-item-hidden { display: none; }

    /* Copy buttons */
    /* Top-of-transcript action row. Holds Back / Download / Copy buttons in a single
       flex container so they stay aligned regardless of label width or count. */
    .tx-actions {
      position: absolute; top: 8px; right: 8px;
      display: flex; flex-wrap: wrap; justify-content: flex-end;
      gap: 6px; z-index: 5;
    }
    .copy-tx-btn {
      display: flex; align-items: center; gap: 6px;
      padding: 7px 12px;
      background: var(--bg-2); border: 1px solid var(--line-strong);
      border-radius: 8px; color: var(--text-2);
      font-family: inherit; font-size: 12px; font-weight: 600;
      cursor: pointer;
      box-shadow: var(--shadow-sm);
      transition: all 160ms ease;
    }
    .copy-tx-btn:hover { border-color: var(--accent-line); color: var(--accent); }
    .copy-tx-btn:active { transform: scale(0.96); }
    .copy-tx-btn.copied { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
    .copy-tx-btn .copy-icon { font-size: 13px; }
    @media(max-width:480px){
      .copy-tx-btn { padding: 6px 9px; font-size: 11px; }
      .copy-tx-btn .copy-icon { font-size: 12px; }
      /* Task B (#4): on a phone the absolutely-positioned action row overlaps the
         call name (.session-title). Drop tx-actions into normal flow so it takes its
         OWN row at the top; the session-header (call name) then flows below it,
         fully legible and never covered. Buttons wrap within their row as needed. */
      .tx-actions {
        position: static; right: auto; top: auto;
        flex-wrap: wrap; justify-content: flex-start;
        margin: 0 0 10px; width: 100%;
      }
      .tx-actions .copy-tx-btn { flex: 1 1 auto; justify-content: center; }
    }

    .copy-call-btn {
      background: transparent; border: none; color: var(--text-4);
      cursor: pointer; font-size: 12px; padding: 2px 4px; flex-shrink: 0;
      opacity: 0; transition: opacity 160ms ease, color 160ms ease;
    }
    .old-call-item:hover .copy-call-btn, .live-call-card:hover .copy-call-btn { opacity: 1; }
    .copy-call-btn:hover { color: var(--accent); }
    .copy-call-btn.copied { color: var(--accent); opacity: 1; }

    /* Markdown */
    .md-content { font-size: 14px; line-height: 1.7; color: var(--text); }
    .md-content strong, .md-content b { color: var(--text); font-weight: 700; }
    .md-content em, .md-content i { color: var(--text-2); font-style: italic; }
    .md-content h1, .md-content h2, .md-content h3 { color: var(--accent); font-weight: 700; margin: 14px 0 6px; letter-spacing: -0.01em; }
    .md-content h1 { font-size: 17px; }
    .md-content h2 { font-size: 15px; }
    .md-content h3 { font-size: 13px; text-transform: uppercase; letter-spacing: 0.04em; }
    .md-content ul, .md-content ol { padding-left: 22px; margin: 8px 0; }
    .md-content li { margin-bottom: 4px; }
    .md-content p { margin: 8px 0; }
    .md-content code {
      background: var(--bg-3); padding: 2px 6px; border-radius: 5px;
      font-size: 12.5px; color: var(--accent);
      font-family: 'JetBrains Mono', ui-monospace, monospace;
      border: 1px solid var(--line);
    }
    .md-content hr { border: none; border-top: 1px solid var(--line); margin: 12px 0; }
    .md-content blockquote { border-left: 3px solid var(--accent); padding-left: 14px; margin: 10px 0; color: var(--text-2); }

    .streaming-cursor::after { content: "▊"; color: var(--accent); animation: pulse 0.8s infinite; margin-left: 2px; }

    /* ── Chat thinking phases — gamified terminal card ── */
    .think-card {
      border: 1px solid var(--accent-line);
      background:
        repeating-linear-gradient(180deg, transparent 0 23px, color-mix(in oklab, var(--accent) 5%, transparent) 23px 24px),
        linear-gradient(180deg, color-mix(in oklab, var(--accent) 6%, var(--bg-2)), var(--bg-2));
      border-radius: 14px; padding: 16px 16px 14px;
      margin-bottom: 14px; box-shadow: var(--shadow-sm);
      position: relative; overflow: hidden;
    }
    .think-card::before {
      content: ""; position: absolute; inset: 0;
      background: linear-gradient(120deg, transparent 30%, color-mix(in oklab, var(--accent) 14%, transparent) 50%, transparent 70%);
      background-size: 200% 100%; animation: shimmer 2.4s linear infinite;
      pointer-events: none;
    }
    .think-card.storm::before { display: none; }
    @keyframes shimmer { to { background-position: -200% 0; } }
    .think-head {
      display: flex; align-items: center; gap: 10px;
      font-size: 11px; font-weight: 700; color: var(--accent);
      letter-spacing: 0.08em; text-transform: uppercase;
      margin-bottom: 14px; position: relative;
    }
    .think-head .think-title { flex: 1; }
    .think-head .think-tick {
      font-size: 11px; font-weight: 600; color: var(--text-3);
      padding: 3px 8px; border-radius: 999px;
      border: 1px solid var(--line);
      background: var(--bg-3);
      letter-spacing: 0;
      font-variant-numeric: tabular-nums;
    }
    .think-head .orb {
      width: 14px; height: 14px; border-radius: 50%;
      background: radial-gradient(circle at 30% 30%, var(--accent), color-mix(in oklab, var(--accent) 30%, var(--bg)));
      box-shadow: 0 0 0 3px var(--accent-glow), 0 0 14px var(--accent);
      animation: orbPulse 1.6s ease-in-out infinite;
    }
    /* ── The Storm — Dalí-esque thinking visualization ── */
    .think-card.storm {
      padding: 0;
      border: 1px solid var(--accent-line);
      background: var(--bg-2);
    }
    .storm-stage {
      position: relative;
      width: 100%;
      height: 440px;
      overflow: hidden;
      background: #03060a; /* deep night sky */
      border-radius: 6px;
    }
    [data-theme="light"] .storm-stage {
      background: #4a5560; /* daytime overcast; JS paints over this */
    }
    .storm-canvas { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
    .storm-overlay {
      position: absolute; inset: 0; pointer-events: none;
      display: flex; flex-direction: column; justify-content: space-between;
      padding: 14px 16px;
    }
    .storm-head {
      display: flex; align-items: center; gap: 10px;
      font-size: 11px; font-weight: 700;
      color: var(--accent);
      letter-spacing: 0.12em; text-transform: uppercase;
      mix-blend-mode: screen;
      text-shadow: 0 0 12px color-mix(in oklab, var(--accent) 40%, transparent);
    }
    [data-theme="light"] .storm-head { mix-blend-mode: normal; }
    .storm-head .storm-title { flex: 1; }
    .storm-head .think-tick {
      font-size: 11px; font-weight: 600;
      padding: 3px 9px; border-radius: 999px;
      border: 1px solid color-mix(in oklab, var(--accent) 25%, transparent);
      background: color-mix(in oklab, oklch(0.18 0.05 270) 60%, transparent);
      color: color-mix(in oklab, var(--accent) 90%, white);
      letter-spacing: 0; font-variant-numeric: tabular-nums;
      backdrop-filter: blur(6px);
    }
    [data-theme="light"] .storm-head .think-tick {
      background: color-mix(in oklab, white 70%, transparent);
      color: var(--accent);
    }
    /* One word, pinned bottom-left — peeks through the jungle storm */
    .storm-thought {
      position: absolute;
      left: 22px;
      bottom: 22px;
      font-family: 'Inter', system-ui, sans-serif;
      font-style: italic;
      font-weight: 300;
      font-size: 15px;
      letter-spacing: 0.06em;
      pointer-events: none;
      white-space: nowrap;
      opacity: 0;
      color: rgba(210, 225, 240, 0.42);
      text-shadow: 0 0 12px rgba(140, 190, 230, 0.20), 0 1px 2px rgba(0,0,0,0.55);
      mix-blend-mode: screen;
      will-change: opacity, filter;
      transition: opacity 1300ms ease, filter 1300ms ease;
    }
    [data-theme="light"] .storm-thought {
      color: rgba(220, 230, 240, 0.50);
    }

    .storm-collapse { animation: stormCollapse 600ms ease-out forwards; }
    @keyframes stormCollapse {
      to { height: 0; opacity: 0; padding: 0; margin-bottom: 0; }
    }

    .think-cancel-btn {
      position: absolute; bottom: 12px; right: 12px;
      padding: 6px 18px; pointer-events: auto;
      background: color-mix(in oklab, oklch(0.18 0.05 270) 60%, transparent);
      color: oklch(0.92 0.02 270);
      border: 1px solid color-mix(in oklab, oklch(0.92 0.02 270) 25%, transparent);
      border-radius: 999px; font-family: inherit; font-size: 11px; font-weight: 600;
      letter-spacing: 0.05em; text-transform: uppercase;
      cursor: pointer; transition: all 160ms ease;
      backdrop-filter: blur(8px);
    }
    [data-theme="light"] .think-cancel-btn {
      background: color-mix(in oklab, white 70%, transparent);
      color: var(--text-2);
      border-color: var(--line-strong);
    }
    .think-cancel-btn:hover { border-color: var(--danger); color: var(--danger); }

    /* streaming bubble polish */
    .chat-a.streaming { border-color: transparent; box-shadow: none; }
    .chat-a .md-content > *:first-child { margin-top: 0; }
    .chat-a .md-content > *:last-child  { margin-bottom: 0; }

    /* Editorial markdown overrides for chat */
    .chat-a .md-content { font-size: 15px; line-height: 1.75; }
    .chat-a .md-content h1,
    .chat-a .md-content h2,
    .chat-a .md-content h3 {
      color: var(--accent); font-weight: 700;
      margin: 22px 0 10px; letter-spacing: -0.005em;
      text-transform: none; font-size: 17px;
    }
    .chat-a .md-content h1:first-child,
    .chat-a .md-content h2:first-child,
    .chat-a .md-content h3:first-child { margin-top: 0; }
    .chat-a .md-content strong { color: var(--text); font-weight: 700; }
    .chat-a .md-content em {
      font-style: italic; color: var(--text-2);
      font-family: 'Inter', sans-serif;
    }
    .chat-a .md-content blockquote {
      border-left: none; padding: 0; margin: 6px 0;
      color: var(--text-2); font-style: italic;
    }
    .chat-a .md-content ul, .chat-a .md-content ol {
      padding-left: 20px; margin: 10px 0;
    }
    .chat-a .md-content li { margin-bottom: 8px; line-height: 1.6; }
    .chat-a .md-content li::marker { color: var(--text-4); }
    .chat-a .md-content p { margin: 10px 0; }
    .chat-a .md-content hr {
      border-top: 1px solid var(--line); margin: 18px 0;
    }

    /* Thinking */
    .thinking-container { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 60px 20px; gap: 16px; }
    .thinking-orb {
      width: 52px; height: 52px; border-radius: 50%;
      background: radial-gradient(circle at 30% 30%, var(--accent), var(--bg));
      animation: orbPulse 2s ease-in-out infinite;
      box-shadow: 0 0 30px var(--accent-glow), 0 0 60px color-mix(in oklab, var(--accent) 12%, transparent);
    }
    @keyframes orbPulse {
      0%,100% { transform: scale(1); box-shadow: 0 0 30px var(--accent-glow), 0 0 60px color-mix(in oklab, var(--accent) 12%, transparent); }
      50%     { transform: scale(1.18); box-shadow: 0 0 40px color-mix(in oklab, var(--accent) 50%, transparent), 0 0 80px color-mix(in oklab, var(--accent) 22%, transparent); }
    }
    .thinking-word { font-size: 15px; font-weight: 600; color: var(--accent); letter-spacing: 0.02em; animation: fadeWord 0.5s ease-in-out; }
    @keyframes fadeWord { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
    .thinking-sub { font-size: 12px; color: var(--text-4); }

    /* Scrollbar */
    ::-webkit-scrollbar { width: 8px; height: 8px; }
    ::-webkit-scrollbar-track { background: transparent; }
    ::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 4px; border: 2px solid transparent; background-clip: padding-box; }
    ::-webkit-scrollbar-thumb:hover { background: var(--text-4); border: 2px solid transparent; background-clip: padding-box; }

    /* Selection */
    ::selection { background: var(--accent-soft); color: var(--text); }

    /* ═══════════════  v2 — DRAMATIC LAYER  ═══════════════ */

    /* Animated mesh background */
    body::after {
      content: ""; position: fixed; inset: -20%;
      background:
        radial-gradient(40% 30% at 20% 20%, color-mix(in oklab, var(--accent) 18%, transparent), transparent 60%),
        radial-gradient(35% 28% at 85% 15%, color-mix(in oklab, oklch(0.7 0.18 280) 14%, transparent), transparent 65%),
        radial-gradient(45% 32% at 75% 85%, color-mix(in oklab, var(--accent) 12%, transparent), transparent 60%),
        radial-gradient(30% 25% at 10% 90%, color-mix(in oklab, oklch(0.7 0.18 200) 10%, transparent), transparent 65%);
      pointer-events: none; z-index: 0; opacity: 0.55;
      filter: blur(60px) saturate(140%);
      animation: mesh 22s ease-in-out infinite;
    }
    :root[data-theme="light"] body::after { opacity: 0.5; filter: blur(70px) saturate(120%); }
    @keyframes mesh {
      0%,100% { transform: translate(0,0) scale(1); }
      33%     { transform: translate(-3%, 2%) scale(1.05); }
      66%     { transform: translate(2%, -3%) scale(0.97); }
    }

    /* Header — frosted glass with hairline gradient */
    .header {
      background: color-mix(in oklab, var(--bg) 70%, transparent) !important;
      backdrop-filter: saturate(180%) blur(18px) !important;
      -webkit-backdrop-filter: saturate(180%) blur(18px) !important;
      border-bottom: none !important;
      position: relative;
    }
    .header::after {
      content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 1px;
      background: linear-gradient(90deg, transparent, color-mix(in oklab, var(--accent) 50%, transparent), transparent);
      opacity: 0.6;
    }

    /* Brand wordmark — interleaved 3-bar mark */
    .brand-mark { background: transparent !important; box-shadow: none !important; }
    .brand-mark::before { content: none; }

    .header h1, .brand-name {
      font-size: 16px !important; font-weight: 700 !important;
      letter-spacing: -0.02em !important;
      color: var(--text);
      -webkit-text-fill-color: var(--text);
    }

    /* Status pill — elevated */
    .status-pill {
      background: color-mix(in oklab, var(--bg-2) 70%, transparent) !important;
      backdrop-filter: blur(10px);
      box-shadow: inset 0 1px 0 color-mix(in oklab, var(--text) 6%, transparent), var(--shadow-sm);
    }

    /* Header buttons — micro shimmer on hover */
    .hbtn { position: relative; overflow: hidden; }
    .hbtn::before {
      content: ""; position: absolute; inset: 0;
      background: linear-gradient(110deg, transparent 30%, color-mix(in oklab, var(--accent) 14%, transparent) 50%, transparent 70%);
      transform: translateX(-100%); transition: transform 600ms cubic-bezier(.2,.7,.2,1);
      pointer-events: none;
    }
    .hbtn:hover::before { transform: translateX(100%); }
    .hbtn.danger-active {
      background: linear-gradient(180deg, var(--danger), color-mix(in oklab, var(--danger) 78%, black)) !important;
      box-shadow: 0 6px 18px -8px var(--danger), inset 0 1px 0 rgba(255,255,255,0.18);
    }
    .hbtn.active-btn {
      background: linear-gradient(180deg, var(--accent-soft), color-mix(in oklab, var(--accent) 8%, transparent)) !important;
      box-shadow: 0 4px 14px -8px var(--accent-glow);
    }

    /* Stats bar — bigger numbers, more drama */
    .stats-bar {
      padding: 14px 16px !important;
      background: linear-gradient(180deg, var(--bg-1), var(--bg)) !important;
      gap: 24px !important;
      position: relative;
    }
    .stats-bar::after {
      content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 1px;
      background: linear-gradient(90deg, transparent, var(--line-strong) 20%, var(--line-strong) 80%, transparent);
    }
    .stat-pill { font-size: 11px !important; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-3) !important; flex-direction: column !important; align-items: flex-start !important; gap: 2px !important; }
    .stat-pill .val {
      font-size: 22px !important; font-weight: 700 !important;
      letter-spacing: -0.02em !important;
      background: linear-gradient(180deg, var(--accent), color-mix(in oklab, var(--accent) 65%, var(--text)));
      -webkit-background-clip: text; background-clip: text;
      -webkit-text-fill-color: transparent;
      font-feature-settings: "tnum","ss01";
    }
    .stat-pill.muted .val, .stat-pill.muted { color: var(--text-3) !important; -webkit-text-fill-color: var(--text-3); }
    .stat-pill.full-meeting { flex: 1 !important; align-items: flex-end !important; text-align: right; }
    .stat-pill.full-meeting .val { font-size: 13px !important; font-weight: 600 !important; max-width: 180px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; -webkit-text-fill-color: var(--text); background: none; }

    /* Tabs — sliding indicator */
    .tabs { padding: 0 6px; gap: 2px; background: transparent !important; border-bottom-color: var(--line-strong) !important; }
    .tab {
      padding: 13px 12px !important; font-size: 11px !important;
      text-transform: uppercase; letter-spacing: 0.1em;
      border-bottom: none !important; position: relative;
    }
    .tab::after {
      content: ""; position: absolute; left: 12px; right: 12px; bottom: -1px; height: 2px;
      background: linear-gradient(90deg, transparent, var(--accent), transparent);
      transform: scaleX(0); transition: transform 280ms cubic-bezier(.2,.8,.2,1);
      box-shadow: 0 0 12px var(--accent-glow);
    }
    .tab.active::after { transform: scaleX(1); }
    .tab.active { color: var(--text) !important; }

    /* Live cards — gradient border, hover lift, breathing glow */
    .live-call-card {
      background: linear-gradient(140deg,
        color-mix(in oklab, var(--accent) 14%, var(--bg-2)),
        color-mix(in oklab, var(--accent) 4%, var(--bg-2))
      ) !important;
      border: none !important;
      border-radius: 14px !important;
      padding: 18px 20px !important;
      box-shadow:
        0 0 0 1px var(--accent-line),
        0 1px 0 color-mix(in oklab, var(--accent) 35%, transparent) inset,
        0 14px 36px -16px var(--accent-glow);
      position: relative; overflow: hidden;
      transition: transform 220ms cubic-bezier(.2,.7,.3,1.4), box-shadow 220ms ease !important;
    }
    .live-call-card::before {
      content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
      background: linear-gradient(180deg, var(--accent), color-mix(in oklab, var(--accent) 50%, transparent));
      box-shadow: 0 0 14px var(--accent);
    }
    .live-call-card::after {
      content: ""; position: absolute; inset: 0; border-radius: 14px;
      background: radial-gradient(120% 80% at 100% 0%, color-mix(in oklab, var(--accent) 16%, transparent), transparent 55%);
      pointer-events: none; opacity: 0.7;
    }
    .live-call-card:hover {
      transform: translateY(-2px);
      box-shadow:
        0 0 0 1px var(--accent),
        0 1px 0 color-mix(in oklab, var(--accent) 50%, transparent) inset,
        0 22px 50px -18px var(--accent-glow);
    }
    .live-call-card .lc-title { font-size: 16px !important; }
    .live-call-card .lc-badge {
      background: linear-gradient(180deg, var(--accent), color-mix(in oklab, var(--accent) 70%, black)) !important;
      box-shadow: 0 4px 12px -4px var(--accent-glow), inset 0 1px 0 rgba(255,255,255,0.25);
      animation: livePulse 2.4s ease-in-out infinite;
    }
    @keyframes livePulse {
      0%,100% { box-shadow: 0 4px 12px -4px var(--accent-glow), inset 0 1px 0 rgba(255,255,255,0.25); }
      50%     { box-shadow: 0 6px 20px -4px var(--accent), inset 0 1px 0 rgba(255,255,255,0.35); }
    }

    /* Live section label — waveform */
    .live-section-label::before {
      animation: pulse 1.4s ease-in-out infinite !important;
      box-shadow: 0 0 0 3px var(--accent-glow), 0 0 14px var(--accent) !important;
    }
    .live-section-label .wave {
      display: inline-flex; gap: 2px; align-items: end; height: 12px; margin-left: 4px;
    }
    .live-section-label .wave i {
      display: inline-block; width: 2px; background: var(--accent); border-radius: 1px;
      animation: bar 1s ease-in-out infinite;
    }
    .live-section-label .wave i:nth-child(1) { height: 40%; animation-delay: 0s; }
    .live-section-label .wave i:nth-child(2) { height: 80%; animation-delay: 0.15s; }
    .live-section-label .wave i:nth-child(3) { height: 60%; animation-delay: 0.3s; }
    .live-section-label .wave i:nth-child(4) { height: 90%; animation-delay: 0.45s; }
    @keyframes bar { 0%,100% { transform: scaleY(0.4); } 50% { transform: scaleY(1); } }

    /* Old call items — refined hover */
    .old-call-item {
      transition: transform 220ms cubic-bezier(.2,.7,.3,1.4), border-color 200ms ease, background 200ms ease, box-shadow 200ms ease !important;
    }
    .old-call-item:hover {
      transform: translateX(3px);
      box-shadow: -3px 0 0 var(--accent), var(--shadow-sm);
    }

    /* Transcript line entry animation.
       Bug 1 fix: previously `from { opacity:0 }` with `both` fill could leave lines
       STUCK invisible (opacity:0) if the animation didn't advance (re-render churn,
       paused/captured frames) — making a loaded transcript look blank. Animate only
       the slide so a line can NEVER end up invisible. */
    @keyframes lineIn { from { transform: translateY(6px); } to { transform: none; } }
    .t-line { animation: lineIn 380ms cubic-bezier(.2,.7,.2,1) both; }
    @media (prefers-reduced-motion: reduce) { .t-line { animation: none; } }

    /* ─── Per-speaker name tags ─── */
    .t-line .t-speaker {
      font-size: 10px !important; letter-spacing: 0.06em !important;
      color: var(--text-3) !important;
      display: inline-flex !important; align-items: center; gap: 8px;
      margin-bottom: 6px !important;
    }
    .t-line .t-speaker .speaker-tag {
      display: inline-flex; align-items: center; gap: 6px;
      padding: 3px 9px 3px 7px;
      border-radius: 999px;
      background: var(--sp-bg, var(--accent-soft));
      color: var(--sp-fg, var(--accent));
      border: 1px solid var(--sp-border, var(--accent-line));
      font-size: 11px; font-weight: 700;
      letter-spacing: 0.02em; text-transform: none;
      box-shadow: 0 1px 0 rgba(255,255,255,0.02) inset, 0 0 0 1px color-mix(in oklab, var(--sp-fg, var(--accent)) 0%, transparent);
      transition: transform 160ms cubic-bezier(.2,.7,.3,1.4), box-shadow 200ms ease;
    }
    .t-line .t-speaker .speaker-tag::before {
      content: "";
      width: 6px; height: 6px; border-radius: 50%;
      background: var(--sp-fg, var(--accent));
      box-shadow: 0 0 0 2px color-mix(in oklab, var(--sp-fg, var(--accent)) 25%, transparent);
      flex-shrink: 0;
    }
    .t-line:hover .t-speaker .speaker-tag {
      box-shadow: 0 1px 0 rgba(255,255,255,0.04) inset, 0 0 0 3px color-mix(in oklab, var(--sp-fg, var(--accent)) 18%, transparent);
    }
    /* leave a colored "rail" along the left of each line */
    .t-line { position: relative; padding-left: 14px; border-left: 2px solid var(--sp-fg, var(--line)); border-radius: 2px; }

    .t-line .t-text { font-size: 15px !important; line-height: 1.65 !important; color: var(--text) !important; }

    /* Session header — gradient accent */
    .session-header {
      background: linear-gradient(140deg, var(--bg-2), var(--bg-3)) !important;
      box-shadow: inset 0 1px 0 color-mix(in oklab, var(--text) 5%, transparent), var(--shadow-md) !important;
    }
    .session-header::before {
      background: linear-gradient(180deg, var(--accent), color-mix(in oklab, var(--accent) 50%, transparent)) !important;
      box-shadow: 0 0 14px var(--accent);
    }

    /* Bottom bar / send-btn premium overrides merged into canonical block above (B7 fix) */

    /* Aa-btn — gradient stroke (base, idle) */
    .aa-btn {
      background: linear-gradient(180deg, var(--bg-2), var(--bg-3)) !important;
      padding: 12px 14px !important;
      transition: transform 220ms cubic-bezier(.2,.7,.3,1.4), border-color 200ms ease, box-shadow 200ms ease, background 220ms ease !important;
    }
    .aa-btn:hover {
      transform: translateY(-2px);
      border-color: var(--aa-c) !important;
      box-shadow: 0 12px 28px -14px var(--aa-glow), inset 0 1px 0 color-mix(in oklab, var(--aa-c) 18%, transparent) !important;
    }
    /* Lit-up states beat the v2 default gradient */
    .aa-btn.loading {
      background: linear-gradient(180deg, var(--aa-soft), color-mix(in oklab, var(--aa-c) 4%, var(--bg-2))) !important;
      border-color: var(--aa-line) !important;
    }
    .aa-btn.has-result {
      background: linear-gradient(180deg, var(--aa-soft), color-mix(in oklab, var(--aa-c) 5%, var(--bg-2))) !important;
      border-color: var(--aa-c) !important;
    }
    .aa-btn.active {
      background: linear-gradient(180deg, color-mix(in oklab, var(--aa-c) 22%, var(--bg-2)), color-mix(in oklab, var(--aa-c) 8%, var(--bg-2))) !important;
      border-color: var(--aa-c) !important;
    }

    /* Empty state — bigger glyph */
    .empty-state .glyph {
      width: 72px !important; height: 72px !important; border-radius: 18px !important;
      background: linear-gradient(140deg, var(--bg-2), var(--bg-3)) !important;
      box-shadow:
        inset 0 1px 0 color-mix(in oklab, var(--accent) 12%, transparent),
        0 14px 30px -14px color-mix(in oklab, var(--accent) 30%, transparent),
        0 0 0 1px var(--line-strong) !important;
    }
    .empty-state .glyph svg { width: 30px !important; height: 30px !important; color: var(--accent) !important; }
    .empty-state .lead {
      font-size: 17px !important; font-weight: 700 !important;
      letter-spacing: -0.01em;
      color: var(--text) !important;
    }

    /* Search input bigger */
    .search-bar-input {
      padding: 13px 16px !important; font-size: 14px !important;
    }

    /* Demo mode badge */
    .demo-pill {
      display: inline-flex; align-items: center; gap: 6px;
      padding: 4px 10px;
      background: linear-gradient(180deg, oklch(0.72 0.18 320), oklch(0.62 0.20 320));
      color: white;
      border-radius: 999px; font-size: 10px; font-weight: 800;
      letter-spacing: 0.1em; text-transform: uppercase;
      box-shadow: 0 4px 14px -6px oklch(0.62 0.20 320 / 0.6), inset 0 1px 0 rgba(255,255,255,0.3);
      animation: demoBreath 2.4s ease-in-out infinite;
    }
    @keyframes demoBreath {
      0%,100% { box-shadow: 0 4px 14px -6px oklch(0.62 0.20 320 / 0.6), inset 0 1px 0 rgba(255,255,255,0.3); }
      50%     { box-shadow: 0 6px 22px -6px oklch(0.62 0.20 320 / 0.9), inset 0 1px 0 rgba(255,255,255,0.4); }
    }

    /* Searching skeleton — radar sweep */
    .searching-state {
      display: flex; flex-direction: column; align-items: center; justify-content: center;
      padding: 50px 20px 36px; gap: 18px;
    }
    .radar {
      position: relative; width: 140px; height: 140px; border-radius: 50%;
      background: radial-gradient(circle, color-mix(in oklab, var(--accent) 6%, transparent), transparent 65%);
      border: 1px solid var(--line);
    }
    .radar::before, .radar::after {
      content: ""; position: absolute; inset: 25%; border-radius: 50%;
      border: 1px solid var(--line);
    }
    .radar::after { inset: 50%; }
    .radar-sweep {
      position: absolute; inset: 0; border-radius: 50%;
      background: conic-gradient(from 0deg, transparent 0deg, color-mix(in oklab, var(--accent) 35%, transparent) 60deg, transparent 90deg);
      animation: sweep 2.4s linear infinite;
      mask: radial-gradient(circle, transparent 0, black 6%, black 100%);
      -webkit-mask: radial-gradient(circle, transparent 0, black 6%, black 100%);
    }
    .radar-center {
      position: absolute; left: 50%; top: 50%; width: 10px; height: 10px;
      transform: translate(-50%,-50%); border-radius: 50%;
      background: var(--accent);
      box-shadow: 0 0 0 4px var(--accent-glow), 0 0 20px var(--accent);
    }
    @keyframes sweep { from { transform: rotate(0); } to { transform: rotate(360deg); } }
    .searching-label { font-size: 13px; color: var(--text-2); font-weight: 600; letter-spacing: 0.04em; }
    .searching-sub { font-size: 11px; color: var(--text-3); font-family: 'JetBrains Mono', monospace; }

    /* Connecting overlay */
    .connecting-overlay {
      position: absolute; inset: 0; z-index: 50;
      background: color-mix(in oklab, var(--bg) 75%, transparent);
      backdrop-filter: blur(10px);
      display: flex; flex-direction: column; align-items: center; justify-content: center;
      gap: 18px;
      animation: fadeIn 200ms ease;
    }
    .connecting-orb {
      position: relative; width: 80px; height: 80px;
    }
    .connecting-orb .ring {
      position: absolute; inset: 0; border-radius: 50%;
      border: 2px solid var(--accent);
      border-top-color: transparent; border-right-color: transparent;
      animation: spin 1.1s linear infinite;
      box-shadow: 0 0 30px var(--accent-glow);
    }
    .connecting-orb .ring2 {
      position: absolute; inset: 12px; border-radius: 50%;
      border: 2px solid var(--accent-line);
      border-bottom-color: transparent; border-left-color: transparent;
      animation: spin 1.6s linear infinite reverse;
    }
    .connecting-orb .core {
      position: absolute; inset: 28px; border-radius: 50%;
      background: radial-gradient(circle at 30% 30%, var(--accent), color-mix(in oklab, var(--accent) 40%, var(--bg)));
      box-shadow: 0 0 30px var(--accent);
      animation: orbPulse 1.6s ease-in-out infinite;
    }
    .connecting-label {
      font-size: 14px; font-weight: 700; color: var(--text); letter-spacing: -0.01em;
    }
    .connecting-sub {
      font-size: 11px; color: var(--text-3); font-family: 'JetBrains Mono', monospace;
    }

    /* New transcript line — fresh highlight */
    .t-line.fresh .t-text {
      animation: freshGlow 1.6s ease-out;
    }
    @keyframes freshGlow {
      0%   { background: linear-gradient(90deg, var(--accent-soft), transparent); padding-left: 8px; }
      100% { background: transparent; padding-left: 0; }
    }

    /* Light mode tweaks for the dramatic layer */
    :root[data-theme="light"] .header h1 {
      background: linear-gradient(180deg, var(--text), color-mix(in oklab, var(--text) 60%, var(--accent)));
      -webkit-background-clip: text; background-clip: text;
    }

    /* Theme toggle micro-icon transitions */
    .theme-toggle .sun, .theme-toggle .moon { transition: opacity 200ms ease, transform 300ms cubic-bezier(.2,.7,.2,1); }
    :root[data-theme="light"] .theme-toggle .sun { opacity: 0; transform: rotate(-30deg) scale(0.6); }
    :root[data-theme="light"] .theme-toggle .moon { opacity: 1; transform: none; }
    :root[data-theme="dark"]  .theme-toggle .sun { opacity: 1; transform: none; }
    :root[data-theme="dark"]  .theme-toggle .moon { opacity: 0; transform: rotate(30deg) scale(0.6); }
    .theme-toggle { position: relative; }
    .theme-toggle .sun, .theme-toggle .moon { position: absolute; }

    /* ═══════════════════════════════════════════════════════════
       P1–P4 POLISH PASS — Settings centering, status bar upgrade,
       header hierarchy, call-list density.
    ═══════════════════════════════════════════════════════════ */

    /* ───── P1 · SETTINGS centering ─────
       The .page is a column flexbox, so `margin: 0 auto` on .page-body never
       centered horizontally. Switch to align-self for proper centering. */
    .page-body {
      align-self: center !important;
      max-width: 760px !important;
      padding: 28px 24px max(24px, env(safe-area-inset-bottom)) !important;
    }
    /* Settings cards — group sections into elevated cards */
    .settings-section {
      background: var(--bg-2);
      border: 1px solid var(--line);
      border-radius: 14px;
      padding: 18px 20px !important;
      margin-bottom: 16px !important;
      box-shadow: var(--shadow-sm);
      position: relative;
    }
    .settings-section h3 {
      font-size: 11px !important; font-weight: 800 !important;
      letter-spacing: 0.09em !important; color: var(--text-2) !important;
      margin-bottom: 14px !important;
      display: flex; align-items: center; justify-content: space-between;
      gap: 8px;
    }
    .settings-section h3::after {
      content: ""; flex: 1; height: 1px;
      background: linear-gradient(90deg, var(--line), transparent);
      margin-left: 4px;
    }
    /* Page header polish */
    .page-header {
      padding: 14px 20px !important;
      padding-top: max(14px, env(safe-area-inset-top)) !important;
    }
    .page-header h2 { font-size: 15px !important; letter-spacing: -0.005em; }

    /* ───── P3 · HEADER hierarchy: meeting name as hero ─────
       Restructure stats-bar so the meeting title is the hero on left,
       and lines/analyses become inline metadata, not big numerals. */
    .stats-bar {
      padding: 10px 16px !important;
      background: var(--bg-1) !important;
      gap: 10px !important;
      align-items: center !important;
      flex-wrap: nowrap;
    }
    .stats-bar::after { display: none !important; }
    /* The meeting title is the hero — push it to the front, make it large */
    .stats-bar #meetingTitle {
      order: -1; flex: 1; min-width: 0;
      flex-direction: row !important; align-items: baseline !important;
      gap: 0 !important;
      font-size: 15px !important; font-weight: 700 !important;
      letter-spacing: -0.01em !important;
      text-transform: none !important;
      color: var(--text) !important;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
      -webkit-text-fill-color: var(--text);
    }
    .stats-bar #meetingTitle.muted {
      color: var(--text-3) !important;
      -webkit-text-fill-color: var(--text-3);
      font-weight: 600 !important;
    }
    /* Demote line / analysis pills to small inline metadata */
    .stats-bar .stat-pill:not(#meetingTitle) {
      flex-direction: row !important;
      align-items: baseline !important;
      gap: 4px !important;
      font-size: 11px !important;
      text-transform: none !important;
      letter-spacing: 0 !important;
      color: var(--text-3) !important;
      flex-shrink: 0;
    }
    .stats-bar .stat-pill:not(#meetingTitle) .val {
      font-size: 12px !important;
      font-weight: 700 !important;
      letter-spacing: 0 !important;
      background: none !important;
      -webkit-text-fill-color: var(--text-2) !important;
      color: var(--text-2) !important;
      font-family: 'JetBrains Mono', ui-monospace, monospace;
    }
    /* Bullet separator before each metadata pill */
    .stats-bar .stat-pill:not(#meetingTitle)::before {
      content: ""; width: 3px; height: 3px; border-radius: 50%;
      background: var(--text-4); margin-right: 6px;
      align-self: center;
    }

    /* ───── P2 · STATUS BAR — keep single row, upgrade internals ─────
       Same height as before. Adds a small colored state indicator
       and uses semantic state colors. No subtitle row → no clutter. */
    .status-bar {
      padding: 8px 16px !important;
      background: var(--bg-1) !important;
      font-size: 12px !important;
      gap: 9px !important;
      transition: color 200ms ease;
    }
    /* Replace hourglass with a smarter dot/spinner indicator */
    .status-bar #statusIcon {
      display: inline-flex !important;
      align-items: center; justify-content: center;
      width: 10px; height: 10px; flex-shrink: 0;
      position: relative;
    }
    .status-bar .hourglass, .status-bar .hg-sand { display: none !important; }
    .status-bar #statusIcon::before {
      content: ""; width: 7px; height: 7px; border-radius: 50%;
      background: var(--text-4);
      transition: background 200ms ease, box-shadow 200ms ease;
    }
    /* Loading: show spinner instead of dot */
    .status-bar.is-loading { color: var(--accent) !important; }
    .status-bar.is-loading #statusIcon::before {
      background: transparent;
      width: 10px; height: 10px;
      border: 1.5px solid var(--line);
      border-top-color: var(--accent);
      animation: ca-spin 0.85s linear infinite;
    }
    /* State variants — use existing dot states piped from updateStatus() */
    .status-bar.state-live #statusIcon::before {
      background: oklch(0.72 0.16 155);
      box-shadow: 0 0 0 3px color-mix(in oklab, oklch(0.72 0.16 155) 25%, transparent);
    }
    .status-bar.state-error { color: var(--danger) !important; }
    .status-bar.state-error #statusIcon::before {
      background: var(--danger);
      box-shadow: 0 0 0 3px color-mix(in oklab, var(--danger) 25%, transparent);
    }
    .status-bar.state-analyzing { color: var(--accent) !important; }
    .status-bar.state-analyzing #statusIcon::before {
      background: var(--accent);
      box-shadow: 0 0 0 3px var(--accent-glow);
      animation: ca-pulse 1.4s ease-in-out infinite;
    }
    .status-bar.state-complete { color: oklch(0.72 0.16 155) !important; }
    .status-bar.state-complete #statusIcon::before {
      background: oklch(0.72 0.16 155);
      box-shadow: 0 0 0 3px color-mix(in oklab, oklch(0.72 0.16 155) 25%, transparent);
    }
    .status-bar #statusText {
      font-weight: 600; letter-spacing: 0.005em;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
      flex: 1; min-width: 0;
    }
    @keyframes ca-spin { to { transform: rotate(360deg); } }
    @keyframes ca-pulse {
      0%, 100% { box-shadow: 0 0 0 3px var(--accent-glow); }
      50%      { box-shadow: 0 0 0 5px var(--accent-glow); }
    }

    /* ───── P4 · CALL LIST density ─────
       Halve row height, drop the giant phone icon to a 6px dot,
       drop "Info?" filler (the meta line keeps date+key), tighten typography. */
    .old-call-item {
      padding: 8px 12px !important;
      margin-bottom: 3px !important;
      border-radius: 8px !important;
      background: transparent !important;
      border: 1px solid transparent !important;
      gap: 10px !important;
    }
    .old-call-item:hover {
      transform: none !important;
      background: var(--bg-2) !important;
      border-color: var(--line) !important;
      box-shadow: none !important;
    }
    /* Replace phone svg with a tiny status dot */
    .old-call-item .oc-icon {
      width: 6px !important; height: 6px !important;
      border-radius: 50%; background: var(--text-4);
      flex-shrink: 0; align-self: center;
      transition: background 160ms ease;
    }
    .old-call-item .oc-icon svg { display: none !important; }
    .old-call-item:hover .oc-icon { background: var(--accent); }
    .old-call-item .oc-info {
      display: flex !important; flex-direction: row !important;
      align-items: baseline; gap: 12px;
      justify-content: space-between; min-width: 0;
    }
    .old-call-item .oc-title-wrap {
      flex: 1; min-width: 0; gap: 6px !important;
    }
    .old-call-item .oc-title {
      font-size: 13px !important; font-weight: 600 !important;
    }
    .old-call-item .oc-meta {
      margin-top: 0 !important;
      font-size: 11px !important;
      font-family: inherit !important;
      flex-shrink: 0;
      font-variant-numeric: tabular-nums;
    }
    /* Hide hover affordances by default in the denser row */
    .old-call-item .edit-name-btn,
    .old-call-item .copy-call-btn { font-size: 11px !important; }

    /* Narrow portrait phones: stack title above meta so call names aren't truncated to ~10 chars. */
    @media(max-width:480px){
      .old-call-item .oc-info {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 2px !important;
      }
      .old-call-item .oc-title-wrap { width: 100%; min-width: 0; }
      .old-call-item .oc-title {
        flex: 1 1 auto; min-width: 0;
        white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
        max-width: 100%; font-size: 13px !important;
      }
      .old-call-item .edit-name-btn,
      .old-call-item .copy-call-btn { flex-shrink: 0; }
      .old-call-item .oc-meta {
        font-size: 10px !important;
        display: flex; align-items: center; gap: 6px;
        white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
      }
      .old-call-item .oc-meta .dup-badge { font-size: 9px; padding: 1px 5px; }
    }

    /* Per-key visual chip so the user can tell instantly which notetaker key each call came from */
    .key-chip {
      display: inline-flex; align-items: center;
      font-size: 10px; font-weight: 700;
      padding: 1px 6px; border-radius: 4px;
      letter-spacing: 0.04em; text-transform: uppercase;
      flex-shrink: 0; margin-right: 4px; line-height: 1.5;
      max-width: 110px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    }
    .key-load-breakdown {
      display: flex; flex-wrap: wrap; gap: 5px;
      padding: 4px 0 6px;
    }
    .key-load-breakdown .kb-item {
      display: inline-flex; align-items: center; gap: 5px;
      padding: 2px 8px 2px 2px;
      border-radius: 4px;
      background: var(--bg-3); color: var(--text-2);
      border: 1px solid var(--line);
      font-size: 11px;
      font-variant-numeric: tabular-nums;
    }
    .key-load-breakdown .kb-item .key-chip { margin-right: 0; }

    /* Duplicate-transcript badge: same meeting appears on multiple notetaker keys */
    .dup-badge {
      display: inline-flex; align-items: center; gap: 3px;
      font-size: 10px; padding: 1px 6px; border-radius: 4px;
      background: var(--accent-soft); color: var(--accent);
      font-weight: 600; letter-spacing: 0.02em;
      flex-shrink: 0; margin-left: 4px; line-height: 1.4;
      cursor: help;
    }
    .live-call-card .dup-badge { font-size: 11px; padding: 2px 7px; }
    /* Bundle a meeting and its duplicate copies (same call recorded by 2+ notetaker keys)
       into one expandable row. The chevron pill on the primary toggles the children. */
    .bundle-expand-btn {
      background: var(--accent-soft); color: var(--accent);
      border: 1px solid var(--accent-line); border-radius: 999px;
      padding: 1px 8px; font-size: 10px; font-weight: 700; letter-spacing: 0.02em;
      cursor: pointer; flex-shrink: 0; margin-left: 4px;
      line-height: 1.5; user-select: none;
      transition: background 140ms ease, transform 140ms cubic-bezier(.2,.7,.3,1.4);
    }
    .bundle-expand-btn:hover { background: color-mix(in oklab, var(--accent-soft) 70%, var(--accent) 30%); }
    .bundle-expand-btn:active { transform: scale(0.94); }
    .bundle-children { display: none; }
    .bundle-children.open { display: block; }
    .bundle-children .old-call-item {
      margin-left: 18px; position: relative;
      border-left: 2px solid var(--accent-line);
      padding-left: 12px;
      background: color-mix(in oklab, var(--bg-2) 75%, transparent);
    }
    /* When the primary is a bundle, the legacy 🔁 N badge would duplicate the
       chevron count — hide it on bundle primaries only. */
    .bundle-primary .dup-badge { display: none; }

    /* ═══════════════════════════════════════════════════════════
       R13.2 — Home port: cv-* design primitives (Spec A-G)
       All NEW classes use cv- prefix to avoid colliding with existing
       index.html classes. Light-mode safe (uses CSS vars only).
       ═══════════════════════════════════════════════════════════ */

    /* (E) status/stats hide via mainView[data-state] — Spec section E */
    #mainView[data-state="value"] .status-bar,
    #mainView[data-state="value"] .stats-bar,
    #mainView[data-state="connect"] .status-bar,
    #mainView[data-state="connect"] .stats-bar { display: none !important; }

    /* (A) FIRST-RUN — show cvFrWrap in value/connect, hide contentArea then;
       inverse when populated/hub. The .cv-fr children also CSS-gate themselves.
       R14 B5 fix: also gate on data-tab="transcript" so the empty-state cv-fr
       blocks don't overlap Ask Claude / Auto-Analysis tab content. */
    #cvFrWrap { display: none; flex: 1; min-height: 0; overflow-y: auto; }
    #mainView[data-tab="transcript"][data-state="value"] #cvFrWrap,
    #mainView[data-tab="transcript"][data-state="connect"] #cvFrWrap { display: block; }
    #mainView[data-state="value"] #contentArea,
    #mainView[data-state="connect"] #contentArea { display: none; }
    .cv-fr { max-width: 760px; margin: 0 auto; padding: 18px 24px 28px; text-align: center; display: none; }
    #mainView[data-tab="transcript"][data-state="value"]   .cv-fr[data-cv-fr="value"]   { display: block; }
    #mainView[data-tab="transcript"][data-state="connect"] .cv-fr[data-cv-fr="connect"] { display: block; }
    .cv-fr-badge {
      display: inline-flex; align-items: center; gap: 7px;
      font-size: 11.5px; font-weight: 600; color: var(--text-3);
      background: var(--bg-2); border: 1px solid var(--line-strong);
      border-radius: 999px; padding: 6px 13px; margin-bottom: 20px;
    }
    .cv-fr-badge .d { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
    .cv-fr h1 { font-size: 32px; font-weight: 800; letter-spacing: -.025em; line-height: 1.08; margin: 0 0 12px; color: var(--text); }
    .cv-fr h1 .cv-grad {
      background: linear-gradient(100deg, var(--brand-cyan), var(--brand-blue), var(--brand-violet));
      -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
    }
    .cv-fr .cv-sub { font-size: 15px; color: var(--text-3); max-width: 54ch; margin: 0 auto 24px; line-height: 1.6; }
    .cv-fr-cta { display: flex; gap: 11px; justify-content: center; flex-wrap: wrap; margin-bottom: 14px; }
    .cv-fr-cta .btn { padding: 13px 22px; font-size: 14px; }
    .cv-fr-cta .btn-primary { box-shadow: 0 10px 26px -12px var(--accent-glow); }
    .cv-fr-tertiary { font-size: 13px; color: var(--text-4); }
    .cv-fr-tertiary a { color: var(--accent); text-decoration: none; font-weight: 600; cursor: pointer; }
    /* notetaker grid */
    .cv-nt-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin: 6px 0 18px; }
    .cv-nt {
      display: flex; flex-direction: column; align-items: center; gap: 9px;
      padding: 20px 14px; border: 1px solid var(--line); border-radius: 14px;
      background: var(--bg-2); cursor: pointer;
      transition: border-color .15s, transform .15s, background .15s;
    }
    .cv-nt:hover { border-color: var(--accent-line); transform: translateY(-2px); background: var(--bg-hover); }
    .cv-nt .cv-logo { width: 40px; height: 40px; border-radius: 11px; display: grid; place-items: center; font-weight: 800; font-size: 16px; color: #fff; }
    .cv-nt .cv-nm { font-size: 13px; font-weight: 700; color: var(--text); }
    .cv-nt .cv-ds { font-size: 11.5px; color: var(--text-4); }
    @media (max-width: 560px) { .cv-nt-grid { grid-template-columns: 1fr; } }
    /* tips strip */
    .cv-tips {
      max-width: 680px; margin: 4px auto 0; border: 1px solid var(--line); border-radius: 14px;
      background: var(--bg-1); padding: 13px 16px; text-align: left; position: relative;
    }
    .cv-tips-h { font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--text-4); margin-bottom: 10px; }
    .cv-tips-x { position: absolute; top: 10px; right: 13px; color: var(--text-4); cursor: pointer; font-size: 14px; background: none; border: 0; }
    .cv-tips-row { display: flex; gap: 10px; }
    .cv-tip { flex: 1; display: flex; gap: 10px; align-items: flex-start; }
    .cv-tip .cv-ic { width: 30px; height: 30px; border-radius: 9px; flex-shrink: 0; display: grid; place-items: center; background: var(--bg-3); border: 1px solid var(--line); color: var(--accent); }
    .cv-tip .cv-ic svg { width: 15px; height: 15px; }
    .cv-tip .cv-tt { font-size: 12.5px; font-weight: 600; color: var(--text-2); }
    .cv-tip .cv-ts { font-size: 11.5px; color: var(--text-4); margin-top: 1px; line-height: 1.45; }
    @media (max-width: 600px) { .cv-tips-row { flex-direction: column; gap: 12px; } }
    /* hint dots — pulse on callMatsBtn + voiceBtn in value/connect only */
    #callMatsBtn, #voiceBtn { position: relative; }
    .cv-hintdot {
      position: absolute; top: -3px; right: -3px; width: 11px; height: 11px;
      border-radius: 50%; background: var(--accent); border: 2px solid var(--bg-1);
      display: none; pointer-events: none;
    }
    .cv-hintdot::after {
      content: ""; position: absolute; inset: -3px; border-radius: 50%;
      border: 1.5px solid var(--accent); animation: cvHintPulse 1.8s ease-out infinite;
    }
    @keyframes cvHintPulse { 0% { transform: scale(.6); opacity: .8 } 100% { transform: scale(2.1); opacity: 0 } }
    #mainView[data-state="value"]   .cv-hintdot,
    #mainView[data-state="connect"] .cv-hintdot { display: block; }

    /* (A.5) PATH B FIX 3: populated home view — live cards + past calls.
       Hidden by default; only visible when:
         - state=populated AND tab=transcript AND body.cv-between-calls
       body.cv-between-calls is toggled by renderCvCalls() based on whether
       there's a live-streaming active session. */
    #cvCalls {
      display: none; max-width: 1040px; margin: 0 auto;
      padding: 20px 26px 28px; flex: 1; min-height: 0;
    }
    body.cv-between-calls #mainView[data-tab="transcript"][data-state="populated"] #cvCalls { display: block; }
    /* When cv-calls is visible, hide the legacy contentArea + cvFrWrap so they
       don't double-render past calls. */
    body.cv-between-calls #mainView[data-tab="transcript"][data-state="populated"] #contentArea,
    body.cv-between-calls #mainView[data-tab="transcript"][data-state="populated"] #cvFrWrap { display: none; }
    .cv-calls-live, .cv-calls-past { margin-bottom: 22px; }
    .cv-calls-h {
      font-size: 10.5px; font-weight: 700; letter-spacing: .1em;
      text-transform: uppercase; color: var(--text-3);
      margin-bottom: 11px; display: flex; align-items: center; gap: 8px;
    }
    .cv-calls-live .cv-calls-h { color: var(--accent); }
    .cv-calls-live .cv-led {
      width: 7px; height: 7px; border-radius: 50%; background: var(--accent);
      box-shadow: 0 0 0 3px var(--accent-glow);
      animation: cvLedPulse 1.8s ease-in-out infinite;
    }
    @keyframes cvLedPulse { 0%,100% { opacity: 1 } 50% { opacity: .45 } }
    .cv-calls-n {
      font-family: var(--mono); font-size: 11px; font-weight: 500;
      color: var(--text-4);
    }
    .cv-livecard {
      border: 1px solid var(--accent-line); border-radius: 13px;
      background: linear-gradient(140deg, var(--accent-soft), var(--bg-2));
      padding: 14px 16px; margin-bottom: 8px;
      cursor: pointer; position: relative; overflow: hidden;
      transition: transform .15s, border-color .15s;
      display: flex; align-items: center; gap: 12px;
    }
    .cv-livecard:hover { transform: translateY(-2px); border-color: var(--accent); }
    .cv-livecard .lcb {
      display: inline-block; font-size: 9px; font-weight: 800;
      letter-spacing: .08em; text-transform: uppercase;
      color: var(--accent-ink); background: var(--accent);
      border-radius: 999px; padding: 3px 9px; flex-shrink: 0;
    }
    .cv-livecard .lci { flex: 1; min-width: 0; }
    .cv-livecard .lct {
      font-size: 15px; font-weight: 700; letter-spacing: -.01em;
      color: var(--text);
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .cv-livecard .lcm {
      font-size: 12.5px; color: var(--accent); margin-top: 2px;
      font-weight: 500;
    }
    .cv-livecard .lcj {
      flex-shrink: 0; padding: 7px 14px; border-radius: 9px;
      background: var(--accent); color: var(--accent-ink); border: 0;
      font-family: inherit; font-size: 12px; font-weight: 700; cursor: pointer;
    }
    .cv-livecard .lcj:hover { filter: brightness(1.07); }
    .cv-calls-pastlist { display: flex; flex-direction: column; gap: 6px; }
    .cv-pastitem {
      display: flex; align-items: center; gap: 12px;
      border: 1px solid var(--line); border-radius: 11px;
      background: var(--bg-2); padding: 11px 14px; cursor: pointer;
      transition: border-color .15s, transform .15s, background .15s;
    }
    .cv-pastitem:hover {
      border-color: var(--accent-line); background: var(--bg-hover);
      transform: translateX(2px);
    }
    .cv-pastitem .pd {
      width: 8px; height: 8px; border-radius: 50%;
      background: var(--text-4); flex-shrink: 0;
    }
    .cv-pastitem:hover .pd { background: var(--accent); }
    .cv-pastitem .pi {
      flex: 1; min-width: 0; display: flex; align-items: baseline;
      gap: 12px; justify-content: space-between;
    }
    .cv-pastitem .pt {
      font-size: 13.5px; font-weight: 600; color: var(--text);
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .cv-pastitem .pm {
      font-size: 11.5px; color: var(--text-4);
      font-family: var(--mono); flex-shrink: 0;
    }
    .cv-calls-empty {
      padding: 18px 14px; text-align: center;
      color: var(--text-4); font-size: 12.5px;
      border: 1px dashed var(--line); border-radius: 11px;
      background: var(--bg-1);
    }
    .cv-calls-more {
      margin-top: 12px; width: 100%; padding: 11px 14px;
      border: 1px solid var(--line-strong); border-radius: 10px;
      background: var(--bg-2); color: var(--text-2);
      font-family: inherit; font-size: 12.5px; font-weight: 600;
      cursor: pointer;
    }
    .cv-calls-more:hover { border-color: var(--accent-line); color: var(--text); }

    /* (B) APP SWITCHER */
    .cv-appsw {
      display: inline-flex; align-items: center; gap: 9px;
      padding: 5px 9px; border-radius: 10px; border: 1px solid transparent;
      cursor: pointer; background: none; color: var(--text);
      font-family: inherit;
    }
    .cv-appsw:hover { background: var(--bg-2); border-color: var(--line); }
    .cv-appsw .cv-swname { font-weight: 700; font-size: 13.5px; letter-spacing: -.01em; color: var(--text); }
    .cv-appsw .cv-chev { width: 13px; height: 13px; color: var(--text-3); transition: transform .2s, color .15s; flex-shrink: 0; }
    .cv-appsw:hover .cv-chev { color: var(--text-2); }
    .cv-appsw[aria-expanded="true"] .cv-chev { transform: rotate(180deg); }

    /* dropdown menu (shared by B + C) */
    .cv-menu {
      position: absolute; z-index: 40; min-width: 260px;
      background: color-mix(in oklab, var(--bg-2) 96%, transparent);
      border: 1px solid var(--line-strong); border-radius: 15px;
      box-shadow: var(--shadow-lg), inset 0 1px 0 rgba(255,255,255,.05);
      padding: 8px; display: none;
      backdrop-filter: blur(16px) saturate(140%);
      -webkit-backdrop-filter: blur(16px) saturate(140%);
      animation: cvMenuIn .16s cubic-bezier(.2,.8,.2,1);
    }
    .cv-menu.open { display: block; }
    @keyframes cvMenuIn { from { opacity: 0; transform: translateY(-7px) scale(.97); } to { opacity: 1; transform: none; } }
    .cv-menu-h { font-size: 10px; font-weight: 700; letter-spacing: .11em; text-transform: uppercase; color: var(--text-4); padding: 8px 10px 7px; }
    .cv-mitem {
      display: flex; align-items: center; gap: 13px;
      padding: 10px; border-radius: 11px; cursor: pointer;
      text-decoration: none; color: var(--text);
      transition: background .15s, transform .12s;
    }
    .cv-mitem:hover { background: var(--bg-hover); }
    .cv-mitem:active { transform: scale(.985); }
    .cv-mitem .cv-ic {
      width: 38px; height: 38px; border-radius: 11px; flex-shrink: 0;
      display: grid; place-items: center;
      background: var(--bg-3); border: 1px solid var(--line); color: var(--text-2);
      transition: transform .15s;
    }
    .cv-mitem:hover .cv-ic { transform: scale(1.05); }
    .cv-mitem .cv-ic svg { width: 18px; height: 18px; }
    .cv-mitem.cv-cur { background: color-mix(in oklab, var(--accent) 7%, transparent); }
    .cv-mitem.cv-cur .cv-ic {
      background: linear-gradient(140deg, var(--brand-blue), var(--brand-violet));
      border-color: transparent; color: #fff;
      box-shadow: 0 7px 18px -9px rgba(99,102,241,.65);
    }
    .cv-mitem .cv-tx { flex: 1; min-width: 0; display: flex; flex-direction: column; }
    .cv-mitem .cv-tx .cv-t { font-size: 14px; font-weight: 600; color: var(--text); letter-spacing: -.01em; }
    .cv-mitem .cv-tx .cv-s { font-size: 11.5px; color: var(--text-3); margin-top: 4px; line-height: 1.35; }
    .cv-mitem .cv-badge { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 11px; color: var(--text-3); background: var(--bg-3); border: 1px solid var(--line); border-radius: 999px; padding: 2px 8px; }
    .cv-mitem .cv-check { color: var(--accent); font-weight: 800; }
    .cv-menu-sep { height: 1px; background: var(--line); margin: 6px 4px; }
    .cv-menu-right { right: 14px; top: 54px; }
    .cv-menu-left  { left: 14px;  top: 54px; }

    /* (C) ACCOUNT CHIP */
    .cv-acct {
      display: inline-flex; align-items: center; gap: 7px;
      padding: 3px 8px 3px 3px; border: 1px solid var(--line-strong); border-radius: 999px;
      background: var(--bg-2); cursor: pointer;
      font-family: inherit; color: var(--text);
    }
    .cv-acct:hover { border-color: var(--accent-line); }
    .cv-acct .cv-av {
      width: 26px; height: 26px; border-radius: 50%;
      display: grid; place-items: center; font-size: 11px; font-weight: 700;
      color: var(--accent-ink);
      background: linear-gradient(140deg, var(--brand-blue), var(--brand-violet));
      flex-shrink: 0;
    }
    .cv-acct .cv-em { font-size: 12px; font-weight: 500; color: var(--text-2); max-width: 160px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .cv-acct .cv-plan { font-size: 10px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--accent); }
    .cv-acct .cv-chev { width: 12px; height: 12px; color: var(--text-4); transition: transform .2s; flex-shrink: 0; }
    .cv-acct[aria-expanded="true"] .cv-chev { transform: rotate(180deg); }
    .cv-row-acct {
      padding: 9px; display: flex; align-items: center; gap: 11px;
    }
    .cv-row-acct .cv-av {
      width: 36px; height: 36px; border-radius: 50%;
      display: grid; place-items: center; font-weight: 700;
      color: var(--accent-ink);
      background: linear-gradient(140deg, var(--brand-blue), var(--brand-violet));
    }
    .cv-row-acct .cv-em { font-size: 13px; font-weight: 600; color: var(--text); }
    .cv-row-acct .cv-pl { font-size: 11px; color: var(--text-4); margin-top: 1px; }

    /* (F) SEARCH OVERLAY — anchored as an in-page panel below the header/tabs
       (light scrim, page stays visible) so it reads as part of the current page
       rather than an entirely separate screen. */
    .cv-ov {
      position: fixed; inset: 0; z-index: 90;
      background: rgba(4,6,5,.42); backdrop-filter: blur(2px);
      display: none; justify-content: center; align-items: flex-start;
      padding: 94px 20px 20px;
    }
    [data-theme="light"] .cv-ov { background: rgba(20,25,22,.24); }
    .cv-ov.open { display: flex; animation: cvOvIn .14s ease; }
    @keyframes cvOvIn { from { opacity: 0; } to { opacity: 1; } }
    .cv-ovsheet {
      width: 100%; max-width: 760px;
      background: var(--bg-2); border: 1px solid var(--line); border-radius: 16px;
      box-shadow: var(--shadow-lg); overflow: hidden;
      max-height: calc(100vh - 90px); display: flex; flex-direction: column;
    }
    .cv-ovsearch {
      display: flex; align-items: center; gap: 11px;
      padding: 15px 18px; border-bottom: 1px solid var(--line); flex-shrink: 0;
    }
    .cv-ovsearch svg { width: 18px; height: 18px; color: var(--text-4); flex-shrink: 0; }
    .cv-ovsearch input {
      flex: 1; background: none; border: 0; color: var(--text);
      font-family: inherit; font-size: 16px; outline: none;
    }
    .cv-ovsearch input::placeholder { color: var(--text-4); }
    .cv-ovcount { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 11.5px; color: var(--text-3); background: var(--bg-3); border: 1px solid var(--line); border-radius: 999px; padding: 3px 10px; white-space: nowrap; }
    .cv-ovbody { overflow-y: auto; padding: 8px 8px 12px; }
    .cv-ovlivewrap {
      margin: 4px 4px 12px; border: 1px solid rgba(239,68,68,.4); border-radius: 13px;
      background: linear-gradient(180deg, rgba(239,68,68,.1), rgba(239,68,68,.03));
      padding: 6px;
      box-shadow: 0 0 0 1px rgba(239,68,68,.12), 0 10px 30px -16px rgba(239,68,68,.4);
    }
    .cv-ovlive-h { display: flex; align-items: center; gap: 8px; padding: 7px 9px 9px; font-size: 11px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: #f87171; }
    .cv-liveled { width: 9px; height: 9px; border-radius: 50%; background: #ef4444; box-shadow: 0 0 0 3px rgba(239,68,68,.28); animation: cvLivep 1.4s ease-in-out infinite; }
    @keyframes cvLivep { 0%,100% { opacity: 1; box-shadow: 0 0 0 3px rgba(239,68,68,.28); } 50% { opacity: .55; box-shadow: 0 0 0 6px rgba(239,68,68,0); } }
    .cv-ovlive-h .cv-liven { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 10px; background: #ef4444; color: #fff; border-radius: 999px; padding: 1px 7px; }
    .cv-ovlive { display: flex; align-items: center; gap: 12px; padding: 11px 12px; border-radius: 10px; cursor: pointer; }
    .cv-ovlive:hover { background: rgba(239,68,68,.08); }
    .cv-ovlive .cv-rec { width: 10px; height: 10px; border-radius: 50%; background: #ef4444; flex-shrink: 0; box-shadow: 0 0 0 4px rgba(239,68,68,.18); animation: cvLivep 1.4s ease-in-out infinite; }
    .cv-ovlive .cv-oll-info { flex: 1; min-width: 0; }
    .cv-ovlive .cv-ot { font-size: 14.5px; font-weight: 700; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .cv-ovlive .cv-om { font-size: 12px; color: #f87171; font-weight: 500; margin-top: 1px; }
    .cv-joinbtn { flex-shrink: 0; padding: 8px 16px; border-radius: 9px; background: #ef4444; color: #fff; border: 0; font-family: inherit; font-size: 12.5px; font-weight: 700; cursor: pointer; }
    .cv-joinbtn:hover { filter: brightness(1.07); }
    .cv-ovsec { font-size: 10.5px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--text-4); padding: 8px 12px 6px; }
    .cv-ovrow { display: grid; grid-template-columns: 84px 1fr auto; align-items: center; gap: 12px; padding: 9px 12px; border-radius: 10px; cursor: pointer; }
    .cv-ovrow:hover { background: var(--bg-hover); }
    .cv-ovdate { display: flex; flex-direction: column; line-height: 1.25; font-family: 'JetBrains Mono', ui-monospace, monospace; }
    .cv-ovdate b { font-size: 12px; font-weight: 700; color: var(--text-2); }
    .cv-ovdate span { font-size: 11px; color: var(--text-4); }
    .cv-ovr-info { min-width: 0; }
    .cv-ovr-info .cv-ot { font-size: 13.5px; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .cv-ovr-info .cv-om { font-size: 11.5px; color: var(--text-4); margin-top: 1px; display: flex; align-items: center; gap: 7px; }
    .cv-prov { font-weight: 600; color: var(--text-3); }
    .cv-oact { display: flex; gap: 4px; opacity: 0; flex-shrink: 0; }
    .cv-ovrow:hover .cv-oact { opacity: 1; }
    .cv-oact button { width: 28px; height: 28px; border-radius: 7px; border: 1px solid var(--line); background: var(--bg-1); color: var(--text-3); cursor: pointer; display: grid; place-items: center; }
    .cv-oact button:hover { color: var(--accent); border-color: var(--accent-line); }
    .cv-oact button svg { width: 14px; height: 14px; }
    .cv-renameinp { font-family: inherit; font-size: 13.5px; font-weight: 600; background: var(--bg-1); border: 1px solid var(--accent); border-radius: 6px; color: var(--text); padding: 4px 8px; outline: none; box-shadow: 0 0 0 3px var(--accent-soft); width: 100%; }
    .cv-ovempty { padding: 34px; text-align: center; color: var(--text-4); font-size: 13px; display: none; }
    .cv-ovsearching { display: flex; align-items: center; justify-content: center; gap: 9px; padding: 14px 12px; margin: 4px 6px 8px; border-radius: 10px; background: color-mix(in srgb, var(--accent) 8%, transparent); border: 1px solid var(--accent-line, color-mix(in srgb, var(--accent) 30%, transparent)); color: var(--text-2); font-size: 13px; font-weight: 600; }
    .cv-ovsearching[hidden] { display: none; }
    .cv-ovspin { width: 14px; height: 14px; border-radius: 50%; border: 2px solid color-mix(in srgb, var(--accent) 35%, transparent); border-top-color: var(--accent); animation: cvOvSpin .7s linear infinite; flex-shrink: 0; }
    @keyframes cvOvSpin { to { transform: rotate(360deg); } }

    /* (G) ADD-TO-MEETING MODAL */
    .cv-mscrim {
      position: fixed; inset: 0; z-index: 92;
      background: rgba(2,5,4,.72); backdrop-filter: blur(5px);
      display: none; align-items: center; justify-content: center; padding: 20px;
    }
    [data-theme="light"] .cv-mscrim { background: rgba(20,25,22,.4); }
    .cv-mscrim.open { display: flex; animation: cvOvIn .14s ease; }
    .cv-mmodal {
      width: 100%; max-width: 460px;
      background: var(--bg-2); border: 1px solid var(--line); border-radius: 16px;
      box-shadow: var(--shadow-lg); padding: 22px;
    }
    .cv-mh { display: flex; align-items: center; gap: 11px; margin-bottom: 2px; }
    .cv-mh .cv-ic {
      width: 34px; height: 34px; border-radius: 10px;
      display: grid; place-items: center;
      background: var(--accent-soft); border: 1px solid var(--accent-line);
      color: var(--accent); flex-shrink: 0;
    }
    .cv-mh .cv-ic svg { width: 17px; height: 17px; }
    .cv-mh h3 { font-size: 17px; font-weight: 700; letter-spacing: -.01em; color: var(--text); }
    .cv-msub { font-size: 12.5px; color: var(--text-3); margin: 8px 0 16px; line-height: 1.5; }
    .cv-provseg { display: flex; gap: 8px; margin-bottom: 15px; }
    .cv-provseg button {
      flex: 1; display: flex; flex-direction: column; align-items: center; gap: 8px;
      padding: 13px 8px; border: 1px solid var(--line-strong); border-radius: 11px;
      background: var(--bg-3); color: var(--text-2); cursor: pointer;
      font-family: inherit; font-size: 12.5px; font-weight: 600;
    }
    .cv-provseg button[disabled] { opacity: .4; cursor: not-allowed; }
    .cv-provseg button .cv-lg { width: 30px; height: 30px; border-radius: 8px; display: grid; place-items: center; font-weight: 800; color: #fff; font-size: 13px; }
    .cv-provseg button.cv-on { border-color: var(--accent); background: var(--accent-soft); color: var(--text); }
    .cv-mlabel { display: block; font-size: 12px; color: var(--text-2); margin-bottom: 6px; font-weight: 500; }
    .cv-minput { width: 100%; padding: 11px 13px; border: 1px solid var(--line-strong); border-radius: 9px; background: var(--bg-3); color: var(--text); font-family: inherit; font-size: 13.5px; outline: none; }
    .cv-minput:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
    .cv-mnote { display: flex; align-items: center; gap: 7px; font-size: 11.5px; color: var(--text-4); margin-top: 11px; }
    .cv-mnote svg { width: 14px; height: 14px; flex-shrink: 0; }
    .cv-mactions { display: flex; gap: 10px; margin-top: 18px; }
    .cv-mactions .btn { flex: 1; justify-content: center; text-align: center; }
    .cv-status { font-size: 12px; min-height: 18px; margin-top: 10px; }

    /* ───────── R13.3 SETTINGS PORT (cv- prefix; scoped to #settingsPage where useful) ───────── */
    /* Account hero */
    #settingsPage .cv-hero { position: relative; overflow: hidden; border-radius: 18px; border: 1px solid var(--line);
      background: linear-gradient(150deg, var(--bg-2), var(--bg-1)); box-shadow: var(--shadow-md);
      padding: 26px 26px 22px; margin-bottom: 22px; }
    #settingsPage .cv-hero::after { content: ""; position: absolute; inset: 0; pointer-events: none;
      background: radial-gradient(120% 90% at 100% 0%, var(--accent-soft), transparent 60%); }
    #settingsPage .cv-hero-top { display: flex; align-items: center; gap: 16px; position: relative; }
    #settingsPage .cv-avatar { width: 54px; height: 54px; border-radius: 50%; flex-shrink: 0; display: grid; place-items: center;
      font-weight: 700; font-size: 19px; color: #fff;
      background: linear-gradient(140deg, var(--brand-blue), var(--brand-violet)); box-shadow: var(--shadow-sm); }
    #settingsPage .cv-hero-id { min-width: 0; flex: 1; }
    #settingsPage .cv-hero-id .cv-em { font-size: 16px; font-weight: 700; letter-spacing: -.01em; color: var(--text); }
    #settingsPage .cv-hero-id .cv-sub { font-size: 12.5px; color: var(--text-3); margin-top: 2px; }
    #settingsPage .cv-planbadge { margin-left: auto; font-size: 11px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
      color: var(--text-2); background: var(--bg-3); border: 1px solid var(--line-strong); border-radius: 999px; padding: 5px 11px; white-space: nowrap; }
    #settingsPage .cv-usage { position: relative; margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--line); }
    #settingsPage .cv-usage-row { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 9px; }
    #settingsPage .cv-usage-row .cv-lab { font-size: 12.5px; color: var(--text-2); }
    #settingsPage .cv-usage-row .cv-val { font-family: var(--mono); font-size: 13px; color: var(--text); }
    #settingsPage .cv-meter { height: 6px; background: var(--bg-2); border-radius: 999px; overflow: hidden; }
    #settingsPage .cv-meter > span { display: block; height: 100%; background: var(--accent); transition: width .3s; }
    #settingsPage .cv-hero-cta { position: relative; display: flex; gap: 10px; margin-top: 18px; flex-wrap: wrap; }
    #settingsPage .cv-hero-cta:empty { display: none; }
    #settingsPage .cv-hero-cta .btn-primary { flex: 1; min-width: 200px; text-align: center; justify-content: center; }
    /* Sections */
    #settingsPage .cv-sec { margin-top: 24px; }
    #settingsPage .cv-sec-head { display: flex; align-items: center; gap: 10px; margin-bottom: 11px; }
    #settingsPage .cv-sec-head h2 { font-size: 13px; font-weight: 700; letter-spacing: .02em; color: var(--text); margin: 0; }
    #settingsPage .cv-sec-head .cv-hint { margin-left: auto; font-size: 12px; color: var(--text-4); }
    #settingsPage .cv-card { border: 1px solid var(--line); border-radius: 14px; background: var(--bg-2); box-shadow: var(--shadow-sm); padding: 18px; }
    #settingsPage .cv-card + .cv-card { margin-top: 10px; }
    /* Connections sources strip */
    #settingsPage .cv-sources { display: flex; gap: 6px; margin-top: 14px; flex-wrap: wrap; }
    #settingsPage .cv-chip { font-size: 12px; font-weight: 600; color: var(--text-2); background: var(--bg-3);
      border: 1px solid var(--line-strong); border-radius: 8px; padding: 6px 11px; }
    /* Fireflies = prominent green live option; Otter/Fathom = muted "past calls" */
    #settingsPage .cv-chip.cv-chip-live { color: var(--ok, #10b981); background: rgba(16,185,129,0.10);
      border-color: rgba(16,185,129,0.55); font-weight: 700; }
    #settingsPage .cv-chip.cv-chip-muted { color: var(--text-3); background: var(--bg-2);
      border-color: var(--line); opacity: 0.78; font-weight: 600; }
    /* Field primitives (scoped) */
    #settingsPage .cv-field { margin-bottom: 14px; }
    #settingsPage .cv-field:last-child { margin-bottom: 0; }
    #settingsPage .cv-field > label { display: block; font-size: 12px; color: var(--text-2); margin-bottom: 6px; font-weight: 500; }
    #settingsPage .cv-field .cv-row { display: flex; gap: 8px; align-items: stretch; }
    #settingsPage .cv-field .cv-row .s-input { flex: 1; margin-bottom: 0; }
    #settingsPage .cv-twocol { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
    #settingsPage .cv-notebar { display: flex; align-items: center; gap: 8px; margin-top: 9px; font-size: 11.5px; color: var(--text-3); }
    #settingsPage .cv-ctx-wrap { position: relative; }
    #settingsPage .cv-ctx-foot { display: flex; align-items: center; gap: 10px; margin-top: 10px; }
    #settingsPage .cv-ctx-foot .cv-drop { flex: 1; font-size: 12.5px; color: var(--text-3);
      border: 1px dashed var(--line-strong); border-radius: 9px; padding: 9px 12px; display: flex; align-items: center; gap: 8px; }
    #settingsPage .cv-lock { display: inline-block; font-size: 10px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
      color: var(--text-3); border: 1px solid var(--line-strong); border-radius: 999px; padding: 2px 8px; }
    /* Advanced accordion */
    #settingsPage .cv-adv { border: 1px solid var(--line); border-radius: 14px; background: var(--bg-1); overflow: hidden; }
    #settingsPage .cv-adv-trigger { display: flex; align-items: center; gap: 11px; width: 100%; padding: 15px 18px;
      background: none; border: none; color: var(--text); font-family: inherit; font-size: 14px; font-weight: 600;
      cursor: pointer; text-align: left; }
    #settingsPage .cv-adv-trigger:hover { background: var(--bg-2); }
    #settingsPage .cv-adv-trigger .cv-ic { color: var(--text-3); display: inline-flex; }
    #settingsPage .cv-adv-trigger .cv-ic svg { width: 16px; height: 16px; }
    #settingsPage .cv-adv-trigger .cv-sum { margin-left: auto; display: flex; align-items: center; gap: 9px; font-weight: 400; color: var(--text-4); font-size: 12.5px; }
    #settingsPage .cv-adv-trigger .cv-chev { transition: transform .22s; color: var(--text-4); }
    #settingsPage .cv-adv.open .cv-adv-trigger .cv-chev { transform: rotate(180deg); }
    #settingsPage .cv-adv-body { display: none; padding: 8px 18px 18px; border-top: 1px solid var(--line); }
    #settingsPage .cv-adv.open .cv-adv-body { display: block; }
    #settingsPage .cv-adv-row { display: flex; align-items: center; gap: 12px; padding: 14px 0; border-bottom: 1px solid var(--line); }
    #settingsPage .cv-adv-row:first-child { padding-top: 8px; }
    #settingsPage .cv-adv-row:last-child { border-bottom: none; padding-bottom: 2px; }
    #settingsPage .cv-adv-row .cv-k { flex: 1; min-width: 0; }
    #settingsPage .cv-adv-row .cv-k .cv-t { font-size: 13.5px; color: var(--text); font-weight: 500; }
    #settingsPage .cv-adv-row .cv-k .cv-s { font-size: 11.5px; color: var(--text-4); margin-top: 2px; }
    #settingsPage .cv-adv-row.cv-danger .cv-t { color: var(--danger); }
    /* Advanced page (FIX 2: un-nested, directly visible, grouped) */
    #settingsPage .cv-adv-page { display: flex; flex-direction: column; gap: 20px; }
    #settingsPage .cv-adv-grphead { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; margin-bottom: 8px; }
    #settingsPage .cv-adv-grphead h3 { font-size: 14px; font-weight: 600; letter-spacing: -.01em; margin: 0; color: var(--text); }
    #settingsPage .cv-adv-grphead .cv-hint { font-size: 12px; color: var(--text-4); }
    /* Key presets card (Advanced) — clean stacked layout, never the warped flex-row */
    #settingsPage .cv-presets-card { display: flex; flex-direction: column; gap: 14px; }
    #settingsPage .cv-presets-intro .cv-t { font-size: 13.5px; color: var(--text); font-weight: 500; }
    #settingsPage .cv-presets-intro .cv-s { font-size: 12px; color: var(--text-4); margin-top: 3px; line-height: 1.55; }
    #settingsPage #presetsList { display: flex; flex-direction: column; gap: 10px; }
    #settingsPage #presetsList:empty { display: none; }
    #settingsPage .cv-presets-empty { color: var(--text-3); font-size: 13px; line-height: 1.6;
      padding: 16px; border: 1px dashed var(--line-strong); border-radius: 12px; background: var(--bg-1); }
    #settingsPage .cv-presets-card .preset-card { margin-bottom: 0; }
    #settingsPage .cv-presets-add { align-self: flex-start; }
    /* Clear-data modal */
    .cv-scrim { position: fixed; inset: 0; background: rgba(2,5,4,.72); backdrop-filter: blur(5px); z-index: 99990;
      display: none; align-items: center; justify-content: center; padding: 20px; }
    [data-theme="light"] .cv-scrim { background: rgba(20,25,22,.4); }
    .cv-scrim.open { display: flex; animation: cvFadeIn .16s ease; }
    @keyframes cvFadeIn { from { opacity: 0; } to { opacity: 1; } }
    .cv-modal { width: 100%; max-width: 440px; background: var(--bg-2); border: 1px solid var(--line); border-radius: 16px;
      box-shadow: var(--shadow-lg); padding: 22px; animation: cvModalIn .2s cubic-bezier(.2,.7,.2,1); }
    @keyframes cvModalIn { from { opacity: 0; transform: translateY(8px) scale(.98); } to { opacity: 1; transform: none; } }
    .cv-modal .cv-mh { display: flex; align-items: center; gap: 10px; margin-bottom: 3px; }
    .cv-modal .cv-mh .cv-warn { width: 30px; height: 30px; border-radius: 9px; display: grid; place-items: center; flex-shrink: 0;
      background: var(--danger-soft); border: 1px solid var(--danger-line); color: var(--danger); }
    .cv-modal .cv-mh .cv-warn svg { width: 16px; height: 16px; }
    .cv-modal h3 { font-size: 17px; font-weight: 700; letter-spacing: -.01em; margin: 0; }
    .cv-modal .cv-msub { font-size: 12.5px; color: var(--text-3); margin: 4px 0 16px; }
    .cv-opt { display: flex; align-items: center; gap: 12px; padding: 12px 13px; border: 1px solid var(--line); border-radius: 11px;
      background: var(--bg-1); cursor: pointer; margin-bottom: 8px; transition: border-color .14s, background .14s; }
    .cv-opt:hover { border-color: var(--danger-line); }
    .cv-opt.on { border-color: var(--danger); background: var(--danger-soft); }
    .cv-opt .cv-box { width: 19px; height: 19px; border: 1px solid var(--line-strong); border-radius: 6px; flex-shrink: 0;
      display: grid; place-items: center; color: #fff; font-size: 12px; font-weight: 800; }
    .cv-opt.on .cv-box { background: var(--danger); border-color: var(--danger); }
    .cv-opt .cv-ot { flex: 1; }
    .cv-opt .cv-ot .cv-k { font-size: 13.5px; font-weight: 600; color: var(--text); }
    .cv-opt .cv-ot .cv-s { font-size: 11.5px; color: var(--text-4); margin-top: 1px; }
    .cv-opt .cv-cnt { font-family: var(--mono); font-size: 12px; color: var(--text-4); }
    .cv-modal-actions { display: flex; gap: 10px; margin-top: 16px; }
    .cv-modal-actions .btn { flex: 1; justify-content: center; text-align: center; }
    .btn-danger-solid { background: var(--danger); color: #fff; border-color: var(--danger); }
    .btn-danger-solid:hover { filter: brightness(1.06); color: #fff; }
    .btn-danger-solid:disabled { opacity: .45; cursor: not-allowed; filter: none; }
    @media (max-width: 640px) { #settingsPage .cv-twocol { grid-template-columns: 1fr; } }

    /* ============================================================
       v3 cvHome module — scoped to #cvHome. Wholesale replacement
       of legacy home (cvFrWrap, cvCalls, contentArea chrome).
       Source: design-merge2/v3/home/cvHome.css
       ============================================================ */
    #cvHome{
      --cv-violet:var(--brand-violet,#8b5cf6);
      --cv-cyan:var(--brand-cyan,#06b6d4);
      --cv-blue:var(--brand-blue,#3b82f6);
      position:relative;display:flex;flex-direction:column;min-height:0;height:100%;
      font-family:var(--font,'Inter',system-ui,sans-serif);color:var(--text,#e9eee9);
      background:var(--bg,#0a0c0b);
    }
    #cvHome *{box-sizing:border-box}
    #cvHome .cvhdr{display:flex;align-items:center;gap:12px;padding:11px 16px;flex-shrink:0;position:relative;z-index:30;
      border-bottom:1px solid var(--line,#1b211e);background:color-mix(in srgb,var(--bg-1,#0e1110) 88%,transparent);backdrop-filter:saturate(160%) blur(14px)}
    #cvHome[data-cvchrome="off"] .cvhdr{display:none}
    #cvHome .cvbrandmark{display:inline-flex;gap:2px;align-items:flex-end}
    #cvHome .cvbrandmark i{display:block;width:3px;height:15px;border-radius:2px}
    #cvHome .cvbrandmark i:nth-child(1){height:9px;background:var(--cv-cyan)}
    #cvHome .cvbrandmark i:nth-child(2){height:15px;background:var(--cv-blue)}
    #cvHome .cvbrandmark i:nth-child(3){height:12px;background:var(--cv-violet)}
    #cvHome .cvappsw{display:flex;align-items:center;gap:9px;padding:6px 9px;border-radius:10px;border:1px solid transparent;cursor:pointer;background:none;font:inherit}
    #cvHome .cvappsw:hover{background:var(--bg-2,#151917);border-color:var(--line,#1b211e)}
    #cvHome .cvappsw .cvnm{font-weight:700;font-size:14.5px;letter-spacing:-.01em;color:var(--text,#e9eee9)}
    /* Match the Hub-side switcher (.hub-chev): without an explicit box + svg size
       the I.chev SVG (viewBox-only, no width/height attr) renders unsized and the
       arrow disappears / sits off-baseline. Mirror .hub-chev exactly so the
       Call-Analyst-side app-switcher shows the same dropdown arrow, aligned. */
    #cvHome .cvappsw .cvchev{width:13px;height:13px;flex-shrink:0;display:inline-flex;align-items:center;color:var(--text-4,#555d5b);transition:transform .2s,color .15s}
    #cvHome .cvappsw .cvchev svg{width:13px;height:13px;display:block}
    #cvHome .cvappsw:hover .cvchev{color:var(--text-2,#b4bdb8)}
    #cvHome .cvappsw[aria-expanded="true"] .cvchev{transform:rotate(180deg)}
    #cvHome .cvstatuspill{display:inline-flex;align-items:center;gap:7px;padding:4px 10px 4px 8px;border:1px solid var(--line,#1b211e);
      border-radius:999px;background:var(--bg-2,#151917);font-size:11px;font-weight:600;color:var(--text-3,#7d8784)}
    #cvHome .cvstatuspill .d{width:7px;height:7px;border-radius:50%;background:var(--text-4,#555d5b)}
    #cvHome[data-cvstate="active"] .cvstatuspill .d{background:var(--good,#3fb968);box-shadow:0 0 0 3px color-mix(in srgb,var(--good,#3fb968) 26%,transparent)}
    #cvHome .cvstatuspill.cv-searching{color:#f0a500;border-color:rgba(240,165,0,.4);background:color-mix(in srgb,#f0a500 10%,var(--bg-2,#151917))}
    #cvHome .cvstatuspill.cv-searching .d{background:#f0a500;animation:cvSearchPulse 1s ease-in-out infinite}
    @keyframes cvSearchPulse{0%,100%{box-shadow:0 0 0 0 rgba(240,165,0,.55);opacity:1}50%{box-shadow:0 0 0 5px rgba(240,165,0,0);opacity:.55}}
    #cvHome .cvhdr-actions{margin-left:auto;display:flex;align-items:center;gap:6px}
    #cvHome .cvhbtn{padding:7px 12px;border:1px solid var(--line-strong,#27302c);border-radius:8px;background:var(--bg-2,#151917);color:var(--text-2,#b4bdb8);
      font:inherit;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap}
    #cvHome .cvhbtn:hover{border-color:var(--accent-line,rgba(79,151,242,.34));color:var(--text,#e9eee9)}
    #cvHome .cvhbtn .cvplus{color:var(--accent,#4f97f2);font-weight:800;font-size:1.25em;vertical-align:-1px;margin-right:1px}
    #cvHome .cviconbtn{width:30px;height:30px;display:grid;place-items:center;border:1px solid var(--line-strong,#27302c);border-radius:8px;
      background:var(--bg-2,#151917);color:var(--text-2,#b4bdb8);cursor:pointer}
    #cvHome .cviconbtn:hover{color:var(--text,#e9eee9);border-color:var(--accent-line,rgba(79,151,242,.34))}
    #cvHome .cviconbtn svg{width:14px;height:14px}
    #cvHome .cvacct{display:flex;align-items:center;gap:7px;padding:3px 8px 3px 3px;border:1px solid var(--line-strong,#27302c);border-radius:999px;
      background:var(--bg-2,#151917);cursor:pointer;margin-left:4px;font:inherit}
    #cvHome .cvacct:hover{border-color:var(--accent-line,rgba(79,151,242,.34))}
    #cvHome .cvav{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:700;
      color:var(--accent-ink,#07101e);background:linear-gradient(140deg,var(--cv-blue),var(--cv-violet))}
    #cvHome .cvacct .cvchev{color:var(--text-4,#555d5b)}
    #cvHome .cvmenu{position:absolute;z-index:40;min-width:248px;padding:8px;display:none;
      background:color-mix(in srgb,var(--bg-2,#151917) 96%,transparent);border:1px solid var(--line-strong,#27302c);border-radius:15px;
      box-shadow:var(--shadow-lg,0 24px 50px -12px rgba(0,0,0,.6));backdrop-filter:blur(16px) saturate(140%)}
    #cvHome .cvmenu[data-open="1"]{display:block;animation:cvHome_menuIn .16s cubic-bezier(.2,.8,.2,1)}
    @keyframes cvHome_menuIn{from{opacity:0;transform:translateY(-7px) scale(.97)}to{opacity:1;transform:none}}
    #cvHome .cvmenu-h{font-size:10px;font-weight:700;letter-spacing:.11em;text-transform:uppercase;color:var(--text-4,#555d5b);padding:8px 10px 7px}
    #cvHome .cvmitem{display:flex;align-items:center;gap:13px;padding:10px;border-radius:11px;cursor:pointer;width:100%;border:0;background:none;text-align:left;font:inherit;color:var(--text,#e9eee9)}
    #cvHome .cvmitem:hover{background:var(--bg-hover,#1b211e)}
    #cvHome .cvmitem .cvmic{width:38px;height:38px;border-radius:11px;flex-shrink:0;display:grid;place-items:center;background:var(--bg-3,#1b211e);border:1px solid var(--line,#1b211e);color:var(--text-2,#b4bdb8)}
    #cvHome .cvmitem .cvmic svg{width:18px;height:18px}
    #cvHome .cvmitem.cur{background:color-mix(in srgb,var(--accent,#4f97f2) 7%,transparent)}
    #cvHome .cvmitem.cur .cvmic{background:linear-gradient(140deg,var(--cv-blue),var(--cv-violet));border-color:transparent;color:#fff}
    #cvHome .cvmitem .cvtx{flex:1;min-width:0;display:flex;flex-direction:column}
    #cvHome .cvmitem .cvtx .t{font-size:14px;font-weight:600;color:var(--text,#e9eee9);letter-spacing:-.01em}
    #cvHome .cvmitem .cvtx .s{font-size:11.5px;color:var(--text-3,#7d8784);margin-top:4px;line-height:1.35}
    #cvHome .cvmitem .cvbadge{font-family:var(--mono,'JetBrains Mono',monospace);font-size:11px;color:var(--text-3,#7d8784);background:var(--bg-3,#1b211e);border:1px solid var(--line,#1b211e);border-radius:999px;padding:2px 8px}
    #cvHome .cvmitem .cvcheck{color:var(--accent,#4f97f2);font-weight:800}
    #cvHome .cvmenu-sep{height:1px;background:var(--line,#1b211e);margin:6px 4px}
    #cvHome .cvrow-acct{padding:9px;display:flex;align-items:center;gap:11px}
    #cvHome .cvrow-acct .cvav{width:36px;height:36px}
    #cvHome .cvrow-acct .em{font-size:13px;font-weight:600;color:var(--text,#e9eee9)}
    #cvHome .cvrow-acct .pl{font-size:11px;color:var(--text-4,#555d5b);margin-top:1px}
    #cvHome .cvstatusbar,#cvHome .cvstatsbar{display:none;flex-shrink:0;border-bottom:1px solid var(--line,#1b211e);background:var(--bg-1,#0e1110)}
    #cvHome .cvstatusbar{padding:7px 16px;font-size:11px;color:var(--text-3,#7d8784)}
    #cvHome .cvstatsbar{gap:18px;padding:9px 16px}
    #cvHome[data-cvstate="active"] .cvstatusbar{display:block}
    #cvHome[data-cvstate="active"] .cvstatsbar{display:flex}
    #cvHome .cvstatsbar .cvstat{font-size:12px;color:var(--text-3,#7d8784)}
    #cvHome .cvstatsbar .cvstat b{color:var(--accent,#4f97f2);font-weight:700;font-family:var(--mono,'JetBrains Mono',monospace);font-size:13px}
    #cvHome .cvtabs{display:none;align-items:center;padding:0 14px;background:var(--bg,#0a0c0b);border-bottom:1px solid var(--line,#1b211e);flex-shrink:0;position:relative}
    /* Tabs (Transcript/Ask Claude/Auto-Analysis) only make sense once a call is open
       (active). In "populated" the user is picking a call, so the tab panes are hidden —
       showing the tab bar there is a dead-end. */
    #cvHome[data-cvstate="active"] .cvtabs{display:flex}
    #cvHome .cvtab{flex:1;text-align:center;padding:15px 10px;font-size:13px;font-weight:600;color:var(--text-3,#7d8784);cursor:pointer;position:relative;white-space:nowrap;background:none;border:0;font-family:inherit;transition:color .18s}
    #cvHome .cvtab:hover{color:var(--text-2,#b4bdb8)}
    #cvHome .cvtab::after{content:"";position:absolute;left:12px;right:12px;bottom:-1px;height:2px;transform:scaleX(0);transition:transform 280ms cubic-bezier(.2,.8,.2,1);
      background:linear-gradient(90deg,transparent,var(--accent,#4f97f2),transparent);box-shadow:0 0 12px var(--accent-glow,rgba(79,151,242,.28))}
    #cvHome .cvtab[aria-selected="true"]::after{transform:scaleX(1)}
    #cvHome .cvtab[aria-selected="true"]{color:var(--text,#e9eee9)}
    #cvHome .cvtab:focus-visible{outline:2px solid var(--accent,#4f97f2);outline-offset:-4px;border-radius:6px}
    #cvHome .cvspacer{flex:0 0 auto}
    #cvHome .cvtab-hub{display:inline-flex;align-items:center;gap:8px;margin-left:10px;padding:8px 14px;border-radius:10px;cursor:pointer;font-family:inherit;
      background:var(--bg-2,#151917);border:1px solid var(--line-strong,#27302c);color:#c2b6ef;font-size:12px;font-weight:600}
    #cvHome .cvtab-hub:hover{border-color:color-mix(in srgb,var(--cv-violet) 50%,transparent);color:#e8defc}
    #cvHome .cvtab-hub .cvct{font-family:var(--mono,'JetBrains Mono',monospace);font-size:10.5px;background:color-mix(in srgb,var(--cv-violet) 20%,transparent);border-radius:999px;padding:1px 7px;color:#d9ccfb}
    :root[data-theme="light"] #cvHome .cvtab-hub{background:color-mix(in srgb,var(--cv-violet) 9%,transparent);border-color:color-mix(in srgb,var(--cv-violet) 40%,transparent);color:#6d28d9}
    :root[data-theme="light"] #cvHome .cvtab-hub .cvct{background:color-mix(in srgb,var(--cv-violet) 16%,transparent);color:#6d28d9}
    /* internal-only mini DRA link: text-sized, no chrome, sits where the hub button would */
    #cvHome .cvtab-dra-mini{margin-left:10px;padding:4px 8px;border:none;background:none;border-radius:7px;cursor:pointer;font-family:inherit;font-size:11px;font-weight:600;color:var(--text-4,#555d5b);white-space:nowrap}
    #cvHome .cvtab-dra-mini:hover{color:var(--text-2,#aab3ae);background:var(--bg-2,#151917)}
    #cvHome .cvcontent{flex:1;min-height:0;overflow-y:auto;position:relative}
    #cvHome .cvview{display:none}
    #cvHome[data-cvstate="connect"] .cvview[data-view="connect"]{display:block}
    #cvHome[data-cvstate="value"] .cvview[data-view="value"]{display:block}
    #cvHome[data-cvstate="populated"] .cvview[data-view="populated"]{display:block}
    #cvHome[data-cvstate="active"] .cvview[data-view="active"]{display:block}
    #cvHome .cvfr{max-width:760px;margin:0 auto;padding:48px 24px 40px;text-align:center}
    #cvHome .cvfr-badge{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;font-weight:600;color:var(--text-3,#7d8784);white-space:nowrap;
      background:var(--bg-2,#151917);border:1px solid var(--line-strong,#27302c);border-radius:999px;padding:6px 13px;margin-bottom:22px}
    #cvHome .cvfr-badge .d{width:6px;height:6px;border-radius:50%;background:var(--accent,#4f97f2)}
    #cvHome .cvfr h1{font-size:33px;font-weight:800;letter-spacing:-.025em;line-height:1.08;margin:0 0 12px}
    #cvHome .cvgrad{background:linear-gradient(100deg,var(--cv-cyan),var(--cv-blue),var(--cv-violet));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
    #cvHome .cvfr .cvsub{font-size:15.5px;color:var(--text-3,#7d8784);max-width:54ch;margin:0 auto 28px;line-height:1.6}
    #cvHome .cvfr-cta{display:flex;gap:11px;justify-content:center;flex-wrap:wrap;margin-bottom:14px}
    #cvHome .cvbtn{padding:13px 22px;font-size:14px;font-weight:600;border-radius:11px;cursor:pointer;font-family:inherit;
      background:var(--bg-2,#151917);border:1px solid var(--line-strong,#27302c);color:var(--text,#e9eee9)}
    #cvHome .cvbtn:hover{border-color:var(--accent-line,rgba(79,151,242,.34))}
    #cvHome .cvbtn-primary{background:var(--accent,#4f97f2);border-color:transparent;color:var(--accent-ink,#07101e);box-shadow:0 10px 26px -12px var(--accent-glow,rgba(79,151,242,.28))}
    #cvHome .cvfr-tertiary{font-size:13px;color:var(--text-4,#555d5b)}
    #cvHome .cvfr-tertiary button{color:var(--accent,#4f97f2);background:none;border:0;font:inherit;font-weight:600;cursor:pointer}
    /* ── "Welcome back" dashboard (value state) ── */
    #cvHome .cvdash{max-width:760px;margin:0 auto;padding:40px 24px 36px;text-align:left}
    #cvHome .cvdash-greet{font-size:25px;font-weight:800;letter-spacing:-.02em;margin:0 0 4px}
    #cvHome .cvdash-sub{margin:0 0 22px;color:var(--text-3,#7d8784);font-size:13.5px}
    #cvHome .cvdash-searchwrap{position:relative;margin:0 0 20px}
    #cvHome .cvdash-searchwrap .cvdash-sico{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-4,#555d5b);width:18px;height:18px;pointer-events:none}
    #cvHome .cvdash-search{width:100%;height:52px;padding:0 16px 0 46px;border:1px solid var(--line-strong,#2a3331);border-radius:13px;background:var(--bg-3,#181d1f);color:var(--text,#e9eee9);font:inherit;font-size:15px;outline:none}
    #cvHome .cvdash-search::placeholder{color:var(--text-4,#555d5b)}
    #cvHome .cvdash-search:focus{border-color:var(--accent,#4f97f2);box-shadow:0 0 0 3px var(--accent-soft,rgba(79,151,242,.14))}
    /* 5 cards: 3-up on desktop (3 + 2), 2-up on tablet, 1-up on phones.
       grid-auto-rows:1fr keeps every card equal height regardless of copy length. */
    #cvHome .cvdash-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:1fr;gap:14px}
    @media (max-width:900px){#cvHome .cvdash-grid{grid-template-columns:repeat(2,1fr)}}
    /* Unified home search results (calls + projects, iteration-3 tabs) */
    #cvHome .cvus-panel{margin:0 0 6px}
    #cvHome .cvus-tabs{display:flex;gap:4px;margin-bottom:14px;border-bottom:1px solid var(--line,#1b211e)}
    #cvHome .cvus-tab{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;padding:9px 14px;color:var(--text-3,#7d8784);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:.15s}
    #cvHome .cvus-tab:hover{color:var(--text,#e9eee9)}
    #cvHome .cvus-tab.on{color:var(--text,#e9eee9);border-bottom-color:var(--accent,#4f97f2)}
    #cvHome .cvus-tab svg{width:13px;height:13px}
    #cvHome .cvus-tab .cvus-cnt{font-size:11px;padding:1px 7px;border-radius:999px;background:var(--bg-3,#181d1f);color:var(--text-3,#7d8784)}
    #cvHome .cvus-empty{text-align:center;padding:34px 18px;color:var(--text-4,#555d5b);font-size:13px}
    #cvHome .cvus-empty b{color:var(--text-3,#7d8784)}
    #cvHome .cvus-row{display:flex;align-items:center;gap:13px;padding:13px 14px;border:1px solid var(--line,#1b211e);border-radius:12px;background:var(--bg-2,#151917);margin-bottom:8px;transition:.15s}
    #cvHome .cvus-row:hover{border-color:var(--line-strong,#2a3331)}
    #cvHome .cvus-ico{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;flex:0 0 auto}
    #cvHome .cvus-ico.call{background:color-mix(in oklab,var(--cv-cyan,#06b6d4) 18%,transparent);color:var(--cv-cyan,#06b6d4)}
    #cvHome .cvus-ico.project{background:color-mix(in oklab,var(--cv-violet,#8b5cf6) 18%,transparent);color:var(--cv-violet,#8b5cf6)}
    #cvHome .cvus-body{flex:1;min-width:0}
    #cvHome .cvus-ttl{font-size:14px;font-weight:600;margin:0 0 3px;color:var(--text,#e9eee9);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
    #cvHome .cvus-snip{color:var(--text-3,#7d8784);font-size:12.5px;line-height:1.5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    #cvHome .cvus-badge{font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:999px;letter-spacing:.02em}
    #cvHome .cvus-badge.call{background:color-mix(in oklab,var(--cv-cyan,#06b6d4) 15%,transparent);color:var(--cv-cyan,#06b6d4)}
    #cvHome .cvus-badge.project{background:color-mix(in oklab,var(--cv-violet,#8b5cf6) 15%,transparent);color:var(--cv-violet,#8b5cf6)}
    #cvHome .cvus-badge.has-proj{background:color-mix(in oklab,var(--cv-violet,#8b5cf6) 13%,transparent);color:var(--cv-violet,#8b5cf6);border:1px solid color-mix(in oklab,var(--cv-violet,#8b5cf6) 35%,transparent)}
    #cvHome .cvus-acts{display:flex;align-items:center;gap:9px;flex:0 0 auto}
    #cvHome .cvus-btn{font-family:inherit;font-weight:600;border-radius:9px;cursor:pointer;transition:.15s;white-space:nowrap;border:1px solid var(--line-strong,#2a3331);background:var(--bg-2,#151917);color:var(--text-2,#b4bdb8)}
    #cvHome .cvus-btn:hover{border-color:var(--accent-line,rgba(79,151,242,.34));color:var(--text,#e9eee9)}
    #cvHome .cvus-btn.cvus-primary{font-size:12.5px;padding:8px 13px;background:var(--accent,#4f97f2);color:var(--accent-ink,#07101e);border-color:transparent}
    #cvHome .cvus-btn.cvus-primary:hover{filter:brightness(1.07);color:var(--accent-ink,#07101e);border-color:transparent}
    #cvHome .cvus-btn.cvus-mini{font-size:11px;padding:5px 9px;background:transparent;color:var(--text-3,#7d8784)}
    #cvHome .cvus-btn.cvus-mini:hover{color:var(--text-2,#b4bdb8);border-color:var(--line-strong,#2a3331)}
    #cvHome .cvdcard{position:relative;display:block;text-align:left;padding:20px;border:1px solid var(--line,#1b211e);border-radius:14px;background:var(--bg-2,#151917);cursor:pointer;font-family:inherit;transition:transform .16s,border-color .16s,background .16s;overflow:hidden}
    #cvHome .cvdcard:hover{border-color:var(--accent-line,rgba(79,151,242,.34));transform:translateY(-2px);background:var(--bg-hover,#1b211e)}
    #cvHome .cvdcard:focus-visible{outline:none;border-color:var(--accent,#4f97f2);box-shadow:0 0 0 3px var(--accent-soft,rgba(79,151,242,.14))}
    #cvHome .cvdcard .cvdic{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;margin-bottom:13px;background:var(--bg-3,#181d1f);border:1px solid var(--line,#1b211e);color:var(--text-2,#b4bdb8)}
    #cvHome .cvdcard .cvdic svg{width:18px;height:18px}
    #cvHome .cvdcard.cvd-feat{background:linear-gradient(150deg,var(--accent-soft,rgba(79,151,242,.13)),var(--bg-2,#151917))}
    #cvHome .cvdcard.cvd-feat .cvdic{background:linear-gradient(140deg,var(--cv-blue,#3b82f6),var(--cv-violet,#8b5cf6));border-color:transparent;color:#fff}
    #cvHome .cvdcard h3{font-size:15px;font-weight:700;margin:0 0 4px;color:var(--text,#e9eee9)}
    #cvHome .cvdcard p{font-size:12.5px;color:var(--text-3,#7d8784);margin:0}
    #cvHome .cvdcard .cvdarrow{position:absolute;top:18px;right:18px;color:var(--text-4,#555d5b);transition:transform .16s,color .16s}
    #cvHome .cvdcard:hover .cvdarrow{color:var(--accent,#4f97f2);transform:translate(2px,-2px)}
    @media (max-width:680px){
      #cvHome .cvdash-grid{grid-template-columns:1fr}
      #cvHome .cvdash{padding:28px 18px}
      #cvHome .cvdash-greet{font-size:22px}
    }
    /* Compact dashboard = the home header above the calls list (populated state).
       Slimmer than the standalone value-state dashboard so it doesn't dominate. */
    #cvHome .cvcalls .cvdash-compact{max-width:none;margin:0;padding:6px 0 26px;border-bottom:1px solid var(--line,#1b211e);margin-bottom:22px}
    #cvHome .cvdash-compact .cvdash-greet{font-size:20px;margin-bottom:3px}
    #cvHome .cvdash-compact .cvdash-sub{margin-bottom:16px;font-size:13px}
    #cvHome .cvdash-compact .cvdash-searchwrap{margin-bottom:16px}
    #cvHome .cvdash-compact .cvdash-search{height:46px}
    #cvHome .cvdash-compact .cvdash-grid{gap:10px}
    #cvHome .cvdash-compact .cvdcard{padding:14px}
    #cvHome .cvdash-compact .cvdcard .cvdic{width:32px;height:32px;margin-bottom:9px;border-radius:9px}
    #cvHome .cvdash-compact .cvdcard .cvdic svg{width:16px;height:16px}
    #cvHome .cvdash-compact .cvdcard h3{font-size:14px}
    #cvHome .cvdash-compact .cvdcard p{font-size:11.5px}
    #cvHome .cvdash-compact .cvdcard .cvdarrow{top:14px;right:14px}
    /* One coherent search: the compact dashboard's hero search drives the list,
       so the legacy per-list search box is hidden when the dashboard is on top. */
    #cvHome .cvcalls .cvdash-compact ~ .cvcalls-sec .cvcalls-search{display:none}
    /* Full calls-only page (Search-for-calls card): dashboard hidden, ← Home back bar. */
    #cvHome .cvcalls-fullbar{display:flex;align-items:center;gap:14px;padding:4px 0 18px;margin-bottom:6px;border-bottom:1px solid var(--line,#1b211e)}
    #cvHome .cvcalls-home{display:inline-flex;align-items:center;gap:7px;background:var(--bg-2,#151917);border:1px solid var(--line,#1b211e);border-radius:10px;color:var(--text,#e8ede9);font-size:13px;font-weight:600;padding:8px 13px;cursor:pointer}
    #cvHome .cvcalls-home:hover{border-color:var(--line-strong,#2a322d);background:var(--bg-3,#1b211e)}
    #cvHome .cvcalls-fulltitle{font-size:13px;color:var(--text-3,#7a8780);font-weight:600;letter-spacing:.02em}
    #cvHome .cvnt-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:6px 0 22px}
    #cvHome .cvnt-grid-2{grid-template-columns:repeat(2,1fr);gap:16px}
    #cvHome .cvnt{display:flex;flex-direction:column;align-items:center;gap:10px;padding:22px 16px;border:1px solid var(--line,#1b211e);border-radius:14px;background:var(--bg-2,#151917);cursor:pointer;text-align:center}
    #cvHome .cvnt:hover{border-color:var(--accent-line,rgba(79,151,242,.34));transform:translateY(-2px);background:var(--bg-hover,#1b211e)}
    #cvHome .cvnt .cvlogo{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-weight:800;font-size:17px;color:#fff}
    #cvHome .cvnt .cvnm{font-size:13.5px;font-weight:700;color:var(--text,#e9eee9)}
    #cvHome .cvnt .cvds{font-size:11.5px;color:var(--text-4,#555d5b)}
    /* Primary vs secondary framing for the rebranded 2-tile hero. */
    #cvHome .cvnt-primary{padding:30px 18px;border-color:var(--accent-line,rgba(79,151,242,.34));background:linear-gradient(160deg,var(--accent-soft,rgba(79,151,242,.13)),var(--bg-2,#151917));box-shadow:0 14px 32px -18px var(--accent-glow,rgba(79,151,242,.28))}
    #cvHome .cvnt-primary:hover{border-color:var(--accent,#4f97f2);background:linear-gradient(160deg,var(--accent-soft,rgba(79,151,242,.2)),var(--bg-2,#151917))}
    #cvHome .cvnt-primary .cvlogo{width:50px;height:50px;border-radius:13px}
    #cvHome .cvnt-primary .cvnm{font-size:15px;color:var(--text,#e9eee9)}
    #cvHome .cvnt-primary .cvds{font-size:12px;color:var(--text-2,#b4bdb8)}
    #cvHome .cvnt-secondary{padding:30px 18px}
    #cvHome .cvnt-secondary .cvlogo{width:46px;height:46px;border-radius:12px}
    #cvHome .cvnt-secondary .cvnm{font-size:14px}
    #cvHome .cvtips{max-width:680px;margin:6px auto 0;border:1px solid var(--line,#1b211e);border-radius:14px;background:var(--bg-1,#0e1110);padding:14px 16px;text-align:left;position:relative}
    #cvHome .cvtips-h{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-4,#555d5b);margin-bottom:11px}
    #cvHome .cvtips-x{position:absolute;top:11px;right:13px;color:var(--text-4,#555d5b);cursor:pointer;font-size:14px;background:none;border:0}
    #cvHome .cvtips-row{display:flex;gap:10px}
    #cvHome .cvtip{flex:1;display:flex;gap:10px;align-items:flex-start}
    #cvHome .cvtip .cvti{width:30px;height:30px;border-radius:9px;flex-shrink:0;display:grid;place-items:center;background:var(--bg-3,#1b211e);border:1px solid var(--line,#1b211e);color:var(--accent,#4f97f2)}
    #cvHome .cvtip .cvti svg{width:15px;height:15px}
    #cvHome .cvtip .tt{font-size:12.5px;font-weight:600;color:var(--text-2,#b4bdb8)}
    #cvHome .cvtip .ts{font-size:11.5px;color:var(--text-4,#555d5b);margin-top:1px;line-height:1.45}
    #cvHome .cvcalls{max-width:720px;margin:0 auto;padding:20px 22px 28px}
    #cvHome .cvcalls-sec{margin-bottom:20px}
    #cvHome .cvcalls-search{width:100%;box-sizing:border-box;margin:0 0 12px;padding:10px 13px;border:1px solid var(--line-strong,#27302c);border-radius:10px;background:var(--bg-2,#151917);color:var(--text,#e9eee9);font:inherit;font-size:13.5px}
    #cvHome .cvcalls-search:focus{outline:none;border-color:var(--accent,#4f97f2)}
    #cvHome .cvcalls-search::placeholder{color:var(--text-4,#555d5b)}
    #cvHome .cvcalls-nomatch{padding:18px;text-align:center;color:var(--text-4,#555d5b);font-size:13px}
    #cvHome .cvlbl{font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent,#4f97f2);margin-bottom:11px;display:flex;align-items:center;gap:8px}
    #cvHome .cvlbl.live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent,#4f97f2);box-shadow:0 0 0 3px var(--accent-glow,rgba(79,151,242,.28));animation:cvHome_lp 1.8s ease-in-out infinite}
    @keyframes cvHome_lp{0%,100%{opacity:1}50%{opacity:.45}}
    #cvHome .cvlivecard{border:1px solid var(--accent-line,rgba(79,151,242,.34));border-radius:13px;background:linear-gradient(140deg,var(--accent-soft,rgba(79,151,242,.13)),var(--bg-2,#151917));
      padding:16px 18px;cursor:pointer;position:relative;overflow:hidden;width:100%;text-align:left;font-family:inherit;display:block;margin-bottom:8px}
    #cvHome .cvlivecard:hover{transform:translateY(-2px);border-color:var(--accent,#4f97f2)}
    #cvHome .cvlivecard .cvbg{display:inline-block;font-size:9px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-ink,#07101e);background:var(--accent,#4f97f2);border-radius:999px;padding:3px 9px;margin-bottom:9px}
    #cvHome .cvlivecard .cvti{font-size:15.5px;font-weight:700;letter-spacing:-.01em;color:var(--text,#e9eee9)}
    #cvHome .cvlivecard .cvme{font-size:12.5px;color:var(--accent,#4f97f2);margin-top:3px;font-weight:500}
    /* V3 Timeline calls list (Mark 6/13): vertical thread, day groups, gutter times */
    #cvHome .cvpastlist{position:relative;display:flex;flex-direction:column;gap:6px;padding-left:74px}
    #cvHome .cvpastlist.cvtl::before{content:"";position:absolute;left:54px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,var(--accent,#4f97f2),var(--line,#1b211e) 30%)}
    #cvHome .cvtl-day{position:relative;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--accent,#4f97f2);margin:14px 0 2px}
    #cvHome .cvtl-day::before{content:"";position:absolute;left:-25px;top:3px;width:10px;height:10px;border-radius:50%;background:var(--bg,#0f1311);border:2.5px solid var(--accent,#4f97f2);box-sizing:border-box}
    #cvHome .cvpastitem{position:relative;display:flex;flex-direction:column;gap:2px;border:1px solid var(--line,#1b211e);border-radius:11px;background:var(--bg-2,#151917);padding:11px 14px;cursor:pointer;width:100%;text-align:left;font-family:inherit;transition:border-color .15s ease,transform .14s cubic-bezier(.2,.7,.3,1.2),background .15s ease}
    #cvHome .cvpastitem:hover{border-color:var(--accent-line,rgba(79,151,242,.34));background:var(--bg-hover,#1b211e);transform:translateX(4px)}
    #cvHome .cvpastitem::before{content:"";position:absolute;left:-23px;top:17px;width:7px;height:7px;border-radius:50%;background:var(--text-4,#555d5b);transition:background .15s ease}
    #cvHome .cvpastitem:hover::before{background:var(--accent,#4f97f2)}
    #cvHome .cvtl-time{position:absolute;left:-74px;top:13px;width:44px;text-align:right;font-size:10.5px;font-weight:600;font-family:var(--mono,'JetBrains Mono',monospace);color:var(--text-4,#555d5b);white-space:nowrap}
    #cvHome .cvtl-body{display:flex;align-items:baseline;gap:12px;justify-content:space-between;min-width:0}
    #cvHome .cvpastitem .ot{font-size:14px;font-weight:600;color:var(--text,#e9eee9);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    #cvHome .cvtl-meta{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--text-4,#555d5b);font-family:var(--mono,'JetBrains Mono',monospace);flex-shrink:0}
    #cvHome .cvtl-dot{width:7px;height:7px;border-radius:50%;background:#f97316}
    #cvHome .cvtl-dot[data-prov="otter"]{background:#3b82f6}
    #cvHome .cvtl-dot[data-prov="fathom"]{background:#8b5cf6}
    #cvHome .cvtl-dot[data-prov="notetaker"],#cvHome .cvtl-dot[data-prov="recall"]{background:#10b981}
    /* Call Analyst native (Recall) calls read as first-class: brandmark chip,
       brighter accent, hairline accent border — quietly above the gray
       Fireflies/Otter/Fathom rows, not shouting. */
    .cv-ca-chip{display:inline-flex;align-items:center;gap:5px;font-weight:600;
      color:var(--text-2,#cdd6d3);letter-spacing:.01em;
      padding:1px 7px 1px 5px;border-radius:999px;
      background:color-mix(in oklch, var(--cv-blue,#3b82f6) 14%, transparent);
      border:1px solid color-mix(in oklch, var(--cv-blue,#3b82f6) 34%, transparent)}
    .cv-ca-chip .cvbrandmark{display:inline-flex;gap:2px;align-items:flex-end}
    .cv-ca-chip .cvbrandmark i{display:block;width:2.5px;border-radius:2px}
    .cv-ca-chip .cvbrandmark i:nth-child(1){height:7px;background:var(--cv-cyan,#22d3ee)}
    .cv-ca-chip .cvbrandmark i:nth-child(2){height:11px;background:var(--cv-blue,#3b82f6)}
    .cv-ca-chip .cvbrandmark i:nth-child(3){height:9px;background:var(--cv-violet,#a78bfa)}
    /* Recall (Call Analyst notetaker) rows must be visually IDENTICAL to a
       Fireflies row — the cv-ca-chip provider badge is the ONLY allowed
       difference. The former bespoke accents (blue inset border on past/overlay
       rows, recolored live-card border, bolder title) made recall rows read as a
       different, "laughable" surface. Neutralized; .cv-ca-item is kept only as a
       harmless hook so the markup/JS need no change. */
    /* compact flavor (internal builds): denser, smaller, more rows per screen */
    #cvHome .cvpastlist.compact{padding-left:64px;gap:4px}
    #cvHome .cvpastlist.compact::before{left:46px}
    #cvHome .cvpastlist.compact .cvtl-day{font-size:10px;margin:10px 0 1px}
    #cvHome .cvpastlist.compact .cvtl-day::before{left:-23px;width:9px;height:9px;top:2px}
    #cvHome .cvpastlist.compact .cvpastitem{padding:7px 11px;border-radius:9px}
    #cvHome .cvpastlist.compact .cvpastitem::before{left:-21px;top:12px}
    #cvHome .cvpastlist.compact .cvtl-time{left:-64px;width:40px;font-size:9.5px;top:9px}
    #cvHome .cvpastlist.compact .ot{font-size:12.5px}
    #cvHome .cvpastlist.compact .cvtl-meta{font-size:10px}
    @media (max-width:520px){
      #cvHome .cvpastlist{padding-left:58px}
      #cvHome .cvpastlist.cvtl::before{left:42px}
      #cvHome .cvtl-day::before{left:-21px}
      #cvHome .cvpastitem::before{left:-19px}
      #cvHome .cvtl-time{left:-58px;width:36px;font-size:9.5px}
    }
    #cvHome .cvempty-calls{padding:40px 20px;text-align:center;color:var(--text-4,#555d5b);font-size:13px}
    #cvHome .cvpane{display:none;padding:18px}
    #cvHome .cvpane[data-pane-open="1"]{display:block}
    #cvHome .cvslot{min-height:120px}
    #cvHome .cvchatwrap{max-width:1133px;margin:0 auto}
    #cvHome .cvaawrap{max-width:1040px;margin:0 auto}
    #cvHome .cvaagrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}
    /* Item 2: the cvHome aa tiles ARE the analysis buttons; hide the DUPLICATE
       legacy .auto-analysis-controls that renderContent paints into the analysis
       slot (kept in the DOM so cv:runAnalysis can still click the hidden .aa-btn). */
    #cvHome .cvslot[data-cv-slot="analysis"] .auto-analysis-controls{display:none !important}
    #cvHome .cvaa{display:flex;align-items:center;gap:8px;padding:11px 12px;border:1px solid var(--line-strong,#27302c);border-radius:12px;background:transparent;color:var(--text-2,#b4bdb8);cursor:pointer;text-align:left;font-family:inherit;transition:border-color .15s,background .15s,color .15s}
    #cvHome .cvaa .cvaic{width:26px;height:26px;border-radius:8px;flex-shrink:0;display:grid;place-items:center;background:transparent;color:var(--cvc,var(--accent,#4f97f2));font-size:14px;font-weight:700}
    #cvHome .cvaa .cvalab{font-size:11.5px;font-weight:600;color:inherit;line-height:1.2;white-space:nowrap}
    #cvHome .cvaa:hover{border-color:var(--cvc,var(--accent,#4f97f2));color:var(--text,#e9eee9)}
    #cvHome .cvaa[aria-pressed="true"]{border-color:var(--cvc,var(--accent,#4f97f2));background:var(--cvc,var(--accent,#4f97f2));color:#fff;box-shadow:0 6px 16px -8px color-mix(in srgb,var(--cvc,#4f97f2) 60%,transparent)}
    #cvHome .cvaa[aria-pressed="true"] .cvaic{color:#fff}
    #cvHome .cvcomposer{display:flex;align-items:center;gap:9px;padding:11px 13px;border-top:1px solid var(--line,#1b211e);flex-shrink:0;position:relative;
      background:color-mix(in srgb,var(--bg-1,#0e1110) 94%,transparent);backdrop-filter:blur(10px)}
    #cvHome[data-cvstate="connect"] .cvcomposer,#cvHome[data-cvstate="value"] .cvcomposer{opacity:.92}
    /* Model quick-selector in the cvHome composer (internal builds only) */
    #cvHome .cvmodelsel{height:34px;max-width:106px;padding:0 5px;background:var(--bg-3,#181d1f);color:var(--text-2,#b6bdba);border:1px solid var(--line,#1b211e);border-radius:9px;font-size:11.5px;font-family:inherit;cursor:pointer;flex-shrink:0}
    #cvHome .cvmodelsel:focus{outline:none;border-color:var(--accent,#4ba3f5)}
    #cvHome .cvmatbtn,#cvHome .cvmicbtn{width:40px;height:40px;flex-shrink:0;display:grid;place-items:center;cursor:pointer;position:relative;border:1px solid var(--line-strong,#27302c);background:var(--bg-2,#151917)}
    #cvHome .cvmatbtn{border-radius:11px;color:var(--text-3,#7d8784)}
    #cvHome .cvmatbtn:hover{color:var(--accent,#4f97f2);border-color:var(--accent-line,rgba(79,151,242,.34))}
    #cvHome .cvmicbtn{border-radius:50%;background:var(--text,#e9eee9);color:var(--bg,#0a0c0b);border:0;box-shadow:0 2px 8px -2px rgba(0,0,0,.4)}
    #cvHome .cvmatbtn svg{width:17px;height:17px}#cvHome .cvmicbtn svg{width:18px;height:18px}
    #cvHome .cvcin{flex:1;padding:11px 14px;border:1px solid var(--line-strong,#27302c);border-radius:11px;background:var(--bg-2,#151917);color:var(--text,#e9eee9);font-family:inherit;font-size:14px;outline:none}
    #cvHome .cvcin::placeholder{color:var(--text-4,#555d5b)}
    #cvHome .cvcin:focus{border-color:var(--accent,#4f97f2);box-shadow:0 0 0 3px var(--accent-soft,rgba(79,151,242,.13))}
    #cvHome .cvsendbtn{padding:11px 18px;background:var(--accent,#4f97f2);color:var(--accent-ink,#07101e);border:0;border-radius:11px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit}
    #cvHome .cvhintdot{position:absolute;top:-3px;right:-3px;width:11px;height:11px;border-radius:50%;background:var(--accent,#4f97f2);border:2px solid var(--bg-1,#0e1110);display:none}
    #cvHome[data-cvstate="value"] .cvhintdot,#cvHome[data-cvstate="connect"] .cvhintdot{display:block}
    #cvHome .cvscrim{position:fixed;inset:0;z-index:92;background:rgba(2,5,4,.72);backdrop-filter:blur(5px);display:none;align-items:center;justify-content:center;padding:20px}
    :root[data-theme="light"] #cvHome .cvscrim{background:rgba(20,25,22,.4)}
    #cvHome .cvscrim[data-open="1"]{display:flex;animation:cvHome_menuIn .14s ease}
    #cvHome .cvmodal{width:100%;max-width:460px;background:var(--bg-2,#151917);border:1px solid var(--line,#1b211e);border-radius:16px;box-shadow:var(--shadow-lg,0 24px 50px -12px rgba(0,0,0,.6));padding:22px}
    #cvHome .cvmback{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--text-3,#7d8784);font-size:13px;font-weight:600;cursor:pointer;padding:2px 4px;margin:0 0 10px -4px;line-height:1}
    #cvHome .cvmback:hover{color:var(--text,#e9eee9)}
    #cvHome .cvmh{display:flex;align-items:center;gap:11px}
    #cvHome .cvmh .cvmhic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:var(--accent-soft,rgba(79,151,242,.13));border:1px solid var(--accent-line,rgba(79,151,242,.34));color:var(--accent,#4f97f2)}
    #cvHome .cvmh .cvmhic svg{width:17px;height:17px}
    #cvHome .cvmodal h3{font-size:17px;font-weight:700;letter-spacing:-.01em;color:var(--text,#e9eee9)}
    #cvHome .cvmsub{font-size:12.5px;color:var(--text-3,#7d8784);margin:8px 0 16px;line-height:1.5}
    #cvHome .cvprovseg{display:flex;gap:8px;margin-bottom:15px}
    #cvHome .cvprovseg button{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:13px 8px;border:1px solid var(--line-strong,#27302c);border-radius:11px;background:var(--bg-3,#1b211e);color:var(--text-2,#b4bdb8);cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:600}
    #cvHome .cvprovseg button .cvlg{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;font-weight:800;color:#fff;font-size:13px}
    #cvHome .cvprovseg button[aria-pressed="true"]{border-color:var(--accent,#4f97f2);background:var(--accent-soft,rgba(79,151,242,.13));color:var(--text,#e9eee9)}
    /* Stacked 2-option layout for the rebranded add-meeting modal. */
    #cvHome .cvprovseg-stack{flex-direction:column;gap:10px}
    #cvHome .cvprovextra{display:flex;flex-direction:column;gap:10px}
    #cvHome .cvprovseg-stack .cvprov-opt,#cvHome .cvprovextra .cvprov-opt{display:flex;flex-direction:row;align-items:center;gap:13px;padding:14px 14px;text-align:left;justify-content:flex-start;width:100%;border:1px solid var(--line-strong,#27302c);border-radius:11px;background:var(--bg-3,#1b211e);color:var(--text-2,#b4bdb8);cursor:pointer;font-family:inherit}
    #cvHome .cvprovseg-stack .cvprov-opt .cvlg,#cvHome .cvprovextra .cvprov-opt .cvlg{width:36px;height:36px;flex-shrink:0;border-radius:8px;display:grid;place-items:center;font-weight:800;color:#fff;font-size:13px}
    #cvHome .cvprovseg-stack .cvprov-tx,#cvHome .cvprovextra .cvprov-tx{display:flex;flex-direction:column;gap:2px;min-width:0}
    #cvHome .cvprovseg-stack .cvprov-t,#cvHome .cvprovextra .cvprov-t{font-size:13.5px;font-weight:700;color:var(--text,#e9eee9);display:flex;align-items:center;gap:8px}
    #cvHome .cvprovseg-stack .cvprov-s,#cvHome .cvprovextra .cvprov-s{font-size:11.5px;font-weight:500;color:var(--text-4,#555d5b)}
    #cvHome .cvprovseg-stack .cvprov-rec,#cvHome .cvprovextra .cvprov-rec{font-size:9.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-ink,#07101e);background:var(--accent,#4f97f2);border-radius:999px;padding:2px 7px}
    #cvHome .cvprovseg-stack .cvprov-opt[aria-pressed="true"],#cvHome .cvprovextra .cvprov-opt[aria-pressed="true"]{border-color:var(--accent,#4f97f2);background:var(--accent-soft,rgba(79,151,242,.13));color:var(--text,#e9eee9)}
    #cvHome .cvmlabel{display:block;font-size:12px;color:var(--text-2,#b4bdb8);margin-bottom:6px;font-weight:500}
    #cvHome .cvminput{width:100%;padding:11px 13px;border:1px solid var(--line-strong,#27302c);border-radius:9px;background:var(--bg-3,#1b211e);color:var(--text,#e9eee9);font-family:inherit;font-size:13.5px;outline:none}
    #cvHome .cvminput:focus{border-color:var(--accent,#4f97f2);box-shadow:0 0 0 3px var(--accent-soft,rgba(79,151,242,.13))}
    #cvHome .cvmnote{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--text-4,#555d5b);margin-top:11px}
    #cvHome .cvmnote svg{width:14px;height:14px;flex-shrink:0}
    #cvHome .cvmactions{display:flex;gap:10px;margin-top:18px}
    #cvHome .cvmactions .cvbtn{flex:1;justify-content:center;text-align:center;padding:11px 16px}
    #cvHome .cvbtn-primary[disabled]{opacity:.45;cursor:not-allowed;pointer-events:none}
    /* iteration-3 compact: link validation status (mirrors Settings key validator) */
    #cvHome .cvminput.cv-ok{border-color:var(--ok,#34d39e);box-shadow:0 0 0 3px rgba(52,211,158,.13)}
    #cvHome .cvminput.cv-bad{border-color:var(--danger,#f87171);box-shadow:0 0 0 3px rgba(248,113,113,.13)}
    #cvHome .cvvstatus{font-size:12px;min-height:16px;margin:8px 2px 0;display:flex;align-items:center;gap:6px;letter-spacing:-.01em}
    #cvHome .cvvstatus.cv-hint{color:var(--text-4,#555d5b)}
    #cvHome .cvvstatus.cv-wait{color:var(--text-3,#7d8784)}
    #cvHome .cvvstatus.cv-okk{color:var(--ok,#34d39e)}
    #cvHome .cvvstatus.cv-badd{color:var(--danger,#f87171)}
    #cvHome .cvvstatus .cv-pulse{animation:cvHome_pulse 1s ease-in-out infinite}
    @keyframes cvHome_pulse{0%,100%{opacity:.4}50%{opacity:1}}
    /* provider option states (selected / disabled grayed) */
    #cvHome .cvprovseg-stack .cvprov-opt[aria-disabled="true"],#cvHome .cvprovextra .cvprov-opt[aria-disabled="true"]{opacity:.5;cursor:not-allowed;filter:grayscale(.5)}
    #cvHome .cvprovseg-stack .cvprov-opt[aria-disabled="true"][aria-pressed="true"],#cvHome .cvprovextra .cvprov-opt[aria-disabled="true"][aria-pressed="true"]{border-color:var(--line-strong,#27302c);background:var(--bg-3,#1b211e)}
    #cvHome .cvprov-nokey{font-size:11px;font-weight:700;color:var(--text-3,#7d8784);background:var(--bg-2,#151917);border:1px solid var(--line-strong,#27302c);padding:5px 9px;border-radius:7px;margin-left:auto;white-space:nowrap;flex-shrink:0}
    /* "Add in Settings" is a real CLICKABLE shortcut, not a disabled chip — accent it. */
    #cvHome .cvprov-byok{cursor:pointer}
    #cvHome .cvprov-byok:hover{border-color:var(--accent-line,rgba(79,151,242,.34))}
    #cvHome .cvprov-nokey-go{color:var(--accent,#4f97f2);background:color-mix(in srgb,var(--accent,#4f97f2) 14%,transparent);border-color:color-mix(in srgb,var(--accent,#4f97f2) 40%,transparent);cursor:pointer}
    #cvHome .cvprov-byok:hover .cvprov-nokey-go{background:color-mix(in srgb,var(--accent,#4f97f2) 22%,transparent)}
    /* show-more toggle */
    #cvHome .cvprovmore{appearance:none;border:0;background:none;color:var(--accent,#4f97f2);font:inherit;font-size:12px;font-weight:600;cursor:pointer;margin-top:2px;padding:2px 0;text-align:left}
    #cvHome .cvprovextra{margin-top:10px}
    #cvHome .cvprovextra[data-open="0"]{display:none}
    #cvHome button:focus-visible,#cvHome input:focus-visible,#cvHome [tabindex]:focus-visible{outline:2px solid var(--accent,#4f97f2);outline-offset:2px;border-radius:8px}
    @media (max-width:640px){
      #cvHome .cvaagrid{grid-template-columns:repeat(3,1fr)}
      #cvHome .cvnt-grid{grid-template-columns:repeat(2,1fr)}
      #cvHome .cvnt-grid-2{grid-template-columns:1fr}
      #cvHome .cvtips-row{flex-direction:column;gap:12px}
      #cvHome .cvfr h1{font-size:26px}
      #cvHome .cvfr{padding:30px 18px}
    }
    @media (max-width:460px){
      #cvHome .cvhbtn{padding:7px 9px}
      #cvHome .cvappsw .cvnm{display:none}
      #cvHome .cvstatuspill{display:none}
      #cvHome .cvaagrid{grid-template-columns:repeat(2,1fr)}
      #cvHome .cvnt-grid{grid-template-columns:1fr}
      #cvHome .cvnt-grid-2{grid-template-columns:1fr}
    }
    @media (prefers-reduced-motion: reduce){
      #cvHome *,#cvHome *::after,#cvHome *::before{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
      #cvHome .cvtab::after{transition:none}
    }
    /* host-side: contentArea is relocated into transcript/chat/analysis slots
       and must render its own scroll/layout inside the slot. */
    #cvHome .cvslot > #contentArea{display:block;min-height:60vh}
  