/* ============================================================
 * Scraper UI — dark theme (graphite → black)
 * Tokens + components. Both / and /v1 share this stylesheet.
 * ============================================================ */

:root {
  /* surfaces */
  --bg:          #0a0a0c;   /* page (near-black) */
  --bg-elev:     #131418;   /* panels, sticky bars */
  --bg-elev-2:   #1b1d22;   /* inputs, op-forms, tables */
  --bg-hover:    #23262c;
  --bg-pre:      #0e1014;   /* code blocks */

  /* lines */
  --line:        #2a2c33;
  --line-strong: #3a3d46;

  /* text */
  --fg:          #e6e7ea;
  --fg-muted:    #9ca3af;
  --fg-dim:      #6b7280;

  /* accent */
  --accent:      #7aa7ff;
  --accent-hi:   #9bc0ff;
  --accent-bg:   #1b2c4f;
  --accent-fg:   #0a0a0c;

  /* status */
  --error:       #f87171;
  --error-bg:    #2a1014;
  --error-line:  #5d1d24;
  --warn:        #fbbf24;
  --ok:          #4ade80;

  /* radii + shadow */
  --r-sm: 4px;
  --r-md: 6px;
  --r-lg: 10px;
  --r-pill: 999px;
  --shadow: 0 4px 24px rgba(0, 0, 0, 0.4);
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  font: 14px/1.5 system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--fg);
  margin: 0 auto;
  padding: 0 16px 48px;
  max-width: 1100px;
  -webkit-font-smoothing: antialiased;
}

/* selection */
::selection { background: var(--accent-bg); color: var(--fg); }

/* scrollbars (subtle) */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--line); border-radius: var(--r-pill); }
::-webkit-scrollbar-thumb:hover { background: var(--line-strong); }

/* ------ headings ------ */
h2, h3 { color: var(--fg); }
h2 { margin: 0 0 12px 0; font-size: 18px; font-weight: 600; letter-spacing: -0.01em; }
h3 { margin: 16px 0 8px 0; font-size: 14px; font-weight: 600; color: var(--fg-muted); text-transform: uppercase; letter-spacing: 0.05em; }
a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-hi); }

/* ------ project bar (top) ------ */
#proj-bar {
  display: flex; gap: 12px; align-items: center;
  padding: 10px 0; border-bottom: 1px solid var(--line);
  background: var(--bg);
  position: sticky; top: 0; z-index: 20;
  font-size: 13px;
}
#proj-bar label { display: inline-flex; align-items: center; gap: 6px; margin: 0; color: var(--fg-muted); }
#proj-bar select {
  min-width: 200px; padding: 5px 8px;
  background: var(--bg-elev-2); color: var(--fg);
  border: 1px solid var(--line); border-radius: var(--r-sm);
}
#proj-bar select:focus { outline: none; border-color: var(--accent); }
#proj-bar #proj-counts { color: var(--fg-muted); font-size: 12px; }
#proj-bar .grow { flex: 1; }
#proj-bar a { color: var(--fg-muted); font-size: 12px; padding: 4px 8px; border-radius: var(--r-sm); }
#proj-bar a:hover { background: var(--bg-elev-2); color: var(--accent); }

#proj-new {
  width: 28px; height: 28px; padding: 0; line-height: 1;
  font-size: 16px; font-weight: 600;
}

/* ------ tabs ------ */
#tabs {
  display: flex; gap: 2px;
  border-bottom: 1px solid var(--line);
  margin: 0 0 20px 0; padding-top: 12px;
  position: sticky; top: 49px; z-index: 10;
  background: var(--bg);
}
#tabs button {
  background: transparent; border: none;
  padding: 10px 16px; cursor: pointer; font-size: 13px;
  color: var(--fg-muted);
  border-bottom: 2px solid transparent;
  border-radius: 0;
  transition: color 120ms, border-color 120ms;
}
#tabs button:hover { color: var(--fg); }
#tabs button.active {
  color: var(--fg); border-bottom-color: var(--accent);
  background: transparent;
}

/* ------ panel ------ */
.panel { display: none; }
.panel.active { display: block; }

.panel-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  padding-bottom: 12px; margin-bottom: 16px;
  border-bottom: 1px solid var(--line);
}
.panel-head h2 { margin: 0; }
.panel-head .head-actions { display: flex; gap: 8px; }

/* ------ form controls ------ */
label {
  display: block; margin: 12px 0;
  color: var(--fg);
}
label > input[type=text],
label > input:not([type]),
label > input[type=number],
label > input[type=url],
label > textarea,
label > select,
input[type=text]:not(.bare),
input:not([type]):not(.bare),
textarea, select {
  display: block; width: 100%; padding: 8px 10px;
  background: var(--bg-elev-2); color: var(--fg);
  border: 1px solid var(--line); border-radius: var(--r-sm);
  font: inherit;
  transition: border-color 120ms;
}
input[type=checkbox] { width: auto; margin-right: 6px; accent-color: var(--accent); }
input[type=range] { accent-color: var(--accent); width: 140px; }
input:focus, textarea:focus, select:focus { outline: none; border-color: var(--accent); }
textarea { font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 13px; line-height: 1.5; }

label > input[type=checkbox] + .help {
  vertical-align: middle;
}

::placeholder { color: var(--fg-dim); }

/* ------ buttons ------ */
button {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px;
  background: var(--bg-elev-2); color: var(--fg);
  border: 1px solid var(--line); border-radius: var(--r-sm);
  font: inherit; font-size: 13px; line-height: 1;
  cursor: pointer;
  transition: background 120ms, border-color 120ms, color 120ms;
}
button:hover { background: var(--bg-hover); border-color: var(--line-strong); }
button:active { transform: translateY(1px); }
button:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
button.primary {
  background: var(--accent); color: var(--accent-fg);
  border-color: var(--accent); font-weight: 600;
}
button.primary:hover { background: var(--accent-hi); border-color: var(--accent-hi); }
button.ghost {
  background: transparent; color: var(--fg-muted);
  border: 1px solid var(--line);
}
button.ghost:hover { color: var(--fg); border-color: var(--line-strong); background: var(--bg-elev-2); }
button.active { background: var(--accent-bg); color: var(--fg); border-color: var(--accent); }

/* small help (?) chip */
button.help {
  display: inline-flex; align-items: center; justify-content: center;
  width: 18px; height: 18px; min-width: 18px;
  padding: 0; line-height: 1;
  background: transparent; color: var(--fg-muted);
  border: 1px solid var(--line); border-radius: 50%;
  font-size: 11px; cursor: help;
  margin-left: 6px; vertical-align: middle;
}
button.help:hover { color: var(--accent); border-color: var(--accent); background: var(--accent-bg); }

/* ------ rows / layout helpers ------ */
.row { display: flex; gap: 8px; align-items: center; margin: 12px 0; flex-wrap: wrap; }
.meta { color: var(--fg-muted); font-size: 12px; margin: 4px 0; }

/* ------ fieldset ------ */
fieldset {
  border: 1px solid var(--line); border-radius: var(--r-md);
  padding: 12px 16px; margin: 16px 0;
  background: var(--bg-elev);
}
fieldset legend {
  padding: 0 8px; color: var(--fg-muted); font-size: 12px;
  text-transform: uppercase; letter-spacing: 0.05em;
}
fieldset label { display: inline-flex; align-items: center; margin: 4px 12px 4px 0; gap: 6px; }
fieldset label > input[type=checkbox] { margin-right: 0; }

/* ------ details / summary ------ */
details { margin: 12px 0; }
details summary {
  cursor: pointer; user-select: none; padding: 6px 0;
  color: var(--fg-muted); font-size: 13px;
}
details summary:hover { color: var(--fg); }
details[open] summary { color: var(--fg); }

/* ------ chips ------ */
.chips { display: inline-flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.chip {
  display: inline-flex; align-items: center;
  padding: 3px 10px;
  background: var(--bg-elev-2); color: var(--fg-muted);
  border: 1px solid var(--line); border-radius: var(--r-pill);
  font-size: 12px; cursor: pointer; user-select: none; white-space: nowrap;
  transition: background 120ms, color 120ms, border-color 120ms;
}
.chip:hover { color: var(--fg); border-color: var(--line-strong); }
.chip.active {
  background: var(--accent-bg); color: var(--fg);
  border-color: var(--accent);
}
.chip a {
  display: inline-block; margin-left: 6px; padding: 0 2px;
  color: var(--fg-dim); cursor: pointer; line-height: 1;
}
.chip a:hover { color: var(--error); }

#run-tags-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; min-height: 24px; }

/* ------ op-form (Run tab sub-panels) ------ */
.op-form {
  margin: 12px 0;
  padding: 14px 16px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
}
.op-form label { margin: 8px 0; }
.op-form label:first-child { margin-top: 0; }

/* ------ results filters ------ */
#results-filters {
  display: flex; flex-wrap: wrap; gap: 12px; align-items: center;
  padding: 12px;
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--r-md);
  margin-bottom: 12px;
}
#results-filters > label { margin: 0; display: inline-flex; align-items: center; gap: 8px; color: var(--fg-muted); }
#results-filters > input[type=text],
#results-filters > input:not([type]) {
  width: auto; min-width: 200px; flex: 1 1 220px; margin: 0;
}
#results-score-val {
  display: inline-block; min-width: 28px; text-align: right;
  font-family: ui-monospace, monospace; color: var(--fg);
}
#results-count { margin: 4px 0 10px 4px; color: var(--fg-muted); font-size: 12px; }

/* ------ tables ------ */
#results-table, #src-table, #schema-table, #runs-table, #sc-fields {
  width: 100%; border-collapse: collapse; font-size: 13px;
  background: var(--bg-elev);
  border: 1px solid var(--line); border-radius: var(--r-md);
  overflow: hidden;
}
#results-table thead th, #src-table thead th,
#schema-table thead th, #runs-table thead th,
#sc-fields thead th {
  background: var(--bg-elev-2);
  color: var(--fg-muted);
  font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em;
  padding: 8px 12px; text-align: left;
  border-bottom: 1px solid var(--line);
}
#results-table td, #src-table td, #schema-table td, #runs-table td, #sc-fields td {
  padding: 8px 12px; vertical-align: top;
  border-bottom: 1px solid var(--line);
  color: var(--fg);
}
#results-table tbody tr:last-child td,
#src-table tbody tr:last-child td,
#schema-table tbody tr:last-child td,
#runs-table tbody tr:last-child td { border-bottom: 0; }
#results-table tbody tr:hover,
#src-table tbody tr:hover,
#schema-table tbody tr:hover,
#runs-table tbody tr:hover { background: var(--bg-hover); }

#results-table td:first-child {
  max-width: 380px; overflow: hidden; text-overflow: ellipsis;
  white-space: nowrap;
}

#sc-fields td input, #sc-fields td select { padding: 4px 6px; font-size: 12px; }
#sc-fields td button { padding: 2px 8px; font-size: 11px; }

/* ------ result panel (Run status) ------ */
.result {
  margin-top: 16px; padding: 12px 14px;
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--r-md);
  min-height: 56px;
}
.result pre {
  background: var(--bg-pre); color: var(--fg);
  white-space: pre-wrap; word-break: break-word;
  max-height: 60vh; overflow: auto; margin: 0;
  padding: 10px; border-radius: var(--r-sm);
  font-size: 12px; font-family: ui-monospace, "SF Mono", Menlo, monospace;
}
.result code {
  background: var(--bg-pre); padding: 1px 5px; border-radius: var(--r-sm);
  font-size: 12px; color: var(--accent-hi);
}

/* ------ RAG hits ------ */
.hit {
  padding: 10px 12px; margin-bottom: 6px;
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--r-md);
}
.hit .score {
  font-family: ui-monospace, monospace; color: var(--fg-muted);
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em;
  margin-bottom: 6px;
}
.hit .content { white-space: pre-wrap; color: var(--fg); }

/* ------ dialogs ------ */
dialog#help-dialog, dialog#row-dialog {
  max-width: 640px; width: 90vw;
  background: var(--bg-elev);
  color: var(--fg);
  border: 1px solid var(--line-strong); border-radius: var(--r-lg);
  padding: 20px 24px;
  box-shadow: var(--shadow);
}
dialog#row-dialog { max-width: 880px; max-height: 80vh; overflow: hidden; }
dialog h3 { margin: 0 0 12px 0; color: var(--fg); }
dialog p { color: var(--fg-muted); margin: 0 0 12px 0; }
dialog pre {
  background: var(--bg-pre); color: var(--fg);
  padding: 12px; border-radius: var(--r-sm);
  font-size: 12px; font-family: ui-monospace, monospace;
  white-space: pre-wrap; word-break: break-word;
  max-height: 60vh; overflow: auto;
  margin: 0 0 16px 0;
  border: 1px solid var(--line);
}
dialog::backdrop { background: rgba(0, 0, 0, 0.6); backdrop-filter: blur(2px); }
dialog button { margin-top: 4px; }

/* ------ error block ------ */
.error {
  color: var(--error);
  padding: 10px 12px;
  background: var(--error-bg); border: 1px solid var(--error-line);
  border-radius: var(--r-md);
  margin: 8px 0; font-size: 13px;
}
.error pre { background: var(--bg-pre); color: var(--error); border: none; margin: 8px 0 0 0; }
