/* Bosun Control – PM-Cockpit. Design erbt das Bosun-One-System:
   Graphit + Indigo-Akzent, Domänenfarben, Linien-Icons, Inter. */
:root{
  --ind:#7d8cf5; --green:#3fcf8e; --blue:#4aa8f0; --amber:#e6a44c; --red:#e8615f;
  --violet:#a98bf0; --teal:#3bc9c0;
  --txt:#eef1f7; --txt2:#a6afc0; --txt3:#677085; --line:rgba(255,255,255,.07);
  --bg:#080b11; --panel:linear-gradient(180deg,#141b27,#0f151f);
  --card:#101622; --card2:#0c111a;
  --radius:16px;
}
*{margin:0;padding:0;box-sizing:border-box;font-family:'Inter',system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased}
html,body{height:100%}
body{color:var(--txt);background:radial-gradient(120% 90% at 82% -10%,#19223a 0%,#0a0e15 50%),var(--bg);overflow:hidden}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
a{color:inherit;text-decoration:none}
.i{stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;width:20px;height:20px;flex-shrink:0}
.hidden{display:none!important}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.09);border-radius:6px}

#app{display:flex;height:100%}

/* ───── Sidebar ───── */
#side{width:240px;flex-shrink:0;border-right:1px solid var(--line);display:flex;flex-direction:column;padding:18px 14px;background:rgba(8,11,17,.5)}
.brand{display:flex;align-items:center;gap:11px;padding:4px 8px 22px}
.logo{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#8b99ff,#4a5ce0);box-shadow:0 6px 18px rgba(80,98,230,.4);position:relative}
.logo::after{content:"";position:absolute;inset:9px;border:2px solid rgba(255,255,255,.85);border-radius:3px;border-bottom-color:transparent;transform:rotate(45deg)}
.bt{font-size:1.15rem;font-weight:800;letter-spacing:-.4px}
.bt span{color:var(--ind);margin-left:4px;font-weight:700}
#nav{display:flex;flex-direction:column;gap:3px;flex:1}
.navi{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:11px;color:var(--txt2);font-size:.9rem;font-weight:500}
.navi:hover{background:rgba(255,255,255,.04);color:var(--txt)}
.navi.on{background:rgba(125,140,245,.14);color:#cdd4ff}
.navi .i{width:19px;height:19px}
.navi .ct{margin-left:auto;font-size:.7rem;background:rgba(255,255,255,.08);color:var(--txt2);padding:1px 7px;border-radius:8px;font-weight:600}
.side-foot{display:flex;flex-direction:column;gap:7px;padding:12px 8px 2px;border-top:1px solid var(--line)}
.stat{display:flex;align-items:center;gap:8px;font-size:.72rem;color:var(--txt3);font-weight:500}
.stat .dot{width:7px;height:7px;border-radius:50%;background:var(--green)}
.stat .dot.warn{background:var(--amber)}

/* ───── Main ───── */
#main{flex:1;display:flex;flex-direction:column;min-width:0}
#top{display:flex;align-items:center;gap:14px;padding:16px 26px;border-bottom:1px solid var(--line)}
.crumb{font-size:1.05rem;font-weight:700;letter-spacing:-.3px}
.crumb small{color:var(--txt3);font-weight:500;margin-left:8px;font-size:.8rem}
#top .sp{flex:1}
.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 15px;border-radius:11px;font-size:.83rem;font-weight:600;background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--txt)}
.btn:hover{background:rgba(255,255,255,.09)}
.btn.primary{background:linear-gradient(135deg,#8b99ff,#4a5ce0);border-color:transparent;color:#fff;box-shadow:0 6px 18px rgba(80,98,230,.32)}
.btn .i{width:17px;height:17px}
#view{flex:1;overflow:auto;padding:22px 26px 40px}

/* ───── Board: Tabs + Übersicht ───── */
.board-wrap{display:flex;flex-direction:column;height:100%;gap:14px}
.board-tabs{display:flex;gap:8px;flex-wrap:wrap;flex-shrink:0}
.btab{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:11px;font-size:.82rem;font-weight:600;color:var(--txt2);background:rgba(255,255,255,.04);border:1px solid var(--line)}
.btab .i{width:15px;height:15px}
.btab .cdot{width:8px;height:8px;border-radius:50%}
.btab .tico{display:inline-flex}
.btab .tico .i{width:16px;height:16px}
.btab:hover{color:var(--txt);background:rgba(255,255,255,.07)}
.btab.on{background:rgba(125,140,245,.16);border-color:rgba(125,140,245,.4);color:#cdd4ff}
.board-body{flex:1;min-height:0}

.ov-sum{display:flex;gap:30px;padding:16px 20px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:16px}
.ov-sum-k .v{font-size:1.7rem;font-weight:800;letter-spacing:-.6px;line-height:1}
.ov-sum-k .k{font-size:.72rem;color:var(--txt3);font-weight:600;margin-top:5px;text-transform:uppercase;letter-spacing:.04em}
.ov-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}
.ov-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 17px;cursor:pointer;transition:border-color .12s,transform .08s}
.ov-card:hover{border-color:rgba(125,140,245,.45);transform:translateY(-2px)}
.ov-h{display:flex;align-items:center;gap:9px;margin-bottom:13px}
.ov-h .cdot{width:9px;height:9px;border-radius:50%}
.ov-h .tico{display:inline-flex}
.ov-h .tico .i{width:18px;height:18px}
.ov-name{font-size:.95rem;font-weight:700;letter-spacing:-.2px}
.ov-ver{margin-left:auto;font-size:.7rem;font-weight:700;color:var(--txt2);background:rgba(255,255,255,.07);padding:2px 9px;border-radius:8px;font-variant-numeric:tabular-nums}
.ov-bar{height:8px;border-radius:5px;background:rgba(255,255,255,.07);overflow:hidden}
.ov-bar i{display:block;height:100%;border-radius:5px;transition:width .3s}
.ov-line{display:flex;justify-content:space-between;align-items:baseline;margin-top:8px;font-size:.78rem;color:var(--txt2)}
.ov-line b{font-size:.95rem;font-weight:800;color:var(--txt)}
.ov-chips{display:flex;gap:7px;flex-wrap:wrap;margin-top:13px}
.ov-chip{font-size:.68rem;font-weight:700;padding:3px 9px;border-radius:8px}
.ov-chip.bug{background:rgba(232,97,95,.16);color:var(--red)}
.ov-chip.feature{background:rgba(63,207,142,.16);color:var(--green)}
.ov-chip.act{background:rgba(125,140,245,.16);color:var(--ind)}
.ov-chip.done{background:rgba(63,207,142,.12);color:var(--green)}

/* ───── Board: Filter-/Suchleiste ───── */
.kfilter{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.ksearch{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:11px;padding:0 12px;min-width:240px}
.ksearch .i{width:17px;height:17px;color:var(--txt3);flex-shrink:0}
.ksearch input{background:none;border:none;outline:none;color:var(--txt);font-size:.85rem;padding:9px 0;width:100%}
.ksearch input::placeholder{color:var(--txt3)}
.chips{display:flex;gap:6px;flex-wrap:wrap}
.chip{padding:6px 12px;border-radius:9px;border:1px solid var(--line);background:rgba(255,255,255,.03);font-size:.76rem;font-weight:600;color:var(--txt2)}
.chip:hover{color:var(--txt);background:rgba(255,255,255,.06)}
.chip.on{border-color:var(--pa,var(--ind));color:var(--txt);background:color-mix(in srgb,var(--pa,var(--ind)) 16%,transparent)}

/* ───── Batch-Steuerung (Abarbeiten-Spalte) ───── */
.batch-ctl{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;margin-bottom:9px;background:rgba(230,164,76,.08);border:1px solid rgba(230,164,76,.22);border-radius:10px}
.bc-count{font-size:.78rem;font-weight:700;color:var(--amber);font-variant-numeric:tabular-nums}
.bc-count.ready{color:var(--green)}
.bc-run{font-size:.7rem;font-weight:700;padding:5px 10px;border-radius:8px;background:rgba(230,164,76,.2);color:var(--amber)}
.bc-run:hover{background:rgba(230,164,76,.3)}
.bc-run.dim{opacity:.4;pointer-events:none}

/* ───── Einstellungen (Anweisungen-Seite) ───── */
.set-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.set-lbl{font-size:.82rem;color:var(--txt2);min-width:190px}
.instr input[type=number]{width:90px;background:var(--card);border:1px solid var(--line);border-radius:9px;padding:8px 11px;color:var(--txt);font-size:.85rem}
.instr input[type=number]:focus{outline:none;border-color:var(--ind)}
.instr .panel h3{font-size:.95rem}
.instr .panel h3 .i{width:18px;height:18px;color:var(--ind)}

/* ───── Board: Kanban ───── */
.board{display:flex;gap:14px;align-items:flex-start;height:100%}
.col{flex:1;min-width:210px;max-width:340px;background:rgba(10,14,21,.6);border:1px solid var(--line);border-radius:var(--radius);display:flex;flex-direction:column;max-height:calc(100vh - 150px)}
.col.drag-over{border-color:var(--ind);box-shadow:0 0 0 1px var(--ind) inset}
.col-h{display:flex;align-items:center;gap:9px;padding:13px 14px 11px;font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.col-h .cdot{width:8px;height:8px;border-radius:50%}
.col-h .n{margin-left:auto;font-size:.72rem;color:var(--txt3);background:rgba(255,255,255,.06);padding:1px 8px;border-radius:8px}
.col-h.doing .lbl{color:var(--amber)}
.col-body{flex:1;overflow-y:auto;padding:4px 10px 12px;display:flex;flex-direction:column;gap:9px}
.col-body:empty::after{content:"–";color:var(--txt3);text-align:center;padding:18px 0;font-size:.8rem}

.card{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:12px;cursor:grab;transition:transform .08s,border-color .12s}
.card:hover{border-color:rgba(125,140,245,.4)}
.card.dragging{opacity:.5;cursor:grabbing}
.card .ct{font-size:.86rem;font-weight:600;line-height:1.35;margin-bottom:9px}
.card .cm{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.tag{font-size:.66rem;font-weight:700;padding:2px 8px;border-radius:7px;letter-spacing:.02em}
.tag.repo{background:rgba(255,255,255,.06);color:var(--txt2)}
.tag.bug{background:rgba(232,97,95,.16);color:var(--red)}
.tag.feature{background:rgba(63,207,142,.16);color:var(--green)}
.card .num{margin-left:auto;font-size:.7rem;color:var(--txt3);font-weight:600}

/* ───── generische Karten-Raster ───── */
.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:0 12px 30px rgba(0,0,0,.3)}
.panel h3{font-size:.95rem;font-weight:700;display:flex;align-items:center;gap:10px;margin-bottom:6px}
.panel .accbar{width:9px;height:9px;border-radius:50%}
.muted{color:var(--txt2);font-size:.83rem;line-height:1.55}
.kv{display:flex;align-items:baseline;gap:8px;margin-top:10px;font-size:.8rem}
.kv .k{color:var(--txt3);width:96px;flex-shrink:0}
.kv .v{font-weight:600}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:.68rem;font-weight:700;padding:3px 9px;border-radius:8px}
.pill.ok{background:rgba(63,207,142,.15);color:var(--green)}
.pill.upd{background:rgba(230,164,76,.16);color:var(--amber)}
.pill.miss{background:rgba(232,97,95,.15);color:var(--red)}

/* ───── Changelog / Docs (Markdown) ───── */
.md{font-size:.86rem;line-height:1.62;color:var(--txt2)}
.md h1{font-size:1.3rem;color:var(--txt);margin:.2em 0 .5em;letter-spacing:-.4px}
.md h2{font-size:1.08rem;color:var(--txt);margin:1.1em 0 .4em;padding-bottom:.25em;border-bottom:1px solid var(--line)}
.md h3{font-size:.96rem;color:var(--txt);margin:1em 0 .35em}
.md h4{font-size:.88rem;color:var(--txt);margin:.9em 0 .3em}
.md a{color:var(--ind)}
.md code{font-family:ui-monospace,Menlo,monospace;font-size:.82em;background:rgba(255,255,255,.07);padding:1px 6px;border-radius:6px;color:#cdd4ff}
.md pre{background:var(--card2);border:1px solid var(--line);border-radius:11px;padding:13px 15px;overflow:auto;margin:.6em 0}
.md pre code{background:none;padding:0;color:var(--txt2)}
.md ul,.md ol{padding-left:1.3em;margin:.4em 0}
.md li{margin:.22em 0}
.md table{border-collapse:collapse;width:100%;margin:.6em 0;font-size:.82rem}
.md th,.md td{border:1px solid var(--line);padding:6px 10px;text-align:left}
.md th{background:rgba(255,255,255,.04);color:var(--txt)}
.md blockquote{border-left:3px solid var(--ind);padding:.2em 0 .2em 14px;margin:.6em 0;color:var(--txt3)}
.md hr{border:none;border-top:1px solid var(--line);margin:1em 0}
.md strong{color:var(--txt)}

.doc-layout{display:flex;gap:18px;height:100%}
.doc-list{width:280px;flex-shrink:0;overflow-y:auto;padding-right:4px}
.doc-repo{margin-bottom:16px}
.doc-repo .rh{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--txt3);margin-bottom:6px;display:flex;align-items:center;gap:8px}
.doc-item{display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:10px;color:var(--txt2);font-size:.82rem;cursor:pointer}
.doc-item:hover{background:rgba(255,255,255,.04);color:var(--txt)}
.doc-item.on{background:rgba(125,140,245,.13);color:#cdd4ff}
.doc-view{flex:1;overflow-y:auto;background:var(--card2);border:1px solid var(--line);border-radius:var(--radius);padding:26px 30px}

.cl-grid{display:flex;flex-direction:column;gap:16px}

/* ───── Chat ───── */
.chat{display:flex;flex-direction:column;height:100%;max-width:860px;margin:0 auto;width:100%}
.chat-log{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:14px;padding:6px 2px 16px}
.msg{display:flex;gap:12px;max-width:88%}
.msg.user{align-self:flex-end;flex-direction:row-reverse}
.msg .av{width:30px;height:30px;border-radius:9px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700}
.msg.user .av{background:rgba(255,255,255,.08);color:var(--txt2)}
.msg.bot .av{background:linear-gradient(135deg,#8b99ff,#4a5ce0);color:#fff}
.bubble{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:11px 15px;font-size:.87rem;line-height:1.55}
.msg.user .bubble{background:rgba(125,140,245,.14);border-color:rgba(125,140,245,.25)}
.chat-in{display:flex;gap:10px;padding:12px 0 4px;border-top:1px solid var(--line)}
.chat-in textarea{flex:1;resize:none;background:var(--card);border:1px solid var(--line);border-radius:13px;padding:12px 14px;color:var(--txt);font-size:.88rem;max-height:140px}
.chat-in textarea:focus{outline:none;border-color:var(--ind)}

/* ───── Drawer (Work / Issue) ───── */
#drawer{position:fixed;top:0;right:0;bottom:0;width:520px;max-width:92vw;background:linear-gradient(180deg,#0f1623,#0b0f17);border-left:1px solid var(--line);box-shadow:-20px 0 60px rgba(0,0,0,.5);z-index:40;display:flex;flex-direction:column;animation:slide .22s ease}
@keyframes slide{from{transform:translateX(40px);opacity:.4}to{transform:none;opacity:1}}
.dw-h{display:flex;align-items:center;gap:12px;padding:18px 20px;border-bottom:1px solid var(--line)}
.dw-h .ti{font-size:.98rem;font-weight:700;line-height:1.3}
.dw-h .x{margin-left:auto;width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;color:var(--txt2)}
.dw-body{flex:1;overflow-y:auto;padding:18px 20px}
.work-log{display:flex;flex-direction:column;gap:9px}
.wl{display:flex;gap:11px;font-size:.83rem;align-items:flex-start}
.wl .ic{width:24px;height:24px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.wl.status .ic{background:rgba(125,140,245,.15);color:var(--ind)}
.wl.tool .ic{background:rgba(59,201,192,.15);color:var(--teal)}
.wl.text{color:var(--txt2);line-height:1.55}
.wl.text .ic{background:rgba(255,255,255,.05);color:var(--txt2)}
.wl.error .ic{background:rgba(232,97,95,.15);color:var(--red)}
.wl.error{color:var(--red)}
.wl .tx{padding-top:3px}
.wl.tool .tx{font-family:ui-monospace,Menlo,monospace;font-size:.78rem;color:var(--teal)}

/* ───── Form / Modal ───── */
.modal-bg{position:fixed;inset:0;background:rgba(4,6,10,.6);z-index:50;display:flex;align-items:center;justify-content:center;animation:fade .15s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{width:480px;max-width:92vw;background:linear-gradient(180deg,#141b27,#0f151f);border:1px solid var(--line);border-radius:20px;padding:22px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.modal h3{font-size:1.05rem;font-weight:700;margin-bottom:16px}
.field{margin-bottom:13px}
.field label{display:block;font-size:.74rem;color:var(--txt3);font-weight:600;margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}
.field input,.field textarea,.field select{width:100%;background:var(--card);border:1px solid var(--line);border-radius:11px;padding:10px 13px;color:var(--txt);font-size:.87rem}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--ind)}
.field textarea{resize:vertical;min-height:80px}
.seg{display:flex;gap:8px}
.seg button{flex:1;padding:9px;border-radius:10px;border:1px solid var(--line);background:var(--card);font-size:.8rem;font-weight:600;color:var(--txt2)}
.seg button.on{border-color:var(--ind);background:rgba(125,140,245,.14);color:#cdd4ff}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}

#toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:60;display:flex;flex-direction:column;gap:8px;align-items:center}
.tmsg{background:#1a2233;border:1px solid var(--line);border-radius:11px;padding:10px 18px;font-size:.82rem;box-shadow:0 12px 30px rgba(0,0,0,.4);animation:fade .15s}

/* ───── Prio / Badges auf Karten ───── */
.card.pr-critical{border-left:3px solid var(--red)}
.card.pr-high{border-left:3px solid var(--amber)}
.card.pr-medium{border-left:3px solid var(--blue)}
.card.pr-low{border-left:3px solid var(--txt3)}
.tag.prio.p-critical{background:rgba(232,97,95,.16);color:var(--red)}
.tag.prio.p-high{background:rgba(230,164,76,.16);color:var(--amber)}
.tag.prio.p-medium{background:rgba(74,168,240,.16);color:var(--blue)}
.tag.prio.p-low{background:rgba(255,255,255,.06);color:var(--txt3)}
.cm2{display:flex;gap:6px;flex-wrap:wrap;margin-top:9px}
.bdg{display:inline-flex;align-items:center;gap:5px;font-size:.66rem;font-weight:700;padding:3px 8px;border-radius:7px}
.bdg .i{width:12px;height:12px}
.b-green{background:rgba(63,207,142,.14);color:var(--green)}
.b-amber{background:rgba(230,164,76,.15);color:var(--amber)}
.b-red{background:rgba(232,97,95,.15);color:var(--red)}
.b-txt3{background:rgba(255,255,255,.06);color:var(--txt2)}

/* ───── Prio-Segment (Modal / Drawer) ───── */
.prio-seg{display:flex;gap:7px}
.prio-seg button{flex:1;padding:8px 4px;border-radius:9px;border:1px solid var(--line);background:var(--card);font-size:.74rem;font-weight:600;color:var(--txt2)}
.prio-seg button.on{border-color:var(--pa);color:var(--txt);background:color-mix(in srgb,var(--pa) 14%,transparent)}

/* ───── Drawer-Sektionen ───── */
.dw-sec{margin-bottom:16px}
.dw-lbl{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--txt3);margin-bottom:7px}

/* ───── Toggle (Katalog) ───── */
.toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:.72rem;color:var(--txt2);margin-left:auto}
.toggle input{display:none}
.toggle .tg{width:34px;height:19px;border-radius:11px;background:rgba(255,255,255,.12);position:relative;transition:background .15s}
.toggle .tg::after{content:"";position:absolute;top:2px;left:2px;width:15px;height:15px;border-radius:50%;background:#fff;transition:transform .15s}
.toggle input:checked + .tg{background:var(--green)}
.toggle input:checked + .tg::after{transform:translateX(15px)}

/* ───── CORE_NEEDS ───── */
.cn-head{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius)}
.cn-head .i{width:22px;height:22px;color:var(--teal);flex-shrink:0;margin-top:2px}

/* ───── Anweisungen ───── */
.instr{max-width:900px;margin:0 auto;width:100%}
.instr textarea{width:100%;min-height:60vh;background:var(--card2);border:1px solid var(--line);border-radius:14px;padding:18px 20px;color:var(--txt);font-family:ui-monospace,Menlo,monospace;font-size:.83rem;line-height:1.6;resize:vertical}
.instr textarea:focus{outline:none;border-color:var(--ind)}

/* ───── Login / 2FA-Gate ───── */
#gate{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(120% 90% at 50% -10%,#19223a 0%,#0a0e15 55%),var(--bg);padding:20px}
.gate-card{width:380px;max-width:94vw;background:linear-gradient(180deg,#141b27,#0f151f);border:1px solid var(--line);
  border-radius:22px;padding:30px 28px;box-shadow:0 30px 80px rgba(0,0,0,.55);text-align:center}
.gate-logo{width:46px;height:46px;border-radius:13px;margin:0 auto 14px;background:linear-gradient(135deg,#8b99ff,#4a5ce0);
  box-shadow:0 8px 22px rgba(80,98,230,.42);position:relative}
.gate-logo::after{content:"";position:absolute;inset:12px;border:2px solid rgba(255,255,255,.85);border-radius:4px;border-bottom-color:transparent;transform:rotate(45deg)}
.gate-card h2{font-size:1.3rem;font-weight:800;letter-spacing:-.5px}
.gate-card h2 span{color:var(--ind)}
.gate-sub{color:var(--txt2);font-size:.84rem;line-height:1.5;margin:8px 0 20px}
.gate-card input{width:100%;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px 14px;
  color:var(--txt);font-size:.9rem;margin-bottom:11px;text-align:center}
.gate-card input:focus{outline:none;border-color:var(--ind)}
.gate-btn{width:100%;justify-content:center;padding:12px;margin-top:4px}
.gate-err{color:var(--red);font-size:.8rem;min-height:1.1em;margin-top:10px}
.gate-qr{background:#fff;border-radius:14px;padding:12px;width:200px;margin:4px auto 12px}
.gate-qr svg{width:100%;height:auto;display:block}
.gate-secret{font-size:.74rem;color:var(--txt3);margin-bottom:14px;word-break:break-all}
.gate-secret code{color:#cdd4ff;background:rgba(255,255,255,.07);padding:2px 7px;border-radius:6px}

.empty{text-align:center;color:var(--txt3);padding:60px 0;font-size:.9rem}
.spin{width:26px;height:26px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--ind);border-radius:50%;animation:rot .8s linear infinite;margin:50px auto}
@keyframes rot{to{transform:rotate(360deg)}}

/* ───── Repos-Datei-Browser ───── */
.tnode{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:8px;font-size:.81rem;color:var(--txt2);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tnode:hover{background:rgba(255,255,255,.05);color:var(--txt)}
.tnode .tfi{width:15px;height:15px;flex-shrink:0;opacity:.8}
.tnode .tchev{width:13px;height:13px;flex-shrink:0;transition:transform .15s;opacity:.7}
.tdir.open>.tchev{transform:rotate(90deg)}
.tdir{font-weight:600;color:var(--txt)}
.tfile.on{background:rgba(125,140,245,.14);color:#cdd4ff}
.filehead{font-size:.74rem;color:var(--txt3);font-family:ui-monospace,monospace;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--line)}
pre.code{margin:0;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.8rem;line-height:1.55;color:var(--txt);white-space:pre;overflow-x:auto}
pre.code code{white-space:pre}

/* ───── Modell & Effort ───── */
.me-head,.me-row{display:grid;grid-template-columns:1fr 1.4fr .9fr;gap:12px;align-items:center}
.me-head{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--txt3);margin-bottom:8px;padding:0 2px}
.me-row{margin-bottom:10px}
.me-lbl{font-size:.85rem;color:var(--txt2);font-weight:600}
.me-row select{width:100%;padding:8px 10px;border-radius:9px;background:var(--card2);border:1px solid var(--line);color:var(--txt);font-size:.82rem}

/* ───── Chat-Kopf / Planungs-Banner ───── */
.chat-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 2px 12px;border-bottom:1px solid var(--line);margin-bottom:8px}
.plan-banner{display:flex;gap:12px;align-items:flex-start;background:rgba(125,140,245,.1);border:1px solid rgba(125,140,245,.3);border-radius:12px;padding:12px 14px;margin-bottom:14px}
.plan-banner>.i{width:18px;height:18px;flex-shrink:0;color:var(--ind);margin-top:1px}
.plan-banner .pb-body{flex:1}
.plan-banner .pb-notes{font-size:.82rem;color:var(--txt2);margin-top:5px;line-height:1.5}
.plan-banner .pb-x{background:none;border:none;color:var(--txt3);cursor:pointer;padding:2px}
.plan-banner .pb-x:hover{color:var(--txt)}
.plan-banner .pb-x .i{width:15px;height:15px}

/* ───── Claude-Login-Flow ───── */
.cl-flow{margin-top:14px}
.cl-flow.hidden{display:none}
.cl-url{font-size:.86rem;color:var(--txt);margin-bottom:10px}
.cl-url a{color:var(--ind);font-weight:600}
.cl-console{background:#05080d;border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.78rem;line-height:1.5;color:#b9c4d6;max-height:240px;overflow:auto;white-space:pre-wrap;word-break:break-word;margin-bottom:10px}
.cl-sum{cursor:pointer;color:var(--txt3);font-size:.82rem}
.cl-sum:hover{color:var(--txt2)}

/* ───── Vorhaben ───── */
.init-head{margin-bottom:16px}
.init-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.init-card{background:var(--card2);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;cursor:pointer;transition:border-color .15s,transform .1s}
.init-card:hover{border-color:rgba(125,140,245,.5);transform:translateY(-1px)}
.ic-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.ic-title{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--txt);margin-bottom:6px}
.ic-title .i{width:16px;height:16px;color:var(--ind);flex-shrink:0}
.ic-goal{font-size:.82rem;color:var(--txt2);line-height:1.45;min-height:34px}
.ic-foot{font-size:.74rem;margin-top:8px}
.badge{font-size:.7rem;font-weight:700;padding:2px 9px;border-radius:20px;color:var(--c);background:color-mix(in srgb,var(--c) 16%,transparent);border:1px solid color-mix(in srgb,var(--c) 35%,transparent)}
.ov-inits{margin-top:22px}
.ov-inits-h{display:flex;align-items:center;gap:9px;margin-bottom:12px;font-size:.95rem}
.ov-inits-h .i{width:17px;height:17px;color:var(--ind)}
.ov-inits-h .muted{font-size:.78rem;font-weight:400}

.init-detail{height:100%;display:flex;flex-direction:column}
.init-cols{display:flex;gap:18px;flex:1;min-height:0}
.init-meta{flex:1;min-width:0;display:flex;flex-direction:column;overflow-y:auto;padding-right:4px}
.init-chat{width:42%;min-width:340px;border-left:1px solid var(--line);padding-left:18px;display:flex}
.init-chat .chat{height:100%}
.vh-title{font-size:1.15rem;font-weight:700;background:transparent;border:1px solid transparent;border-radius:9px;color:var(--txt);padding:6px 8px;margin:-6px -8px 12px}
.vh-title:hover,.vh-title:focus{border-color:var(--line);background:var(--card2);outline:none}
.vh-row{display:flex;gap:14px;margin-bottom:14px;flex-wrap:wrap}
.vh-row label{display:flex;flex-direction:column;gap:5px;font-size:.75rem;color:var(--txt3);font-weight:600;flex:1;min-width:160px}
.vh-row select{padding:8px 10px;border-radius:9px;background:var(--card2);border:1px solid var(--line);color:var(--txt);font-size:.85rem}
.vh-lbl{font-size:.75rem;color:var(--txt3);font-weight:600;margin-bottom:5px}
.vh-goal{min-height:160px;resize:vertical;padding:11px 13px;border-radius:11px;background:var(--card2);border:1px solid var(--line);color:var(--txt);font:inherit;font-size:.86rem;line-height:1.5}
.vh-goal:focus{outline:none;border-color:rgba(125,140,245,.5)}
.vh-actions{display:flex;gap:9px;flex-wrap:wrap;margin-top:14px}
.btn.danger{color:var(--red);border-color:color-mix(in srgb,var(--red) 35%,transparent)}
.btn.danger:hover{background:color-mix(in srgb,var(--red) 14%,transparent)}
.vh-console{margin-top:14px;background:#05080d;border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-family:ui-monospace,Menlo,monospace;font-size:.76rem;line-height:1.5;color:#b9c4d6;max-height:260px;overflow:auto;white-space:pre-wrap}
.vh-console.hidden{display:none}
@media(max-width:900px){.init-cols{flex-direction:column}.init-chat{width:auto;border-left:none;border-top:1px solid var(--line);padding-left:0;padding-top:16px;min-height:420px}}
