/* Container & typography */
.xg-cvss { background:#fff; border:1px solid #e5e7eb; border-radius:12px; padding:16px; box-shadow:0 1px 3px rgba(15,23,42,.06); }
.xg-title { margin:0 0 6px; font-size:20px; }
.xg-sub { margin:0 0 12px; color:#505b67; }

/* Inputs & layout */
.xg-row { margin-bottom:12px; }
.xg-label { display:block; font-weight:600; margin-bottom:6px; }
.xg-inline { display:flex; gap:8px; align-items:center; }
.xg-input, .xg-select { width:100%; padding:10px 12px; border:1px solid #d1d5db; border-radius:8px; }
.xg-input { flex:1; }
.xg-form { margin-top:8px; }
.xg-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(220px,1fr)); gap:10px; }
.xg-field { display:flex; flex-direction:column; gap:6px; }

/* Buttons */
.xg-actions { margin-top:12px; display:flex; gap:8px; }
.xg-btn { background:#0b5fff; color:#fff; padding:10px 14px; border:none; border-radius:8px; cursor:pointer; }
.xg-btn:hover { opacity:.95; }
.xg-btn-outline { background:#fff; color:#0b5fff; border:1px solid #0b5fff; }
.xg-btn-secondary { background:#fff; color:#111827; border:1px solid #d1d5db; }
#xg-copy.xg-ok { border-color:#16a34a; color:#16a34a; }

/* Result */
.xg-result { margin-top:12px; padding:12px; border:1px dashed #e5e7eb; border-radius:8px; background:#fafafb; }
.xg-score { display:inline-block; padding:.35em .6em; border-radius:8px; font-weight:600; }
.xg-vector { margin-top:8px; font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; }
.xg-help { color:#6b7280; font-size:12px; }

/* Severity colors */
#xg-scoreBadge[data-sev="none"] { background:#f3f4f6; color:#374151; }
#xg-scoreBadge[data-sev="low"] { background:#dcfce7; color:#166534; }
#xg-scoreBadge[data-sev="medium"] { background:#e0f2fe; color:#075985; }
#xg-scoreBadge[data-sev="high"] { background:#fef3c7; color:#92400e; }
#xg-scoreBadge[data-sev="critical"] { background:#fee2e2; color:#991b1b; }

/* Dark mode (optional) */
@media (prefers-color-scheme: dark) {
  .xg-cvss { background:#101418; border-color:#1f2937; }
  .xg-sub, .xg-help { color:#a3a9b2; }
  .xg-input, .xg-select { background:#0f1317; border-color:#2a3340; color:#e5e7eb; }
  .xg-btn-secondary { background:#0f1317; color:#e5e7eb; border-color:#2a3340; }
  .xg-result { background:#0f1216; border-color:#1f2937; }
}
