/* ═══════════════════════════════════════════════════════════
   Base / Reset
═══════════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:          #0f1117;
  --bg2:         #171b26;
  --bg3:         #1e2335;
  --border:      #2a2f45;
  --accent:      #5865f2;
  --accent2:     #7289da;
  --text:        #e2e8f0;
  --text-dim:    #8892a4;
  --crit:        #ff4757;
  --high:        #ff6b35;
  --med:         #ffa502;
  --low:         #2ed573;
  --sidebar-w:   280px;
  --header-h:    58px;
}

html, body { height: 100%; overflow: hidden; font-family: 'Segoe UI', system-ui, sans-serif; font-size: 14px; color: var(--text); background: var(--bg); }

/* ═══════════════════════════════════════════════════════════
   Layout
═══════════════════════════════════════════════════════════ */
#sidebar {
  position: fixed; left: 0; top: 0; bottom: 0;
  width: var(--sidebar-w);
  background: var(--bg2);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  z-index: 10;
}

#main {
  margin-left: var(--sidebar-w);
  height: 100vh;
  display: flex; flex-direction: column;
  overflow: hidden;
}

#ext-header {
  height: var(--header-h);
  min-height: var(--header-h);
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 16px;
  padding: 0 20px;
  flex-shrink: 0;
}

#panels {
  flex: 1;
  display: flex;
  overflow: hidden;
}

#left-panel {
  flex: 1;
  overflow-y: auto;
  padding: 18px 20px;
  display: flex; flex-direction: column; gap: 16px;
}

#right-panel {
  width: 320px;
  min-width: 300px;
  border-left: 1px solid var(--border);
  background: var(--bg2);
  overflow-y: auto;
  padding: 16px;
  display: flex; flex-direction: column; gap: 12px;
}

/* ═══════════════════════════════════════════════════════════
   Sidebar
═══════════════════════════════════════════════════════════ */
#sidebar-header {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 14px 10px;
  border-bottom: 1px solid var(--border);
}
.logo { font-size: 22px; }
#sidebar-title { font-weight: 700; font-size: 13px; color: var(--text); }
#sidebar-sub   { font-size: 11px; color: var(--text-dim); margin-top: 2px; }

#search-wrap { padding: 10px 12px 6px; }
#search {
  width: 100%; padding: 7px 10px;
  background: var(--bg3); border: 1px solid var(--border); border-radius: 6px;
  color: var(--text); font-size: 13px; outline: none;
}
#search:focus { border-color: var(--accent); }

#filter-bar {
  display: flex; flex-wrap: wrap; gap: 4px;
  padding: 0 12px 8px;
}
.filter-btn {
  font-size: 10px; padding: 3px 7px; border-radius: 4px; border: 1px solid var(--border);
  background: var(--bg3); color: var(--text-dim); cursor: pointer;
}
.filter-btn.active, .filter-btn:hover { background: var(--accent); color: #fff; border-color: var(--accent); }

#ext-list { list-style: none; overflow-y: auto; flex: 1; }

.ext-item {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 12px; cursor: pointer;
  border-bottom: 1px solid var(--border);
  transition: background .12s;
}
.ext-item:hover { background: var(--bg3); }
.ext-item.active { background: var(--bg3); border-left: 3px solid var(--accent); }

.sev-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.sev-critical { background: var(--crit); }
.sev-high     { background: var(--high); }
.sev-medium   { background: var(--med); }
.sev-low      { background: var(--low); }
.sev-unknown  { background: var(--text-dim); }

.ext-item-name {
  flex: 1; overflow: hidden; white-space: nowrap; text-overflow: ellipsis;
  font-size: 12.5px;
}
.ext-item-cat  { font-size: 10px; color: var(--text-dim); flex-shrink: 0; }
.ext-item-obf  { font-size: 9px; background: #4a3800; color: var(--med); padding: 1px 4px; border-radius: 3px; }

/* ═══════════════════════════════════════════════════════════
   Header
═══════════════════════════════════════════════════════════ */
#header-name {
  font-size: 17px; font-weight: 700; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
#header-meta { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

.badge {
  font-size: 10px; font-weight: 700; letter-spacing: .5px;
  padding: 2px 7px; border-radius: 4px; text-transform: uppercase;
}
.badge-crit  { background: var(--crit);   color: #fff; }
.badge-high  { background: var(--high);  color: #fff; }
.badge-med   { background: var(--med);   color: #000; }
.badge-low   { background: var(--low);   color: #000; }
.badge-warn  { background: #4a3800; color: var(--med); }
.badge-info  { background: var(--bg3); color: var(--text-dim); border: 1px solid var(--border); }

/* ═══════════════════════════════════════════════════════════
   Left Panel Sections
═══════════════════════════════════════════════════════════ */
.panel-section {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px 16px;
}

.section-label {
  font-size: 11px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase;
  color: var(--text-dim); margin-bottom: 10px;
  display: flex; align-items: center; gap: 8px;
}

.file-path {
  font-size: 11px; color: var(--accent2); font-family: monospace;
  margin-bottom: 8px; padding: 4px 8px;
  background: var(--bg); border-radius: 4px; border: 1px solid var(--border);
}

.code-block {
  border-radius: 6px; font-size: 12.5px; max-height: 380px; overflow-y: auto;
  border: 1px solid var(--border);
}
.code-block code { font-family: 'Cascadia Code', 'Fira Code', 'Consolas', monospace; }

.obf-technique {
  font-size: 12px; color: var(--med); margin-bottom: 8px;
  padding: 6px 10px; background: #1a1500; border-radius: 4px;
  border-left: 3px solid var(--med);
}

.text-box {
  font-size: 13px; line-height: 1.6; padding: 10px 12px;
  border-radius: 6px;
}
.intended-box  { background: #0d1f1a; border-left: 3px solid var(--low);  color: #a8e6cf; }
.malicious-box { background: #1f0d0d; border-left: 3px solid var(--crit); color: #f5a0a0; }

/* Comments */
#comment-form { display: flex; flex-direction: column; gap: 8px; margin-bottom: 14px; }
#cmt-name, #cmt-body {
  background: var(--bg3); border: 1px solid var(--border); border-radius: 6px;
  color: var(--text); font-size: 13px; padding: 8px 10px; outline: none;
  font-family: inherit;
}
#cmt-name { width: 200px; }
#cmt-body { width: 100%; resize: vertical; }
#cmt-name:focus, #cmt-body:focus { border-color: var(--accent); }
#cmt-submit {
  align-self: flex-start; padding: 7px 18px;
  background: var(--accent); color: #fff; border: none; border-radius: 6px;
  font-size: 13px; cursor: pointer; font-weight: 600;
}
#cmt-submit:hover { background: var(--accent2); }

.comment-item {
  padding: 9px 0; border-bottom: 1px solid var(--border);
  font-size: 13px;
}
.comment-item:last-child { border-bottom: none; }
.comment-author { font-weight: 700; color: var(--accent2); margin-right: 8px; }
.comment-date   { font-size: 11px; color: var(--text-dim); }
.comment-body   { margin-top: 4px; line-height: 1.5; }

/* ═══════════════════════════════════════════════════════════
   Right Panel
═══════════════════════════════════════════════════════════ */
.meta-card {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
}

.meta-row {
  display: flex; gap: 8px; padding: 5px 0;
  border-bottom: 1px solid var(--border);
  align-items: flex-start;
}
.meta-row:last-child { border-bottom: none; }
.meta-label  { font-size: 11px; color: var(--text-dim); min-width: 105px; padding-top: 1px; }
.meta-value  { font-size: 12.5px; color: var(--text); flex: 1; word-break: break-word; }
.mono  { font-family: monospace; }
.small { font-size: 11px; }

#m-status {
  background: var(--bg); color: var(--text); border: 1px solid var(--border);
  border-radius: 5px; padding: 3px 6px; font-size: 12px; cursor: pointer;
}

.marketplace-row {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 0; border-bottom: 1px solid var(--border);
  font-size: 12.5px;
}
.marketplace-row:last-child { border-bottom: none; }
.mkt-icon  { font-size: 16px; }
.mkt-name  { flex: 1; }
.mkt-status-removed   { color: var(--crit); font-weight: 700; font-size: 11px; }
.mkt-status-available { color: var(--low);  font-size: 11px; word-break: break-all; }
.mkt-status-available a { color: var(--low); }
.mkt-status-unknown   { color: var(--text-dim); font-size: 11px; }

.log-line { font-size: 11.5px; color: var(--text-dim); margin-bottom: 6px; line-height: 1.5; }
.log-line a { color: var(--accent2); word-break: break-all; }

.related-chip {
  display: inline-block; margin: 3px; padding: 3px 8px;
  background: var(--bg2); border: 1px solid var(--border); border-radius: 4px;
  font-size: 11px; color: var(--accent2); cursor: pointer;
}
.related-chip:hover { border-color: var(--accent); }

/* ═══════════════════════════════════════════════════════════
   Scrollbar
═══════════════════════════════════════════════════════════ */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--bg2); }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--accent); }

/* ═══════════════════════════════════════════════════════════
   Modules & APIs section
═══════════════════════════════════════════════════════════ */
.verdict-box {
  font-size: 12px; line-height: 1.5;
  padding: 7px 10px; border-radius: 5px; margin-bottom: 10px;
  background: #0d1520; border-left: 3px solid var(--accent);
  color: #a0b4d0;
}

.mod-group { margin-bottom: 9px; }
.mod-group-label {
  font-size: 10px; font-weight: 700; letter-spacing: .6px;
  text-transform: uppercase; margin-bottom: 5px;
}
.node-label   { color: #ff6b35; }
.vscode-label { color: #7289da; }
.npm-label    { color: #2ed573; }
.python-label { color: #f7c948; }
.local-label  { color: #8892a4; }

.mod-chips { display: flex; flex-wrap: wrap; gap: 4px; }
.mod-chip {
  display: inline-block; padding: 2px 8px; border-radius: 4px;
  font-size: 11px; font-family: monospace; font-weight: 600;
}
.chip-node   { background: #2a1a0d; color: #ff9d72; border: 1px solid #4a2a10; }
.chip-vscode { background: #0d1230; color: #7289da; border: 1px solid #1e2a50; }
.chip-npm    { background: #0d1f1a; color: #2ed573; border: 1px solid #1a3d2a; }
.chip-python { background: #1a1500; color: #f7c948; border: 1px solid #3a3000; }
.chip-local  { background: #191a1f; color: #8892a4; border: 1px solid #2a2f3a; }

.mod-note {
  font-size: 11px; color: var(--text-dim); margin-top: 8px;
  padding: 5px 8px; background: var(--bg); border-radius: 4px;
  border-left: 2px solid var(--border); line-height: 1.5;
}

/* ═══════════════════════════════════════════════════════════
   Responsive tweak
═══════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  #right-panel { display: none; }
}
