/* MorpheusHub 2.0 — Refine (dark navy). Minimal-Fundament, volle Mockups in design/. */
:root{
  --bg:#0d1117;--bg2:#161b22;--bg3:#21262d;--bg4:#2d333b;
  --accent:#3b82f6;--accent-dim:rgba(59,130,246,.12);
  --text:#e6edf3;--text2:#9da7b3;--text3:#6e7681;--border:#30363d;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}

/* --- Auth --- */
.auth-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.auth-card{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:32px;width:340px;display:flex;flex-direction:column;gap:14px}
.auth-card .brand{font-size:18px;font-weight:700;margin-bottom:8px}
.auth-card label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text2)}
.auth-card input{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);font-size:14px}
.auth-card input:focus{outline:none;border-color:var(--accent)}
.auth-card button{margin-top:6px;background:var(--accent);color:#fff;border:none;border-radius:8px;padding:11px;font-size:14px;font-weight:600;cursor:pointer}
.auth-error{background:rgba(248,81,73,.12);border:1px solid rgba(248,81,73,.4);color:#ff7b72;padding:9px 12px;border-radius:8px;font-size:13px}

/* --- Brand mark --- */
.brand-mark{display:inline-grid;place-items:center;width:26px;height:26px;border-radius:7px;background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;font-weight:800;font-size:14px;vertical-align:middle}
.brand-ver{color:var(--text3);font-size:12px;font-weight:600}

/* --- App-Shell --- */
.sidebar{position:fixed;top:0;left:0;bottom:0;width:240px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:18px 14px}
.sidebar .brand{font-size:16px;font-weight:700;margin-bottom:18px}
.snav{flex:1;display:flex;flex-direction:column;gap:3px}
.slabel{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin:14px 8px 4px}
.sitem{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;color:var(--text2);text-decoration:none;font-size:14px}
.sitem.active{background:var(--accent-dim);color:var(--text)}
.sitem.muted{color:var(--text3)}
.soon{margin-left:auto;font-size:9px;background:var(--bg4);color:var(--text3);padding:2px 6px;border-radius:10px;text-transform:uppercase;letter-spacing:.05em}
.suser{display:flex;align-items:center;gap:10px;padding-top:12px;border-top:1px solid var(--border)}
.avatar{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,#3b82f6,#6366f1);display:grid;place-items:center;font-weight:700;color:#fff}
.uinfo{flex:1;min-width:0}
.uname{font-size:13px;font-weight:600}
.umodel{font-size:11px;color:var(--text3)}
.logout button{background:none;border:1px solid var(--border);color:var(--text2);border-radius:7px;width:30px;height:30px;cursor:pointer}

.main{margin-left:240px;min-height:100vh}
.topbar{height:52px;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 22px;background:var(--bg2)}
.topbar-title{font-weight:600}
.content{padding:28px 22px}
.welcome h1{margin:0 0 6px;font-size:24px}
.welcome p{color:var(--text2);margin:0 0 24px}
.btn-ghost{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:7px 13px;font-size:13px;font-weight:600;text-decoration:none}
.btn-ghost:hover{border-color:var(--accent)}

/* --- Dashboard KPIs --- */
.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:24px}
.kpi{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:18px 20px;text-decoration:none;color:var(--text);display:block}
a.kpi:hover{border-color:var(--accent)}
.kpi-val{font-size:28px;font-weight:700}
.kpi-lbl{color:var(--text2);font-size:13px;margin-top:2px}
.kpi-alert .kpi-val{color:#f85149}

/* --- Dashboard Panels --- */
.dash-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:18px}
.dash-panel{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:18px 20px}
.dash-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.dash-panel-head h2{margin:0;font-size:15px}
.dash-panel-head a{color:#6ea8fe;text-decoration:none;font-size:12px}
.dash-list{display:flex;flex-direction:column}
.dash-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 0;border-bottom:1px solid var(--border);text-decoration:none;color:var(--text)}
.dash-row:last-child{border-bottom:none}
.dash-row:hover .dash-row-main{color:#6ea8fe}
.dash-row-main{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-row-meta{color:var(--text3);font-size:12px;white-space:nowrap}

/* --- Panels / Konto-Formulare --- */
.panel{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:20px 22px;margin-bottom:18px;max-width:460px}
.panel h2{margin:0 0 14px;font-size:16px}
.kv{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border);font-size:14px;color:var(--text2)}
.kv:last-child{border-bottom:none}
.kv b{color:var(--text)}
.formcol{display:flex;flex-direction:column;gap:12px}
.formcol label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text2)}
.formcol small{color:var(--text3)}
.formcol input{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);font-size:14px}
.formcol input:focus{outline:none;border-color:var(--accent)}
.formcol button{align-self:flex-start;background:var(--accent);color:#fff;border:none;border-radius:8px;padding:10px 18px;font-size:14px;font-weight:600;cursor:pointer}
.flash{max-width:460px;padding:11px 14px;border-radius:8px;margin-bottom:18px;font-size:14px}
.flash-ok{background:rgba(63,185,80,.12);border:1px solid rgba(63,185,80,.4);color:#3fb950}
.flash-err{background:rgba(248,81,73,.12);border:1px solid rgba(248,81,73,.4);color:#ff7b72}

/* --- Topbar-Extras --- */
.topbar-spacer{flex:1}
.back{color:var(--text2);text-decoration:none;font-size:13px;margin-right:14px}
.back:hover{color:var(--text)}
.btn-accent{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;list-style:none}
.btn-danger{background:rgba(248,81,73,.14);color:#ff7b72;border:1px solid rgba(248,81,73,.4);border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer}

/* --- Neues-Projekt (details/summary) --- */
.newproj{position:relative}
.newproj > summary{cursor:pointer;display:inline-block}
.newproj[open] > summary{opacity:.7}
.newproj-form{position:absolute;right:0;top:38px;z-index:20;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px;width:320px;display:flex;flex-direction:column;gap:10px;box-shadow:0 10px 30px rgba(0,0,0,.4)}
.newproj-form input,.newproj-form select,.newproj-form textarea{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:9px 11px;color:var(--text);font-size:13px;font-family:inherit}
.newproj-form input:focus,.newproj-form textarea:focus,.newproj-form select:focus{outline:none;border-color:var(--accent)}

/* --- Filterleiste --- */
.filterbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.ftab{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:18px;border:1px solid var(--border);color:var(--text2);text-decoration:none;font-size:13px}
.ftab.on{background:var(--accent-dim);border-color:var(--accent);color:var(--text)}
.ftab span{background:var(--bg3);color:var(--text3);font-size:11px;padding:1px 7px;border-radius:10px}

/* --- Projektkarten --- */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.pcard{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px 18px;text-decoration:none;color:var(--text);display:flex;flex-direction:column;gap:8px;transition:border-color .15s}
.pcard:hover{border-color:var(--accent)}
.pcard-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.pname{font-weight:600;font-size:15px}
.pmeta{color:var(--text3);font-size:12px}
.pdesc{color:var(--text2);font-size:13px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* --- Badges --- */
.pbadge{font-size:10px;padding:3px 9px;border-radius:10px;font-weight:600;white-space:nowrap}
.b-green{background:rgba(63,185,80,.14);color:#3fb950}
.b-amber{background:rgba(210,153,34,.16);color:#d29922}
.b-blue{background:var(--accent-dim);color:#6ea8fe}
.b-grey{background:var(--bg3);color:var(--text2)}

/* --- Detail-Kopf --- */
.detail-head{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:18px 20px;margin-bottom:20px}
.dh-meta{display:flex;gap:22px;flex-wrap:wrap;color:var(--text3);font-size:13px}
.dh-meta b{color:var(--text)}
.dh-desc{color:var(--text2);margin:12px 0 0;line-height:1.5}
.dh-actions{display:flex;gap:10px;align-items:center;margin-top:16px}
.inline{display:inline}
.dh-actions select{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 11px;color:var(--text);font-size:13px}

/* --- Phasen / Aufgaben --- */
.phases{display:flex;flex-direction:column;gap:14px;max-width:720px}
.phase{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:14px 18px}
.phase-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.phase-head h3{margin:0;font-size:15px}
.phase-count{font-size:12px;color:var(--text3);background:var(--bg3);padding:2px 9px;border-radius:10px}
.tasks{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.task{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--border)}
.task:last-child{border-bottom:none}
.task .check{background:none;border:none;color:var(--text2);font-size:16px;cursor:pointer;padding:0;line-height:1}
.task.done .task-title{color:var(--text3);text-decoration:line-through}
.task.done .check{color:#3fb950}
.task-title{flex:1;font-size:14px}
.x{background:none;border:none;color:var(--text3);cursor:pointer;font-size:16px;padding:0 4px;opacity:.5}
.x:hover{opacity:1;color:#ff7b72}
.addrow{display:flex;gap:8px;margin-top:10px}
.addrow input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 11px;color:var(--text);font-size:13px}
.addrow button{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:8px;width:34px;cursor:pointer}
.addphase{display:flex;gap:8px;margin-top:6px}
.addphase input{flex:1;max-width:300px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:9px 11px;color:var(--text);font-size:13px}

.scard.link{text-decoration:none;color:inherit;display:block;transition:border-color .15s}
.scard.link:hover{border-color:var(--accent)}
.empty{color:var(--text3);padding:24px;text-align:center;border:1px dashed var(--border);border-radius:12px}

/* --- Doku: Liste --- */
.docgroup{margin-bottom:22px}
.docgroup-h{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--text3);margin:0 0 8px}
.doclist{display:flex;flex-direction:column;gap:6px}
.docrow{display:flex;align-items:center;gap:10px;background:var(--bg2);border:1px solid var(--border);border-radius:9px;padding:10px 14px;text-decoration:none;color:var(--text)}
.docrow:hover{border-color:var(--accent)}
.doc-ic{font-size:15px}
.doc-title{flex:1;font-size:14px;font-weight:500}
.doc-meta{color:var(--text3);font-size:12px}

/* --- Doku: Projekt-Sektion --- */
.docsec{max-width:720px;margin-top:24px}
.docsec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.docsec-head h3{margin:0;font-size:15px}

/* --- Doku: Kontext + Formular --- */
.doc-context{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.doc-context a.pbadge{text-decoration:none}
.docform{display:flex;flex-direction:column;gap:14px;max-width:820px}
.docform label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text2)}
.docform input,.docform select,.docform textarea{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);font-size:14px;font-family:inherit}
.docform input:focus,.docform select:focus,.docform textarea:focus{outline:none;border-color:var(--accent)}
.docform .mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;line-height:1.5;resize:vertical}
.docform small{color:var(--text3)}

/* --- Markdown-Rendering --- */
.md-body{max-width:820px;line-height:1.65;color:var(--text)}
.md-body h1,.md-body h2,.md-body h3{margin:1.4em 0 .5em;line-height:1.25}
.md-body h1{font-size:26px;border-bottom:1px solid var(--border);padding-bottom:.3em}
.md-body h2{font-size:21px;border-bottom:1px solid var(--border);padding-bottom:.3em}
.md-body h3{font-size:17px}
.md-body p{margin:.7em 0}
.md-body a{color:#6ea8fe}
.md-body code{background:var(--bg3);padding:2px 6px;border-radius:5px;font-family:ui-monospace,Menlo,monospace;font-size:.9em}
.md-body pre{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;overflow:auto}
.md-body pre code{background:none;padding:0}
.md-body blockquote{border-left:3px solid var(--accent);margin:.8em 0;padding:.2em 1em;color:var(--text2)}
.md-body ul,.md-body ol{padding-left:1.5em;margin:.6em 0}
.md-body li{margin:.3em 0}
.md-body table{border-collapse:collapse;margin:1em 0;width:100%}
.md-body th,.md-body td{border:1px solid var(--border);padding:7px 11px;text-align:left}
.md-body th{background:var(--bg2)}
.md-body img{max-width:100%;border-radius:8px}
.md-body hr{border:none;border-top:1px solid var(--border);margin:1.5em 0}

/* --- Sidebar Unread-Badge --- */
.sbadge{margin-left:auto;background:#f85149;color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:9px;min-width:16px;text-align:center}

/* --- Chat-Layout (zweispaltig) --- */
.chat-main{display:flex;height:100vh}
.chat-col{height:100vh;overflow-y:auto}
.chat-list{width:300px;border-right:1px solid var(--border);background:var(--bg2);flex-shrink:0;padding:10px}
.chat-list-head{font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);padding:14px 8px 6px}
.convo{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:9px;text-decoration:none;color:var(--text)}
.convo:hover{background:var(--bg3)}
.convo.on{background:var(--accent-dim)}
.convo.slim{padding:7px 10px}
.convo-av{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#3b82f6,#6366f1);display:grid;place-items:center;font-weight:700;color:#fff;flex-shrink:0}
.convo-av.sm{width:28px;height:28px;font-size:12px}
.convo-body{flex:1;min-width:0}
.convo-name{font-size:14px;font-weight:600}
.convo-last{font-size:12px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.convo-badge{background:#f85149;color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:9px;min-width:16px;text-align:center}
.convo-empty{color:var(--text3);font-size:13px;padding:10px}

.chat-thread{flex:1;display:flex;flex-direction:column}
.thread-head{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);background:var(--bg2)}
.thread-name{font-weight:600}
.thread-sub{font-size:12px;color:var(--text3)}
.msgs{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:10px}
.msg{display:flex;flex-direction:column;max-width:64%}
.msg.mine{align-self:flex-end;align-items:flex-end}
.msg.their{align-self:flex-start;align-items:flex-start}
.bubble{padding:9px 13px;border-radius:13px;font-size:14px;line-height:1.45;white-space:pre-wrap;word-break:break-word}
.msg.mine .bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px}
.msg.their .bubble{background:var(--bg3);color:var(--text);border-bottom-left-radius:4px}
.mtime{font-size:10px;color:var(--text3);margin-top:3px}
.sendbar{display:flex;gap:10px;padding:14px 20px;border-top:1px solid var(--border);background:var(--bg2)}
.sendbar input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:9px;padding:11px 14px;color:var(--text);font-size:14px}
.sendbar input:focus{outline:none;border-color:var(--accent)}
.sendbar button{background:var(--accent);color:#fff;border:none;border-radius:9px;padding:11px 20px;font-weight:600;cursor:pointer}
.thread-empty{flex:1;display:grid;place-items:center;color:var(--text3);text-align:center}
.te-ic{font-size:40px;margin-bottom:8px}
/* AI-Bubble: Markdown im Chat, etwas breiter als normale Bubbles */
.msg .ai-bubble{max-width:none}
.chat-thread .msg.their{max-width:78%}
.ai-bubble p:first-child{margin-top:0}
.ai-bubble p:last-child{margin-bottom:0}
.ai-bubble pre{background:var(--bg);}
.sendbar button:disabled{opacity:.6;cursor:default}

/* --- Benutzer-Tabelle --- */
.utable{width:100%;border-collapse:collapse;background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.utable th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text3);padding:11px 14px;border-bottom:1px solid var(--border)}
.utable td{padding:11px 14px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:middle}
.utable tr:last-child td{border-bottom:none}
.row-off{opacity:.5}
.ut-name{font-weight:600}
.ut-you{font-size:10px;background:var(--accent-dim);color:#6ea8fe;padding:1px 6px;border-radius:8px;margin-left:4px}
.ut-sub{font-size:12px;color:var(--text3)}
.ut-date{color:var(--text2);font-size:13px;white-space:nowrap}
.rolesel{background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:6px 9px;color:var(--text);font-size:13px}
.pill{border:1px solid var(--border);border-radius:14px;padding:5px 11px;font-size:12px;font-weight:600;cursor:pointer;background:var(--bg)}
.pill-on{color:#3fb950;border-color:rgba(63,185,80,.4)}
.pill-off{color:var(--text3)}
.mini{cursor:pointer;font-size:12px;color:#6ea8fe;list-style:none}
.pwreset{position:relative}
.pwreset-form{position:absolute;right:0;z-index:20;background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:10px;display:flex;gap:6px;margin-top:6px;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.pwreset-form input{background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:7px 10px;color:var(--text);font-size:13px}
.pwreset-form button{background:var(--accent);color:#fff;border:none;border-radius:7px;padding:7px 12px;font-size:13px;cursor:pointer}

.appfoot{position:fixed;bottom:8px;right:14px;color:var(--text3);font-size:11px}
.appfoot .ver{color:var(--accent)}
