/* ══════════════════════════════════════════
   RESULTS PANEL
   Results body, token card, score card,
   issue groups and items, empty state.
══════════════════════════════════════════ */

.results-panel-body {
  flex: 1;
  overflow-y: auto;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: var(--bg);
}

/* ════════════════════════════════════════
   TOKEN CARD
════════════════════════════════════════ */
.token-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 14px 18px;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.token-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.token-card-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .7px;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 6px;
}
.token-count {
  font-size: 22px;
  font-weight: 700;
  font-family: var(--font-code);
  color: var(--text);
  letter-spacing: -1px;
  line-height: 1;
}
.token-count-sub {
  font-size: 11.5px;
  color: var(--text-muted);
  font-family: var(--font-ui);
  margin-left: 3px;
  font-weight: 400;
  letter-spacing: 0;
}
.token-label {
  font-size: 11.5px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 99px;
  border: 1px solid;
}
.token-label.lightweight { background: var(--success-bg); color: var(--success); border-color: var(--success-border); }
.token-label.moderate    { background: var(--info-bg);    color: var(--info);    border-color: var(--info-border); }
.token-label.heavy       { background: var(--warning-bg); color: var(--warning); border-color: var(--warning-border); }
.token-label.very-heavy  { background: var(--error-bg);   color: var(--error);   border-color: var(--error-border); }

.token-bar-wrap {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.token-bar-track {
  height: 6px;
  background: var(--border);
  border-radius: 99px;
  overflow: hidden;
}
.token-bar-fill {
  height: 100%;
  border-radius: 99px;
  transition: width .5s cubic-bezier(.4,0,.2,1), background .4s;
  min-width: 4px;
}
.token-bar-fill.lightweight { background: var(--success); }
.token-bar-fill.moderate    { background: var(--info); }
.token-bar-fill.heavy       { background: var(--warning); }
.token-bar-fill.very-heavy  { background: var(--error); }

.token-bar-labels {
  display: flex;
  justify-content: space-between;
  font-size: 10.5px;
  color: var(--text-faint);
  font-family: var(--font-code);
}
.token-contexts {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.token-ctx {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11.5px;
  color: var(--text-muted);
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 3px 8px;
}
.token-ctx-bar {
  width: 28px;
  height: 4px;
  background: var(--border);
  border-radius: 99px;
  overflow: hidden;
}
.token-ctx-fill {
  height: 100%;
  border-radius: 99px;
  background: var(--brand);
  transition: width .5s;
}
.token-note {
  font-size: 11px;
  color: var(--text-faint);
  font-style: italic;
}

/* ════════════════════════════════════════
   SCORE CARD
════════════════════════════════════════ */
.score-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 18px 20px;
  display: flex;
  align-items: center;
  gap: 18px;
  box-shadow: var(--shadow-sm);
}
.score-ring-wrap {
  flex-shrink: 0;
  position: relative;
  width: 72px;
  height: 72px;
}
.score-ring-wrap svg { transform: rotate(-90deg); }
.score-ring-bg { fill: none; stroke: var(--border); stroke-width: 5; }
.score-ring-fg {
  fill: none;
  stroke-width: 5;
  stroke-linecap: round;
  transition: stroke-dashoffset .6s cubic-bezier(.4,0,.2,1), stroke .4s;
}
.score-ring-label {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 700;
  font-family: var(--font-ui);
}
.grade-a .score-ring-fg    { stroke: var(--success); }
.grade-a .score-ring-label { color: var(--success); }
.grade-b .score-ring-fg    { stroke: #E2A800; }
.grade-b .score-ring-label { color: #C98E00; }
.grade-c .score-ring-fg    { stroke: var(--warning); }
.grade-c .score-ring-label { color: var(--warning); }
.grade-d .score-ring-fg    { stroke: var(--error); }
.grade-d .score-ring-label { color: var(--error); }
.grade-empty .score-ring-fg    { stroke: var(--border-strong); }
.grade-empty .score-ring-label { color: var(--text-faint); font-size: 14px; }

.score-meta { flex: 1; min-width: 0; }
.score-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 3px;
}
.score-sub {
  font-size: 12.5px;
  color: var(--text-muted);
  line-height: 1.45;
}
.score-pills {
  display: flex;
  gap: 6px;
  margin-top: 10px;
  flex-wrap: wrap;
}
.pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 9px;
  border-radius: 99px;
  font-size: 11.5px;
  font-weight: 600;
  border: 1px solid;
}
.pill-error   { background: var(--error-bg);   color: var(--error);   border-color: var(--error-border); }
.pill-warning { background: var(--warning-bg); color: var(--warning); border-color: var(--warning-border); }
.pill-info    { background: var(--info-bg);    color: var(--info);    border-color: var(--info-border); }
.pill-success { background: var(--success-bg); color: var(--success); border-color: var(--success-border); }

/* ════════════════════════════════════════
   ISSUE GROUPS
════════════════════════════════════════ */
.issue-group-header {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .8px;
  margin-bottom: 6px;
  margin-top: 2px;
  display: flex;
  align-items: center;
  gap: 7px;
}
.issue-group-header.errors   { color: var(--error); }
.issue-group-header.warnings { color: var(--warning); }
.issue-group-header.infos    { color: var(--info); }
.issue-group-header.success  { color: var(--success); }
.issue-group-line {
  flex: 1;
  height: 1px;
  background: currentColor;
  opacity: .15;
}

.issue-item {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  margin-bottom: 5px;
  overflow: hidden;
  cursor: pointer;
  transition: box-shadow .15s, border-color .15s, transform .1s;
}
.issue-item:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--border-strong);
  transform: translateY(-1px);
}
.issue-item:active { transform: translateY(0); }

.issue-item-body { display: flex; align-items: stretch; }
.issue-stripe {
  width: 4px;
  flex-shrink: 0;
  border-radius: var(--r-lg) 0 0 var(--r-lg);
}
.issue-item.error   .issue-stripe { background: var(--error); }
.issue-item.warning .issue-stripe { background: var(--warning); }
.issue-item.info    .issue-stripe { background: var(--info); }

.issue-content { padding: 10px 13px; flex: 1; min-width: 0; }
.issue-top {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
}
.issue-sev-icon {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 10px;
  font-weight: 700;
}
.issue-item.error   .issue-sev-icon { background: var(--error-bg);   color: var(--error);   border: 1px solid var(--error-border); }
.issue-item.warning .issue-sev-icon { background: var(--warning-bg); color: var(--warning); border: 1px solid var(--warning-border); }
.issue-item.info    .issue-sev-icon { background: var(--info-bg);    color: var(--info);    border: 1px solid var(--info-border); }

.issue-message {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  flex: 1;
  line-height: 1.3;
}
.issue-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.issue-location {
  font-size: 11px;
  font-family: var(--font-code);
  color: var(--text-faint);
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 1px 6px;
}
.issue-rule-id {
  font-size: 11px;
  font-family: var(--font-code);
  color: var(--text-muted);
  opacity: .7;
}
.issue-hint {
  margin-top: 8px;
  padding: 8px 10px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.55;
}
.issue-hint-label {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text-muted);
  margin-bottom: 3px;
}

/* ════════════════════════════════════════
   EMPTY STATE
════════════════════════════════════════ */
.empty-state {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 48px 32px;
  gap: 14px;
}
.empty-visual {
  width: 72px;
  height: 72px;
  background: linear-gradient(135deg, var(--bg) 0%, var(--border) 100%);
  border-radius: var(--r-2xl);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  border: 2px dashed var(--border-strong);
  margin-bottom: 4px;
}
.empty-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-secondary);
}
.empty-sub {
  font-size: 13px;
  color: var(--text-muted);
  max-width: 260px;
  line-height: 1.6;
}
