/* ───────────────────────────────────────────────────────────────────────────
 * Melo Dev UI — component styles
 * Tokens live in /theme.css (loaded first). Don't introduce literal colors
 * here — extend theme.css instead.
 * ─────────────────────────────────────────────────────────────────────────── */

/* ╔═══════════════════════════════════════════════════════════════════════╗
   ║  Primitives                                                          ║
   ╚═══════════════════════════════════════════════════════════════════════╝ */

/* Buttons -------------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  padding: 7px 14px;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.12s, border-color 0.12s, color 0.12s, opacity 0.12s;
  background: transparent;
  color: var(--foreground);
}
.btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.btn-primary {
  background: var(--primary);
  color: var(--primary-foreground);
  box-shadow: var(--shadow-xs);
}
.btn-primary:hover:not(:disabled) { opacity: 0.88; }

.btn-enhanced {
  background: var(--enhanced-bg);
  color: var(--enhanced-fg);
  border-color: var(--enhanced-border);
}
.btn-enhanced:hover:not(:disabled) {
  background: var(--enhanced-border);
  color: var(--foreground);
}

.btn-ghost {
  background: transparent;
  border-color: var(--border);
  color: var(--muted-foreground);
}
.btn-ghost:hover:not(:disabled) {
  color: var(--foreground);
  border-color: var(--muted-foreground);
}
.btn-ghost--active {
  color: var(--enhanced-fg);
  border-color: var(--enhanced-border);
  background: var(--enhanced-bg);
}

.btn-icon {
  width: 28px;
  height: 28px;
  padding: 0;
  border-radius: var(--radius-md);
}

.btn-link {
  background: none;
  border: none;
  color: var(--enhanced-fg);
  cursor: pointer;
  text-decoration: underline;
  font-size: 11px;
  padding: 0 0 0 4px;
}

/* Inputs --------------------------------------------------------------- */
.input,
.field input[type="text"],
.field input[type="number"],
.field textarea,
.field select,
.config-panel input,
.config-panel textarea,
.input-text,
.tool-form-raw-text {
  background: var(--secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  color: var(--foreground);
  padding: 7px 10px;
  font-size: 13px;
  font-family: var(--font-mono);
  outline: none;
  transition: border-color 0.12s, box-shadow 0.12s;
}
.input:focus,
.field input:focus,
.field textarea:focus,
.field select:focus,
.config-panel input:focus,
.config-panel textarea:focus,
.input-text:focus,
.tool-form-raw-text:focus {
  border-color: var(--ring);
  box-shadow: 0 0 0 3px var(--enhanced-bg);
}

/* Section header label (the small uppercase ones) ----------------------
 * "Operator console" eyebrows: a tiny mono slash glyph leads each label,
 * giving the section a path-like read (/ MCP TOOLS, / OUTPUT). The slash
 * is dimmed further so the label still reads first.
 * --------------------------------------------------------------------- */
.eyebrow {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted-foreground);
  font-weight: 600;
  font-family: var(--font-mono);
  font-feature-settings: 'tnum' 1, 'cv11' 1;
}
.eyebrow::before {
  content: '/ ';
  opacity: 0.4;
}

/* Pill / tag count chip ------------------------------------------------- */
.chip {
  display: inline-block;
  background: var(--secondary);
  color: var(--muted-foreground);
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 999px;
  letter-spacing: 0;
  font-family: var(--font-mono);
}

/* ╔═══════════════════════════════════════════════════════════════════════╗
   ║  Layout                                                              ║
   ╚═══════════════════════════════════════════════════════════════════════╝ */

.app {
  display: flex;
  height: 100vh;
  overflow: hidden;
}

/* ╔═══════════════════════════════════════════════════════════════════════╗
   ║  Sidebar                                                             ║
   ╚═══════════════════════════════════════════════════════════════════════╝ */

.sidebar {
  width: 260px;
  min-width: 260px;
  background: var(--sidebar);
  border-right: 1px solid var(--sidebar-border);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.sidebar-tools {
  width: 300px;
  min-width: 300px;
}

/* Sidebar head: brand wordmark + view tabs ----------------------------- */
.sidebar-head {
  display: flex;
  flex-direction: column;
  border-bottom: 1px solid var(--sidebar-border);
}
.brand {
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding: 14px 16px 10px;
}
.brand-mark {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 26px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--foreground);
}
.brand-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted-foreground);
  position: relative;
  top: -1px;
}
.brand-env {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--enhanced-fg);
  background: var(--enhanced-bg);
  border: 1px solid var(--enhanced-border);
  padding: 2px 7px;
  border-radius: 2px;
  position: relative;
  top: -2px;
}
.brand-env-prod {
  color: var(--warning-fg);
  background: var(--warning-bg);
  border-color: var(--warning-border);
}

.view-tabs {
  display: flex;
  padding: 0 14px;
  gap: 18px;
}
.view-tab {
  background: none;
  border: none;
  color: var(--muted-foreground);
  padding: 10px 0;
  font-size: 11px;
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  cursor: pointer;
  border-bottom: 1px solid transparent;
  margin-bottom: -1px;
  transition: color 0.12s, border-color 0.12s;
}
.view-tab:hover {
  color: var(--foreground);
}
.view-tab-active {
  color: var(--foreground);
  border-bottom-color: var(--enhanced);
  font-weight: 500;
}

.sidebar-action-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px 6px;
}
.sidebar-section-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted-foreground);
  font-weight: 600;
  font-family: var(--font-mono);
}
.sidebar-section-label::before {
  content: '/ ';
  opacity: 0.4;
}
.sidebar-count {
  display: inline-block;
  margin-left: 4px;
  background: var(--secondary);
  color: var(--muted-foreground);
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 999px;
  letter-spacing: 0;
  font-family: var(--font-mono);
}
.sidebar-token-total {
  display: inline-block;
  margin-left: 6px;
  font-size: 10px;
  color: var(--muted-foreground);
  font-family: var(--font-mono);
  letter-spacing: 0;
  text-transform: none;
  font-weight: 400;
}
.btn-new {
  background: var(--primary);
  color: var(--primary-foreground);
  border: none;
  border-radius: var(--radius-md);
  width: 28px;
  height: 28px;
  font-size: 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-xs);
  transition: opacity 0.12s;
}
.btn-new:hover { opacity: 0.85; }

.sidebar-loading,
.sidebar-empty {
  padding: 24px 16px;
  color: var(--muted-foreground);
  font-size: 13px;
  line-height: 1.5;
}
.thread-list {
  flex: 1;
  overflow-y: auto;
  padding: 8px;
  list-style: none;
}
.thread-item {
  position: relative;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  cursor: pointer;
  margin-bottom: 2px;
  transition: background 0.12s;
}
.thread-item:hover {
  background: var(--sidebar-accent);
}
.thread-item-active {
  background: var(--sidebar-accent);
}
.thread-title {
  font-size: 13px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding-right: 20px;
}
.thread-meta {
  font-size: 11px;
  color: var(--muted-foreground);
  margin-top: 3px;
  font-family: var(--font-mono);
}
.thread-delete {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: var(--muted-foreground);
  cursor: pointer;
  font-size: 16px;
  opacity: 0;
  transition: opacity 0.15s, color 0.15s;
  padding: 2px 4px;
}
.thread-item:hover .thread-delete {
  opacity: 1;
}
.thread-delete:hover {
  color: var(--destructive-fg);
}

/* ╔═══════════════════════════════════════════════════════════════════════╗
   ║  Main pane                                                           ║
   ╚═══════════════════════════════════════════════════════════════════════╝ */

.main {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.main-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 18px;
  border-bottom: 1px solid var(--rule);
  background: transparent;
  backdrop-filter: blur(8px);
}
.active-thread {
  font-size: 11px;
  color: var(--muted-foreground);
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
}
.active-thread::before {
  content: '/ ';
  opacity: 0.4;
  text-transform: uppercase;
}
.btn-config {
  background: none;
  border: 1px solid var(--border);
  color: var(--muted-foreground);
  border-radius: var(--radius-sm);
  padding: 4px 10px;
  cursor: pointer;
  font-size: 12px;
  font-family: var(--font-sans);
  transition: color 0.12s, border-color 0.12s;
}
.btn-config:hover {
  color: var(--foreground);
  border-color: var(--muted-foreground);
}

.error-bar {
  background: var(--destructive-bg);
  color: var(--destructive-fg);
  border-bottom: 1px solid var(--destructive-border);
  padding: 8px 16px;
  font-size: 13px;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
}
.error-dismiss {
  font-size: 16px;
}

/* ╔═══════════════════════════════════════════════════════════════════════╗
   ║  Chat                                                                ║
   ╚═══════════════════════════════════════════════════════════════════════╝ */

.chat {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.message-list {
  flex: 1;
  overflow-y: auto;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.chat-empty {
  color: var(--muted-foreground);
  text-align: center;
  margin-top: 40px;
  font-size: 13px;
}

/* Messages ------------------------------------------------------------- */
.message {
  display: flex;
  max-width: 80%;
}
.message-user {
  align-self: flex-end;
}
.message-assistant {
  align-self: flex-start;
}
.message-bubble {
  padding: 10px 14px;
  border-radius: var(--radius-lg);
  line-height: 1.5;
  white-space: pre-wrap;
  word-break: break-word;
}
.message-user .message-bubble {
  background: var(--secondary);
  color: var(--foreground);
  border-bottom-right-radius: 4px;
}
.message-assistant .message-bubble {
  background: transparent;
  border: 1px solid var(--border);
  border-bottom-left-radius: 4px;
}
.streaming .message-bubble {
  border-color: var(--enhanced-border);
}
.cursor {
  color: var(--enhanced-fg);
  animation: blink 1s step-end infinite;
}
@keyframes blink {
  50% { opacity: 0; }
}

/* Markdown rendered content ------------------------------------------- */
.markdown {
  line-height: 1.6;
  color: var(--foreground);
}
.markdown p { margin-bottom: 0.75em; }
.markdown p:last-child { margin-bottom: 0; }
.markdown strong { font-weight: 600; color: var(--foreground); }
.markdown em { font-style: italic; }
.markdown h1,
.markdown h2,
.markdown h3,
.markdown h4 {
  font-weight: 600;
  margin: 1em 0 0.4em;
  color: var(--foreground);
  letter-spacing: -0.01em;
}
.markdown h1 { font-size: 1.2em; }
.markdown h2 { font-size: 1.1em; }
.markdown h3 { font-size: 1em; }
.markdown ul,
.markdown ol {
  padding-left: 1.4em;
  margin-bottom: 0.75em;
}
.markdown li { margin-bottom: 0.25em; }
.markdown code {
  background: var(--secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 1px 5px;
  font-family: var(--font-mono);
  font-size: 0.88em;
}
.markdown pre {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 12px;
  overflow-x: auto;
  margin-bottom: 0.75em;
}
.markdown pre code {
  background: none;
  border: none;
  padding: 0;
}
.markdown blockquote {
  border-left: 3px solid var(--enhanced);
  padding-left: 12px;
  color: var(--muted-foreground);
  margin: 0.5em 0;
}
.markdown a {
  color: var(--enhanced-fg);
  text-decoration: underline;
}
.markdown table {
  border-collapse: collapse;
  width: 100%;
  margin-bottom: 0.75em;
  font-size: 13px;
}
.markdown th,
.markdown td {
  border: 1px solid var(--border);
  padding: 6px 10px;
  text-align: left;
}
.markdown th {
  background: var(--secondary);
  font-weight: 600;
}
.streaming .markdown { display: inline; }

/* Tool / status events (inline in chat) ------------------------------- */
.tool-event {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 12px;
  color: var(--warning-fg);
  background: var(--warning-bg);
  border: 1px solid var(--warning-border);
  border-radius: var(--radius-md);
  padding: 6px 10px;
  align-self: flex-start;
  font-family: var(--font-mono);
}
.tool-result-event {
  opacity: 0.7;
}
.tool-icon {
  font-size: 11px;
  margin-top: 1px;
}
.tool-name {
  font-family: var(--font-mono);
}
.tool-args {
  font-family: var(--font-mono);
  font-size: 11px;
  margin-top: 4px;
  white-space: pre-wrap;
  max-height: 120px;
  overflow-y: auto;
  color: var(--muted-foreground);
}
.tool-args-toggle {
  cursor: pointer;
  user-select: none;
  font-size: 11px;
  color: var(--muted-foreground);
  padding: 1px 0;
}
.tool-args-toggle:hover {
  color: var(--foreground);
}
.status-event {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--muted-foreground);
  align-self: flex-start;
  padding: 4px 0;
}
.status-spinner {
  animation: pulse 1s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}

/* Reasoning / thinking ------------------------------------------------- */
.reasoning-block {
  align-self: flex-start;
  max-width: 80%;
  font-size: 12px;
  color: var(--muted-foreground);
  background: var(--enhanced-bg);
  border: 1px solid var(--enhanced-border);
  border-left: 3px solid var(--enhanced);
  border-radius: var(--radius-md);
  padding: 6px 10px;
}
.reasoning-block summary {
  cursor: pointer;
  font-style: italic;
  user-select: none;
  color: var(--enhanced-fg);
}
.reasoning-block[open] summary {
  margin-bottom: 4px;
}
.reasoning-text {
  white-space: pre-wrap;
  margin-top: 2px;
  line-height: 1.5;
}
.reasoning-text .markdown {
  font-size: 12px;
  color: var(--muted-foreground);
}

/* Input bar ------------------------------------------------------------ */
.input-bar {
  display: flex;
  gap: 8px;
  padding: 12px 16px;
  border-top: 1px solid var(--border);
  background: var(--sidebar);
}
.input-text {
  flex: 1;
  font-family: var(--font-sans);
  font-size: 14px;
  resize: none;
  max-height: 120px;
  overflow-y: auto;
  padding: 10px 14px;
  border-radius: var(--radius-md);
}
.input-text:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.btn-send {
  background: var(--enhanced-bg);
  color: var(--enhanced-fg);
  border: 1px solid var(--enhanced-border);
  border-radius: var(--radius-md);
  padding: 10px 18px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  font-family: var(--font-sans);
  transition: background 0.12s, color 0.12s;
}
.btn-send:hover:not(:disabled) {
  background: var(--enhanced-border);
  color: var(--foreground);
}
.btn-send:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* ╔═══════════════════════════════════════════════════════════════════════╗
   ║  Config modal                                                        ║
   ╚═══════════════════════════════════════════════════════════════════════╝ */

.config-overlay {
  position: fixed;
  inset: 0;
  background: oklch(0 0 0 / 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  backdrop-filter: blur(2px);
}
.config-panel {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  padding: 28px;
  width: 460px;
  max-width: 95vw;
}
.config-panel h2 {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 8px;
  letter-spacing: -0.01em;
}
.config-hint {
  font-size: 13px;
  color: var(--muted-foreground);
  margin-bottom: 20px;
}
.config-panel label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 13px;
  color: var(--muted-foreground);
  margin-bottom: 14px;
}
.config-panel input,
.config-panel textarea {
  font-family: var(--font-mono);
  padding: 8px 12px;
  font-size: 13px;
}
.btn-save {
  width: 100%;
  background: var(--primary);
  color: var(--primary-foreground);
  border: none;
  border-radius: var(--radius-md);
  padding: 10px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  margin-top: 4px;
  box-shadow: var(--shadow-xs);
  transition: opacity 0.12s;
}
.btn-save:hover { opacity: 0.88; }

/* Environment selector ------------------------------------------------- */
.env-selector {
  display: flex;
  gap: 6px;
  margin-top: 2px;
}
.env-option {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 5px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: 13px;
  color: var(--muted-foreground);
  flex-direction: row;
  margin-bottom: 0;
  transition: border-color 0.12s, color 0.12s, background 0.12s;
}
.env-option input[type="radio"] {
  display: none;
}
.env-option:hover {
  border-color: var(--muted-foreground);
  color: var(--foreground);
}
.env-option-active {
  border-color: var(--enhanced-border);
  color: var(--enhanced-fg);
  background: var(--enhanced-bg);
}

/* Header actions ------------------------------------------------------- */
.header-actions {
  display: flex;
  gap: 6px;
  align-items: center;
}
.btn-debug {
  background: none;
  border: 1px solid var(--border);
  color: var(--muted-foreground);
  border-radius: var(--radius-sm);
  padding: 4px 10px;
  cursor: pointer;
  font-size: 12px;
  font-family: var(--font-mono);
  transition: color 0.12s, border-color 0.12s, background 0.12s;
}
.btn-debug:hover {
  color: var(--foreground);
  border-color: var(--muted-foreground);
}
.btn-debug-active {
  color: var(--enhanced-fg);
  border-color: var(--enhanced-border);
  background: var(--enhanced-bg);
}

/* ╔═══════════════════════════════════════════════════════════════════════╗
   ║  Debug panel                                                         ║
   ╚═══════════════════════════════════════════════════════════════════════╝ */

.main-content {
  flex: 1;
  display: flex;
  overflow: hidden;
}
.main-content > .chat {
  flex: 1;
  min-width: 0;
}

.debug-panel {
  width: 420px;
  min-width: 320px;
  max-width: 50vw;
  background: var(--sidebar);
  border-left: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.debug-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  background: var(--secondary);
}
.debug-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--foreground);
  letter-spacing: -0.01em;
}
.debug-tabs {
  display: flex;
  gap: 2px;
  flex: 1;
  margin-left: 8px;
}
.debug-tab {
  background: none;
  border: 1px solid transparent;
  color: var(--muted-foreground);
  border-radius: var(--radius-sm);
  padding: 3px 10px;
  cursor: pointer;
  font-size: 12px;
  transition: color 0.12s, border-color 0.12s, background 0.12s;
}
.debug-tab:hover {
  color: var(--foreground);
}
.debug-tab-active {
  color: var(--enhanced-fg);
  border-color: var(--enhanced-border);
  background: var(--enhanced-bg);
}
.debug-close {
  background: none;
  border: none;
  color: var(--muted-foreground);
  cursor: pointer;
  font-size: 14px;
  padding: 2px 6px;
  margin-left: auto;
  font-family: var(--font-mono);
}
.debug-close:hover { color: var(--foreground); }
.debug-body {
  flex: 1;
  overflow-y: auto;
  padding: 12px;
}
.debug-loading,
.debug-empty {
  color: var(--muted-foreground);
  font-size: 13px;
  padding: 20px 0;
  text-align: center;
}
.debug-section { font-size: 13px; }
.debug-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 12px;
}
.debug-table td {
  padding: 4px 8px;
  border-bottom: 1px solid var(--border);
}
.debug-label {
  color: var(--muted-foreground);
  font-size: 12px;
  white-space: nowrap;
  width: 80px;
}
.debug-subsection { margin-top: 12px; }
.debug-subtitle {
  font-size: 10px;
  font-weight: 600;
  color: var(--muted-foreground);
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-family: var(--font-mono);
}
.debug-subtitle::before {
  content: '/ ';
  opacity: 0.4;
}
.debug-muted {
  color: var(--muted-foreground);
  font-size: 12px;
  font-style: italic;
  margin-top: 8px;
}
.debug-code {
  background: var(--background);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  white-space: pre-wrap;
  word-break: break-word;
  overflow-y: auto;
  max-height: 600px;
  color: var(--muted-foreground);
  line-height: 1.5;
}
.debug-prompt { max-height: none; }
.debug-prompt-stats {
  font-size: 11px;
  color: var(--muted-foreground);
  margin-bottom: 8px;
  font-family: var(--font-mono);
}

/* ╔═══════════════════════════════════════════════════════════════════════╗
   ║  Tools view                                                          ║
   ╚═══════════════════════════════════════════════════════════════════════╝ */

/* Tools sidebar -------------------------------------------------------- */
.tools-sidebar {
  flex: 1;
  overflow-y: auto;
  padding: 4px 8px 12px;
}
.tool-group {
  margin-bottom: 4px;
}
.tool-group-header {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 8px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  user-select: none;
  font-size: 12px;
  color: var(--foreground);
  font-weight: 500;
  transition: background 0.12s;
}
.tool-group-header:hover {
  background: var(--sidebar-accent);
}
.tool-group-caret {
  color: var(--muted-foreground);
  font-size: 10px;
  width: 10px;
  display: inline-block;
}
.tool-group-name {
  flex: 1;
}
.tool-group-count {
  background: var(--secondary);
  color: var(--muted-foreground);
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 999px;
  font-family: var(--font-mono);
}
.tool-group-tokens {
  font-size: 10px;
  color: var(--muted-foreground);
  font-family: var(--font-mono);
  font-weight: 400;
  white-space: nowrap;
}
.tool-group-loading {
  color: var(--muted-foreground);
  font-size: 12px;
}
.tool-group-error {
  color: var(--destructive-fg);
  font-weight: 700;
  font-family: var(--font-mono);
  cursor: help;
}
.tool-group-error-detail {
  font-size: 11px;
  color: var(--destructive-fg);
  padding: 6px 12px;
  line-height: 1.4;
  word-break: break-word;
}
.tool-group-empty {
  font-size: 11px;
  color: var(--muted-foreground);
  font-style: italic;
  padding: 4px 24px;
}
.tool-group-body {
  padding: 2px 0 6px 16px;
  border-left: 1px solid var(--border);
  margin-left: 14px;
}
.tool-item {
  position: relative;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 8px 5px 16px;
  border-radius: 3px;
  cursor: pointer;
  font-size: 12px;
  font-family: var(--font-mono);
  color: var(--muted-foreground);
  transition: background 0.12s, color 0.12s;
}
.tool-item::before {
  content: '';
  position: absolute;
  left: 4px;
  top: 50%;
  width: 4px;
  height: 4px;
  margin-top: -2px;
  border-radius: 50%;
  background: var(--muted-foreground);
  opacity: 0.18;
  transition: background 0.12s, opacity 0.12s, transform 0.12s;
}
.tool-item:hover {
  background: var(--sidebar-accent);
  color: var(--foreground);
}
.tool-item:hover::before {
  opacity: 0.4;
}
.tool-item-active {
  background: var(--enhanced-bg);
  color: var(--enhanced-fg);
  font-weight: 500;
  box-shadow: inset 2px 0 0 0 var(--enhanced);
}
.tool-item-active::before {
  background: var(--enhanced);
  opacity: 1;
  transform: scale(1.1);
}
.tool-item .tool-item-name {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.tool-item-tokens {
  flex-shrink: 0;
  font-size: 10px;
  color: var(--muted-foreground);
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  opacity: 0.6;
}
.tool-item:hover .tool-item-tokens {
  opacity: 0.9;
}
.tool-item-active .tool-item-tokens {
  color: var(--enhanced-fg);
  opacity: 0.9;
}
.tool-item-tag {
  display: inline-block;
  margin-left: 6px;
  padding: 0 5px;
  border-radius: var(--radius-sm);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  background: var(--card);
  color: var(--muted-foreground);
  border: 1px solid var(--border);
  vertical-align: middle;
}
.tool-group-section-label {
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted-foreground);
  font-weight: 600;
  font-family: var(--font-mono);
  padding: 8px 8px 4px;
  margin-top: 4px;
  opacity: 0.7;
}
.tool-group-section-label:first-child { margin-top: 0; }

/* Resource detail ------------------------------------------------------ */
.resource-uri {
  display: inline-block;
  background: var(--secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 4px 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--foreground);
  margin: 4px 0 8px;
  white-space: pre-wrap;
  word-break: break-all;
}
.resource-image {
  max-width: 100%;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}
.resource-markdown {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  max-height: 480px;
  overflow-y: auto;
  font-size: 13px;
}
.resource-markdown.markdown { font-size: 13px; }

/* Tools main panel ----------------------------------------------------- */
.tools-main {
  flex: 1;
  overflow-y: auto;
  padding: 24px 32px;
}
.tools-empty {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--muted-foreground);
  font-size: 13px;
  padding: 40px 20px;
  text-align: center;
}
.tools-empty-title {
  font-size: 14px;
  margin-bottom: 6px;
  color: var(--foreground);
  font-weight: 500;
}
.tools-empty-hint {
  font-size: 12px;
}

/* Tool detail ---------------------------------------------------------- */
.tool-detail {
  max-width: 1400px;
}
.tool-detail-header {
  margin-bottom: 24px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--rule);
  position: relative;
}
.tool-detail-eyebrow {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--muted-foreground);
  font-family: var(--font-mono);
  font-weight: 500;
  margin-bottom: 14px;
}
.tool-detail-eyebrow .sep {
  opacity: 0.25;
  font-weight: 400;
}
.tool-detail-name {
  font-size: 26px;
  font-family: var(--font-mono);
  font-weight: 500;
  color: var(--foreground);
  margin-bottom: 10px;
  word-break: break-word;
  letter-spacing: -0.01em;
  line-height: 1.15;
}
.tool-detail-name .tool-detail-name-tag {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  color: var(--enhanced-fg);
  margin-right: 8px;
  letter-spacing: -0.02em;
}
.tool-detail-description {
  color: var(--muted-foreground);
  line-height: 1.55;
  font-size: 13.5px;
  max-width: 72ch;
}

/* Token meter — visual indication of how much of a chunky tools-list
 * budget this single tool eats. Bar width is set via CSS custom property
 * --pct on the .tool-detail-meter element (0..100). */
.tool-detail-meter {
  margin-top: 14px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  color: var(--muted-foreground);
  text-transform: uppercase;
}
.tool-detail-meter-track {
  position: relative;
  flex: 1;
  max-width: 280px;
  height: 4px;
  background: var(--secondary);
  border-radius: 999px;
  overflow: hidden;
}
.tool-detail-meter-fill {
  position: absolute;
  inset: 0;
  width: var(--pct, 0%);
  background: linear-gradient(
    90deg,
    var(--enhanced) 0%,
    var(--enhanced) 60%,
    var(--enhanced-fg) 100%
  );
  border-radius: 999px;
}
.tool-detail-meter-value {
  font-variant-numeric: tabular-nums;
  color: var(--foreground);
  text-transform: none;
  letter-spacing: 0;
  font-size: 11px;
}
.tool-detail-meter-meta {
  font-variant-numeric: tabular-nums;
  text-transform: none;
  letter-spacing: 0;
  cursor: help;
}

.tool-detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 28px;
  align-items: start;
  margin-top: 20px;
}
@media (max-width: 1100px) {
  .tool-detail-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}
.tool-detail-col {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 0;
}
.tool-col-title {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted-foreground);
  font-weight: 600;
  font-family: var(--font-mono);
  margin: 0;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--rule);
  display: flex;
  align-items: center;
  gap: 10px;
}
.tool-col-title::before {
  content: '/ ';
  opacity: 0.4;
}
.tool-col-title-meta {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  color: var(--muted-foreground);
  margin-left: auto;
}
.tool-detail-subsection {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 4px;
}
.tool-subsection-title {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted-foreground);
  font-weight: 600;
  font-family: var(--font-mono);
  display: flex;
  align-items: center;
  gap: 6px;
}
.tool-subsection-title::before {
  content: '/ ';
  opacity: 0.4;
}
.tool-subsection-count {
  background: var(--secondary);
  color: var(--muted-foreground);
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 999px;
  font-family: var(--font-mono);
  letter-spacing: 0;
}

.output-empty {
  background: var(--card);
  border: 1px dashed var(--rule);
  border-radius: var(--radius-md);
  padding: 36px 20px;
  text-align: center;
  color: var(--muted-foreground);
  position: relative;
}
.output-empty::before {
  content: '∅';
  display: block;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 28px;
  color: var(--muted-foreground);
  opacity: 0.5;
  margin-bottom: 6px;
  line-height: 1;
}
.output-empty-title {
  font-size: 13px;
  color: var(--foreground);
  margin-bottom: 4px;
  font-weight: 500;
  letter-spacing: -0.005em;
}
.output-empty-hint {
  font-size: 12px;
}

/* Annotation badges ---------------------------------------------------- */
.tool-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}
.tool-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: 11px;
  font-family: var(--font-mono);
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--muted-foreground);
  cursor: help;
  user-select: none;
}
.tool-badge-safe {
  background: var(--success-bg);
  color: var(--success-fg);
  border-color: var(--success-border);
}
.tool-badge-warn {
  background: var(--destructive-bg);
  color: var(--destructive-fg);
  border-color: var(--destructive-border);
}
.tool-badge-neutral {
  /* explicit class for clarity; matches .tool-badge default */
  background: var(--card);
  color: var(--muted-foreground);
  border-color: var(--border);
}

/* Output schema panel -------------------------------------------------- */
.output-schema-panel {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.output-schema-summary {
  cursor: pointer;
  padding: 8px 12px;
  font-size: 12px;
  color: var(--muted-foreground);
  user-select: none;
}
.output-schema-summary:hover { color: var(--foreground); }
.output-schema-body {
  font-family: var(--font-mono);
  font-size: 11px;
  white-space: pre-wrap;
  word-break: break-word;
  padding: 0 12px 12px;
  color: var(--muted-foreground);
  max-height: 280px;
  overflow-y: auto;
  line-height: 1.5;
  margin: 0;
}

/* Status pills --------------------------------------------------------- */
.tool-result-status {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 4px;
}
.tool-status-pill {
  display: inline-flex;
  align-items: center;
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 500;
  font-family: var(--font-mono);
  border: 1px solid;
}
.tool-status-success {
  background: var(--success-bg);
  color: var(--success-fg);
  border-color: var(--success-border);
}
.tool-status-error {
  background: var(--destructive-bg);
  color: var(--destructive-fg);
  border-color: var(--destructive-border);
}
.tool-status-valid {
  background: var(--success-bg);
  color: var(--success-fg);
  border-color: var(--success-border);
  cursor: help;
}
.tool-status-invalid {
  background: var(--warning-bg);
  color: var(--warning-fg);
  border-color: var(--warning-border);
  cursor: help;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Result section sub-blocks ------------------------------------------- */
.tool-result-section {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.tool-result-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted-foreground);
  font-weight: 600;
  font-family: var(--font-mono);
}
.tool-result-label::before {
  content: '/ ';
  opacity: 0.4;
}

/* Tool form ------------------------------------------------------------ */
.tool-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 0;
}

.tool-form-modes {
  display: inline-flex;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 2px;
  align-self: flex-start;
}
.tool-form-mode {
  background: none;
  border: none;
  color: var(--muted-foreground);
  font-size: 12px;
  font-family: var(--font-sans);
  padding: 4px 14px;
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: color 0.12s, background 0.12s;
}
.tool-form-mode:hover { color: var(--foreground); }
.tool-form-mode-active {
  background: var(--secondary);
  color: var(--foreground);
  font-weight: 500;
}

.tool-form-raw {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.tool-form-raw-text {
  width: 100%;
  resize: vertical;
  min-height: 160px;
  font-family: var(--font-mono);
  font-size: 12px;
  line-height: 1.5;
  padding: 10px 12px;
}
.tool-form-raw-error {
  color: var(--destructive-fg);
  font-size: 11px;
  background: var(--destructive-bg);
  border: 1px solid var(--destructive-border);
  border-radius: var(--radius-sm);
  padding: 6px 10px;
  font-family: var(--font-mono);
}
.tool-form-empty {
  font-size: 13px;
  color: var(--muted-foreground);
  font-style: italic;
}

/* Form fields --------------------------------------------------------- */
.field {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.field-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
}
.field-name {
  font-family: var(--font-mono);
  color: var(--foreground);
  font-weight: 500;
}
.field-required {
  color: var(--destructive-fg);
  font-weight: 700;
}
.field-type {
  font-family: var(--font-mono);
  font-size: 10px;
  background: var(--secondary);
  color: var(--muted-foreground);
  padding: 1px 6px;
  border-radius: var(--radius-sm);
  margin-left: auto;
}
.field-description {
  font-size: 11px;
  color: var(--muted-foreground);
  line-height: 1.4;
}
.field-hint {
  font-size: 10px;
  color: var(--muted-foreground);
  font-style: italic;
}
.field-json {
  resize: vertical;
}
.field-boolean {
  flex-direction: row;
  align-items: center;
}
.field-checkbox-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
}
.field-boolean input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--enhanced);
  cursor: pointer;
}

.tool-form-error {
  color: var(--destructive-fg);
  font-size: 12px;
  background: var(--destructive-bg);
  border: 1px solid var(--destructive-border);
  border-radius: var(--radius-sm);
  padding: 8px 12px;
}
.tool-form-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 4px;
}
.btn-run {
  background: var(--primary);
  color: var(--primary-foreground);
  border: none;
  border-radius: var(--radius-sm);
  padding: 8px 18px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  font-family: var(--font-sans);
  box-shadow: var(--shadow-xs);
  transition: opacity 0.12s;
}
.btn-run:hover:not(:disabled) { opacity: 0.88; }
.btn-run:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.btn-secondary {
  background: none;
  border: 1px solid var(--border);
  color: var(--muted-foreground);
  border-radius: var(--radius-sm);
  padding: 7px 14px;
  font-size: 12px;
  cursor: pointer;
  font-family: var(--font-sans);
  transition: color 0.12s, border-color 0.12s;
}
.btn-secondary:hover:not(:disabled) {
  color: var(--foreground);
  border-color: var(--muted-foreground);
}
.btn-secondary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.tool-form-schema-toggle {
  margin-left: auto;
}
.tool-form-schema-active {
  color: var(--enhanced-fg);
  border-color: var(--enhanced-border);
}
.tool-form-schema {
  background: var(--background);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  white-space: pre-wrap;
  word-break: break-word;
  color: var(--muted-foreground);
  max-height: 320px;
  overflow-y: auto;
}

/* Tool result ---------------------------------------------------------- */
.tool-result {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.tool-result-loading {
  color: var(--muted-foreground);
  font-style: italic;
  font-size: 13px;
  padding: 8px 0;
}
.tool-result-error {
  background: var(--destructive-bg);
  color: var(--destructive-fg);
  border: 1px solid var(--destructive-border);
  border-radius: var(--radius-sm);
  padding: 12px;
  font-family: var(--font-mono);
  font-size: 12px;
  white-space: pre-wrap;
  word-break: break-word;
}
.tool-result-body {
  background: var(--background);
  border: 1px solid var(--border);
  border-left: 3px solid var(--enhanced);
  border-radius: var(--radius-sm);
  padding: 12px;
  font-family: var(--font-mono);
  font-size: 12px;
  white-space: pre-wrap;
  word-break: break-word;
  color: var(--foreground);
  line-height: 1.5;
  max-height: 480px;
  overflow-y: auto;
}
.tool-result-empty {
  color: var(--muted-foreground);
  font-style: italic;
  font-size: 12px;
  padding: 8px 0;
}
.tool-result-args,
.tool-result-raw {
  font-size: 12px;
}
.tool-result-args summary,
.tool-result-raw summary {
  cursor: pointer;
  color: var(--muted-foreground);
  user-select: none;
  padding: 2px 0;
}
.tool-result-args summary:hover,
.tool-result-raw summary:hover {
  color: var(--foreground);
}
.tool-result-args pre,
.tool-result-raw pre {
  background: var(--background);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  white-space: pre-wrap;
  word-break: break-word;
  color: var(--muted-foreground);
  margin-top: 6px;
  max-height: 320px;
  overflow-y: auto;
}

/* Config sub-label ----------------------------------------------------- */
.config-sublabel {
  font-size: 11px;
  color: var(--muted-foreground);
  font-weight: normal;
  margin-left: 4px;
}

/* Config: device flow + org picker ------------------------------------- */
.config-brand {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 18px;
}
.config-brand .brand-mark {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 30px;
  line-height: 1;
  letter-spacing: -0.02em;
}
.config-brand .brand-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted-foreground);
}
.config-label-text {
  display: inline-block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted-foreground);
  font-family: var(--font-mono);
  font-weight: 500;
  margin-bottom: 6px;
}
.config-error {
  background: var(--destructive-bg);
  color: var(--destructive-fg);
  border: 1px solid var(--destructive-border);
  border-radius: var(--radius-sm);
  padding: 8px 12px;
  font-size: 12px;
  font-family: var(--font-mono);
  margin: 12px 0;
}
.config-manual-toggle {
  background: none;
  border: none;
  color: var(--muted-foreground);
  font-size: 12px;
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
  cursor: pointer;
  padding: 14px 0 6px;
  display: block;
  text-align: left;
}
.config-manual-toggle:hover { color: var(--foreground); }
.config-manual {
  border-top: 1px dashed var(--rule);
  padding-top: 14px;
  margin-top: 4px;
}

/* Device-code display: the big code is the centerpiece. Wide letter-spacing
 * + serif italic at small sizes for the helper text gives it some character
 * without competing with the code itself. */
.config-device {
  text-align: center;
}
.config-device .config-brand,
.config-device .config-hint { text-align: left; }
.device-code {
  font-family: var(--font-mono);
  font-size: 44px;
  font-weight: 500;
  letter-spacing: 0.16em;
  color: var(--enhanced-fg);
  background: var(--enhanced-bg);
  border: 1px solid var(--enhanced-border);
  border-radius: var(--radius-md);
  padding: 22px 8px;
  margin: 18px 0 12px;
  user-select: all;
  font-variant-numeric: tabular-nums;
}
.config-device-meta {
  font-size: 12px;
  color: var(--muted-foreground);
  margin-bottom: 16px;
}
.config-device-meta a {
  color: var(--enhanced-fg);
  text-decoration: underline;
  margin-left: 4px;
}
.device-verify-btn {
  display: block;
  text-align: center;
  text-decoration: none;
  margin-bottom: 16px;
}
.device-poll {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--muted-foreground);
  font-family: var(--font-mono);
  margin-bottom: 14px;
}
.device-poll-spinner {
  color: var(--enhanced);
  animation: pulse 1.2s ease-in-out infinite;
  font-size: 8px;
}

/* Org picker ----------------------------------------------------------- */
.org-list {
  list-style: none;
  margin: 12px 0 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 320px;
  overflow-y: auto;
}
.org-item {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: border-color 0.12s, background 0.12s;
}
.org-item:hover {
  border-color: var(--enhanced-border);
  background: var(--enhanced-bg);
}
.org-item-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--foreground);
}
.org-item-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 11px;
  color: var(--muted-foreground);
  font-family: var(--font-mono);
}
.org-item-id { margin-left: auto; opacity: 0.6; }
.org-item-active {
  border-color: var(--enhanced-border);
  background: var(--enhanced-bg);
}
.org-item-current-tag {
  display: inline-block;
  margin-left: 8px;
  padding: 1px 7px;
  font-size: 9px;
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--enhanced-fg);
  border: 1px solid var(--enhanced-border);
  border-radius: 2px;
  vertical-align: middle;
  font-weight: 500;
}
.org-list-loading {
  padding: 18px 12px;
  font-size: 12px;
  color: var(--muted-foreground);
  font-family: var(--font-mono);
  text-align: center;
}

/* Config close button (X in the corner) ------------------------------- */
.config-close {
  position: absolute;
  top: 10px;
  right: 12px;
  background: none;
  border: none;
  color: var(--muted-foreground);
  cursor: pointer;
  font-size: 22px;
  line-height: 1;
  padding: 4px 8px;
  border-radius: var(--radius-sm);
  transition: color 0.12s, background 0.12s;
}
.config-close:hover {
  color: var(--foreground);
  background: var(--secondary);
}
.config-panel { position: relative; }

/* Sidebar footer: user menu ------------------------------------------- */
.user-menu {
  position: relative;
  border-top: 1px solid var(--sidebar-border);
  padding: 8px;
  flex-shrink: 0;
}
.user-menu-trigger {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  background: none;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  padding: 8px 10px;
  cursor: pointer;
  color: var(--foreground);
  font-family: var(--font-sans);
  text-align: left;
  transition: background 0.12s, border-color 0.12s;
}
.user-menu-trigger:hover,
.user-menu-open {
  background: var(--sidebar-accent);
  border-color: var(--border);
}
.user-avatar {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--enhanced-bg);
  color: var(--enhanced-fg);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  border: 1px solid var(--enhanced-border);
}
.user-menu-text {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
  line-height: 1.2;
}
.user-menu-name {
  font-size: 12px;
  font-weight: 500;
  color: var(--foreground);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.user-menu-org {
  font-size: 10px;
  font-family: var(--font-mono);
  color: var(--muted-foreground);
  letter-spacing: 0.04em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.user-menu-caret {
  font-size: 10px;
  color: var(--muted-foreground);
  flex-shrink: 0;
}
.user-menu-popover {
  position: absolute;
  bottom: calc(100% - 4px);
  left: 8px;
  right: 8px;
  background: var(--popover);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  padding: 4px;
  display: flex;
  flex-direction: column;
  z-index: 50;
}
.user-menu-item {
  display: flex;
  align-items: center;
  gap: 10px;
  background: none;
  border: none;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: 12px;
  font-family: var(--font-sans);
  color: var(--foreground);
  text-align: left;
  transition: background 0.12s, color 0.12s;
}
.user-menu-item:hover {
  background: var(--sidebar-accent);
}
.user-menu-item-icon {
  width: 16px;
  display: inline-flex;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted-foreground);
}
.user-menu-item-danger { color: var(--destructive-fg); }
.user-menu-item-danger:hover { background: var(--destructive-bg); }
.user-menu-item-danger .user-menu-item-icon { color: var(--destructive-fg); }
.user-menu-divider {
  height: 1px;
  background: var(--rule);
  margin: 4px 6px;
}

/* Recent inputs -------------------------------------------------------- */
.recent-inputs {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 4px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  max-height: 220px;
  overflow-y: auto;
}
.recent-empty {
  color: var(--muted-foreground);
  font-size: 12px;
  font-style: italic;
  padding: 16px 10px;
  text-align: center;
  line-height: 1.5;
}
.recent-entry {
  position: relative;
  padding: 7px 22px 7px 9px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background 0.12s, border-color 0.12s;
}
.recent-entry:hover {
  background: var(--secondary);
  border-color: var(--border);
}
.recent-entry-time {
  font-size: 10px;
  color: var(--muted-foreground);
  margin-bottom: 3px;
  font-family: var(--font-mono);
}
.recent-entry-args {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--foreground);
  margin: 0;
  white-space: pre-wrap;
  word-break: break-all;
  line-height: 1.4;
  max-height: 56px;
  overflow: hidden;
}
.recent-entry-delete {
  position: absolute;
  right: 4px;
  top: 4px;
  background: none;
  border: none;
  color: var(--muted-foreground);
  font-size: 14px;
  cursor: pointer;
  opacity: 0;
  padding: 0 4px;
  line-height: 1;
}
.recent-entry:hover .recent-entry-delete {
  opacity: 1;
}
.recent-entry-delete:hover {
  color: var(--destructive-fg);
}
