
/* === CRAWLER DASHBOARD === */
.crawler-section { margin: 20px 0; }
.crawler-logs-container {
  background: #0d1117;
  border: 1px solid #30363d;
  border-radius: 8px;
  padding: 12px;
  height: 400px;
  overflow-y: auto;
  font-family: 'Consolas', 'Monaco', monospace;
  font-size: 12px;
}
.log-line {
  padding: 2px 0;
  display: flex;
  gap: 8px;
  border-bottom: 1px solid #1c2028;
}
.log-time { color: #6e7681; min-width: 65px; }
.log-level { min-width: 60px; font-weight: bold; }
.log-msg { color: #c9d1d9; flex: 1; word-break: break-all; }
.log-info .log-level { color: #58a6ff; }
.log-success .log-level { color: #3fb950; }
.log-warn .log-level { color: #d29922; }
.log-error .log-level { color: #f85149; }

.results-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
  margin-top: 16px;
}
.result-card {
  background: #161b22;
  border: 1px solid #30363d;
  border-radius: 8px;
  padding: 16px;
}
.result-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}
.result-header h3 { margin: 0; font-size: 14px; color: #c9d1d9; }
.badge { padding: 2px 8px; border-radius: 12px; font-size: 11px; font-weight: bold; }
.badge.success { background: #1a3a2a; color: #3fb950; }
.badge.warning { background: #3a2f1a; color: #d29922; }
.badge.error { background: #3a1a1a; color: #f85149; }
.result-stats { display: flex; gap: 20px; }
.stat { text-align: center; }
.stat-num { display: block; font-size: 20px; font-weight: bold; color: #58a6ff; }
.stat-label { font-size: 11px; color: #6e7681; }
.result-meta { margin-top: 12px; font-size: 11px; color: #6e7681; }
.empty { color: #6e7681; text-align: center; padding: 40px; }

.crawler-controls {
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.crawler-controls input {
  background: #0d1117;
  border: 1px solid #30363d;
  color: #c9d1d9;
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 13px;
}
.crawler-controls input:focus { border-color: #58a6ff; outline: none; }
.crawler-controls button {
  padding: 8px 16px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  font-weight: bold;
  font-size: 13px;
}
.btn-launch { background: #238636; color: white; }
.btn-launch:hover { background: #2ea043; }
.btn-stop { background: #da3633; color: white; }
.btn-stop:hover { background: #f85149; }
.btn-stream { background: #1f6feb; color: white; }
.btn-stream:hover { background: #388bfd; }

/* === CRAWL RESULTS TABLE === */
.crawl-results-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.crawl-results-table th {
  text-align: left;
  padding: 10px 12px;
  color: #6e7681;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 1px solid var(--border, #1a1a2a);
}
.crawl-results-table td {
  padding: 10px 12px;
  color: var(--text, #c9d1d9);
  border-bottom: 1px solid var(--border, #1a1a2a);
}
.crawl-row {
  cursor: pointer;
  transition: background 0.15s;
}
.crawl-row:hover {
  background: var(--card, #161b22);
}
.crawl-name {
  font-weight: 600;
}
.crawl-date {
  color: var(--muted, #6e7681);
  font-size: 12px;
}
.btn-detail {
  color: var(--accent, #7c6afc);
  text-decoration: none;
  font-size: 12px;
  font-weight: 600;
  padding: 4px 10px;
  border: 1px solid var(--border, #1a1a2a);
  border-radius: 6px;
  transition: border-color 0.2s, background 0.2s;
  white-space: nowrap;
}
.btn-detail:hover {
  border-color: var(--accent, #7c6afc);
  background: rgba(124, 106, 252, 0.1);
}
