/* ─── PYTHON ICON FALLBACK (ri-python-fill absent in RemixIcon 4.2) ──── */
i.ri-python-fill { font-style: normal !important; }
i.ri-python-fill::before {
  content: 'Py' !important;
  font-family: 'JetBrains Mono', 'Consolas', monospace !important;
  font-size: 0.68em !important;
  font-weight: 800 !important;
  letter-spacing: -1.5px !important;
  line-height: 1 !important;
}

/* ─── THEME VARIABLES ─────────────────────────────────────────── */
:root {
  --bg-dark:    #09090b;
  --bg-panel:   #18181b;
  --bg-editor:  #282c34;
  --tab-bg:     #1f1f22;
  --tab-active: #282c34;
  --primary:    #3b82f6;
  --text-main:  #f4f4f5;
  --text-muted: #a1a1aa;
  --border:     #27272a;
  --folder-color: #fbbf24;
  --error:      #f87171;
  --success:    #4ade80;
  --warn:       #fbbf24;
  --editor-font-size: 14px;
  --plugin-footer-h: 44px;
  --workspace-h: calc(100dvh - 48px - var(--plugin-footer-h));
}
/* Mobile: reduce footer height var */
@media (max-width: 768px) {
  :root { --plugin-footer-h: 40px; }
}
.pro-ui {
  --bg-dark:   #000;
  --bg-panel:  #0a0a0a;
  --bg-editor: #111;
  --tab-bg:    #050505;
  --border:    #1a1a1a;
}
* { box-sizing: border-box; margin: 0; padding: 0; outline: none; -webkit-tap-highlight-color: transparent; }
body {
  background: var(--bg-dark); color: var(--text-main);
  font-family: 'Segoe UI', system-ui, sans-serif;
  height: 100vh; height: 100dvh;
  display: flex; flex-direction: column; overflow: hidden;
  transition: background 0.3s, color 0.3s;
}
body.no-animations * { transition: none !important; animation: none !important; }
/* ── Refresh spin ─────────────────────────────────────────────── */
@keyframes refresh-spin { 0%{transform:rotate(0deg)} 100%{transform:rotate(360deg)} }
.pm-refreshing .ri-refresh-line { animation: refresh-spin 0.6s linear; }
/* ── Mobile line-picker row hover (touch) ─────────────────────── */
.mlp-row-selected { background: rgba(59,130,246,0.15) !important; }
/* Make workspace fill remaining height above plugin footer */
.workspace { flex: 1; min-height: 0; }

/* ─── HEADER ──────────────────────────────────────────────────── */
header {
  height: 48px; background: var(--bg-panel); border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 12px; z-index: 20; flex-shrink: 0;
}
.logo { font-weight: 700; color: var(--primary); display: flex; align-items: center; gap: 8px; font-size: 1.1rem; letter-spacing: -0.5px; }
.logo-version { font-size: 0.6em; color: #555; margin-left: 2px; }
.toolbar {
  display: flex; gap: 6px; align-items: center;
  overflow-x: auto; overflow-y: hidden;
  scrollbar-width: none; -webkit-overflow-scrolling: touch;
  flex-shrink: 1; min-width: 0; max-width: calc(100vw - 140px);
  padding-right: 0;
}
.toolbar::-webkit-scrollbar { display: none; }
/* Run button always anchored to right — never clipped by plugin buttons */
.toolbar button.primary {
  flex-shrink: 0; position: sticky; right: 0;
  background: var(--primary); z-index: 6;
  box-shadow: -8px 0 12px var(--bg-panel);
}
button {
  background: #27272a; border: 1px solid var(--border); color: var(--text-main);
  padding: 5px 10px; border-radius: 4px; cursor: pointer; font-size: 0.8rem;
  display: flex; align-items: center; gap: 6px; transition: 0.2s;
}
button:hover { background: #3f3f46; border-color: #52525b; }
button.primary { background: var(--primary); border-color: var(--primary); color: #fff; }
button.primary:hover { background: #2563eb; }
button.icon-btn { padding: 8px; border: none; background: transparent; font-size: 1.1rem; color: var(--text-muted); }
button.icon-btn:hover { color: #fff; background: rgba(255,255,255,0.1); border-radius: 4px; }

/* ─── WORKSPACE ───────────────────────────────────────────────── */
.workspace { display: flex; flex: 1; position: relative; overflow: hidden; min-height: 0; }

/* ─── SIDEBAR ─────────────────────────────────────────────────── */
.sidebar {
  width: 260px; background: var(--bg-panel); border-right: 1px solid var(--border);
  display: flex; flex-direction: column; z-index: 15; flex-shrink: 0;
  transition: transform 0.3s ease;
}
.sidebar-header { padding: 10px; border-bottom: 1px solid var(--border); }
.sidebar-header select {
  width: 100%; background: #000; color: #fff; border: 1px solid var(--border);
  padding: 6px; border-radius: 4px; font-size: 0.85rem; margin-bottom: 8px;
}
.sidebar-actions { display: flex; gap: 2px; flex-wrap: wrap; justify-content: flex-start; }
.file-search {
  width: 100%; margin-top: 8px; padding: 6px 8px; border-radius: 6px;
  border: 1px solid var(--border); background: #000; color: #fff; font-size: 0.8rem;
}
.file-explorer { flex: 1; overflow-y: auto; padding: 4px 0; }
.file-explorer::-webkit-scrollbar { width: 4px; }
.file-explorer::-webkit-scrollbar-thumb { background: #333; border-radius: 2px; }
.tree-node {
  padding: 5px 10px; color: var(--text-muted); cursor: pointer;
  display: flex; align-items: center; gap: 6px; font-size: 0.83rem;
  user-select: none; transition: background 0.15s; position: relative;
}
.tree-node:hover { background: rgba(255,255,255,0.05); color: #fff; }
.tree-node.active { background: rgba(59,130,246,0.15); color: var(--primary); border-left: 2px solid var(--primary); }
.tree-node .file-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.file-size { margin-left: auto; font-size: 0.68rem; color: #555; flex-shrink: 0; }
.tree-folder-header {
  padding: 5px 10px; color: #ddd; cursor: pointer;
  display: flex; align-items: center; gap: 6px; font-size: 0.83rem;
  font-weight: 600; user-select: none; transition: background 0.15s;
}
.tree-folder-header:hover { background: rgba(255,255,255,0.05); }
.tree-folder-content { padding-left: 14px; border-left: 1px solid #2a2a2a; margin-left: 16px; display: none; }
.tree-folder-content.open { display: block; }
.arrow { transition: transform 0.2s; display: inline-block; }
.arrow.open { transform: rotate(90deg); }

/* ─── EDITOR AREA ─────────────────────────────────────────────── */
.editor-wrapper { flex: 1; display: flex; flex-direction: column; position: relative; overflow: hidden; background: var(--bg-editor); }

/* ─── SPLIT CONTAINER ─────────────────────────────────────────── */
.split-container { display: flex; flex: 1; overflow: hidden; flex-direction: row; position: relative; }
.split-container.vertical { flex-direction: column; }
.split-pane { display: flex; flex-direction: column; overflow: hidden; flex: 1; min-width: 0; min-height: 0; }
.split-divider {
  background: var(--border); flex-shrink: 0; position: relative; z-index: 5;
  display: flex; align-items: center; justify-content: center; transition: background 0.2s;
}
.split-divider:hover, .split-divider.dragging { background: var(--primary); }
.split-divider.horiz { width: 5px; cursor: col-resize; }
.split-divider.vert  { height: 5px; cursor: row-resize; }
.split-divider-handle {
  width: 28px; height: 28px; border-radius: 4px;
  background: var(--bg-panel); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-muted); font-size: 0.6rem; gap: 1px; flex-direction: column; pointer-events: none;
}
.split-divider.horiz .split-divider-handle { flex-direction: column; }
.split-divider.vert  .split-divider-handle { flex-direction: row; }
.split-handle-line { width: 16px; height: 2px; background: var(--text-muted); border-radius: 1px; }
.split-divider.horiz .split-handle-line { width: 2px; height: 16px; }
.split-badge {
  font-size: 0.65rem; padding: 1px 6px; border-radius: 3px;
  background: rgba(59,130,246,0.15); color: var(--primary);
  border: 1px solid rgba(59,130,246,0.3); margin-left: 4px; cursor: pointer; user-select: none;
}
.split-toggle-group {
  display: flex; gap: 2px; background: #000;
  border: 1px solid var(--border); border-radius: 6px; padding: 2px; overflow: hidden;
}
.split-toggle-btn {
  padding: 4px 8px; border: none; background: transparent;
  color: var(--text-muted); cursor: pointer; border-radius: 4px;
  font-size: 0.75rem; display: flex; align-items: center; gap: 4px; transition: 0.15s;
}
.split-toggle-btn.active { background: var(--primary); color: #fff; }
.split-toggle-btn:hover:not(.active) { background: rgba(255,255,255,0.07); color: #fff; }

/* ─── TAB BAR ─────────────────────────────────────────────────── */
.tab-bar {
  height: 36px; background: var(--bg-panel); display: flex; align-items: flex-end;
  border-bottom: 1px solid var(--bg-editor);
  overflow-x: auto; overflow-y: hidden; -webkit-overflow-scrolling: touch;
  scrollbar-width: thin; scrollbar-color: #444 transparent; flex-shrink: 0;
}
.tab-bar::-webkit-scrollbar { height: 3px; }
.tab-bar::-webkit-scrollbar-thumb { background: #444; border-radius: 2px; }
.tab {
  height: 32px; padding: 0 10px; display: flex; align-items: center; gap: 6px;
  background: var(--tab-bg); color: var(--text-muted); font-size: 0.79rem; cursor: pointer;
  border-right: 1px solid var(--border); border-top: 2px solid transparent;
  min-width: 110px; max-width: 180px; flex-shrink: 0; white-space: nowrap;
}
.tab.active { background: var(--tab-active); color: #fff; border-top-color: var(--primary); }
.tab-close { margin-left: auto; opacity: 0.5; transition: opacity 0.2s; }
.tab:hover .tab-close { opacity: 1; }
.tab-close:hover { color: #ef4444; }
.tab-close-all {
  height: 32px; padding: 0 10px; display: flex; align-items: center;
  font-size: 0.72rem; color: #555; cursor: pointer; flex-shrink: 0;
  border-left: 1px solid var(--border);
}
.tab-close-all:hover { color: var(--error); background: rgba(248,113,113,0.08); }
.tab-map-btn {
  height: 32px; min-width: 34px; display: flex; align-items: center; justify-content: center;
  border-left: 1px solid var(--border); color: var(--text-muted); cursor: pointer; flex-shrink: 0;
}
.tab-map-btn:hover { color: #fff; background: rgba(59,130,246,0.14); }
.tab-map-btn.active { color: var(--primary); background: rgba(59,130,246,0.14); border-left: 1px solid rgba(59,130,246,0.35); }

/* ─── CM6 EDITOR ──────────────────────────────────────────────── */
#codeEditor { flex: 1; overflow: hidden; display: flex; flex-direction: column; }
.minimap-wrap {
  position: absolute; top: 40px; right: 6px; bottom: 6px; width: 74px;
  background: rgba(0,0,0,0.5); border: 1px solid var(--border); border-radius: 6px;
  z-index: 12; display: none; overflow: hidden;
}
.minimap-wrap.show { display: block; }
#minimapCanvas { width: 100%; height: 100%; display: block; cursor: pointer; }
#minimapViewport {
  position: absolute; left: 2px; right: 2px; border: 1px solid rgba(59,130,246,0.85);
  background: rgba(59,130,246,0.18); border-radius: 2px; pointer-events: none;
}
.editor-dropzone {
  position: absolute; inset: 0; display: none; align-items: center; justify-content: center;
  background: rgba(59,130,246,0.14); border: 2px dashed var(--primary); z-index: 80;
  font-size: 1rem; font-weight: 700; color: #bfdbfe;
}
.editor-dropzone.show { display: flex; }
.cm-editor {
  height: 100%;
  font-size: var(--editor-font-size, 14px) !important;
  font-family: 'JetBrains Mono','Consolas','Fira Code',monospace !important;
}
.cm-editor .cm-content { font-size: var(--editor-font-size, 14px) !important; }
.cm-editor .cm-gutters { background: #21252b !important; border-right: 1px solid #3a3f4b !important; }
.cm-editor.cm-focused { outline: none !important; }
.cm-color-swatch {
  display: inline-block; width: 11px; height: 11px;
  border-radius: 2px; border: 1px solid #555;
  vertical-align: middle; margin-right: 3px; pointer-events: none;
}

/* ─── IMAGE / MARKDOWN VIEWS ──────────────────────────────────── */
.image-preview { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; background: #111; color: #666; }
.image-preview img { max-width: 90%; max-height: 90%; border: 1px solid #333; }
.markdown-preview {
  flex: 1; overflow-y: auto; padding: 24px; background: var(--bg-editor); color: var(--text-main);
  font-family: 'Segoe UI', system-ui, sans-serif; line-height: 1.7; display: none;
}
.markdown-preview h1,.markdown-preview h2,.markdown-preview h3 { margin-top: 1.2em; margin-bottom: 0.5em; color: var(--primary); border-bottom: 1px solid var(--border); padding-bottom: 4px; }
.markdown-preview p { margin-bottom: 0.8em; }
.markdown-preview code { background: rgba(255,255,255,0.1); padding: 2px 6px; border-radius: 3px; font-family: monospace; font-size: 0.9em; }
.markdown-preview pre { background: rgba(0,0,0,0.4); padding: 15px; border-radius: 6px; overflow-x: auto; border: 1px solid var(--border); margin-bottom: 1em; }
.markdown-preview pre code { background: none; padding: 0; }
.markdown-preview blockquote { border-left: 3px solid var(--primary); padding: 4px 12px; color: var(--text-muted); margin: 1em 0; background: rgba(59,130,246,0.05); }
.markdown-preview table { border-collapse: collapse; width: 100%; margin-bottom: 1em; }
.markdown-preview th,.markdown-preview td { border: 1px solid var(--border); padding: 8px 12px; }
.markdown-preview th { background: rgba(255,255,255,0.07); color: #fff; }
.markdown-preview a { color: var(--primary); }
.markdown-preview ul,.markdown-preview ol { padding-left: 1.5em; margin-bottom: 0.8em; }
.markdown-preview .katex-display { overflow-x: auto; }

/* ─── BOTTOM PANEL ────────────────────────────────────────────── */
.bottom-panel {
  background: var(--bg-panel); border-top: 1px solid var(--border);
  position: absolute; bottom: 0; width: 100%; z-index: 25;
  height: 240px; display: flex; flex-direction: column;
  transform: translateY(100%); transition: transform 0.3s; overflow: hidden;
}
.bottom-panel.open { transform: translateY(0); }
.panel-header {
  padding: 4px 6px; background: #000;
  display: flex; flex-wrap: nowrap; gap: 4px;
  justify-content: space-between; align-items: center;
  font-size: 0.8rem; border-bottom: 1px solid var(--border);
  max-width: 100vw; padding-right: max(6px, env(safe-area-inset-right));
  overflow-x: auto; overflow-y: hidden; scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.panel-header::-webkit-scrollbar { display: none; }
.panel-header-left {
  display: flex; align-items: center; gap: 2px;
  flex-wrap: nowrap; min-width: 0; overflow-x: auto;
  scrollbar-width: none; -webkit-overflow-scrolling: touch;
  flex-shrink: 1;
}
.panel-header-left::-webkit-scrollbar { display: none; }
.panel-header-right {
  display: flex; align-items: center; gap: 4px;
  flex-shrink: 0; position: sticky; right: 0;
  background: #000; padding-left: 6px;
  box-shadow: -8px 0 10px #000;
}
.panel-close-btn {
  width: 28px; height: 28px; display: flex; align-items: center; justify-content: center;
  border-radius: 4px; cursor: pointer; color: var(--text-muted); font-size: 1.1rem; flex-shrink: 0;
}
.panel-close-btn:hover { color: var(--error); background: rgba(248,113,113,0.1); }
.panel-content { flex: 1; overflow-y: auto; padding: 8px 10px; font-family: monospace; font-size: 12px; color: #ccc; min-height: 0; }
.log-error { color: var(--error); border-bottom: 1px solid #2a2a2a; padding: 3px 0; word-break: break-all; }
.log-info  { color: var(--success); border-bottom: 1px solid #2a2a2a; padding: 3px 0; word-break: break-all; }
.log-warn  { color: #fbbf24; border-bottom: 1px solid #2a2a2a; padding: 3px 0; }
.log-dim   { color: #555; padding: 2px 0; }
.console-log-entry { cursor: pointer; border-radius: 2px; transition: background 0.15s; }
.console-log-entry:hover { background: rgba(255,255,255,0.05); }

/* ─── BOTTOM TABS ─────────────────────────────────────────────── */
.bottom-tabs { display: flex; background: transparent; border: none; }
.bottom-tab-btn {
  padding: 5px 12px; font-size: 0.78rem; cursor: pointer; color: var(--text-muted);
  border: none; background: transparent; border-bottom: 2px solid transparent; transition: 0.2s;
}
.bottom-tab-btn.active { color: var(--primary); border-bottom-color: var(--primary); }
.bottom-tab-panel { display: none; flex: 1; flex-direction: column; min-height: 0; }
.bottom-tab-panel.active { display: flex; }

/* ─── TERMINAL ────────────────────────────────────────────────── */
.terminal-output {
  flex: 1; overflow-y: auto; padding: 8px 10px;
  font-family: 'JetBrains Mono','Consolas','Courier New',monospace; font-size: 12px;
  color: #c0c0c0; background: #0d0d0d; min-height: 0;
}
.terminal-output::-webkit-scrollbar { width: 4px; }
.terminal-output::-webkit-scrollbar-thumb { background: #333; }
.term-line { line-height: 1.55; white-space: pre-wrap; word-break: break-all; }
.term-prompt { color: #4ade80; }
.term-error  { color: #f87171; }
.term-warn   { color: #fbbf24; }
.term-info   { color: #60a5fa; }
.term-dim    { color: #555; }
.term-wc     { color: #c084fc; }
.ansi-30{color:#000}.ansi-31{color:#f87171}.ansi-32{color:#4ade80}
.ansi-33{color:#fbbf24}.ansi-34{color:#60a5fa}.ansi-35{color:#c084fc}
.ansi-36{color:#34d399}.ansi-37{color:#f4f4f5}.ansi-1{font-weight:700}
.terminal-input-row {
  display: flex; align-items: center; padding: 4px 8px;
  background: #0d0d0d; border-top: 1px solid #1a1a1a; gap: 6px;
}
.terminal-prompt-label { color: #4ade80; font-size: 12px; font-family: monospace; white-space: nowrap; }
.terminal-input {
  flex: 1; background: transparent; border: none; color: #c0c0c0;
  font-family: 'JetBrains Mono', monospace; font-size: 12px; outline: none;
}

/* ─── XTERM ───────────────────────────────────────────────────── */
#xtermContainer {
  flex: 1; overflow: hidden; background: #0d0d0d;
  padding: 4px 2px 2px 4px;
  /* NOTE: touch-action MUST NOT be set on this container — it prevents
     Chromium from dispatching mousedown/pointerdown events on desktop,
     which breaks xterm.js focus and kills keyboard input entirely.
     touch-action is applied below only to the inner xterm elements
     that actually need it for mobile scroll suppression. */
}
#xtermContainer .xterm-helper-textarea {
  /* Ensure xterm's hidden input textarea is focusable on all platforms */
  pointer-events: auto !important;
}
#xtermContainer .xterm { height: 100%; }
/* Apply touch-action only to the inner elements that need it for mobile:
   prevents the page from scrolling while interacting with the terminal
   on touch devices, without breaking desktop pointer/mouse events. */
#xtermContainer .xterm-screen {
  touch-action: none;
  cursor: text; /* Desktop: signals the terminal is a typing area */
}
#xtermContainer .xterm-viewport {
  scrollbar-width: thin; scrollbar-color: #333 transparent;
  -webkit-overflow-scrolling: touch;
}
/* Same fix for the split-pane terminal container */
#xtermContainer2 .xterm-screen {
  touch-action: none;
  cursor: text;
}
#xtermContainer2 .xterm-viewport {
  -webkit-overflow-scrolling: touch;
}

/* ─── WEBCONTAINER STATUS ─────────────────────────────────────── */
.wc-status-bar {
  position: absolute; top: 8px; right: 10px;
  display: flex; align-items: center; gap: 6px;
  background: rgba(0,0,0,0.8); border: 1px solid var(--border);
  padding: 4px 10px; border-radius: 20px; font-size: 0.72rem;
  color: var(--text-muted); z-index: 10; transition: all 0.3s; pointer-events: none;
}
.wc-dot { width: 7px; height: 7px; border-radius: 50%; background: #555; transition: background 0.3s; }
.wc-dot.loading { background: var(--warn); animation: wc-pulse 1s infinite; }
.wc-dot.ready   { background: var(--success); }
.wc-dot.error   { background: var(--error); }
.wc-dot.cdn     { background: var(--primary); }
@keyframes wc-pulse { 0%,100%{opacity:1} 50%{opacity:0.4} }

/* ─── SETTINGS PANEL ──────────────────────────────────────────── */
.settings-panel {
  background: var(--bg-panel); border-top: 1px solid var(--border);
  position: fixed; bottom: var(--plugin-footer-h, 44px); left: 0; right: 0; z-index: 260;
  height: min(380px, calc(100dvh - 48px - var(--plugin-footer-h, 44px)));
  display: flex; flex-direction: column;
  transform: translateY(calc(100% + var(--plugin-footer-h, 44px))); transition: transform 0.3s;
}
.settings-panel.open { transform: translateY(0); }
.settings-content { flex: 1; overflow-y: auto; padding: 14px 16px; }
.setting-item { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--border); }
.setting-label { font-size: 0.9rem; color: var(--text-main); }
.setting-desc  { font-size: 0.73rem; color: var(--text-muted); margin-top: 2px; }
.toggle-switch { position: relative; width: 44px; height: 24px; background: #27272a; border-radius: 12px; cursor: pointer; transition: background 0.3s; flex-shrink: 0; }
.toggle-switch.active { background: var(--primary); }
.toggle-slider { position: absolute; top: 3px; left: 3px; width: 18px; height: 18px; background: #fff; border-radius: 50%; transition: transform 0.3s; }
.toggle-switch.active .toggle-slider { transform: translateX(20px); }
.setting-select { background: #27272a; border: 1px solid var(--border); color: var(--text-main); padding: 5px 8px; border-radius: 4px; font-size: 0.82rem; }
.exec-mode-group { display: flex; gap: 6px; margin-top: 8px; }
.exec-btn {
  flex: 1; padding: 7px 10px; border-radius: 6px; border: 1px solid var(--border);
  background: #000; color: var(--text-muted); cursor: pointer; font-size: 0.8rem;
  display: flex; align-items: center; justify-content: center; gap: 6px; transition: 0.2s;
}
.exec-btn.active { border-color: var(--primary); color: var(--primary); background: rgba(59,130,246,0.1); }

/* ─── PREVIEW PANEL ───────────────────────────────────────────── */
.preview-panel {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  background: #fff; z-index: 30; transform: translateY(100%); transition: transform 0.3s;
  display: flex; flex-direction: column;
}
.preview-panel.open { transform: translateY(0); }
.preview-panel.fullscreen { position: fixed; inset: 0; width: 100vw; height: 100vh; z-index: 9999; }
.preview-bar { height: 40px; background: #111; display: flex; align-items: center; justify-content: space-between; padding: 0 10px; color: #fff; gap: 8px; }
.preview-url { font-size: 0.78rem; color: #888; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.preview-bar-btns { display: flex; gap: 6px; align-items: center; }
iframe { flex: 1; width: 100%; border: none; background: #fff; }

/* ─── CONTEXT MENU ────────────────────────────────────────────── */
.context-menu {
  position: fixed; background: var(--bg-panel); border: 1px solid var(--border);
  min-width: 170px; display: none; flex-direction: column; z-index: 9998;
  box-shadow: 0 8px 24px rgba(0,0,0,0.7); border-radius: 8px; overflow: hidden;
  animation: ctxIn 0.12s ease;
}
@keyframes ctxIn { from{opacity:0;transform:scale(0.93)} to{opacity:1;transform:scale(1)} }
.ctx-item { padding: 9px 14px; font-size: 0.84rem; cursor: pointer; color: var(--text-muted); display: flex; align-items: center; gap: 8px; }
.ctx-item:hover { background: var(--primary); color: #fff; }
.ctx-sep { height: 1px; background: var(--border); margin: 3px 0; }

/* ─── MODALS ──────────────────────────────────────────────────── */
.modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.75); z-index: 1000; display: none; align-items: center; justify-content: center; backdrop-filter: blur(3px); }
.modal-backdrop.active { display: flex; }
.modal { background: var(--bg-panel); padding: 20px; border-radius: 10px; width: 92%; max-width: 520px; border: 1px solid var(--border); }
.modal h3 { margin-bottom: 15px; color: #fff; }
.modal input { width: 100%; padding: 10px; background: #000; border: 1px solid var(--border); color: #fff; margin-bottom: 12px; border-radius: 6px; }
.pkg-modal { max-width: 520px !important; max-height: 80vh; overflow-y: auto; }
.pkg-search-row { display: flex; gap: 8px; margin-bottom: 12px; }
.pkg-search-input { flex: 1; padding: 8px 10px; background: #000; border: 1px solid var(--border); color: #fff; border-radius: 4px; font-size: 0.85rem; }
.pkg-result-item { display: flex; justify-content: space-between; align-items: center; padding: 8px 10px; border-radius: 6px; background: #1a1a1a; margin-bottom: 6px; }
.pkg-result-name { font-size: 0.85rem; font-weight: 600; color: #fff; }
.pkg-result-ver  { font-size: 0.73rem; color: var(--text-muted); }

/* ─── CUSTOM DIALOG ───────────────────────────────────────────── */
.custom-dialog-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.88);
  backdrop-filter: blur(8px); z-index: 9999;
  display: none; align-items: center; justify-content: center; padding: 20px;
}
.custom-dialog-overlay.active { display: flex; }
.custom-dialog-box {
  background: var(--bg-panel); border: 1px solid var(--primary);
  border-radius: 16px; padding: 28px; min-width: 340px; max-width: 92vw;
  box-shadow: 0 30px 90px rgba(0,0,0,0.7), 0 0 50px rgba(59,130,246,0.2);
  animation: dlgIn 0.3s cubic-bezier(0.68,-0.55,0.265,1.55);
  max-height: 88vh; overflow-y: auto;
}
@keyframes dlgIn { 0%{opacity:0;transform:scale(0.78) translateY(-30px)} 60%{transform:scale(1.05)} 100%{opacity:1;transform:scale(1) translateY(0)} }
.dialog-title { font-size: 1.2rem; font-weight: 700; margin-bottom: 18px; color: var(--text-main); display: flex; align-items: center; gap: 10px; padding-bottom: 14px; border-bottom: 1px solid var(--border); }
.dialog-title i { color: var(--primary); font-size: 1.4rem; }
.dialog-content { margin: 16px 0; color: var(--text-main); line-height: 1.6; word-break: break-word; overflow-wrap: break-word; }
.dialog-input, .dialog-textarea, .dialog-select {
  width: 100%; padding: 10px 12px; border-radius: 8px;
  background: var(--bg-dark); color: var(--text-main);
  border: 2px solid var(--border); font-size: 0.92rem;
  margin-bottom: 12px; font-family: inherit; transition: border-color 0.25s, box-shadow 0.25s;
}
.dialog-input:focus, .dialog-textarea:focus, .dialog-select:focus {
  border-color: var(--primary); box-shadow: 0 0 0 3px rgba(59,130,246,0.15); outline: none;
}
.dialog-textarea { min-height: 80px; resize: vertical; font-family: 'JetBrains Mono', monospace; }
.dialog-actions { display: flex; gap: 10px; justify-content: flex-end; padding-top: 18px; border-top: 1px solid var(--border); flex-wrap: wrap; }
.dialog-label { font-size: 0.82rem; color: var(--text-muted); margin-bottom: 6px; display: block; }
/* Dialog box — ensure it never clips content */
.custom-dialog-box { word-break: break-word; overflow-wrap: break-word; }

/* ─── TOAST ───────────────────────────────────────────────────── */
.toast {
  position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%) translateY(80px);
  background: #27272a; border: 1px solid #3f3f46; color: #fff;
  padding: 8px 16px; border-radius: 8px; font-size: 0.83rem;
  z-index: 99999; display: flex; align-items: center; gap: 8px;
  transition: transform 0.3s, opacity 0.3s; opacity: 0; pointer-events: none;
  box-shadow: 0 4px 20px rgba(0,0,0,0.6); white-space: nowrap; max-width: 90vw;
}
@media (max-width: 768px) {
  .toast {
    bottom: calc(var(--plugin-footer-h) + 12px);
  }
}
.toast.show { transform: translateX(-50%) translateY(0); opacity: 1; }
.toast.success i { color: var(--success); }
.toast.error   i { color: var(--error); }
.toast.warn    i { color: var(--warn); }
.toast.info    i { color: var(--primary); }

/* ─── TEMPLATE GRID ───────────────────────────────────────────── */
.template-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px; margin: 16px 0; max-height: 460px; overflow-y: auto;
}
.template-card {
  padding: 14px; border: 2px solid var(--border); border-radius: 12px;
  cursor: pointer; transition: all 0.25s; background: var(--bg-dark);
}
.template-card:hover { border-color: var(--primary); transform: translateY(-3px); box-shadow: 0 8px 24px rgba(59,130,246,0.2); }
.tc-header { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; font-weight: 700; font-size: 0.92rem; }
.tc-icon { width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; border-radius: 7px; font-size: 1.1rem; }
.tc-desc { font-size: 0.76rem; color: var(--text-muted); line-height: 1.5; }
.tc-badge { font-size: 0.65rem; padding: 1px 5px; border-radius: 3px; margin-left: auto; }
.tc-badge.new { background: rgba(74,222,128,0.15); color: var(--success); border: 1px solid rgba(74,222,128,0.3); }

/* ─── SELECTION LIST ──────────────────────────────────────────── */
.selection-list { max-height: 320px; overflow-y: auto; border: 1px solid var(--border); border-radius: 8px; background: var(--bg-dark); margin: 12px 0; }
.selection-item { padding: 10px 14px; display: flex; align-items: center; gap: 12px; border-bottom: 1px solid var(--border); cursor: pointer; transition: background 0.15s; }
.selection-item:hover { background: rgba(59,130,246,0.08); }
.selection-item:last-child { border-bottom: none; }
.selection-item input[type="checkbox"] { width: 18px; height: 18px; cursor: pointer; accent-color: var(--primary); }
.selection-item-name { font-size: 0.85rem; color: var(--text-main); }
.selection-item-size { font-size: 0.72rem; color: var(--text-muted); margin-left: auto; }

/* ─── LANG BADGES ─────────────────────────────────────────────── */
.lang-badge { font-size: 0.63rem; padding: 1px 5px; border-radius: 3px; border: 1px solid; white-space: nowrap; }
.lang-badge.new  { background: rgba(74,222,128,0.15); color: var(--success); border-color: rgba(74,222,128,0.3); }

/* ─── BOOT OVERLAY ────────────────────────────────────────────── */
#bootOverlay {
  position: fixed; inset: 0; z-index: 99999; background: #000;
  display: flex; align-items: center; justify-content: center;
  flex-direction: column; gap: 24px; transition: opacity 0.5s;
}
#bootOverlay.hidden { opacity: 0; pointer-events: none; }
.boot-logo { font-size: 2rem; font-weight: 800; color: var(--primary); display: flex; align-items: center; gap: 12px; letter-spacing: -1px; }
.boot-logo i { font-size: 2.4rem; }
.boot-status { color: var(--text-muted); font-size: 0.85rem; font-family: 'JetBrains Mono', monospace; min-height: 1.4em; text-align: center; }
.boot-progress-track { width: min(380px, 88vw); height: 4px; background: #1a1a1a; border-radius: 2px; overflow: hidden; }
.boot-progress-fill {
  height: 100%; width: 0%; border-radius: 2px;
  background: linear-gradient(90deg, #3b82f6, #8b5cf6);
  transition: width 0.4s cubic-bezier(0.4,0,0.2,1);
}
.boot-steps { display: flex; flex-direction: column; gap: 6px; width: min(380px, 88vw); }
.boot-step { display: flex; align-items: center; gap: 10px; font-size: 0.78rem; color: #444; font-family: monospace; transition: color 0.3s; }
.boot-step.done   { color: var(--success); }
.boot-step.active { color: var(--text-main); }
.boot-step.error  { color: var(--error); }
.boot-step-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; flex-shrink: 0; }
.boot-step.active .boot-step-dot { animation: wc-pulse 1s infinite; }
/* Boot animated brackets */
.boot-brackets { display: flex; gap: 8px; font-family: monospace; font-size: 1.1rem; }
.boot-bracket { color: #333; transition: color 0.3s; padding: 4px 8px; border: 1px solid #222; border-radius: 4px; min-width: 32px; text-align: center; }
.boot-bracket.loading { color: var(--warn); border-color: var(--warn); animation: wc-pulse 0.8s infinite; }
.boot-bracket.done    { color: var(--success); border-color: var(--success); }
.boot-bracket.error   { color: var(--error); border-color: var(--error); }
.boot-warning {
  background: rgba(251,191,36,0.08); border: 1px solid rgba(251,191,36,0.3);
  border-radius: 8px; padding: 12px 16px; width: min(380px, 88vw);
  font-size: 0.78rem; color: var(--warn); line-height: 1.7; display: none;
}
.boot-warning.show { display: block; }
.boot-warning code { background: rgba(0,0,0,0.4); padding: 1px 5px; border-radius: 3px; font-family: monospace; }

/* ─── IDB SYNC INDICATOR ──────────────────────────────────────── */
.idb-sync-indicator {
  position: fixed; top: 56px; right: 10px; z-index: 200;
  display: flex; align-items: center; gap: 5px;
  background: rgba(0,0,0,0.85); border: 1px solid var(--border);
  padding: 3px 9px; border-radius: 12px; font-size: 0.68rem;
  color: var(--text-muted); pointer-events: none; opacity: 0; transition: opacity 0.4s;
}
.idb-sync-indicator.show { opacity: 1; }
.idb-sync-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--success); }
.idb-sync-indicator.syncing .idb-sync-dot { background: var(--warn); animation: wc-pulse 0.7s infinite; }

/* ─── PWA BANNER ──────────────────────────────────────────────── */
#pwaBanner {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 500;
  background: linear-gradient(135deg, #18181b 0%, #1f1f2e 100%);
  border-top: 1px solid var(--primary); padding: 14px 20px;
  display: flex; align-items: center; gap: 14px;
  transform: translateY(100%); transition: transform 0.4s cubic-bezier(0.34,1.56,0.64,1);
}
#pwaBanner.show { transform: translateY(0); }
.pwa-banner-icon { width: 40px; height: 40px; border-radius: 10px; overflow: hidden; font-size: 2rem; flex-shrink: 0; }
.pwa-banner-text { flex: 1; }
.pwa-banner-title { font-weight: 700; font-size: 0.9rem; color: var(--text-main); }
.pwa-banner-sub   { font-size: 0.75rem; color: var(--text-muted); margin-top: 2px; }
.pwa-banner-btns  { display: flex; gap: 8px; flex-shrink: 0; }

/* ─── DEEP INTELLIGENCE SYSTEM (DIS) ───────────────────────────── */
.cm-tooltip-autocomplete {
  border: 1px solid #3b82f6 !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.8), 0 0 20px rgba(59,130,246,0.15) !important;
  background: #1a1a1f !important;
  border-radius: 8px !important;
  max-height: 320px !important;
  min-width: 260px !important;
}
.cm-tooltip-autocomplete ul { padding: 4px 0 !important; }
.cm-tooltip-autocomplete ul li { padding: 5px 10px 5px 8px !important; font-size: 0.81rem !important; display: flex !important; align-items: center !important; gap: 7px !important; border-radius: 0 !important; }
.cm-tooltip-autocomplete ul li[aria-selected] { background: rgba(59,130,246,0.25) !important; }
.cm-tooltip-autocomplete ul li:hover { background: rgba(255,255,255,0.07) !important; }
.cm-completionLabel { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cm-completionDetail { font-size: 0.72rem !important; color: #6b7280 !important; margin-left: 6px !important; font-style: italic !important; }
.cm-completionIcon { width: 18px !important; height: 18px !important; flex-shrink: 0 !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; border-radius: 3px !important; font-size: 0.68rem !important; font-weight: 700 !important; }
.cm-completionIcon-function::after { content: 'ƒ'; color: #60a5fa; background: rgba(96,165,250,0.12); padding: 1px 3px; border-radius: 3px; }
.cm-completionIcon-variable::after { content: '●'; color: #4ade80; }
.cm-completionIcon-class::after    { content: 'C'; color: #f59e0b; background: rgba(245,158,11,0.12); padding: 1px 3px; border-radius: 3px; }
.cm-completionIcon-keyword::after  { content: 'K'; color: #f87171; background: rgba(248,113,113,0.12); padding: 1px 3px; border-radius: 3px; }
.cm-completionIcon-property::after { content: '◈'; color: #34d399; }
.cm-completionIcon-method::after   { content: 'M'; color: #a78bfa; background: rgba(167,139,250,0.12); padding: 1px 3px; border-radius: 3px; }
.cm-completionIcon-interface::after{ content: 'I'; color: #38bdf8; background: rgba(56,189,248,0.12); padding: 1px 3px; border-radius: 3px; }
.cm-completionIcon-type::after     { content: 'T'; color: #fb923c; background: rgba(251,146,60,0.12); padding: 1px 3px; border-radius: 3px; }
.cm-completionIcon-constant::after { content: 'c'; color: #f472b6; background: rgba(244,114,182,0.12); padding: 1px 3px; border-radius: 3px; }
.cm-completionIcon-enum::after     { content: 'E'; color: #a3e635; background: rgba(163,230,53,0.12); padding: 1px 3px; border-radius: 3px; }
/* Signature Help / Hover Tooltip */
.beyo-sig-help {
  position: fixed; z-index: 9000;
  background: #1a1a1f; border: 1px solid #3b82f6;
  border-radius: 7px; padding: 8px 12px;
  font-family: 'JetBrains Mono', monospace; font-size: 0.78rem;
  color: #e2e8f0; box-shadow: 0 6px 24px rgba(0,0,0,0.7);
  max-width: 420px; line-height: 1.6; pointer-events: none;
  display: none;
}
.beyo-sig-help.show { display: block; }
.beyo-sig-name { color: #60a5fa; font-weight: 700; }
.beyo-sig-param { color: #fbbf24; }
.beyo-sig-param.active { color: #f87171; text-decoration: underline; }
.beyo-sig-doc { font-size: 0.73rem; color: #6b7280; margin-top: 4px; font-family: sans-serif; }
.beyo-hover-doc {
  position: fixed; z-index: 8999;
  background: #1a1a1f; border: 1px solid var(--border);
  border-radius: 7px; padding: 10px 14px;
  font-size: 0.79rem; color: #e2e8f0;
  box-shadow: 0 6px 24px rgba(0,0,0,0.7);
  max-width: 380px; line-height: 1.6; pointer-events: none;
  display: none;
}
.beyo-hover-doc.show { display: block; }
.beyo-hover-type { color: #60a5fa; font-family: 'JetBrains Mono', monospace; font-size: 0.76rem; margin-bottom: 4px; }
.beyo-hover-desc { color: #9ca3af; font-family: sans-serif; }
/* ─── DEBUGGER PANEL ──────────────────────────────────────────── */
#debuggerPanel {
  display: flex; flex-direction: column; height: 100%;
  background: #0d0d0d; overflow: hidden;
}
.dbg-toolbar {
  display: flex; align-items: center; gap: 4px;
  padding: 5px 8px; border-bottom: 1px solid var(--border);
  background: var(--bg-panel); flex-shrink: 0; flex-wrap: wrap;
}
.dbg-btn {
  padding: 4px 8px; border-radius: 4px; border: 1px solid var(--border);
  background: #27272a; color: var(--text-main); font-size: 0.73rem;
  cursor: pointer; display: flex; align-items: center; gap: 4px;
  transition: 0.15s; white-space: nowrap; font-family: 'JetBrains Mono', monospace;
}
.dbg-btn:hover { background: #3f3f46; border-color: var(--primary); }
.dbg-btn.active { background: rgba(59,130,246,0.2); border-color: var(--primary); color: var(--primary); }
.dbg-btn.green  { color: #4ade80; border-color: rgba(74,222,128,0.3); }
.dbg-btn.green:hover { background: rgba(74,222,128,0.15); border-color: #4ade80; }
.dbg-btn.red    { color: #f87171; border-color: rgba(248,113,113,0.3); }
.dbg-btn.red:hover { background: rgba(248,113,113,0.15); }
.dbg-btn.orange { color: #fb923c; border-color: rgba(251,146,60,0.3); }
.dbg-btn:disabled { opacity: 0.38; cursor: not-allowed; pointer-events: none; }
.dbg-status {
  margin-left: auto; font-size: 0.72rem; color: var(--text-muted);
  font-family: 'JetBrains Mono', monospace; padding: 2px 8px;
  border-radius: 999px; border: 1px solid var(--border); white-space: nowrap;
}
.dbg-status.paused { color: #fbbf24; border-color: rgba(251,191,36,0.4); background: rgba(251,191,36,0.08); }
.dbg-status.running { color: #4ade80; border-color: rgba(74,222,128,0.4); background: rgba(74,222,128,0.08); animation: dbgPulse 1.2s ease infinite; }
.dbg-status.stopped { color: #f87171; border-color: rgba(248,113,113,0.4); background: rgba(248,113,113,0.08); }
@keyframes dbgPulse { 0%,100%{opacity:1} 50%{opacity:0.5} }
.dbg-body {
  display: flex; flex: 1; overflow: hidden; min-height: 0;
}
.dbg-left {
  flex: 1; display: flex; flex-direction: column; overflow: hidden; border-right: 1px solid var(--border);
}
.dbg-right {
  width: 220px; flex-shrink: 0; display: flex; flex-direction: column; overflow: hidden;
}
@media (max-width: 768px) { .dbg-right { display: none; } }
.dbg-section-header {
  padding: 4px 10px; font-size: 0.68rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.5px; color: var(--text-muted); border-bottom: 1px solid var(--border);
  background: var(--bg-panel); display: flex; align-items: center; gap: 6px; flex-shrink: 0;
}
.dbg-section-header i { color: var(--primary); }
.dbg-output {
  flex: 1; overflow-y: auto; padding: 6px 8px;
  font-family: 'JetBrains Mono', monospace; font-size: 0.78rem; line-height: 1.6;
  color: #c0c0c0;
}
.dbg-output::-webkit-scrollbar { width: 4px; }
.dbg-output::-webkit-scrollbar-thumb { background: #333; border-radius: 2px; }
.dbg-entry { padding: 2px 0; border-bottom: 1px solid rgba(255,255,255,0.04); display: flex; gap: 8px; }
.dbg-entry .dbg-ln { color: #555; min-width: 32px; flex-shrink: 0; user-select: none; }
.dbg-entry.dbg-hit { background: rgba(251,191,36,0.08); border-left: 2px solid #fbbf24; padding-left: 4px; }
.dbg-entry.dbg-err { color: #f87171; }
.dbg-entry.dbg-info { color: #60a5fa; }
.dbg-entry.dbg-warn { color: #fbbf24; }
.dbg-vars { flex: 1; overflow-y: auto; }
.dbg-vars::-webkit-scrollbar { width: 3px; }
.dbg-vars::-webkit-scrollbar-thumb { background: #333; }
.dbg-var-item {
  padding: 4px 10px; font-size: 0.75rem; border-bottom: 1px solid rgba(255,255,255,0.04);
  display: flex; align-items: flex-start; gap: 6px; font-family: 'JetBrains Mono', monospace;
}
.dbg-var-item:hover { background: rgba(255,255,255,0.03); }
.dbg-var-name { color: #60a5fa; min-width: 70px; flex-shrink: 0; overflow: hidden; text-overflow: ellipsis; }
.dbg-var-val  { color: #4ade80; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dbg-var-type { color: #6b7280; font-size: 0.68rem; }
.dbg-callstack { flex: 1; overflow-y: auto; max-height: 130px; }
.dbg-stack-frame {
  padding: 5px 10px; font-size: 0.73rem; border-bottom: 1px solid rgba(255,255,255,0.04);
  cursor: pointer; transition: background 0.12s; display: flex; align-items: center; gap: 6px;
  font-family: 'JetBrains Mono', monospace; color: var(--text-muted);
}
.dbg-stack-frame:hover { background: rgba(59,130,246,0.08); color: #fff; }
.dbg-stack-frame.active { background: rgba(59,130,246,0.14); color: var(--primary); }
.dbg-stack-frame i { font-size: 0.85rem; }
.dbg-watch-input {
  width: 100%; padding: 4px 8px; background: #000; border: 1px solid var(--border);
  border-radius: 4px; color: #fff; font-size: 0.76rem; font-family: 'JetBrains Mono', monospace;
  margin: 6px 8px; width: calc(100% - 16px);
}
.dbg-watch-input:focus { border-color: var(--primary); outline: none; }
.dbg-breakpoints-list { flex: 1; overflow-y: auto; max-height: 100px; }
.dbg-bp-item {
  padding: 4px 10px; font-size: 0.73rem; display: flex; align-items: center; gap: 6px;
  border-bottom: 1px solid rgba(255,255,255,0.04); font-family: 'JetBrains Mono', monospace;
  cursor: pointer; transition: background 0.12s;
}
.dbg-bp-item:hover { background: rgba(248,113,113,0.08); }
.dbg-bp-dot { width: 8px; height: 8px; border-radius: 50%; background: #f87171; flex-shrink: 0; }
.dbg-bp-dot.disabled { background: #555; }
.dbg-bp-file { color: var(--text-muted); flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 0.7rem; }
.dbg-bp-line { color: #fbbf24; margin-left: auto; }
/* Breakpoint gutter marker */
.cm-breakpoint-gutter { width: 14px; }
.cm-breakpoint-marker {
  width: 10px; height: 10px; border-radius: 50%; background: #f87171;
  display: inline-block; cursor: pointer; margin: 2px 2px 0 2px;
  box-shadow: 0 0 6px rgba(248,113,113,0.6);
}
.cm-breakpoint-marker.disabled { background: #555; box-shadow: none; }
/* Debug highlight line */
.cm-debugLine { background: rgba(251,191,36,0.1) !important; }
.cm-debugLine .cm-line { background: rgba(251,191,36,0.1) !important; }


/* ─── DIS STATUS BADGE ──────────────────────────────────────── */
#disBadge {
  position: fixed; bottom: calc(var(--plugin-footer-h, 44px) + 8px); right: 10px;
  z-index: 500; display: flex; align-items: center; gap: 5px;
  background: rgba(9,9,11,0.90); border: 1px solid rgba(59,130,246,0.45);
  padding: 3px 9px 3px 7px; border-radius: 999px; font-size: 0.68rem;
  color: var(--primary); pointer-events: none;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  transition: opacity 0.3s, transform 0.3s;
  opacity: 0; transform: translateY(6px);
}
#disBadge.show { opacity: 1; transform: translateY(0); }
#disBadge.dis-off { color: #555; border-color: rgba(255,255,255,0.12); }
#disBadge .dis-dot {
  width: 5px; height: 5px; border-radius: 50%; background: var(--primary);
  flex-shrink: 0; animation: disPulse 2s ease infinite;
}
#disBadge.dis-off .dis-dot { background: #555; animation: none; }
@keyframes disPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.5;transform:scale(0.7)} }

/* ─── DIS AUTOCOMPLETE POPUP IMPROVEMENTS ──────────────────── */
.cm-tooltip-autocomplete {
  border: 1px solid rgba(59,130,246,0.7) !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.85), 0 0 0 1px rgba(59,130,246,0.08) !important;
  background: #13131a !important;
  border-radius: 10px !important;
  max-height: 380px !important;
  min-width: 320px !important;
  overflow: hidden !important;
  animation: acPopIn 0.12s cubic-bezier(0.16,1,0.3,1) !important;
}
@keyframes acPopIn {
  from { opacity:0; transform:translateY(-4px) scale(0.98); }
  to   { opacity:1; transform:translateY(0) scale(1); }
}
.cm-tooltip-autocomplete ul { padding: 4px !important; margin: 0 !important; }
.cm-tooltip-autocomplete ul li {
  padding: 6px 10px 6px 8px !important; font-size: 0.8rem !important;
  display: flex !important; align-items: center !important; gap: 7px !important;
  border-radius: 6px !important; margin: 1px 0 !important; transition: background 0.1s !important;
  line-height: 1.4 !important;
}
.cm-tooltip-autocomplete ul li[aria-selected] {
  background: rgba(59,130,246,0.22) !important;
  outline: 1px solid rgba(59,130,246,0.35) !important;
}
.cm-tooltip-autocomplete ul li:hover { background: rgba(255,255,255,0.06) !important; }
/* completion type label pill */
.cm-completionLabel { flex: 1 !important; }
.cm-completionDetail {
  color: #4b5563 !important; font-size: 0.72rem !important;
  font-family: 'JetBrains Mono', monospace !important;
  max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
/* Colour the type icons */
.cm-completionIcon-function::after  { content: 'ƒ'; color: #60a5fa; font-weight: 700; font-size:0.85rem; }
.cm-completionIcon-keyword::after   { content: 'k'; color: #c084fc; font-weight: 700; font-size:0.85rem; }
.cm-completionIcon-class::after     { content: 'C'; color: #fbbf24; font-weight: 700; font-size:0.85rem; }
.cm-completionIcon-method::after    { content: 'm'; color: #4ade80; font-weight: 700; font-size:0.85rem; }
.cm-completionIcon-property::after  { content: '◆'; color: #f472b6; font-size:0.75rem; }
.cm-completionIcon-variable::after  { content: 'v'; color: #34d399; font-weight: 700; font-size:0.85rem; }
.cm-completionIcon-constant::after  { content: '●'; color: #fb923c; font-size:0.75rem; }
.cm-completionIcon-interface::after { content: 'I'; color: #38bdf8; font-weight: 700; font-size:0.85rem; }
/* completion info panel */
.cm-tooltip.cm-completionInfo {
  background: #1a1a24 !important;
  border: 1px solid rgba(59,130,246,0.35) !important;
  border-radius: 8px !important;
  padding: 2px !important;
  max-width: 380px !important;
  font-size: 0.78rem !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.7) !important;
}

/* ─── SNIPPET MANAGER SCROLLBAR ────────────────────────────── */
#snipList::-webkit-scrollbar { width: 4px; }
#snipList::-webkit-scrollbar-thumb { background: #333; border-radius: 2px; }
#snipList::-webkit-scrollbar-track { background: transparent; }

/* ─── ENHANCED HOVER DOC ─────────────────────────────────────── */
.beyo-hover-doc {
  background: #1a1a24 !important; border: 1px solid rgba(59,130,246,0.4) !important;
  border-radius: 8px !important; backdrop-filter: blur(4px) !important;
}
.beyo-hover-type {
  color: #60a5fa !important;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  padding-bottom: 5px; margin-bottom: 5px;
  white-space: pre-wrap; word-break: break-all;
}

/* ─── TAILWIND BADGE IN COMPLETIONS ─────────────────────────── */
.tw-badge {
  font-size: 0.6rem; padding: 1px 5px; border-radius: 3px;
  background: rgba(56,189,248,0.15); color: #38bdf8;
  border: 1px solid rgba(56,189,248,0.3); margin-left: 4px;
  font-family: monospace;
}

/* ─── COMPLETION INFO PANEL ──────────────────────────────────── */
.cm-tooltip.cm-completionInfo {
  background: #1a1a24 !important;
  border: 1px solid rgba(59,130,246,0.35) !important;
  border-radius: 8px !important;
  max-width: 380px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.7) !important;
}

/* ─── DIS SIGNATURE HELP — mobile-safe ─────────────────────── */
.beyo-sig-help {
  max-width: min(380px, 92vw) !important;
  font-size: 0.76rem !important;
}

/* ─── MOBILE DEBUGGER ACCORDION ────────────────────────────── */
.dbg-mobile-tabs {
  display: none; gap: 0; border-bottom: 1px solid var(--border);
  background: var(--bg-panel); overflow-x: auto; flex-shrink: 0;
  scrollbar-width: none;
}
.dbg-mobile-tabs::-webkit-scrollbar { display: none; }
.dbg-mobile-tab {
  padding: 6px 12px; font-size: 0.72rem; font-weight: 600; white-space: nowrap;
  color: var(--text-muted); cursor: pointer; border-bottom: 2px solid transparent;
  transition: 0.15s; display: flex; align-items: center; gap: 5px;
}
.dbg-mobile-tab.active { color: var(--primary); border-bottom-color: var(--primary); }
@media (max-width: 768px) {
  .dbg-mobile-tabs { display: flex; }
  .dbg-right { display: flex !important; width: 100% !important; flex-direction: column; }
  .dbg-body { flex-direction: column !important; }
  .dbg-left { border-right: none !important; border-bottom: 1px solid var(--border); max-height: 160px; }
  .dbg-mobile-section { display: none; }
  .dbg-mobile-section.active { display: flex !important; flex-direction: column; }
  .dbg-toolbar { flex-wrap: wrap; gap: 3px !important; }
  .dbg-btn span.dbg-btn-label { display: none; }
  .dbg-status { margin-left: 0; }
}

/* ─── SETTINGS DIS SECTION ──────────────────────────────────── */
.setting-section-title {
  font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px;
  color: var(--primary); padding: 10px 0 4px; margin-top: 4px;
  border-top: 1px solid var(--border); display: flex; align-items: center; gap: 6px;
}
.setting-section-title i { font-size: 0.85rem; }
.setting-sub { padding-left: 12px; border-left: 2px solid rgba(59,130,246,0.25); margin-left: 2px; }
.setting-sub .setting-item { padding: 7px 0; }
.setting-sub .setting-label { font-size: 0.82rem; color: var(--text-muted); }
.setting-sub .setting-label.active-lbl { color: var(--text-main); }

/* ─── DIS+ LSP HOVER TOOLTIP ─────────────────────────────────── */
.displus-lsp-hover {
  background: #13131f !important;
  border: 1px solid rgba(168,85,247,0.45) !important;
  border-radius: 10px !important;
  padding: 0 !important;
  max-width: min(480px, 92vw) !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.8), 0 0 24px rgba(168,85,247,0.12) !important;
  overflow: hidden !important;
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 0.8rem !important;
  pointer-events: auto !important;
}
.displus-lsp-hover-header {
  display: flex; align-items: center; gap: 7px;
  padding: 7px 12px 6px;
  background: rgba(168,85,247,0.07);
  border-bottom: 1px solid rgba(168,85,247,0.2);
  font-size: 0.68rem; font-weight: 700; color: #a78bfa; letter-spacing: 0.3px;
}
.displus-lsp-hover-type {
  padding: 8px 12px; color: #93c5fd;
  font-size: 0.78rem; white-space: pre-wrap; word-break: break-all;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.displus-lsp-hover-doc {
  padding: 7px 12px 9px;
  color: var(--text-muted); font-size: 0.75rem; line-height: 1.6;
  font-family: 'Segoe UI', system-ui, sans-serif;
}
.displus-lsp-hover-kind {
  display: inline-block; margin-left: 4px;
  padding: 1px 6px; border-radius: 999px; font-size: 0.63rem;
  background: rgba(59,130,246,0.15); color: #60a5fa;
  border: 1px solid rgba(59,130,246,0.3);
}
/* LSP diagnostic underlines */
.cm-lsp-error   { text-decoration: underline wavy #f87171 !important; }
.cm-lsp-warning { text-decoration: underline wavy #fbbf24 !important; }
.cm-lsp-hint    { text-decoration: underline dotted #a855f7 !important; }
/* DIS+ action links in tooltip */
.displus-lsp-actions {
  display: flex; gap: 6px; padding: 5px 12px 8px; flex-wrap: wrap;
}
.displus-lsp-action-btn {
  font-size: 0.68rem; padding: 2px 8px; border-radius: 5px; cursor: pointer;
  background: rgba(59,130,246,0.1); border: 1px solid rgba(59,130,246,0.3);
  color: #60a5fa; transition: background 0.15s;
}
.displus-lsp-action-btn:hover { background: rgba(59,130,246,0.22); }
/* DIS+ status sidebar pill in editor */
#disPlusEnginePill {
  position: fixed; top: 54px; right: 10px; z-index: 500;
  display: none; align-items: center; gap: 4px;
  padding: 2px 8px; border-radius: 999px; font-size: 0.63rem;
  font-family: 'JetBrains Mono', monospace; font-weight: 700;
  background: rgba(13,13,26,0.95); border: 1px solid rgba(168,85,247,0.4);
  color: #a78bfa; pointer-events: none;
  box-shadow: 0 2px 12px rgba(168,85,247,0.15);
}
#disPlusEnginePill.visible { display: flex; }
#disPlusEnginePill .pill-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: #a78bfa; animation: disPlusPulse 1.8s ease infinite;
}

/* ─── DIS+ (Deep Intelligence System Plus) ──────────────────── */
@keyframes disPlusGlow {
  0%,100%{box-shadow:0 0 8px rgba(168,85,247,0.3),0 0 16px rgba(59,130,246,0.15)}
  50%{box-shadow:0 0 14px rgba(249,115,22,0.35),0 0 28px rgba(168,85,247,0.2)}
}
@keyframes disPlusPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.5;transform:scale(0.6)} }
#disPlusBadge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 9px 3px 6px; border-radius: 999px;
  font-size: 0.65rem; font-weight: 800; letter-spacing: 0.2px;
  font-family: 'JetBrains Mono', monospace;
  background: linear-gradient(#13131a, #13131a) padding-box,
              linear-gradient(135deg, #a855f7 0%, #3b82f6 55%, #f97316 100%) border-box;
  border: 1px solid transparent;
  position: fixed; bottom: calc(var(--plugin-footer-h) + 46px); right: 10px;
  z-index: 9991; opacity: 0; transition: opacity 0.3s;
  pointer-events: none;
}
#disPlusBadge.show { opacity: 1; animation: disPlusGlow 2.5s ease infinite; }
#disPlusBadge .dp-text {
  background: linear-gradient(135deg, #a855f7 0%, #3b82f6 55%, #f97316 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
#disPlusBadge .dp-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: linear-gradient(135deg, #a855f7, #3b82f6, #f97316);
  animation: disPlusPulse 1.8s ease infinite; flex-shrink: 0;
}
.dis-plus-label {
  font-size: inherit; font-weight: 800; font-family: 'JetBrains Mono', monospace;
  background: linear-gradient(135deg, #a855f7 0%, #3b82f6 55%, #f97316 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  letter-spacing: -0.3px;
}
.displus-section-hdr {
  font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px;
  padding: 10px 0 4px; margin-top: 4px;
  border-top: 1px solid var(--border); display: flex; align-items: center; gap: 7px;
}
.displus-section-hdr .dp-section-txt {
  background: linear-gradient(135deg, #a855f7 0%, #3b82f6 55%, #f97316 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.displus-mode-row { display: flex; gap: 5px; margin: 6px 0 4px; }
.displus-mode-btn {
  flex: 1; padding: 7px 8px; border-radius: 7px; font-size: 0.73rem; font-weight: 600;
  border: 1px solid var(--border); background: var(--bg-dark); color: var(--text-muted);
  cursor: pointer; transition: all 0.15s; display: flex; align-items: center; justify-content: center; gap: 5px;
}
.displus-mode-btn.instant.active {
  background: rgba(59,130,246,0.1); border-color: #3b82f6; color: #93c5fd;
}
.displus-mode-btn.deep.active {
  background: linear-gradient(135deg,rgba(168,85,247,0.12),rgba(59,130,246,0.1),rgba(249,115,22,0.08));
  border-color: rgba(168,85,247,0.6); color: var(--text-main);
}
.displus-stat {
  font-size: 0.66rem; padding: 2px 8px; border-radius: 999px;
  display: inline-flex; align-items: center; gap: 4px; white-space: nowrap; flex-shrink: 0;
}
.displus-stat.ready  { color:#4ade80; background:rgba(74,222,128,0.08); border:1px solid rgba(74,222,128,0.3); }
.displus-stat.booting{ color:#fbbf24; background:rgba(251,191,36,0.08); border:1px solid rgba(251,191,36,0.3); animation:dbgPulse 1.2s ease infinite; }
.displus-stat.cdn    { color:#a855f7; background:rgba(168,85,247,0.08); border:1px solid rgba(168,85,247,0.3); }
.displus-stat.err    { color:#f87171; background:rgba(248,113,113,0.08); border:1px solid rgba(248,113,113,0.3); }
.displus-stat.off    { color:#555; background:transparent; border:1px solid rgba(255,255,255,0.1); }
.displus-sub { padding-left:12px; border-left:2px solid rgba(168,85,247,0.25); margin-left:2px; }
.displus-sub .setting-item { padding:7px 0; }
.displus-sub .setting-label { font-size:0.82rem; color:var(--text-muted); }

/* ─── CONSOLE COPY TOAST ──────────────────────────────────────── */
#consoleCopyToast {
  position: fixed; bottom: calc(var(--plugin-footer-h) + 56px); left: 50%;
  transform: translateX(-50%) translateY(10px);
  background: #27272a; color: #fff; padding: 6px 14px; border-radius: 6px;
  font-size: 0.78rem; z-index: 99999; pointer-events: none;
  border: 1px solid #3b82f6; opacity: 0; transition: opacity 0.2s, transform 0.2s;
  white-space: nowrap;
}
#consoleCopyToast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ─── CONSOLE ENTRY COPY FLASH ────────────────────────────────── */
@keyframes consoleCopyFlash {
  0%   { background: rgba(59,130,246,0.35); transform: scale(1.012); }
  60%  { background: rgba(74,222,128,0.18); }
  100% { background: transparent; transform: scale(1); }
}
.console-log-entry.copying { animation: consoleCopyFlash 0.55s ease forwards; }

/* Long-press ripple ring on console entry */
.console-log-entry {
  position: relative; overflow: hidden;
}
.console-log-entry.lp-active::after {
  content: ''; position: absolute; inset: 0;
  border: 2px solid rgba(59,130,246,0.5); border-radius: 3px;
  animation: lpRing 0.5s ease forwards; pointer-events: none;
}
@keyframes lpRing {
  0%  { opacity: 0; transform: scale(0.92); }
  50% { opacity: 1; transform: scale(1); }
  100%{ opacity: 0; }
}

/* ─── PLUGIN (i) INFO BUTTON ──────────────────────────────────── */
.plugin-info-btn {
  width: 26px; height: 26px; border-radius: 50%;
  border: 1.5px solid rgba(59,130,246,0.5);
  background: rgba(59,130,246,0.1); color: var(--primary);
  font-size: 0.72rem; font-weight: 700; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.18s; flex-shrink: 0; letter-spacing: 0;
  font-family: Georgia, serif; font-style: italic;
}
.plugin-info-btn:hover { background: var(--primary); color: #fff; border-color: var(--primary); transform: scale(1.1); }

/* ─── PLUGIN USAGE DIALOG ─────────────────────────────────────── */
.plugin-usage-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.8);
  backdrop-filter: blur(8px); z-index: 10100;
  display: none; align-items: center; justify-content: center; padding: 16px;
}
.plugin-usage-overlay.show { display: flex; }
.plugin-usage-dialog {
  background: var(--bg-panel); border: 1px solid var(--primary);
  border-radius: 14px; width: 100%; max-width: 500px;
  max-height: 88vh; overflow-y: auto;
  box-shadow: 0 24px 72px rgba(0,0,0,0.8), 0 0 40px rgba(59,130,246,0.15);
  animation: dlgIn 0.28s cubic-bezier(0.34,1.56,0.64,1);
}
.plugin-usage-header {
  padding: 18px 20px 14px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  background: linear-gradient(135deg,var(--bg-panel),var(--bg-dark));
  border-radius: 14px 14px 0 0;
}
.plugin-usage-title {
  font-size: 1.05rem; font-weight: 700; color: var(--text-main);
  display: flex; align-items: center; gap: 9px;
}
.plugin-usage-title i { color: var(--primary); font-size: 1.25rem; }
.plugin-usage-body { padding: 18px 20px; display: flex; flex-direction: column; gap: 16px; }
.plugin-usage-section {
  background: var(--bg-dark); border: 1px solid var(--border);
  border-radius: 10px; padding: 14px 16px;
}
.plugin-usage-section h4 {
  font-size: 0.82rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.5px; margin-bottom: 10px;
  display: flex; align-items: center; gap: 7px;
}
.plugin-usage-section h4 i { font-size: 0.95rem; }
.plugin-usage-section h4.mobile-h { color: #34d399; }
.plugin-usage-section h4.desktop-h { color: #60a5fa; }
.plugin-usage-section h4.api-h { color: #a78bfa; }
.plugin-usage-row {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 6px 0; border-bottom: 1px solid #1a1a1a; font-size: 0.82rem;
}
.plugin-usage-row:last-child { border-bottom: none; }
.plugin-usage-row .pug-icon { font-size: 1rem; flex-shrink: 0; margin-top: 1px; }
.plugin-usage-row .pug-text { color: var(--text-muted); line-height: 1.5; }
.plugin-usage-row .pug-text strong { color: var(--text-main); }
.plugin-usage-code {
  background: var(--bg-editor); border: 1px solid var(--border);
  border-radius: 6px; padding: 10px 12px; font-family: 'JetBrains Mono',monospace;
  font-size: 0.74rem; color: #86efac; line-height: 1.65; margin-top: 8px;
  overflow-x: auto; white-space: pre;
}
.plugin-usage-footer {
  padding: 14px 20px; border-top: 1px solid var(--border);
  display: flex; justify-content: flex-end;
  background: var(--bg-dark); border-radius: 0 0 14px 14px;
}

/* ─── MOBILE PLUGIN ITEM IMPROVEMENTS ────────────────────────── */
@media (max-width: 768px) {
  .plugin-item { padding: 14px 14px; gap: 10px; }
  .plugin-item-actions {
    gap: 6px; flex-wrap: wrap;
  }
  .plugin-action-btn {
    padding: 7px 10px; font-size: 0.78rem; min-height: 36px;
    touch-action: manipulation;
  }
  .plugin-fav-btn { width: 36px; height: 36px; min-height: 36px; font-size: 1.1rem; }
  .plugin-toggle { width: 48px; height: 26px; }
  .plugin-toggle::after { width: 20px; height: 20px; }
  .plugin-toggle.active::after { transform: translateX(22px); }
  /* Long-press active state */
  .plugin-item.lp-pressing {
    background: rgba(59,130,246,0.08);
    border-color: rgba(59,130,246,0.4);
    transition: background 0.15s, border-color 0.15s;
  }
}

/* ─── PLUGIN ITEM LONG-PRESS CONTEXT MENU (MOBILE) ───────────── */
.plugin-lp-menu {
  position: fixed; background: var(--bg-panel);
  border: 1px solid var(--border); border-radius: 10px;
  z-index: 10050; box-shadow: 0 12px 36px rgba(0,0,0,0.75);
  min-width: 180px; overflow: hidden; display: none;
  animation: ctxFadeIn 0.15s ease;
}
.plugin-lp-menu.show { display: block; }
.plugin-lp-item {
  padding: 11px 16px; font-size: 0.85rem; cursor: pointer;
  display: flex; align-items: center; gap: 10px;
  color: var(--text-main); transition: background 0.12s;
}
.plugin-lp-item:hover, .plugin-lp-item:active { background: rgba(59,130,246,0.1); }
.plugin-lp-item i { font-size: 1rem; color: var(--text-muted); width: 18px; text-align: center; }
.plugin-lp-item.danger { color: var(--error); }
.plugin-lp-item.danger i { color: var(--error); }
.plugin-lp-item.fav-active i { color: var(--warn); }
.plugin-lp-sep { height: 1px; background: var(--border); }

/* ─── STOP BUTTON ─────────────────────────────────────────────── */
#termStopBtn {
  display: none; padding: 3px 8px; border-radius: 4px; font-size: 11px;
  background: rgba(248,113,113,0.15); border: 1px solid var(--error);
  color: var(--error); cursor: pointer; align-items: center; gap: 4px;
}
#termStopBtn.active { display: flex; animation: wc-pulse 1.5s infinite; }
#termStopBtn:hover { background: rgba(248,113,113,0.35); }



/* ─── AUDIT LOG ───────────────────────────────────────────────── */
.audit-entry {
  display: flex; align-items: flex-start; gap: 8px;
  padding: 7px 10px; border-bottom: 1px solid #1a1a1a;
  font-family: monospace; font-size: 11px; cursor: pointer;
  transition: background 0.15s;
}
.audit-entry:hover { background: rgba(59,130,246,0.08); }
.audit-meta { color: #555; font-size: 10px; white-space: nowrap; }
.audit-path { color: var(--primary); font-weight: 600; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.audit-preview { color: #777; font-size: 10px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 200px; }
.audit-toolbar { display: flex; gap: 6px; padding: 6px 10px; border-bottom: 1px solid var(--border); background: #000; flex-shrink: 0; flex-wrap: wrap; align-items: center; }
.audit-empty { color: #555; font-size: 0.82rem; padding: 20px; text-align: center; }

/* ─── OPTIMIZATION PANEL ─────────────────────────────────────── */
.opt-panel {
  position: absolute; bottom: 0; right: 0; width: min(310px, 96vw);
  max-height: 420px; background: var(--bg-panel); border: 1px solid var(--border);
  border-radius: 10px 10px 0 0; z-index: 60; display: flex; flex-direction: column;
  transform: translateY(100%); transition: transform 0.3s;
  box-shadow: 0 -8px 32px rgba(0,0,0,0.6);
}
.opt-panel.open { transform: translateY(0); }
.opt-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; border-bottom: 1px solid var(--border); background: #000; border-radius: 10px 10px 0 0; }
.opt-header-title { font-size: 0.85rem; font-weight: 700; display: flex; align-items: center; gap: 6px; }
.opt-body { flex: 1; overflow-y: auto; padding: 12px 14px; display: flex; flex-direction: column; gap: 12px; }
.opt-item { display: flex; flex-direction: column; gap: 5px; }
.opt-label { font-size: 0.78rem; color: var(--text-muted); display: flex; justify-content: space-between; align-items: center; }
.opt-label span { color: var(--text-main); font-weight: 600; }
.opt-bar-track { height: 7px; background: #1a1a1a; border-radius: 4px; overflow: hidden; }
.opt-bar-fill { height: 100%; border-radius: 4px; transition: width 0.6s, background 0.4s; }
.opt-bar-fill.low  { background: var(--success); }
.opt-bar-fill.mid  { background: var(--warn); }
.opt-bar-fill.high { background: var(--error); animation: wc-pulse 1.2s infinite; }
.opt-slider { width: 100%; accent-color: var(--primary); cursor: pointer; margin-top: 2px; }
.opt-divider { height: 1px; background: var(--border); }
.wc-limit-alert {
  display: none; position: fixed; top: 58px; left: 50%; transform: translateX(-50%);
  background: rgba(248,113,113,0.18); border: 1px solid var(--error);
  color: #fca5a5; padding: 8px 18px; border-radius: 8px;
  font-size: 0.83rem; z-index: 99998; align-items: center; gap: 8px;
  pointer-events: none; white-space: nowrap; max-width: 90vw;
  box-shadow: 0 4px 20px rgba(0,0,0,0.5);
}
.wc-limit-alert.show { display: flex; animation: wc-pulse 2s infinite; }

/* ─── STACKED MOBILE FIX ─────────────────────────────────────── */
@media (max-width: 768px) {
  body.layout-stacked .bottom-panel { height: 44vh !important; transform: translateY(0) !important; }
  body.layout-stacked #secondaryPane { display: none !important; }
  body.layout-stacked #splitContainer { flex-direction: column; }
}

/* ─── COMPREHENSIVE MOBILE UI OVERHAUL ───────────────────────── */
@media (max-width: 768px) {
  /* --- Header: clamp height, make toolbar scroll --- */
  header {
    height: 48px; padding: 0 8px;
    position: relative; z-index: 20;
  }
  .logo span { display: none; }
  .logo { gap: 5px; min-width: 0; flex-shrink: 0; }

  /* Toolbar: scrollable horizontal strip, Run button always visible */
  .toolbar {
    gap: 2px;
    max-width: calc(100vw - 90px);
    flex-shrink: 1;
  }
  .toolbar button.icon-btn {
    padding: 8px 7px; font-size: 1rem; flex-shrink: 0;
  }
  .toolbar button:not(.icon-btn):not(.primary) {
    padding: 5px 8px; font-size: 0.75rem; flex-shrink: 0;
  }
  .toolbar button.primary {
    padding: 6px 12px; font-size: 0.8rem; flex-shrink: 0;
    border-radius: 4px;
  }
  .split-toggle-group { display: none; }

  /* --- Sidebar: drawer overlay --- */
  .sidebar {
    position: absolute; height: 100%; width: min(290px, 85vw);
    transform: translateX(-100%); box-shadow: 10px 0 30px rgba(0,0,0,0.6);
  }
  .sidebar.show { transform: translateX(0); }

  /* --- Bottom panel: taller on mobile --- */
  .bottom-panel { height: 48vh; }

  /* --- Panel header: scrollable nowrap --- */
  .panel-header-left {
    gap: 2px;
  }
  .bottom-tab-btn {
    padding: 5px 9px; font-size: 0.73rem; white-space: nowrap; flex-shrink: 0;
  }
  .panel-plugin-btn { font-size: 0.7rem; padding: 3px 7px; flex-shrink: 0; }
  .panel-plugin-btn span { display: none; }

  /* Panel right-side action buttons: tighten up */
  .panel-header-right button.icon-btn { padding: 6px; font-size: 0.9rem; }
  #termStopBtn { font-size: 10px; padding: 2px 6px; }
  button#termStopBtn { flex-shrink: 0; }

  /* Hide less-critical panel buttons on very narrow screens */
  @media (max-width: 480px) {
    #bottomPanel .panel-header-left .icon-btn[title="Set Python STDIN"],
    #bottomPanel .panel-header-left .icon-btn[title="Optimization"],
    #bottomPanel .panel-header-left .icon-btn[title="Download Log"] {
      display: none;
    }
  }

  /* --- Tab bar: compact --- */
  .tab { min-width: 90px; max-width: 140px; font-size: 0.75rem; padding: 0 8px; }
  button.icon-btn { padding: 10px; }
  .tree-node { padding: 8px 10px; }

  /* --- Bottom panel close btn --- */
  .panel-close-btn { flex-shrink: 0; }

  /* --- Misc --- */
  .bottom-panel { height: 48vh; }
  .template-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
  .mobile-dock { display: flex; }
  body { padding-bottom: 0; }
  button.icon-btn { padding: 10px; }
  .boot-warning { width: 92vw; }
  .minimap-wrap { display:none !important; }
  .minimap-wrap.mobile-open {
    display: block !important; top: 38px; right: 6px; left: 6px; width: auto; bottom: 8px;
    background: rgba(9,9,11,0.98); z-index: 140; border-color: #334155;
  }

  /* --- Plugin footer on mobile --- */
  .plugin-footer-bar { height: 40px; padding: 0 4px; }
  .plugin-footer-label { display: none; }
  .plugin-footer-chip { padding: 4px 8px; font-size: 0.7rem; }
  .plugin-footer-chip .chip-name { max-width: 56px; }
  .plugin-footer-open { padding: 4px 8px; font-size: 0.7rem; }
  .plugin-footer-open span { display: none; }

  /* --- Mobile dock: above footer bar --- */
  .mobile-dock {
    bottom: calc(var(--plugin-footer-h) + max(8px, env(safe-area-inset-bottom)));
  }

  /* --- Focus mode overlay: make double-tap area cover editor --- */
  #focusModeExitHint {
    display: none;
    position: fixed; bottom: calc(var(--plugin-footer-h) + 10px); left: 50%;
    transform: translateX(-50%);
    background: rgba(0,0,0,0.7); border: 1px solid var(--border);
    color: var(--text-muted); font-size: 0.72rem;
    padding: 5px 12px; border-radius: 20px; z-index: 9998;
    pointer-events: none; white-space: nowrap;
  }
  body.focus-mode-active #focusModeExitHint { display: block; }
}

/* ─── PLUGIN FOOTER BAR ──────────────────────────────────────── */
.plugin-footer-bar {
  height: var(--plugin-footer-h);
  background: var(--bg-panel);
  border-top: 1px solid var(--border);
  display: flex; align-items: center; flex-shrink: 0;
  overflow-y: hidden; overflow-x: hidden; z-index: 30;
  padding: 0 6px; gap: 4px;
  position: relative;
}
.plugin-footer-label {
  font-size: 0.65rem; font-weight: 700; letter-spacing: 0.5px;
  color: #444; text-transform: uppercase; white-space: nowrap;
  padding: 0 8px 0 4px; border-right: 1px solid var(--border);
  flex-shrink: 0; display: flex; align-items: center; gap: 4px;
}
.plugin-footer-scroll {
  flex: 1; display: flex; align-items: center;
  overflow-x: auto; overflow-y: hidden; gap: 6px;
  padding: 4px 2px; scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}
.plugin-footer-scroll::-webkit-scrollbar { display: none; }
.plugin-footer-chip {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 10px; border-radius: 999px; white-space: nowrap;
  background: rgba(255,255,255,0.04); border: 1px solid var(--border);
  color: var(--text-muted); font-size: 0.72rem; cursor: pointer;
  flex-shrink: 0; transition: all 0.18s; user-select: none;
  -webkit-tap-highlight-color: transparent; position: relative;
}
.plugin-footer-chip:hover { background: rgba(59,130,246,0.12); border-color: var(--primary); color: #fff; }
.plugin-footer-chip.is-active {
  background: rgba(59,130,246,0.15); border-color: var(--primary); color: #cfe0ff;
}
.plugin-footer-chip.is-fav {
  border-color: rgba(251,191,36,0.4); background: rgba(251,191,36,0.06);
}
.plugin-footer-chip.is-fav.is-active {
  border-color: var(--warn); background: rgba(251,191,36,0.14); color: var(--warn);
}
.plugin-footer-chip .chip-dot {
  width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0;
  background: var(--border); transition: background 0.2s;
}
.plugin-footer-chip.is-active .chip-dot { background: var(--success); animation: dot-pulse 2s infinite; }
@keyframes dot-pulse { 0%,100%{opacity:1} 50%{opacity:0.5} }
.plugin-footer-chip .chip-fav-star {
  font-size: 0.62rem; color: var(--warn); opacity: 0; transition: opacity 0.2s;
}
.plugin-footer-chip.is-fav .chip-fav-star { opacity: 1; }
.plugin-footer-chip .chip-icon { font-size: 0.9rem; line-height: 1; }
.plugin-footer-chip .chip-name { max-width: 80px; overflow: hidden; text-overflow: ellipsis; }

/* empty state */
.plugin-footer-empty {
  font-size: 0.72rem; color: #333; padding: 0 8px; white-space: nowrap;
  display: flex; align-items: center; gap: 6px;
}

/* open manager button */
.plugin-footer-open {
  display: flex; align-items: center; gap: 5px;
  padding: 4px 10px; border-radius: 999px; flex-shrink: 0;
  background: transparent; border: 1px solid var(--border);
  color: #444; font-size: 0.72rem; cursor: pointer;
  transition: all 0.18s; white-space: nowrap; margin-left: 2px;
}
.plugin-footer-open:hover { border-color: var(--primary); color: var(--primary); background: rgba(59,130,246,0.08); }
.plugin-footer-open i { font-size: 0.85rem; }

/* ─── CHIP CONTEXT MENU ──────────────────────────────────────── */
.chip-ctx-menu {
  position: fixed; background: var(--bg-panel);
  border: 1px solid var(--border); border-radius: 8px;
  z-index: 99990; box-shadow: 0 10px 32px rgba(0,0,0,0.7);
  min-width: 154px; overflow: hidden; display: none; animation: ctxFadeIn 0.15s ease;
}
@keyframes ctxFadeIn { from{opacity:0;transform:scale(0.95)} to{opacity:1;transform:scale(1)} }
.chip-ctx-menu.show { display: block; }
.chip-ctx-item {
  padding: 9px 14px; font-size: 0.8rem; cursor: pointer;
  display: flex; align-items: center; gap: 9px;
  color: var(--text-main); transition: background 0.12s;
}
.chip-ctx-item:hover { background: rgba(59,130,246,0.1); }
.chip-ctx-item i { font-size: 0.95rem; color: var(--text-muted); width: 16px; text-align: center; }
.chip-ctx-item.danger { color: var(--error); }
.chip-ctx-item.danger i { color: var(--error); }
.chip-ctx-item.fav-active i { color: var(--warn); }
.chip-ctx-sep { height: 1px; background: var(--border); }

/* Favorite star in FloatingPluginManager list */
.plugin-fav-btn {
  width: 28px; height: 28px; border-radius: 4px; display: flex;
  align-items: center; justify-content: center; cursor: pointer;
  background: transparent; border: 1px solid var(--border);
  color: var(--text-muted); font-size: 0.9rem; transition: all 0.15s; flex-shrink: 0;
}
.plugin-fav-btn:hover { border-color: var(--warn); color: var(--warn); background: rgba(251,191,36,0.08); }
.plugin-fav-btn.is-fav { border-color: var(--warn); color: var(--warn); background: rgba(251,191,36,0.1); }

/* ─── MOBILE QUICK DOCK ─────────────────────────────────────── */
.mobile-dock {
  display: none;
  position: fixed;
  left: 50%;
  bottom: calc(var(--plugin-footer-h) + max(8px, env(safe-area-inset-bottom)));
  transform: translateX(-50%);
  z-index: 120;
  background: rgba(9,9,11,0.92);
  border: 1px solid var(--border);
  border-radius: 999px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 6px;
  gap: 4px;
  align-items: center;
}
.mobile-dock button {
  border-radius: 999px;
  min-height: 36px;
  padding: 7px 12px;
  font-size: 0.78rem;
  flex-shrink: 0;
}
.template-icon-fallback { font-size: 1rem; line-height: 1; }

@supports (padding: env(safe-area-inset-bottom)) {
  .bottom-panel { padding-bottom: max(4px, env(safe-area-inset-bottom)); }
  header { padding-left: max(8px, env(safe-area-inset-left)); padding-right: max(8px, env(safe-area-inset-right)); }
}

/* ═════════════════ PLUGIN MANAGER ═════════════════ */
.plugin-modal {position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.85);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:9999}
.plugin-modal.show{display:flex}
.plugin-modal-content{background:var(--bg-panel);border:1px solid var(--border);border-radius:8px;width:90%;max-width:780px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,0.6);animation:slideUp 0.3s cubic-bezier(0.34,1.56,0.64,1)}
@keyframes slideUp{from{opacity:0;transform:translateY(30px) scale(0.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.plugin-modal-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,var(--bg-panel),var(--bg-dark))}
.plugin-modal-title{font-size:1.25rem;font-weight:600;display:flex;align-items:center;gap:10px;color:var(--text-main)}
.plugin-modal-title i{color:var(--primary);font-size:1.4rem}
.plugin-close-btn{background:transparent;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:4px 8px;border-radius:4px;transition:0.2s;line-height:1}
.plugin-close-btn:hover{background:var(--bg-dark);color:var(--text-main)}
.plugin-search-bar{padding:16px 22px;border-bottom:1px solid var(--border);background:var(--bg-dark)}
.plugin-search-input{width:100%;padding:10px 14px;background:var(--bg-panel);border:1px solid var(--border);border-radius:6px;color:var(--text-main);font-size:0.9rem;transition:0.2s}
.plugin-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,0.1)}
.plugin-search-input::placeholder{color:var(--text-muted)}
.plugin-modal-body{padding:20px 22px;overflow-y:auto;flex:1;min-height:0}
.plugin-section{margin-bottom:28px}
.plugin-section-title{font-size:0.85rem;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;color:var(--text-muted);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.plugin-section-title i{color:var(--primary)}
.plugin-list{display:flex;flex-direction:column;gap:10px}
.plugin-item{background:var(--bg-dark);border:1px solid var(--border);border-radius:6px;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;transition:0.2s;position:relative}
.plugin-item:hover{border-color:var(--primary);background:var(--bg-panel);transform:translateX(4px)}
.plugin-item-info{flex:1;min-width:0}
.plugin-item-name{font-weight:600;color:var(--text-main);font-size:0.95rem;margin-bottom:4px;display:flex;align-items:center;gap:8px}
.plugin-item-name i{color:var(--primary);font-size:1.1rem}
.plugin-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.3px}
.plugin-badge.active{background:rgba(74,222,128,0.15);color:var(--success)}
.plugin-badge.inactive{background:rgba(161,161,170,0.15);color:var(--text-muted)}
.plugin-badge.builtin{background:rgba(59,130,246,0.15);color:var(--primary)}
.plugin-item-desc{font-size:0.82rem;color:var(--text-muted);line-height:1.4;margin-top:2px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}
.plugin-item-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}
.plugin-toggle{width:44px;height:24px;background:#27272a;border-radius:12px;position:relative;cursor:pointer;transition:0.3s;border:1px solid var(--border)}
.plugin-toggle.active{background:var(--primary)}
.plugin-toggle::after{content:'';position:absolute;top:2px;left:2px;width:18px;height:18px;background:white;border-radius:50%;transition:0.3s;box-shadow:0 2px 4px rgba(0,0,0,0.3)}
.plugin-toggle.active::after{transform:translateX(20px)}
.plugin-action-btn{background:var(--bg-panel);border:1px solid var(--border);color:var(--text-main);padding:6px 12px;border-radius:4px;cursor:pointer;font-size:0.75rem;transition:0.2s;display:flex;align-items:center;gap:4px}
.plugin-action-btn:hover{background:var(--primary);border-color:var(--primary);color:white}
.plugin-action-btn.danger{color:var(--error)}
.plugin-action-btn.danger:hover{background:var(--error);color:white}
.plugin-empty{text-align:center;padding:40px 20px;color:var(--text-muted)}
.plugin-empty i{font-size:3rem;color:#333;margin-bottom:12px}
.plugin-create-btn{background:var(--primary);border:none;color:white;padding:12px 20px;border-radius:6px;cursor:pointer;font-size:0.9rem;font-weight:600;display:flex;align-items:center;gap:8px;margin:0 auto;transition:0.2s;box-shadow:0 4px 12px rgba(59,130,246,0.3)}
.plugin-create-btn:hover{background:#2563eb;transform:translateY(-2px);box-shadow:0 6px 16px rgba(59,130,246,0.4)}
.plugin-editor-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.9);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;z-index:10000}
.plugin-editor-modal.show{display:flex}
.plugin-editor-content{background:var(--bg-panel);border:1px solid var(--border);border-radius:8px;width:92%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 70px rgba(0,0,0,0.7)}
.plugin-editor-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,var(--bg-panel),var(--bg-dark))}
.plugin-editor-body{padding:20px 22px;overflow-y:auto;flex:1}
.plugin-form-group{margin-bottom:18px}
.plugin-form-label{display:block;font-size:0.85rem;font-weight:600;color:var(--text-main);margin-bottom:8px;text-transform:uppercase;letter-spacing:0.3px}
.plugin-form-input{width:100%;padding:10px 14px;background:var(--bg-dark);border:1px solid var(--border);border-radius:6px;color:var(--text-main);font-size:0.9rem}
.plugin-form-textarea{width:100%;min-height:280px;padding:14px;background:var(--bg-dark);border:1px solid var(--border);border-radius:6px;color:var(--text-main);font-size:0.88rem;font-family:'JetBrains Mono',monospace;resize:vertical;line-height:1.6}
.plugin-form-input:focus,.plugin-form-textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px rgba(59,130,246,0.1)}
.plugin-editor-footer{padding:16px 22px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;background:var(--bg-dark)}
.plugin-help-box{background:rgba(59,130,246,0.05);border:1px solid rgba(59,130,246,0.2);border-radius:6px;padding:14px;margin-bottom:18px;font-size:0.82rem;color:var(--text-muted);line-height:1.5}
.plugin-help-box code{background:var(--bg-dark);padding:2px 6px;border-radius:3px;color:var(--primary);font-family:'JetBrains Mono',monospace;font-size:0.8rem}
.plugin-ctx-menu{position:fixed;background:var(--bg-panel);border:1px solid var(--border);border-radius:6px;box-shadow:0 8px 24px rgba(0,0,0,0.4);min-width:160px;padding:6px 0;z-index:10001;display:none}
.plugin-ctx-item{padding:10px 16px;cursor:pointer;display:flex;align-items:center;gap:10px;font-size:0.85rem;color:var(--text-main);transition:0.15s}
.plugin-ctx-item:hover{background:var(--bg-dark)}
.plugin-ctx-item i{font-size:1rem}
.plugin-ctx-sep{height:1px;background:var(--border);margin:6px 0}
@media (max-width:768px){
  .plugin-modal-content{width:96%;max-height:92vh}
  .plugin-editor-content{width:96%;max-height:94vh}
  .plugin-item{flex-direction:column;align-items:flex-start;gap:12px}
  .plugin-item-actions{width:100%;justify-content:space-between}
}

/* ─── PANEL PLUGIN BUTTON (inline, not floating) ─── */
.panel-plugin-btn {
  display: flex; align-items: center; gap: 4px;
  padding: 4px 9px; border-radius: 4px;
  background: rgba(59,130,246,0.12); border: 1px solid rgba(59,130,246,0.3);
  color: var(--primary); font-size: 0.76rem; font-weight: 600;
  cursor: pointer; transition: 0.18s; flex-shrink: 0;
}
.panel-plugin-btn:hover { background: var(--primary); color: #fff; border-color: var(--primary); }

/* ─── FLOATING PLUGIN MANAGER PANEL ─── */
.floating-plugin-panel {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.9);
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 12px;
  width: 90%;
  max-width: 800px;
  max-height: 85vh;
  display: none;
  flex-direction: column;
  box-shadow: 0 25px 70px rgba(0,0,0,0.8);
  z-index: 10001;
  opacity: 0;
  transition: all 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
.floating-plugin-panel.show {
  display: flex;
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}
.floating-plugin-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.85);
  backdrop-filter: blur(6px);
  z-index: 10000;
  display: none;
  opacity: 0;
  transition: opacity 0.3s;
}
.floating-plugin-overlay.show {
  display: block;
  opacity: 1;
}
.floating-plugin-header {
  padding: 20px 24px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: linear-gradient(135deg, var(--bg-panel), var(--bg-dark));
}
.floating-plugin-title {
  font-size: 1.3rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--text-main);
}
.floating-plugin-title i {
  color: var(--primary);
  font-size: 1.6rem;
}
.floating-plugin-body {
  padding: 20px 24px;
  overflow-y: auto;
  flex: 1;
  min-height: 0;
}
.floating-plugin-footer {
  padding: 16px 24px;
  border-top: 1px solid var(--border);
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  background: var(--bg-dark);
}

/* ─── PLUGIN CUSTOMIZATION DIALOG ─── */
.plugin-custom-dialog {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.9);
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  width: 90%;
  max-width: 700px;
  max-height: 80vh;
  display: none;
  flex-direction: column;
  box-shadow: 0 25px 70px rgba(0,0,0,0.9);
  z-index: 10002;
  opacity: 0;
  transition: all 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
.plugin-custom-dialog.show {
  display: flex;
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}
.plugin-custom-header {
  padding: 18px 22px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: linear-gradient(135deg, var(--bg-panel), var(--bg-dark));
}
.plugin-custom-body {
  padding: 20px 22px;
  overflow-y: auto;
  flex: 1;
}
.plugin-custom-footer {
  padding: 16px 22px;
  border-top: 1px solid var(--border);
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  background: var(--bg-dark);
}
.plugin-custom-textarea {
  width: 100%;
  min-height: 350px;
  padding: 14px;
  background: var(--bg-dark);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text-main);
  font-size: 0.9rem;
  font-family: 'JetBrains Mono', monospace;
  resize: vertical;
  line-height: 1.6;
}
.plugin-custom-textarea:focus {
  border-color: var(--primary);
  outline: none;
  box-shadow: 0 0 0 3px rgba(59,130,246,0.1);
}

/* ═══════════════ PLUGIN IDE PANEL ═══════════════ */
.plugin-sidebar{width:280px;background:var(--bg-dark);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}
.plugin-sidebar-header{padding:12px;border-bottom:1px solid var(--border);display:flex;gap:6px;flex-wrap:wrap}
.plugin-btn{padding:6px 12px;border-radius:4px;border:1px solid var(--border);background:var(--bg-panel);color:var(--text-main);cursor:pointer;font-size:0.75rem;display:flex;align-items:center;gap:4px;transition:0.2s;font-weight:500}
.plugin-btn:hover{background:var(--bg-editor);border-color:var(--primary)}
.plugin-btn.primary{background:var(--primary);border-color:var(--primary);color:white}
.plugin-btn.primary:hover{background:#2563eb}
.plugin-btn.danger{color:var(--error)}
.plugin-btn.danger:hover{background:var(--error);color:white;border-color:var(--error)}
.plugin-search{padding:8px 12px;border-bottom:1px solid var(--border)}
.plugin-search-input{width:100%;padding:8px;background:var(--bg-panel);border:1px solid var(--border);border-radius:4px;color:var(--text-main);font-size:0.8rem}
.plugin-search-input:focus{border-color:var(--primary);outline:none}
.plugin-list{flex:1;overflow-y:auto;padding:8px}
.plugin-list-item{padding:10px 12px;border-radius:4px;cursor:pointer;margin-bottom:4px;border:1px solid transparent;transition:0.15s}
.plugin-list-item:hover{background:var(--bg-panel);border-color:var(--border)}
.plugin-list-item.active{background:var(--bg-editor);border-color:var(--primary)}
.plugin-list-item-name{font-size:0.85rem;font-weight:600;color:var(--text-main);display:flex;align-items:center;gap:6px;margin-bottom:2px}
.plugin-list-item-desc{font-size:0.72rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.plugin-list-item-status{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px}
.plugin-list-item-status.active{background:var(--success)}
.plugin-list-item-status.inactive{background:#555}
.plugin-editor-area{flex:1;display:flex;flex-direction:column;background:var(--bg-panel)}
.plugin-editor-toolbar{padding:10px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg-dark)}
.plugin-editor-toolbar-left{display:flex;align-items:center}
.plugin-editor-toolbar-right{display:flex;gap:6px}
.plugin-editor-meta{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:12px;background:var(--bg-dark)}
.plugin-meta-row{display:flex;align-items:center;gap:8px}
.plugin-meta-row label{font-size:0.8rem;color:var(--text-muted);min-width:80px}
.plugin-meta-input{padding:6px 10px;background:var(--bg-panel);border:1px solid var(--border);border-radius:4px;color:var(--text-main);font-size:0.85rem;flex:1;min-width:200px}
.plugin-meta-input:focus{border-color:var(--primary);outline:none}
.plugin-editor-container{flex:1;overflow:hidden;position:relative}
.plugin-code-mirror{height:100%;font-family:'JetBrains Mono',monospace;font-size:13px}
.plugin-code-mirror .cm-editor{height:100%}
.plugin-code-mirror .cm-scroller{overflow:auto}
.plugin-editor-help{padding:12px 16px;border-top:1px solid var(--border);background:var(--bg-dark);font-size:0.75rem}
.plugin-editor-help details{cursor:pointer}
.plugin-editor-help summary{color:var(--primary);font-weight:600;user-select:none}
.plugin-editor-help code{background:var(--bg-panel);padding:2px 6px;border-radius:3px;color:var(--success);font-size:0.72rem}
.plugin-api-list{margin-top:8px;line-height:1.8;color:var(--text-muted)}
@media (max-width:768px){
  .plugin-sidebar{width:100%;max-width:100%;border-right:none;border-bottom:1px solid var(--border)}
  .plugin-editor-meta{flex-direction:column}
  .plugin-meta-row{flex-direction:column;align-items:flex-start;width:100%}
  .plugin-meta-input{width:100%;min-width:unset}
}

/* ─── PLUGIN SANDBOX — Storage Trust Dialog ───────────────────── */
.sandbox-trust-overlay {
  position: fixed; inset: 0; z-index: 99999;
  background: rgba(0,0,0,0.72); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  opacity: 0; transition: opacity 0.2s ease;
  pointer-events: none;
}
.sandbox-trust-overlay.sandbox-trust-visible {
  opacity: 1; pointer-events: all;
}
.sandbox-trust-box {
  background: var(--bg-panel); border: 1px solid var(--border);
  border-radius: 14px; padding: 28px 24px 22px;
  max-width: 380px; width: 100%;
  box-shadow: 0 24px 64px rgba(0,0,0,0.7);
  transform: translateY(8px); transition: transform 0.22s ease;
  display: flex; flex-direction: column; align-items: center; gap: 0;
}
.sandbox-trust-overlay.sandbox-trust-visible .sandbox-trust-box {
  transform: translateY(0);
}
.sandbox-trust-icon {
  width: 52px; height: 52px; border-radius: 50%;
  background: rgba(251,191,36,0.12); border: 1.5px solid rgba(251,191,36,0.35);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 14px; font-size: 1.5rem; color: #fbbf24;
}
.sandbox-trust-title {
  font-size: 1.05rem; font-weight: 700; color: var(--text-main);
  margin-bottom: 14px; text-align: center; letter-spacing: -0.3px;
}
.sandbox-trust-body {
  text-align: center; display: flex; flex-direction: column; gap: 10px;
  width: 100%; margin-bottom: 20px;
}
.sandbox-trust-body p {
  font-size: 0.875rem; color: var(--text-muted); line-height: 1.55;
}
.sandbox-trust-body strong { color: var(--text-main); }
.sandbox-perm-tags {
  display: flex; flex-wrap: wrap; gap: 8px; justify-content: center;
  margin: 4px 0;
}
.sandbox-perm-tag {
  display: inline-flex; align-items: center; gap: 5px;
  background: rgba(59,130,246,0.12); border: 1px solid rgba(59,130,246,0.3);
  color: #60a5fa; border-radius: 20px; padding: 4px 12px;
  font-size: 0.78rem; font-family: 'JetBrains Mono', monospace; font-weight: 600;
}
.sandbox-perm-tag i { font-size: 0.9rem; }
.sandbox-trust-warn {
  font-size: 0.75rem !important;
  color: rgba(251,191,36,0.8) !important;
  background: rgba(251,191,36,0.07); border: 1px solid rgba(251,191,36,0.2);
  border-radius: 7px; padding: 7px 10px;
}
.sandbox-trust-actions {
  display: flex; gap: 10px; width: 100%;
}
.sandbox-btn-cancel, .sandbox-btn-ok {
  flex: 1; padding: 9px 14px; border-radius: 8px; font-size: 0.85rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  gap: 6px; transition: 0.18s; font-weight: 600;
}
.sandbox-btn-cancel {
  background: transparent; border: 1px solid var(--border); color: var(--text-muted);
}
.sandbox-btn-cancel:hover { background: rgba(255,255,255,0.05); color: var(--text-main); border-color: #52525b; }
.sandbox-btn-ok {
  background: var(--primary); border: 1px solid var(--primary); color: #fff;
}
.sandbox-btn-ok:hover { background: #2563eb; border-color: #2563eb; }
@media (max-width: 480px) {
  .sandbox-trust-box { padding: 22px 16px 18px; }
  .sandbox-trust-actions { flex-direction: column-reverse; }
}

  #mobileKbToolbar::-webkit-scrollbar{display:none}
  .mkbt-btn{
    display:inline-flex;align-items:center;justify-content:center;
    height:36px;min-width:36px;padding:0 9px;
    background:var(--bg-editor);border:1px solid var(--border);border-radius:6px;
    color:var(--text-main);font-size:0.88rem;font-family:'JetBrains Mono',monospace;
    cursor:pointer;touch-action:pan-x;user-select:none;
    margin:2px 2px;flex-shrink:0;transition:background 0.12s;
    -webkit-user-select:none;
  }
  .mkbt-btn:active{background:rgba(59,130,246,0.22);}
  .mkbt-sep{display:inline-block;width:1px;height:28px;background:var(--border);margin:4px 4px;vertical-align:middle;flex-shrink:0;}
