:root{
  --purple:#694BFF;
  --purple-dark:#4f37cc;
  --bg:#ffffff;
  --ink:#111111;
  --muted:#666;
  --line:#eee;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Nunito',system-ui,-apple-system,'Segoe UI',Arial,sans-serif;
  color:var(--ink);background:var(--bg);
  line-height:1.5;-webkit-font-smoothing:antialiased;
}
.wrap{max-width:900px;margin:0 auto;padding:20px}
.bar{background:var(--purple);color:#fff;padding:16px 20px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.bar h1{font-size:20px;font-weight:800;letter-spacing:.3px}
.bar .spacer{flex:1}
.tag{background:rgba(255,255,255,.18);padding:4px 10px;border-radius:999px;font-size:13px;font-weight:700}
.card{border:2px solid var(--line);border-radius:16px;padding:18px;margin:16px 0;background:#fff}
.task-banner{background:#f4f1ff;border:2px solid var(--purple);border-radius:16px;padding:14px 18px;margin:16px 0}
.task-banner .k{font-size:13px;font-weight:800;color:var(--purple);text-transform:uppercase;letter-spacing:1px}
.task-banner .v{font-size:20px;font-weight:800}
label{display:block;font-weight:800;margin:10px 0 6px}
textarea,input[type=text],input[type=password],select{
  width:100%;font:inherit;padding:12px 14px;border:2px solid var(--line);border-radius:12px;outline:none
}
textarea:focus,input:focus,select:focus{border-color:var(--purple)}
textarea{min-height:96px;resize:vertical}
button{
  font:inherit;font-weight:800;cursor:pointer;border:none;border-radius:999px;
  padding:12px 22px;background:var(--purple);color:#fff;transition:transform .05s, background .15s
}
button:hover{background:var(--purple-dark)}
button:active{transform:translateY(1px)}
button.ghost{background:#fff;color:var(--purple);border:2px solid var(--purple)}
button.small{padding:8px 14px;font-size:14px}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.result-img{max-width:100%;border-radius:12px;border:2px solid var(--line)}
.story-text{white-space:pre-wrap;background:#faf9ff;border:2px solid var(--line);border-radius:12px;padding:14px}
.muted{color:var(--muted)}
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.gallery .item{cursor:zoom-in}
/* Galerie-Zeilen pro Modus (horizontal scrollbar) */
.galrow{display:flex;gap:16px;overflow-x:auto;padding:4px 2px 14px}
.galrow .item{flex:0 0 240px;cursor:zoom-in}
.galrow .item .result-img{max-height:220px;width:100%;object-fit:contain;background:#faf9ff}
.galrow .item .story-text{max-height:220px;overflow:auto}
.galrow-title{font-weight:800;color:var(--purple);margin:18px 0 4px}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.86);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;cursor:zoom-out}
.lightbox img{max-width:96%;max-height:96%;border-radius:8px;box-shadow:0 0 50px rgba(0,0,0,.5)}
.gallery .item{border:2px solid var(--line);border-radius:14px;overflow:hidden;background:#fff}
.gallery .item .head{background:var(--purple);color:#fff;padding:8px 12px;font-weight:800}
.gallery .item .body{padding:12px}
.gallery .item .prompt{font-size:13px;color:var(--muted);margin-top:8px;border-top:1px dashed var(--line);padding-top:8px}
.sub{border:2px solid var(--line);border-radius:14px;padding:12px;margin:10px 0;display:flex;gap:12px;align-items:flex-start}
.sub .thumb{width:90px;flex:0 0 90px}
.sub .thumb img{width:100%;border-radius:8px}
.sub .meta{flex:1;min-width:0}
.badge{display:inline-block;font-size:12px;font-weight:800;padding:3px 8px;border-radius:999px}
.badge.on{background:#e7ffe9;color:#1e8449;border:1px solid #1e8449}
.badge.off{background:#fff3f3;color:#c0392b;border:1px solid #c0392b}
.hidden{display:none}
.center{text-align:center}
/* Chat */
.chat{border:2px solid var(--line);border-radius:14px;padding:12px;max-height:48vh;overflow-y:auto;background:#fafafe}
.msg{margin:8px 0;display:flex}
.msg .bubble{padding:10px 14px;border-radius:14px;max-width:80%;white-space:pre-wrap}
.msg.user{justify-content:flex-end}
.msg.user .bubble{background:var(--purple);color:#fff;border-bottom-right-radius:4px}
.msg.ai .bubble{background:#fff;border:2px solid var(--line);border-bottom-left-radius:4px}
.modus-pill{background:#fff;color:var(--purple);border:2px solid #fff;border-radius:999px;padding:4px 12px;font-weight:800}
.big-join{max-width:460px;margin:8vh auto;text-align:center}
.big-join h1{color:var(--purple);font-size:30px;font-weight:800;margin-bottom:6px}
.spin{color:var(--muted);font-style:italic}
