/* Kept Panel.
 *
 * Extracted from styles.css 2026-05-20 (Phase 7 bucket 3 follow-up)
 * to bring styles.css under the 700-LoC hard cap. Cascade order is
 * preserved: loads after styles-bubbles.css.
 *
 * Shared design tokens come from styles.css.
 */

    /* ── Kept Panel ── */
    .kept-item {
      display: flex; align-items: flex-start; gap: 8px;
      padding: 12px; border-radius: var(--radius-md);
      border: 1px solid var(--border-card); background: var(--surface-lo);
      margin-bottom: 8px;
    }
    .kept-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; margin-top: 4px; }
    .kept-info { flex: 1; min-width: 0; }
    .kept-term {
      font-weight: 600; font-size: var(--fs-md); color: var(--text); cursor: pointer; user-select: none;
      display: flex; align-items: center; gap: 4px;
    }
    .kept-thread { font-size: var(--fs-xs); color: var(--text-3); text-transform: uppercase; letter-spacing: 0.6px; margin-bottom: 3px; cursor: pointer; }
    .kept-term-text { flex: 1; min-width: 0; }
    .kept-edit { cursor: pointer; opacity: 0.4; margin-left: 6px; flex-shrink: 0; }
    .kept-edit:hover { opacity: 1; }
    .kept-edit-input {
      font-size: inherit; background: var(--bg); color: var(--text-1);
      border: 1px solid var(--purple); border-radius: 4px;
      padding: 2px 6px; width: 120px; outline: none;
    }
    /* ORi #12 — explicit Save / Cancel for Kept rename. Pre-#12 the
       rename committed on blur which was easy to lose by accident.
       Buttons sit inline alongside the input. */
    .kept-edit-wrap { display: inline-flex; align-items: center; gap: 4px; }
    .kept-edit-save, .kept-edit-cancel {
      font-size: var(--fs-xs); font-family: inherit; padding: 2px 8px; height: 22px;
      border: 1px solid var(--border); border-radius: 4px;
      background: var(--surface-hi); color: var(--text-2);
      cursor: pointer;
      transition: border-color 0.15s, color 0.15s, background 0.15s;
    }
    .kept-edit-save { color: var(--purple); border-color: var(--purple-dim); }
    .kept-edit-save:hover { background: var(--active-bg); color: var(--active-text); }
    .kept-edit-cancel:hover { color: var(--text); border-color: var(--text-3); }
    .kept-chevron { font-size: var(--fs-xs); color: var(--text-3); transition: transform 0.2s; flex-shrink: 0; }
    .kept-item.collapsed .kept-chevron { transform: rotate(-90deg); }
    .kept-badge {
      font-size: var(--fs-xs); font-weight: 600; text-transform: uppercase;
      letter-spacing: 0.5px; padding: 2px 8px; border-radius: var(--radius-sm); margin-left: 4px; flex-shrink: 0;
    }
    .kept-context { font-size: var(--fs-sm); color: var(--text-2); line-height: var(--lh-normal); margin-top: 4px; }
    .kept-explanation {
      display: none;
      font-size: var(--fs-base); color: var(--text-2); line-height: 1.65;
      margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--border-sub);
    }
    .kept-explanation.visible { display: block; }
    .kept-explanation strong { color: var(--text); display: block; margin-bottom: 3px; margin-top: 10px; }
    .kept-explanation strong:first-child { margin-top: 0; }
    .kept-item.collapsed .kept-context,
    .kept-item.collapsed .kept-explanation,
    .kept-item.collapsed .kept-actions { display: none !important; }
    .kept-remove { color: var(--text-3); cursor: pointer; flex-shrink: 0; line-height: 1; padding: 2px 4px; border-radius: var(--radius-sm); opacity: 0.35; display: flex; align-items: center; transition: opacity var(--duration-fast), color var(--duration-fast); }
    .kept-remove:hover { opacity: 0.9; color: var(--red); background: var(--hover-red); }

    /* Kept action buttons */
    .kept-actions { display: flex; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
    .kept-lookup-btn {
      display: inline-flex; align-items: center; gap: 4px;
      font-size: var(--fs-sm); font-weight: 500; padding: var(--btn-pad); border-radius: var(--radius-sm);
      border: 1px solid var(--border); background: var(--surface-hi); cursor: pointer;
      transition: background 0.15s, border-color 0.15s; color: var(--purple);
    }
    .kept-lookup-btn:hover { background: var(--active-bg); border-color: var(--purple-dim); }
    .kept-lookup-btn:disabled { opacity: 0.4; cursor: default; }
    .kept-lookup-btn .spinner {
      width: 9px; height: 9px;
      border: 2px solid currentColor; border-top-color: transparent;
      border-radius: 50%; animation: spin 0.6s linear infinite; display: none;
    }
    .kept-lookup-btn.loading .spinner { display: block; }
    .kept-lookup-btn.loading .btn-label { display: none; }

    /* Context Panel + Meeting list + category-edit rules retired
       2026-05-20 with plans/share-ori.md Phase 7 bucket 3. The DOM
       IDs (#context-panel, #meeting-items, #context-textarea,
       #vocab-input, #context-char-count, #context-saved) and the
       .meeting-row / .ctx-mode-* / .cat-btn.loaded classes have no
       live HTML target after the deletion of meeting-management.js
       and context-panel.js. Implicit named-meetings on D1 is the
       planned replacement (separate plan). */

    /* Toolbar toggle buttons — shared base for layout + status */
    .toolbar-toggle {
      display: inline-flex; align-items: center; gap: 5px;
      padding: 3px 10px; font-size: 10px; font-family: inherit;
      border: none; border-radius: 4px; cursor: pointer;
      transition: all var(--duration-fast);
    }

    /* Layout toggle — shows current view, click to switch */
    .toolbar-toggle.layout { background: rgba(167, 139, 250, 0.15); color: var(--purple); }
    .toolbar-toggle.layout:hover { background: rgba(167, 139, 250, 0.3); }

    /* Status toggle — live process indicator */
    .toolbar-toggle.status.listening { background: rgba(76, 175, 80, 0.15); color: var(--green); }
    .toolbar-toggle.status.listening:hover { background: rgba(76, 175, 80, 0.25); }
    .toolbar-toggle.status.paused { background: rgba(255, 183, 77, 0.15); color: var(--amber); }
    .toolbar-toggle.status.paused:hover { background: rgba(255, 183, 77, 0.25); }
    .toolbar-dot {
      width: 8px; height: 8px; border-radius: 50%; background: var(--text-3);
      display: inline-block; flex-shrink: 0;
    }
    .toolbar-dot.listening { background: var(--green); animation: breathe 3s ease-in-out infinite; }
    .toolbar-dot.paused    { background: var(--amber); }
    .toolbar-label { font-size: 10px; font-weight: 500; }

    /* Hamburger menu */
    .hamburger-wrap { position: relative; }
    .hamburger-menu {
      position: absolute; top: calc(100% + 6px); right: 0; min-width: 200px;
      background: var(--surface-glass); border: 1px solid var(--border);
      border-radius: var(--radius-md); box-shadow: var(--shadow-lg);
      backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
      z-index: 300; display: none; flex-direction: column; padding: 4px 0;
      max-height: calc(100vh - 80px);
      max-height: calc(100dvh - 80px);
      overflow-y: auto;
    }
    .hamburger-menu.open { display: flex; }
    .hm-item {
      display: flex; align-items: center; gap: 10px; width: 100%;
      padding: 10px 16px; border: none; background: none; cursor: pointer;
      font-size: var(--fs-sm); font-weight: 500; color: var(--text-2);
      text-align: left; transition: background var(--duration-fast), color var(--duration-fast);
    }
    .hm-item:hover { background: var(--hover-purple); color: var(--text); }
    .hm-item svg { flex-shrink: 0; }
    .hm-divider { height: 1px; background: var(--border); margin: 4px 12px; }
    .hm-about { color: var(--text-3); cursor: default; font-size: var(--fs-xs); }
    .hm-about:hover { background: none; color: var(--text-3); }

    /* Reset confirmation modal */
    .modal-overlay {
      position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 400;
      display: none; align-items: center; justify-content: center;
      backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
    }
    .modal-overlay.open { display: flex; }
    .modal-box {
      background: var(--surface-glass); border: 1px solid var(--border);
      border-radius: var(--radius-lg); padding: 24px; max-width: 380px; width: 90%;
      box-shadow: var(--shadow-lg);
      backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
    }
    .modal-box h3 { margin: 0 0 8px; font-size: 18px; font-weight: 600; color: var(--text); }
    .modal-box p  { margin: 0 0 20px; font-size: var(--fs-sm); color: var(--text-2); line-height: 1.5; }
    .modal-actions { display: flex; gap: 8px; justify-content: flex-end; }
    .modal-danger { color: #fff !important; background: var(--red) !important; border-color: var(--red) !important; }
    .modal-danger:hover { background: #991b1b !important; }

    /* Feedback modal */
    .fb-type-group { display: flex; gap: 6px; margin-bottom: 14px; }
    .fb-type-btn { flex: 1; padding: 8px; border: 1px solid var(--border); border-radius: var(--radius);
      background: transparent; color: var(--text-2); font-size: var(--fs-sm); cursor: pointer; text-align: center; }
    .fb-type-btn.active { border-color: var(--purple); color: var(--purple); background: rgba(167,139,250,0.1); }
    html.light .fb-type-btn.active { background: rgba(37,99,235,0.08); }
    .fb-textarea { width: 100%; background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius);
      color: var(--text); padding: 10px; font-size: var(--fs-sm); resize: vertical; font-family: inherit; }
    .fb-textarea:focus { outline: none; border-color: var(--accent); }
    .fb-stars { display: flex; gap: 4px; margin: 12px 0; align-items: center; }
    .fb-stars .star { font-size: 22px; cursor: pointer; color: var(--border); transition: color 0.15s; }
    .fb-stars .star.lit { color: #fbbf24; }
    .fb-stars label { font-size: var(--fs-sm); color: var(--text-2); margin-right: 8px; }
    .fb-send { width: 100%; padding: 10px; border: none; border-radius: var(--radius); background: var(--purple);
      color: #fff; font-size: var(--fs-sm); font-weight: 600; cursor: pointer; margin-top: 12px; }
    .fb-send:disabled { opacity: 0.4; cursor: not-allowed; }
    .fb-send:not(:disabled):hover { filter: brightness(1.1); }
    .fb-success { text-align: center; padding: 24px 0; }
    .fb-success svg { color: var(--green); margin-bottom: 8px; }
    .fb-success p { color: var(--text-2); font-size: var(--fs-sm); }

    /* Settings panel (slide-in drawer from right) */
    #settings-panel {
      position: fixed; top: 0; right: 0; bottom: 0; width: 320px;
      background: var(--surface-glass); border-left: 1px solid var(--border);
      z-index: 200; display: flex; flex-direction: column; overflow-y: auto;
      box-shadow: var(--shadow-lg);
      border-radius: var(--radius-lg) 0 0 var(--radius-lg);
      backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
      transform: translateX(100%); transition: transform var(--duration-normal) var(--ease-out);
      pointer-events: none;
    }
    #settings-panel.open { transform: translateX(0); pointer-events: auto; }
    .settings-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--border); }
    .settings-header h2 { font-size: var(--fs-md); font-weight: 600; color: var(--text); }
    .settings-close { background: none; border: none; color: var(--text-3); font-size: 18px; cursor: pointer; line-height: 1; transition: color var(--duration-fast); }
    .settings-close:hover { color: var(--text); }
    .settings-section { border-bottom: 1px solid var(--border-sub); }
    .settings-section-hdr { display: flex; align-items: center; padding: 14px 20px; cursor: pointer; gap: 8px; transition: background var(--duration-fast); user-select: none; }
    .settings-section-hdr:hover { background: var(--surface-hi); }
    .settings-section-hdr h3 { flex: 1; font-size: var(--fs-xs); font-weight: 600; text-transform: uppercase; letter-spacing: 0.6px; color: var(--text-3); margin: 0; }
    .settings-section-sum { font-size: var(--fs-xs); color: var(--text-3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 150px; }
    .settings-section-chev { color: var(--text-3); font-size: 10px; transition: transform var(--duration-fast); flex-shrink: 0; }
    .settings-section.expanded .settings-section-chev { transform: rotate(90deg); }
    .settings-section-body { max-height: 0; overflow: hidden; transition: max-height var(--duration-normal) var(--ease-out); padding: 0 20px; }
    .settings-section.expanded .settings-section-body { max-height: 800px; padding: 0 20px 16px; }
    .cat-grid { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 4px; }
    .cat-btn { font-size: var(--fs-sm); font-weight: 500; color: var(--text-2); background: var(--surface-hi); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: var(--btn-pad); cursor: pointer; transition: all var(--duration-fast); }
    .cat-btn:hover { border-color: var(--purple-dim); color: var(--text); }
    .cat-btn.active { color: var(--active-text); border-color: var(--purple-dim); background: var(--active-bg); }
    .cat-btn.cat-default { color: var(--text-3); }
    .cat-btn.cat-edited { border-style: dashed; }
    .cat-btn.cat-custom { font-style: italic; }
    .ctx-action-btn { font-size: var(--fs-xs) !important; padding: var(--btn-pad-sm) !important; }
    .ctx-delete-btn { color: var(--red) !important; }
    #cat-add-form { margin-top: 10px; display: none; flex-direction: column; gap: 6px; }
    #cat-add-form.open { display: flex; }
    #cat-add-form input, #cat-add-form textarea { background: var(--surface-lo); border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text); font-size: var(--fs-sm); padding: 6px 8px; resize: vertical; }
    #cat-add-form textarea { min-height: 60px; }
    .settings-select { width: 100%; background: var(--surface-lo); border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text); font-size: var(--fs-sm); padding: 6px 8px; margin-top: 4px; }
    .settings-label { font-size: var(--fs-sm); color: var(--text-2); margin-bottom: 4px; display: block; }
    .settings-note { font-size: var(--fs-xs); color: var(--text-3); margin-top: 6px; }
    .hf-model-item { display: flex; align-items: center; gap: 8px; padding: 6px 8px; border-radius: var(--radius-sm); cursor: pointer; font-size: var(--fs-sm); color: var(--text-2); border: 1px solid transparent; transition: background var(--duration-fast) ease, border-color var(--duration-fast) ease; }
    .hf-model-item:hover { background: var(--surface-lo); }
    .hf-model-item.active { border-color: var(--purple-dim); background: rgba(167,139,250,0.08); color: var(--text); }
    .hf-model-item .hf-model-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .hf-model-item .hf-model-size { font-size: var(--fs-xs); color: var(--text-3); flex-shrink: 0; }
    .hf-model-item .hf-model-delete { color: var(--text-3); cursor: pointer; opacity: 0; transition: opacity var(--duration-fast) ease, color var(--duration-fast) ease; flex-shrink: 0; padding: 2px; }
    .hf-model-item:hover .hf-model-delete { opacity: 1; }
    .hf-model-item .hf-model-delete:hover { color: var(--red); }
    .settings-range-row { display: flex; align-items: center; gap: 8px; margin-top: 6px; }
    .settings-range-row input[type="range"] { flex: 1; accent-color: var(--purple); }
    .settings-range-val { font-size: var(--fs-sm); font-weight: 600; color: var(--text); min-width: 28px; text-align: right; }
    .engine-toggle { display: flex; border: 1px solid var(--border); border-radius: var(--radius-sm); overflow: hidden; margin-top: 6px; }
    .engine-btn { flex: 1; font-size: var(--fs-sm); font-weight: 500; color: var(--text-3); background: var(--surface-hi); border: none; padding: 6px; cursor: pointer; transition: all var(--duration-fast); }
    .engine-btn + .engine-btn { border-left: 1px solid var(--border); }
    .engine-btn.active { color: var(--active-text); background: var(--active-bg); }
    #settings-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 199; opacity: 0; pointer-events: none; transition: opacity var(--duration-normal) var(--ease-in-out); }
    #settings-overlay.open { opacity: 1; pointer-events: auto; }

    /* Help panel */
    #help-panel {
      position: fixed; top: 0; right: 0; bottom: 0; width: 360px;
      background: var(--surface-glass); border-left: 1px solid var(--border);
      z-index: 200; display: flex; flex-direction: column;
      box-shadow: var(--shadow-lg);
      border-radius: var(--radius-lg) 0 0 var(--radius-lg);
      backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
      transform: translateX(100%); transition: transform var(--duration-normal) var(--ease-out);
      pointer-events: none;
    }
    #help-panel.open { transform: translateX(0); pointer-events: auto; }
    .help-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--border); }
    .help-header h2 { font-size: var(--fs-md); font-weight: 600; color: var(--text); margin: 0; }
    .help-header-left { display: flex; align-items: center; gap: 10px; }
    .help-header-btn { background: none; border: 1px solid var(--border-sub); border-radius: var(--radius-sm); padding: 5px 6px; color: var(--text-2); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: border-color var(--duration-fast), color var(--duration-fast); }
    .help-header-btn:hover { border-color: var(--purple); color: var(--text); }
    .help-thread-banner { background: rgba(167,139,250,0.1); border-left: 3px solid var(--purple); padding: 8px 12px; margin: 0 0 8px; border-radius: 0 var(--radius-sm) var(--radius-sm) 0; cursor: pointer; font-size: 12px; color: var(--text-2); transition: background var(--duration-fast); }
    .help-thread-banner:hover { background: rgba(167,139,250,0.18); }
    .help-thread-banner strong { color: var(--text); }
    .help-thread-list { padding: 8px 0; }
    .help-thread-item { padding: 10px 12px; margin: 4px 0; border-radius: var(--radius-sm); cursor: pointer; border: 1px solid var(--border-sub); transition: border-color var(--duration-fast); }
    .help-thread-item:hover { border-color: var(--purple); }
    .help-thread-item.active { border-color: var(--purple); background: rgba(167,139,250,0.08); }
    .help-thread-item .help-thread-preview { font-size: 12px; color: var(--text-2); margin: 2px 0 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .help-thread-item .help-thread-meta { font-size: 10px; color: var(--text-3); display: flex; gap: 8px; align-items: center; margin-top: 4px; }
    .help-thread-unread { width: 6px; height: 6px; border-radius: 50%; background: var(--purple); display: inline-block; }
    .help-status-pill { font-size: 10px; padding: 1px 6px; border-radius: 8px; font-weight: 500; }
    .help-status-open { color: var(--text-2); border: 1px solid var(--border-sub); }
    .help-status-escalated, .help-status-needs_admin { color: #ef4444; border: 1px solid #ef4444; }
    .help-status-analyzing { color: #f59e0b; border: 1px solid #f59e0b; }
    .help-status-ai_resolved, .help-status-resolved { color: #4ade80; border: 1px solid #4ade80; }
    .help-status-bug_filed { color: #60a5fa; border: 1px solid #60a5fa; }
    .help-messages { flex: 1; overflow-y: auto; padding: 16px; display: flex; flex-direction: column; gap: 12px; }
    .help-msg { max-width: 85%; padding: 10px 14px; border-radius: var(--radius-md); font-size: var(--fs-sm); line-height: 1.5; }
    .help-msg.user { align-self: flex-end; background: var(--purple); color: #fff; border-bottom-right-radius: 4px; }
    .help-msg.assistant { align-self: flex-start; background: var(--surface-hi); color: var(--text); border-bottom-left-radius: 4px; }
    .help-msg.assistant p { margin: 0 0 8px 0; }
    .help-msg.assistant p:last-child { margin-bottom: 0; }
    .help-msg.assistant strong { color: var(--text); }
    .help-msg.assistant ol, .help-msg.assistant ul { margin: 4px 0; padding-left: 20px; }
    .help-msg.assistant li { margin: 2px 0; }
    .help-msg.assistant code { background: var(--surface); padding: 1px 4px; border-radius: 3px; font-size: 0.9em; }
    .help-msg.assistant h2, .help-msg.assistant h3, .help-msg.assistant h4 { font-size: var(--fs-sm); font-weight: 600; color: var(--text); margin: 10px 0 4px 0; }
    .help-msg.assistant h2:first-child, .help-msg.assistant h3:first-child { margin-top: 0; }
    .help-msg.assistant blockquote { border-left: 2px solid var(--purple); padding-left: 10px; margin: 6px 0; color: var(--text-2); font-style: italic; }
    .help-msg.assistant hr { border: none; border-top: 1px solid var(--border-sub); margin: 8px 0; }
    .help-suggestions { display: flex; flex-direction: column; gap: 8px; padding: 16px; }
    .help-suggestion { background: var(--surface); border: 1px solid var(--border-sub); border-radius: var(--radius-md); padding: 10px 14px; font-size: var(--fs-sm); color: var(--text-2); cursor: pointer; text-align: left; transition: background var(--duration-fast), border-color var(--duration-fast); }
    .help-suggestion:hover { background: var(--surface-hi); border-color: var(--purple); color: var(--text); }
    .help-guide-btn { display: flex; align-items: center; gap: 10px; background: var(--purple); color: #fff; border-radius: var(--radius-md); padding: 12px 16px; font-size: var(--fs-sm); font-weight: 600; text-decoration: none; transition: opacity var(--duration-fast); }
    .help-guide-btn:hover { opacity: 0.85; }
    .help-input-row { display: flex; gap: 8px; padding: 12px 16px; border-top: 1px solid var(--border); }
    .help-input-row input { flex: 1; background: var(--surface); border: 1px solid var(--border-sub); border-radius: var(--radius-md); padding: 10px 14px; color: var(--text); font-size: var(--fs-sm); outline: none; }
    .help-input-row input:focus { border-color: var(--purple); }
    .help-input-row input::placeholder { color: var(--text-hint); }
    .help-send-btn { background: var(--purple); color: #fff; border: none; border-radius: var(--radius-md); padding: 10px 16px; font-size: var(--fs-sm); font-weight: 600; cursor: pointer; transition: opacity var(--duration-fast); }
    .help-send-btn:hover { opacity: 0.85; }
    .help-send-btn:disabled { opacity: 0.5; cursor: not-allowed; }
    .help-typing { align-self: flex-start; color: var(--text-3); font-size: var(--fs-xs); padding: 8px 14px; }
    #help-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 199; opacity: 0; pointer-events: none; transition: opacity var(--duration-normal) var(--ease-in-out); }
    #help-overlay.open { opacity: 1; pointer-events: auto; }

