:root {
  --bg: #0f1117;
  --bg-2: #161922;
  --bg-3: #1f2330;
  --fg: #e6e8ee;
  --fg-2: #9aa0ad;
  --accent: #eb5202;
  --green: #16a34a;
  --red: #dc2626;
  --yellow: #ca8a04;
  --blue: #2563eb;
  --border: #2a2f3d;
}

*,*::before,*::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--fg); font-family: -apple-system, system-ui, Segoe UI, Roboto, sans-serif; font-size: 14px; line-height: 1.5; }
a { color: var(--blue); text-decoration: none; } a:hover { text-decoration: underline; }
button { font: inherit; cursor: pointer; }
input, textarea, select { font: inherit; }

.app { display: grid; grid-template-columns: 320px 1fr; min-height: 100vh; }
.sidebar { background: var(--bg-2); border-right: 1px solid var(--border); padding: 16px; overflow-y: auto; }
.sidebar-head h1 { margin: 0 0 4px; font-size: 16px; color: var(--accent); }
.sidebar-head small { color: var(--fg-2); font-size: 11px; }
.sidebar-head small a { color: var(--fg-2); }

.btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; background: var(--bg-3); color: var(--fg); border: 1px solid var(--border); border-radius: 6px; font-weight: 500; }
.btn:hover { border-color: var(--fg-2); }
.btn-primary { background: var(--accent); border-color: var(--accent); color: white; }
.btn-primary:hover { filter: brightness(1.1); border-color: var(--accent); }
#btnNew { width: 100%; margin: 12px 0; justify-content: center; }

.customer-list { list-style: none; padding: 0; margin: 0; }
.customer-list li a { display: grid; grid-template-columns: 1fr auto; gap: 4px 8px; padding: 10px 12px; border-radius: 6px; color: var(--fg); }
.customer-list li a:hover { background: var(--bg-3); text-decoration: none; }
.customer-list li a.active { background: var(--bg-3); border-left: 3px solid var(--accent); padding-left: 9px; }
.customer-list .slug { font-weight: 600; }
.customer-list .origin { color: var(--fg-2); font-size: 11px; grid-column: 1 / -1; }
.customer-list .empty { color: var(--fg-2); padding: 16px; }

.status { padding: 2px 8px; border-radius: 99px; font-size: 11px; font-weight: 500; background: var(--bg-3); }
.status-created { background: var(--bg-3); color: var(--fg-2); }
.status-scraped { background: rgba(37,99,235,.2); color: #93c5fd; }
.status-staging { background: rgba(202,138,4,.2); color: #facc15; }
.status-live    { background: rgba(22,163,74,.2); color: #4ade80; }

.main { padding: 24px 32px; overflow-y: auto; }
.welcome { max-width: 700px; }
.welcome code { background: var(--bg-3); padding: 2px 6px; border-radius: 4px; }

.customer-head { display: flex; align-items: baseline; gap: 16px; margin-bottom: 24px; flex-wrap: wrap; }
.customer-head h2 { margin: 0; font-size: 22px; }
.customer-head .links a { font-size: 12px; color: var(--fg-2); margin-right: 12px; }
.customer-head .links a:hover { color: var(--accent); }

section { background: var(--bg-2); border: 1px solid var(--border); border-radius: 8px; padding: 18px; margin-bottom: 20px; }
section h3 { margin: 0 0 14px; font-size: 13px; text-transform: uppercase; letter-spacing: .05em; color: var(--fg-2); font-weight: 600; }

.stages { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 8px; }
.stage { display: grid; gap: 4px; padding: 14px 12px; background: var(--bg-3); border: 1px solid var(--border); border-radius: 8px; text-align: left; color: var(--fg); transition: all .15s; }
.stages-manual .stage:hover { border-color: var(--accent); transform: translateY(-1px); cursor: pointer; }
.stage:disabled { opacity: .5; cursor: not-allowed; }
.stage-label { font-weight: 600; font-size: 14px; }
.stage-status { font-size: 10px; text-transform: uppercase; color: var(--fg-2); letter-spacing: .05em; }
.stage-desc { font-size: 11px; color: var(--fg-2); }
.stage-running { border-color: var(--yellow); animation: pulse 1.4s ease-in-out infinite; }
.stage-running .stage-status { color: var(--yellow); }
.stage-success { border-color: var(--green); }
.stage-success .stage-status { color: var(--green); }
.stage-failed  { border-color: var(--red); }
.stage-failed .stage-status { color: var(--red); }
@keyframes pulse { 0%,100% { box-shadow: 0 0 0 0 rgba(202,138,4,.5);} 50% { box-shadow: 0 0 0 6px rgba(202,138,4,0);} }

.agent-launch { background: linear-gradient(135deg, rgba(235,82,2,.08), rgba(235,82,2,.02)); border: 1px solid rgba(235,82,2,.3); }
.agent-row { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.agent-row > div { flex: 1; }
.agent-row p { margin: 4px 0 0; }
.btn-lg { padding: 14px 28px; font-size: 15px; }
.muted { color: var(--fg-2); font-weight: normal; font-size: 12px; }
section.pipeline h3 .muted { margin-left: 6px; text-transform: none; letter-spacing: 0; }

details.advanced { background: var(--bg-2); border: 1px solid var(--border); border-radius: 8px; padding: 12px 18px; margin-bottom: 20px; }
details.advanced summary { cursor: pointer; color: var(--fg-2); font-size: 12px; }
details.advanced[open] summary { margin-bottom: 12px; }

#logViewer { background: #000; color: #e6e8ee; padding: 14px; border-radius: 6px; max-height: 400px; min-height: 200px; overflow-y: auto; font-family: ui-monospace, SF Mono, Menlo, monospace; font-size: 12px; line-height: 1.45; white-space: pre-wrap; word-break: break-all; }
#liveJobBadge { display: none; padding: 2px 8px; border-radius: 99px; background: var(--yellow); color: black; font-size: 10px; margin-left: 8px; }
#liveJobBadge.active { display: inline-block; }

.compare-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.compare-grid h4 { margin: 0 0 8px; color: var(--fg-2); font-size: 12px; }
.compare-grid img { width: 100%; border-radius: 6px; border: 1px solid var(--border); display: block; }
.placeholder { background: var(--bg-3); border: 1px dashed var(--border); border-radius: 6px; padding: 60px 20px; text-align: center; color: var(--fg-2); }

table { width: 100%; border-collapse: collapse; font-size: 13px; }
th, td { padding: 8px 10px; border-bottom: 1px solid var(--border); text-align: left; }
th { color: var(--fg-2); font-weight: 600; font-size: 11px; text-transform: uppercase; }
td.empty { color: var(--fg-2); text-align: center; padding: 24px; }

.badge { padding: 2px 8px; border-radius: 99px; font-size: 11px; }
.badge-running { background: rgba(202,138,4,.2); color: #facc15; }
.badge-success { background: rgba(22,163,74,.2); color: #4ade80; }
.badge-failed  { background: rgba(220,38,38,.2); color: #fca5a5; }
.badge-queued  { background: rgba(37,99,235,.2); color: #93c5fd; }

.link { background: none; border: none; color: var(--blue); padding: 0; cursor: pointer; }
.link:hover { text-decoration: underline; }

dialog { background: var(--bg-2); color: var(--fg); border: 1px solid var(--border); border-radius: 12px; padding: 0; max-width: 480px; width: 90%; }
dialog::backdrop { background: rgba(0,0,0,.6); }
dialog form { padding: 24px; }
dialog h2 { margin: 0 0 16px; }
dialog label { display: block; margin-bottom: 14px; font-size: 12px; color: var(--fg-2); }
dialog label small { color: var(--fg-2); margin-left: 6px; font-weight: normal; }
dialog input { width: 100%; margin-top: 4px; padding: 10px 12px; background: var(--bg-3); border: 1px solid var(--border); border-radius: 6px; color: var(--fg); }
dialog input:focus { outline: none; border-color: var(--accent); }
dialog .row { display: flex; gap: 8px; justify-content: flex-end; margin-top: 16px; }
.form-error { background: rgba(220,38,38,.12); border: 1px solid rgba(220,38,38,.4); color: #fca5a5; padding: 10px 12px; border-radius: 6px; margin: 0 0 12px; font-size: 12px; }
dialog button { padding: 8px 16px; background: var(--bg-3); border: 1px solid var(--border); border-radius: 6px; color: var(--fg); }
dialog button.btn-primary { background: var(--accent); border-color: var(--accent); color: white; }

.login-page { background: var(--bg); min-height: 100vh; display: grid; place-items: center; }
.login-card { background: var(--bg-2); border: 1px solid var(--border); border-radius: 12px; padding: 32px; width: 360px; }
.login-card h1 { margin: 0 0 20px; color: var(--accent); font-size: 18px; }
.login-card label { display: block; margin-bottom: 14px; font-size: 12px; color: var(--fg-2); }
.login-card input { width: 100%; margin-top: 4px; padding: 10px 12px; background: var(--bg-3); border: 1px solid var(--border); border-radius: 6px; color: var(--fg); }
.login-card .btn-primary { width: 100%; padding: 10px; margin-top: 8px; background: var(--accent); border: none; color: white; border-radius: 6px; font-weight: 600; }
.login-card .error { color: var(--red); padding: 8px 12px; background: rgba(220,38,38,.1); border-radius: 6px; margin-bottom: 16px; font-size: 12px; }
.login-card .hint { font-size: 11px; color: var(--fg-2); margin-top: 18px; }
.login-card code { background: var(--bg-3); padding: 1px 5px; border-radius: 3px; }
