:root{
  --bg:#0f1220; --card:#191d2e; --card2:#21263b; --line:#2b3147;
  --txt:#e8ebf5; --muted:#9aa3bf; --pri:#4f7cff; --pri2:#3a63e0;
  --ok:#34c759; --warn:#ffb020; --err:#ff5c5c;
}
*{box-sizing:border-box}
body{margin:0;background:linear-gradient(180deg,#0c0f1c,#0f1220);color:var(--txt);
  font:15px/1.5 -apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
a{color:var(--pri);text-decoration:none}
code{background:#0c0f1c;border:1px solid var(--line);border-radius:5px;padding:1px 6px;font-size:.9em}
.topbar{display:flex;align-items:baseline;gap:14px;padding:18px 28px;border-bottom:1px solid var(--line);
  background:#12162400;position:sticky;top:0;backdrop-filter:blur(6px);z-index:5}
.brand{font-size:19px;font-weight:700}
.muted{color:var(--muted)} .small{font-size:.86em}
.wrap{max-width:1000px;margin:0 auto;padding:22px;display:grid;gap:18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 20px;
  box-shadow:0 6px 24px rgba(0,0,0,.25)}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.card-head h2{font-size:16px;margin:0}
.badge{font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;background:var(--card2);
  border:1px solid var(--line);color:var(--muted)}
.badge.running{background:#16335c;color:#9cc1ff;border-color:#27508f}
.badge.done{background:#123a23;color:#79e29b;border-color:#1d6038}
.badge.failed,.badge.error{background:#3a1620;color:#ff9aa2;border-color:#6e2330}
.badge.idle{background:#21263b;color:var(--muted)}
.progress{height:8px;background:#0c0f1c;border:1px solid var(--line);border-radius:99px;overflow:hidden;margin:6px 0}
.bar{height:100%;width:0;background:linear-gradient(90deg,var(--pri),#7aa0ff);transition:width .4s ease}
.current{margin:2px 0 12px;min-height:1.1em}
.stats{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin:6px 0 16px}
.stats div{background:var(--card2);border:1px solid var(--line);border-radius:10px;padding:10px;text-align:center}
.stats b{display:block;font-size:22px} .stats span{font-size:11px;color:var(--muted)}
.actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}
.btn{display:inline-flex;align-items:center;gap:6px;background:var(--card2);border:1px solid var(--line);
  color:var(--txt);padding:9px 14px;border-radius:10px;cursor:pointer;font-size:14px;font-weight:600}
.btn:hover{border-color:#3b466a}
.btn.primary{background:var(--pri);border-color:var(--pri2)}
.btn.primary:hover{background:var(--pri2)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.runs{width:100%;border-collapse:collapse;font-size:14px}
.runs th,.runs td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--line)}
.runs th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:7px;background:var(--muted);vertical-align:middle}
.dot.done{background:var(--ok)} .dot.failed,.dot.error{background:var(--err)} .dot.running{background:var(--pri)}
.log{background:#0a0d18;border:1px solid var(--line);border-radius:10px;padding:12px;max-height:340px;
  overflow:auto;font:12.5px/1.5 ui-monospace,Consolas,Menlo,monospace;white-space:pre-wrap;color:#c7d0ea;margin:0}
pre.code{background:#0a0d18;border:1px solid var(--line);border-radius:8px;padding:8px 12px;margin:6px 0;
  font:13px ui-monospace,Consolas,monospace;color:#c7d0ea}
/* Bestandsbrowser */
.crumbs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;font-size:14px}
.crumbs a::after{content:'/';margin-left:6px;color:var(--muted)}
.filelist{list-style:none;margin:0;padding:0}
.filelist li{display:flex;align-items:center;gap:10px;padding:9px 8px;border-bottom:1px solid var(--line)}
.filelist li:hover{background:var(--card2)}
.filelist .name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.filelist .sz{color:var(--muted);font-size:12px;min-width:70px;text-align:right}
.ic{width:20px;text-align:center}
.preview img{max-width:100%;border:1px solid var(--line);border-radius:8px}
.preview pre,.preview .md{background:#0a0d18;border:1px solid var(--line);border-radius:10px;padding:16px;
  overflow:auto;max-height:75vh}
.md{line-height:1.6} .md table{border-collapse:collapse} .md td,.md th{border:1px solid var(--line);padding:4px 8px}
@media(max-width:720px){.stats{grid-template-columns:repeat(3,1fr)}}
