:root {
  --bg: #0e1014;
  --panel: #181b22;
  --panel-2: #20242d;
  --text: #e9ecf1;
  --muted: #9aa3b2;
  --accent: #6c8cff;
  --green: #2ec27e;
  --border: #2a2f3a;
  --radius: 12px;
}
* { box-sizing: border-box; }
body {
  margin: 0; background: var(--bg); color: var(--text);
  font: 15px/1.5 -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 10px;
  padding: 14px 22px; background: var(--panel); border-bottom: 1px solid var(--border);
}
.brand { font-size: 20px; font-weight: 700; }
.status { display: flex; gap: 6px; flex-wrap: wrap; }
.chip {
  font-size: 12px; padding: 3px 9px; border-radius: 999px;
  background: var(--panel-2); border: 1px solid var(--border);
}
.chip.on { color: var(--green); border-color: rgba(46,194,126,.4); }
.chip.off { color: var(--muted); opacity: .7; }

main { max-width: 820px; margin: 0 auto; padding: 24px 18px 80px; }
.lede { color: var(--muted); margin-top: 4px; }

.hidden { display: none !important; }
.setup {
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 16px 18px; margin: 14px 0;
}
.setup h3 { margin: 0 0 8px; }
.setup ol { margin: 0 0 12px; padding-left: 20px; }
.setup ol li { margin-bottom: 4px; }
.setup input {
  display: block; width: 100%; margin-bottom: 8px; padding: 10px 12px;
  border-radius: 8px; border: 1px solid var(--border);
  background: var(--panel-2); color: var(--text); font-size: 14px;
}
.setup-actions { display: flex; align-items: center; gap: 12px; }
#setupBtn { color: var(--text); }

.tabs { display: flex; gap: 6px; margin: 18px 0 14px; }
.tab {
  background: var(--panel); color: var(--muted); border: 1px solid var(--border);
  padding: 9px 16px; border-radius: 10px; cursor: pointer; font-size: 14px;
}
.tab.active { color: var(--text); border-color: var(--accent); background: var(--panel-2); }

.panel { display: none; }
.panel.active { display: block; }

.dropzone {
  display: block; border: 2px dashed var(--border); border-radius: var(--radius);
  padding: 40px 20px; text-align: center; cursor: pointer; background: var(--panel);
  transition: border-color .15s, background .15s;
}
.dropzone:hover, .dropzone.drag { border-color: var(--accent); background: var(--panel-2); }
.dz-icon { font-size: 34px; margin-bottom: 8px; }
.hint { color: var(--muted); font-size: 13px; margin-top: 6px; }
code { background: var(--panel-2); padding: 1px 6px; border-radius: 6px; }

.folder-row { display: flex; gap: 8px; margin-top: 6px; }
#folderInput {
  flex: 1; padding: 11px 12px; border-radius: 10px; border: 1px solid var(--border);
  background: var(--panel); color: var(--text); font-size: 14px;
}
.primary {
  background: var(--accent); color: #fff; border: none; padding: 11px 18px;
  border-radius: 10px; cursor: pointer; font-weight: 600;
}
.primary:disabled { opacity: .5; cursor: default; }

.progress { display: flex; align-items: center; gap: 12px; margin-top: 14px; }
.progress.hidden { display: none; }
.bar { flex: 1; height: 8px; background: var(--panel-2); border-radius: 999px; overflow: hidden; }
.bar-fill { height: 100%; width: 0; background: var(--accent); transition: width .25s; }
#progressText { color: var(--muted); font-size: 13px; white-space: nowrap; }

.results { margin-top: 22px; display: flex; flex-direction: column; gap: 14px; }
.card {
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 16px;
}
.card-head { display: flex; gap: 14px; align-items: center; }
.art { width: 64px; height: 64px; border-radius: 8px; object-fit: cover; flex: none; }
.info .title { font-weight: 700; font-size: 16px; }
.info .sub { color: var(--muted); }
.meta-src { font-size: 12px; color: var(--muted); margin-top: 3px; }
.preview { width: 100%; margin-top: 12px; height: 38px; }

.platforms { margin-top: 12px; display: flex; flex-direction: column; gap: 8px; }
.prow {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  background: var(--panel-2); border: 1px solid var(--border);
  border-radius: 10px; padding: 9px 11px;
}
.pname { font-weight: 600; min-width: 9