/* Log Stream (design spec section 17) */

.log-stream {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  display: flex; flex-direction: column;
  gap: 1px;
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.log-row {
  display: grid;
  grid-template-columns: 160px 50px 130px 1fr;
  gap: var(--space-3);
  padding: 0 var(--space-4);
  height: 26px;
  align-items: center;
  border-bottom: 1px solid var(--border-subtle);
  transition: background 80ms;
}
.log-row:hover { background: var(--bg-elevated); }
.log-row:last-child { border-bottom: none; }

@keyframes log-row-enter {
  from { opacity: 0; background: var(--accent-dim); }
  to   { opacity: 1; background: transparent; }
}
.log-row.entering { animation: log-row-enter 300ms ease-out forwards; }

.log-ts      { color: var(--text-tertiary); }
.log-level   { font-weight: 600; }
.log-level-INFO  { color: var(--text-secondary); }
.log-level-WARN  { color: var(--warning); }
.log-level-ERROR { color: var(--negative); }
.log-market { color: var(--accent); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.log-msg    { color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
