:root {
  --bg: #0f0a1f;
  --panel: #1a0f33;
  --panel-2: #251847;
  --border: #2e1f5c;
  --text: #f4f1ff;
  --muted: #9a8fc4;
  --accent: #7c5cff;
  --accent-2: #ffd24a;
  --ok: #4ade80;
  --warn: #fbbf24;
  --err: #f87171;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--text); font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; }
.screen { min-height: 100vh; padding: 24px; max-width: 1100px; margin: 0 auto; }
.hidden { display: none !important; }

header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; gap: 16px; }
header h1 { font-size: 22px; margin: 0; }

.card { background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 20px; margin-bottom: 24px; }
.card.narrow { max-width: 380px; margin: 10vh auto; }
.card h2 { margin: 0 0 16px; font-size: 18px; }

.grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; align-items: end; }
.grid .wide { grid-column: 1 / -1; }
.grid button { grid-column: 1 / -1; }

label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--muted); }

input[type=text], input[type=url], input[type=password] {
  background: var(--panel-2);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 10px 12px;
  border-radius: 8px;
  font-size: 15px;
  outline: none;
}
input:focus { border-color: var(--accent); }

button {
  background: var(--accent);
  color: white;
  border: none;
  padding: 10px 16px;
  border-radius: 8px;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
}
button:hover { filter: brightness(1.1); }
button.ghost { background: transparent; border: 1px solid var(--border); color: var(--muted); }
button.danger { background: transparent; border: 1px solid var(--err); color: var(--err); }

.error { color: var(--err); margin-top: 8px; min-height: 18px; font-size: 13px; }
.muted { color: var(--muted); font-size: 13px; }

.badge { display: inline-block; padding: 4px 10px; border-radius: 999px; font-size: 12px; font-weight: 600; background: var(--panel-2); margin-right: 8px; }
.badge.queued { color: var(--muted); }
.badge.downloading { color: #60a5fa; }
.badge.uploading { color: var(--accent-2); }
.badge.done { color: var(--ok); }
.badge.failed { color: var(--err); }
.badge.cancelled { color: var(--muted); }

.jobs { display: flex; flex-direction: column; gap: 14px; }
.job { background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 16px; }
.job-head { display: flex; justify-content: space-between; align-items: center; gap: 8px; flex-wrap: wrap; }
.job-title { font-weight: 700; font-size: 15px; }
.job-source { color: var(--muted); font-size: 12px; word-break: break-all; margin-top: 2px; }
.job-actions { display: flex; gap: 6px; }

.bar { background: var(--panel-2); border-radius: 999px; height: 8px; overflow: hidden; margin-top: 10px; }
.bar > div { background: linear-gradient(90deg, var(--accent), var(--accent-2)); height: 100%; transition: width 200ms; }

.progress-row { display: flex; justify-content: space-between; font-size: 12px; color: var(--muted); margin-top: 6px; }

.urls { background: var(--panel-2); border-radius: 8px; padding: 10px; margin-top: 12px; font-size: 12px; }
.urls .row { display: flex; gap: 8px; align-items: center; padding: 4px 0; }
.urls .row .k { color: var(--muted); min-width: 80px; }
.urls .row code { background: var(--bg); padding: 4px 6px; border-radius: 4px; flex: 1; word-break: break-all; }
.urls .row .copy { background: var(--accent); color: white; border: none; padding: 4px 10px; border-radius: 4px; cursor: pointer; font-size: 11px; }
