/* ── CVE Tracker — uses Bootstrap 5 CSS vars for light/dark theme ── */

.cve-tracker {
  /* Semantic aliases — read from BS5, which Docsy flips for dark mode */
  --ct-bg:        var(--bs-body-bg, #fff);
  --ct-bg2:       var(--bs-secondary-bg, #f6f8fa);
  --ct-bg3:       var(--bs-tertiary-bg, #f0f0f0);
  --ct-text:      var(--bs-body-color, #1f2328);
  --ct-muted:     var(--bs-secondary-color, #656d76);
  --ct-border:    var(--bs-border-color, #d0d7de);
  --ct-code-bg:   var(--bs-tertiary-bg, #eaeef2);
  --ct-link:      var(--bs-link-color, #0969da);
  --radius:       8px;
}

/* ── Full-width override — remove Docsy content max-width for this page ── */
.cve-tracker { width: 100%; }

/* ── Filters bar ── */
.cve-tracker .cve-filters {
  background: var(--ct-bg); border: 1px solid var(--ct-border);
  border-radius: var(--radius); padding: .75rem 1rem; margin-bottom: .6rem;
}
.cve-tracker .cve-filters-row {
  display: flex; flex-wrap: wrap; gap: .5rem; align-items: center;
}
.cve-tracker .cve-filters-row input,
.cve-tracker .cve-filters-row select {
  font-size: .82rem; padding: .35rem .65rem;
  border: 1px solid var(--ct-border); border-radius: 6px;
  background: var(--ct-bg); color: var(--ct-text); min-width: 130px; height: 30px;
}
.cve-tracker .cve-filters-row input:focus,
.cve-tracker .cve-filters-row select:focus { outline: 2px solid var(--ct-link); outline-offset: 1px; }
.cve-tracker .cve-filters-checks {
  display: flex; flex-wrap: wrap; gap: .75rem;
  margin-top: .6rem; padding-top: .5rem; border-top: 1px solid var(--ct-border);
}
.cve-tracker .cve-check {
  display: flex; align-items: center; gap: .35rem;
  font-size: .78rem; color: var(--ct-muted); cursor: pointer; white-space: nowrap;
}
.cve-tracker .cve-check input { cursor: pointer; width: 14px; height: 14px; }


/* ── Summary ── */
.cve-tracker .cve-summary { font-size: .78rem; color: var(--ct-muted); margin-bottom: .4rem; padding: 0 .1rem; }

/* ── Table container ── */
.cve-tracker .cve-wrap {
  background: var(--ct-bg); border: 1px solid var(--ct-border);
  border-radius: var(--radius); overflow: hidden;
}
.cve-tracker .cve-scroll { overflow-x: auto; }

/* ── Table ── */
.cve-tracker table { width: 100%; border-collapse: collapse; font-size: .82rem; }
.cve-tracker thead tr { background: var(--ct-bg2); border-bottom: 1px solid var(--ct-border); }
.cve-tracker th {
  padding: .55rem .85rem; text-align: left;
  font-size: .7rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: .04em; color: var(--ct-muted); white-space: nowrap;
}
.cve-tracker td { padding: .65rem .85rem; border-bottom: 1px solid var(--ct-border); vertical-align: middle; }
.cve-tracker tbody tr.cve-row:hover > td { background: var(--ct-bg2); }
.cve-tracker tbody tr.cve-row:last-child > td { border-bottom: none; }

/* ── Product cell ── */
.cve-tracker .prod-cell { display: flex; align-items: center; gap: .55rem; min-width: 160px; }
.cve-tracker .prod-icon {
  width: 28px; height: 28px; border-radius: 6px; object-fit: contain;
  flex-shrink: 0; background: var(--ct-bg3); border: 1px solid var(--ct-border);
}
.cve-tracker .prod-fallback {
  width: 28px; height: 28px; border-radius: 6px;
  display: none; align-items: center; justify-content: center;
  font-size: .75rem; font-weight: 700; color: #fff; flex-shrink: 0;
}
.cve-tracker .prod-name { font-weight: 600; font-size: .8rem; white-space: nowrap; color: var(--ct-text); }
.cve-tracker .svc-chip {
  display: inline-block; font-size: .67rem; font-weight: 500;
  padding: .08rem .4rem; border-radius: 999px; color: #fff; white-space: nowrap;
}
.cve-tracker .plat-chip {
  display: inline-flex; align-items: center; gap: .2rem;
  font-size: .64rem; font-weight: 500; padding: .06rem .35rem;
  border-radius: 999px; white-space: nowrap; margin-top: .1rem;
  border: 1px solid currentColor;
}
/* Platform chips: keep semantic colors, they work on both themes */
.cve-tracker .plat-linux   { color: #1a5276; background: #eaf2fb; }
.cve-tracker .plat-windows { color: #4a235a; background: #f5eef8; }
.cve-tracker .plat-both    { color: #1d4e2c; background: #eafaf1; }

/* ── CVE cell ── */
.cve-tracker .cve-id { font-family: "SFMono-Regular", Consolas, monospace; font-weight: 600; font-size: .8rem; }
.cve-tracker .cve-pkg { font-size: .72rem; color: var(--ct-muted); white-space: nowrap; }
.cve-tracker .pkg-ver { font-family: "SFMono-Regular", Consolas, monospace; font-size: .68rem; background: var(--ct-code-bg); padding: .05rem .25rem; border-radius: 3px; color: var(--ct-text); }
.cve-tracker .pkg-fix { font-size: .72rem; font-weight: 600; color: #1a7f37; white-space: nowrap; }

/* ── Severity badge — score + label in one chip, e.g. "7.5 HIGH" ── */
.cve-tracker .sev {
  display: inline-block; padding: .18rem .6rem;
  border-radius: 999px; font-size: .72rem; font-weight: 700; letter-spacing: .03em; white-space: nowrap;
}
.cve-tracker .sev-c { background: #ffd2d0; color: #7d0000; }
.cve-tracker .sev-h { background: #fff0c2; color: #6a4000; }
.cve-tracker .sev-m { background: #dce8fb; color: #0b3d7a; }
.cve-tracker .sev-l { background: #d6f5de; color: #1a5e34; }

/* ── VEX status badge ── */
.cve-tracker .vbadge {
  display: inline-flex; align-items: center; gap: .3rem;
  padding: .18rem .55rem; border-radius: 6px; font-size: .72rem; font-weight: 500;
}
.cve-tracker .vbadge .dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.cve-tracker .vb-fixed          { background: #d6f5de; color: #1a5e34; }
.cve-tracker .vb-fixed .dot     { background: #1a7f37; }
.cve-tracker .vb-na             { background: #dce8fb; color: #0b3d7a; }
.cve-tracker .vb-na .dot        { background: #0969da; }
.cve-tracker .vb-inv            { background: #fff8c5; color: #7a4f00; }
.cve-tracker .vb-inv .dot       { background: #d1810c; }
.cve-tracker .vb-vendor         { background: #ffeacc; color: #7a3900; }
.cve-tracker .vb-vendor .dot    { background: #e06500; }
.cve-tracker .vb-os             { background: var(--ct-bg3); color: var(--ct-muted); }
.cve-tracker .vb-os .dot        { background: var(--ct-muted); }
.cve-tracker .vb-fp             { background: var(--ct-bg3); color: var(--ct-muted); }
.cve-tracker .vb-fp .dot        { background: var(--ct-muted); }

/* ── Fix column ── */
.cve-tracker .fix-ok       { font-size: .78rem; font-weight: 600; color: #1a7f37; }
.cve-tracker .fix-planned  { font-size: .78rem; font-weight: 500; color: #d1810c; }
.cve-tracker .fix-incoming { font-size: .78rem; font-weight: 500; color: #7a4f00; background: #fff3cd; border: 1px solid #ffe69c; border-radius: 4px; padding: .05rem .35rem; white-space: nowrap; }
.cve-tracker .fix-na       { color: var(--ct-muted); }

/* ── Expand button ── */
.cve-tracker .xbtn {
  background: none; border: none; cursor: pointer; padding: .25rem .35rem;
  color: var(--ct-muted); border-radius: 4px; display: flex; align-items: center;
}
.cve-tracker .xbtn:hover { color: var(--ct-text); background: var(--ct-bg3); }
.cve-tracker .xbtn svg { transition: transform .2s; }
.cve-tracker .xbtn.open svg { transform: rotate(90deg); }

/* ── Detail row ── */
.cve-tracker .detail-row { background: var(--ct-bg2); }
.cve-tracker .detail-row td { padding: 0; border-bottom: 1px solid var(--ct-border); }
.cve-tracker .detail-row.hidden { display: none; }
.cve-tracker .detail-inner {
  padding: 1rem 1rem 1rem 3.5rem;
  display: grid; grid-template-columns: 1fr 1fr; gap: .8rem 2rem;
}
.cve-tracker .df { display: flex; flex-direction: column; gap: .15rem; }
.cve-tracker .dl { font-size: .68rem; font-weight: 600; text-transform: uppercase; letter-spacing: .05em; color: var(--ct-muted); }
.cve-tracker .dv { font-size: .82rem; line-height: 1.45; color: var(--ct-text); }
.cve-tracker .dv code {
  font-family: "SFMono-Regular",Consolas,monospace; font-size: .78rem;
  background: var(--ct-code-bg); padding: .1rem .3rem; border-radius: 4px;
  color: var(--ct-text);
}
.cve-tracker .tlink {
  display: inline-flex; align-items: center; gap: .2rem; margin-left: .4rem;
  font-size: .74rem; font-weight: 500; background: var(--ct-code-bg); padding: .1rem .4rem;
  border-radius: 4px; color: var(--ct-link);
}

/* ── Loading / error ── */
.cve-tracker .cve-state { text-align: center; padding: 3rem; color: var(--ct-muted); font-style: italic; }
