:root{
  --bg:#0f1419; --panel:#1a212b; --panel2:#222c38; --line:#2c3947;
  --txt:#e7edf3; --muted:#8aa0b4; --accent:#4f9cf9; --accent2:#2f7de0;
  --ok:#3ecf8e; --err:#ff6b6b; --radius:12px;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--txt);line-height:1.5}
h1,h2,h3{font-weight:650;margin:.2em 0 .5em}
small{font-size:.8rem}
code{background:#0008;padding:1px 5px;border-radius:5px}
.muted{color:var(--muted)}
.hidden{display:none !important}
.ok{color:var(--ok)} .err{color:var(--err)}

/* Login */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-card{background:var(--panel);padding:36px 32px;border-radius:var(--radius);
  width:340px;border:1px solid var(--line);display:flex;flex-direction:column;gap:14px;text-align:center}
.login-card input{padding:12px;border-radius:8px;border:1px solid var(--line);background:var(--panel2);color:var(--txt)}

/* Topbar */
.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 22px;
  background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.brand{font-size:1.15rem;font-weight:700}
.brand span{color:var(--accent)}
.top-right{display:flex;align-items:center;gap:14px}

main{max-width:920px;margin:24px auto;padding:0 18px;display:flex;flex-direction:column;gap:18px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px}

/* Buchwahl */
.book-choice{display:flex;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.book-tile{flex:1;min-width:220px;display:flex;gap:10px;align-items:center;cursor:pointer;
  background:var(--panel2);border:2px solid var(--line);border-radius:10px;padding:14px}
.book-tile:has(input:checked){border-color:var(--accent)}
.book-tile input{accent-color:var(--accent)}
.book-tile small{display:block;color:var(--muted)}

/* Formular */
.param-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:5px;font-size:.9rem}
.field span{color:var(--muted)}
.field input,.field select,textarea{padding:10px;border-radius:8px;border:1px solid var(--line);
  background:var(--panel2);color:var(--txt);font-size:.95rem;width:100%;font-family:inherit}
textarea{resize:vertical}

/* Buttons */
button{cursor:pointer;border:1px solid var(--line);background:var(--panel2);color:var(--txt);
  padding:10px 16px;border-radius:8px;font-size:.92rem;font-weight:550}
button:hover{border-color:var(--accent)}
button.primary{background:var(--accent2);border-color:var(--accent2);color:#fff}
button.primary:hover{background:var(--accent)}
button.ghost{background:transparent}
button.sm{padding:3px 9px;font-size:.78rem}
.actions{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}

/* Steps */
.steps{display:flex;gap:8px;flex-wrap:wrap;padding:0 4px}
.step{display:flex;align-items:center;gap:7px;background:var(--panel);border:1px solid var(--line);
  border-radius:30px;padding:6px 14px;font-size:.85rem;color:var(--muted)}
.step .num{width:22px;height:22px;border-radius:50%;background:var(--panel2);display:grid;place-items:center;font-size:.75rem}
.step.active{color:var(--txt);border-color:var(--accent)}
.step.active .num{background:var(--accent2);color:#fff}
.step.done .num{background:var(--ok);color:#04210f}

/* Log */
.log-head{display:flex;justify-content:space-between;font-size:.85rem;margin:14px 0 6px}
.log{background:#0a0e13;border:1px solid var(--line);border-radius:8px;padding:12px;
  max-height:320px;overflow:auto;font-family:ui-monospace,Menlo,monospace;font-size:.8rem;white-space:pre-wrap}

/* Gate */
.gate{margin-top:18px;display:flex;flex-direction:column;gap:14px}
.pdfbox .pdf{width:100%;height:520px;border:1px solid var(--line);border-radius:8px;background:#fff}
.preview{max-width:100%;border:1px solid var(--line);border-radius:8px}
.imggrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}
.imggrid img{width:100%;border:1px solid var(--line);border-radius:6px;background:#fff;cursor:pointer;aspect-ratio:1;object-fit:contain}
.filelinks{display:flex;gap:14px;margin-top:8px;font-size:.85rem}
.filelinks a{color:var(--accent)}
.md{background:#0a0e13;border:1px solid var(--line);border-radius:8px;padding:14px;
  max-height:480px;overflow:auto;font-size:.82rem;white-space:pre-wrap}
.wordlists{display:flex;flex-direction:column;gap:10px}
.wl{background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:10px 12px;font-size:.88rem}

/* Bilderliste mit Einzel-Korrektur */
.scenes{display:flex;flex-direction:column;gap:12px}
.scene-card{display:flex;gap:14px;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:12px}
.scene-img{flex:0 0 150px;width:150px}
.scene-img img{width:100%;aspect-ratio:17/22;object-fit:contain;background:#fff;border:1px solid var(--line);border-radius:6px;cursor:pointer}
.scene-img.empty{display:flex;align-items:center;justify-content:center;min-height:150px;border:1px dashed var(--line);border-radius:6px;color:var(--muted)}
.scene-img.empty::after{content:"kein Bild"}
.scene-body{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}
.scene-h{font-size:.95rem}
.scene-prompt{font-size:.82rem}
.scene-bar{display:flex;align-items:center;gap:12px}
.scene-status{font-size:.82rem}

@media(max-width:640px){ .param-grid{grid-template-columns:1fr} .scene-card{flex-direction:column} .scene-img{width:100%;flex-basis:auto} }
