@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{--surface-ink: #0d1b2e;--surface-muted: #58687c;--surface-bg: #f8faff;--surface-bg-soft: #fefefe;--surface-bg-cool: #e8eaf1;--surface-border: rgba(13, 27, 46, .09);--surface-border-strong: rgba(13, 27, 46, .14);--surface-glass: linear-gradient(180deg, rgba(254, 254, 254, .82), rgba(248, 250, 255, .74));--surface-glass-strong: linear-gradient(180deg, rgba(254, 254, 254, .9), rgba(248, 250, 255, .84));--surface-shadow: 0 24px 60px rgba(13, 27, 46, .1);--surface-shadow-strong: 0 30px 72px rgba(13, 27, 46, .16);--deep-panel: linear-gradient(160deg, rgba(13, 27, 46, .98), rgba(19, 41, 66, .94));--accent-soft: #eff4fb;--accent-active: #e6eef8;--accent-border: rgba(27, 63, 109, .18)}.app-shell{padding:24px;min-height:100vh;color:var(--surface-ink);background:radial-gradient(circle at 10% 14%,rgba(13,27,46,.08),transparent 24%),radial-gradient(circle at 92% 0%,rgba(88,104,124,.1),transparent 28%),linear-gradient(180deg,#f9f9fa,#f8faff 48%,#e8eaf1)}.app-header{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;background:var(--surface-glass-strong);border:1px solid var(--surface-border);border-radius:20px;box-shadow:var(--surface-shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);margin-bottom:18px}.brand{display:flex;align-items:center;gap:12px}.brand-logo{width:52px;height:52px;border-radius:14px;object-fit:contain;background:#f8fafff0;border:1px solid var(--surface-border);box-shadow:0 10px 24px #0d1b2e14}.brand-title{font-weight:700;font-size:19px}.brand-subtitle{color:var(--surface-muted);font-size:13px}.meta{display:flex;gap:20px;flex-wrap:wrap;color:#223046;font-size:13px}.meta-row{display:flex;gap:8px;align-items:baseline}.layout{display:grid;grid-template-columns:2fr 1fr;gap:16px}.left-panel{background:var(--surface-glass);border-radius:24px;border:1px solid var(--surface-border);min-height:70vh;box-shadow:var(--surface-shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);position:relative;overflow:hidden}.content-scroll{padding:20px;max-height:calc(100vh - 200px);overflow-y:auto}.card-stack{display:flex;flex-direction:column;gap:12px}h2{margin:18px 0 10px;font-size:17px}.item-card{border:1px solid #e5e8f0;background:#fff;border-radius:14px;padding:10px 12px;box-shadow:0 8px 18px #0f172a0d;transition:transform .1s ease,box-shadow .1s ease}.item-card:hover{transform:translateY(-2px);box-shadow:0 12px 24px #0f172a14}.item-card.selected{border-color:#5570ff;box-shadow:0 0 0 3px #5570ff26}.item-card__header{display:flex;justify-content:space-between;align-items:center;cursor:pointer}.item-card__title{display:flex;align-items:center;gap:8px}.item-card__id{font-weight:700;color:#4b5563;background:#f1f5f9;padding:4px 8px;border-radius:8px;font-size:11px}.item-card__name{font-weight:600}.item-card__body{margin-top:8px;cursor:pointer}.item-card__text{margin:0 0 8px;color:#344053;white-space:pre-wrap}.item-card__children{margin-left:14px;border-left:2px dashed #e5e8f0;padding-left:8px;display:flex;flex-direction:column;gap:8px}.chevron{font-size:16px;transition:transform .2s ease}.chevron.open{transform:rotate(180deg)}.severity-severe{border-color:#f05b5b;background:linear-gradient(135deg,#fff1f1,#ffe4e4)}.severity-potential{border-color:#f4a261;background:linear-gradient(135deg,#fff6ec,#ffeddc)}.severity-comment{border-color:#f6d34c;background:linear-gradient(135deg,#fffbe8,#fff6d4)}.vereinbarung-card{border:1px solid #e5e8f0;border-radius:14px;padding:12px;background:#f9fbff;box-shadow:0 8px 18px #0f172a0a}.vereinbarung-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-weight:600}.vereinbarung-title{display:flex;align-items:center;gap:6px}.vereinbarung-nr{padding:4px 8px;border-radius:8px;background:#e8ecf5;font-size:11px}.vereinbarung-text{margin:10px 0 0;color:#344053;white-space:pre-wrap}.loading-state,.error-state{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:12px;background:#ffffffeb;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.assistant-hint{display:flex;align-items:center;gap:10px;color:var(--surface-muted);font-size:13px}.assistant-hint img{width:36px;height:36px;border-radius:50%;border:1px solid var(--surface-border);background:#f8faffeb}.right-panel{position:relative}.assistant-panel{background:var(--deep-panel);color:#e6ecf5;border-radius:24px;padding:18px;box-shadow:var(--surface-shadow-strong);border:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);min-height:70vh;position:sticky;top:16px;display:flex;flex-direction:column}.assistant-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}.assistant-tabs{display:inline-flex;gap:8px;margin-bottom:12px}.assistant-tab{border:1px solid rgba(255,255,255,.2);background:#f8faff12;color:#dce8fa;border-radius:10px;padding:8px 12px;font-weight:700;font-size:12px;cursor:pointer}.assistant-tab.active{background:#fefefef2;color:var(--surface-ink);border-color:#fffffff2;box-shadow:0 10px 24px #0d1b2e2e}.assistant-avatar{width:48px;height:48px;border-radius:14px;border:1px solid rgba(255,255,255,.18);background:#f8faff1a;object-fit:contain}.assistant-label{font-weight:700;font-size:15px}.assistant-sub{color:#c8d4e6;font-size:12px}.assistant-body{flex:1;display:flex}.assistant-loading{display:flex;flex-direction:column;align-items:center;gap:10px;padding:14px;width:100%}.assistant-loading-message{white-space:pre-wrap;width:100%;text-align:left;line-height:1.35}.assistant-content{display:flex;flex-direction:column;gap:12px;width:100%}.feedback-filter-row{display:flex;flex-wrap:wrap;gap:8px}.feedback-filter-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.2);background:#ffffff0f;border-radius:10px;padding:7px 10px;font-size:12px;color:#dce8fa}.feedback-filter-chip input{accent-color:#5ea7ff}.feedback-list-view{display:flex;flex-direction:column;gap:8px}.feedback-list-row{width:100%;display:flex;align-items:center;gap:8px;text-align:left;border-radius:12px;border:1px solid rgba(255,255,255,.16);background:#ffffff0a;color:#ecf4ff;padding:10px 12px;cursor:pointer;transition:transform .08s ease,box-shadow .08s ease}.feedback-list-row:hover{transform:translateY(-1px);box-shadow:0 10px 16px #0000002e}.feedback-list-row.severity-severe{background:linear-gradient(145deg,#ff8b8b33,#ffffff08);border-color:#ff8b8b99}.feedback-list-row.severity-potential{background:linear-gradient(145deg,#ffc28b33,#ffffff08);border-color:#ffc28b99}.feedback-list-row.severity-comment{background:linear-gradient(145deg,#ffeb9938,#ffffff08);border-color:#ffeb9999}.feedback-list-main{display:block;flex:1;font-size:13px;line-height:1.4}.feedback-list-done{color:#86efac;font-weight:800;font-size:14px}.assistant-selection{padding:12px;border-radius:14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08)}.selection-id{font-weight:700;letter-spacing:.5px}.selection-name{color:#c8d4e6}.assistant-card{border-radius:18px;padding:12px;background:#f8faff14;border:1px solid rgba(255,255,255,.12);box-shadow:inset 0 1px #ffffff14}.assistant-card.neutral{background:#f8faff0d}.assistant-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px}.assistant-card__top-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.assistant-card__actions{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.assistant-item-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:10px;background:#f8faff1f;font-size:11px;font-weight:700;letter-spacing:.2px}.feedback-nav{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:#d6e2f5}.feedback-nav button{border:1px solid rgba(255,255,255,.25);background:#f8faff0f;color:inherit;padding:2px 6px;border-radius:8px;cursor:pointer}.feedback-nav button:disabled{opacity:.4;cursor:not-allowed}.feedback-toggle-btn{border:1px solid rgba(255,255,255,.22);background:#f8faff14;color:#eef6ff;border-radius:999px;padding:6px 10px;font-size:11px;font-weight:700;cursor:pointer}.feedback-toggle-btn:disabled{opacity:.55;cursor:not-allowed}.feedback-done-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;background:#16a34a2e;color:#bbf7d0;font-size:11px;font-weight:700}.feedback-done-icon{color:#86efac}.assistant-card.severity-severe{border-color:#ff8b8b;background:linear-gradient(145deg,#ff8b8b2e,#ffffff08)}.assistant-card.severity-potential{border-color:#ffc28b;background:linear-gradient(145deg,#ffc28b2e,#ffffff08)}.assistant-card.severity-comment{border-color:#ffeb99;background:linear-gradient(145deg,#ffeb9933,#ffffff08)}.assistant-summary{margin-top:12px;display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-start}.summary-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 8px;border-radius:10px;background:#f8faff1a;font-weight:700;font-size:12px;line-height:1.2;white-space:nowrap}.summary-dot{width:8px;height:8px;border-radius:50%;background:currentColor;display:inline-block}.summary-dot.severe{background:#ff8b8b}.summary-dot.potential{background:#ffc28b}.summary-dot.comment{background:#ffeb99}.summary-chip.severe{border:1px solid rgba(255,139,139,.5)}.summary-chip.potential{border:1px solid rgba(255,194,139,.5)}.summary-chip.comment{border:1px solid rgba(255,235,153,.5)}.assistant-badge{display:inline-block;padding:6px 10px;border-radius:10px;background:#ffffff1a;font-weight:700;margin-bottom:8px}.assistant-markdown p{margin:6px 0}.reference-list{margin-top:10px;display:flex;flex-direction:column;gap:8px}.reference-card{background:#ffffff0a;border-radius:10px;padding:8px}.reference-card summary{cursor:pointer;font-weight:600;color:#2b3a54}.reference-snippet{margin-top:6px;color:#334155}.reference-full{margin:6px 0 0;color:#475569;font-size:11px;word-break:break-word}.assistant-panel .reference-card summary{color:#dce8fa}.assistant-panel .reference-snippet{color:#d6e2f5}.assistant-panel .reference-full{color:#c8d4e6}.project-chat-bubble .reference-card{border:1px solid #d7e4ff;background:#eef4ff}.project-chat-bubble .reference-card summary{color:#1e3a8a}.project-chat-bubble .reference-snippet{color:#1f2937}.project-chat-bubble .reference-full{color:#334155}.spinner{display:flex;gap:6px}.dot{width:10px;height:10px;border-radius:50%;background:#5570ff;animation:pulse 1s ease-in-out infinite}.dot:nth-child(2){animation-delay:.15s}.dot:nth-child(3){animation-delay:.3s}@keyframes pulse{0%,to{transform:scale(.9);opacity:.7}50%{transform:scale(1.2);opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-backdrop{position:fixed;inset:0;background:#070e1a66;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:60}.modal{background:var(--surface-glass-strong);padding:24px;border-radius:24px;width:min(520px,90vw);box-shadow:var(--surface-shadow-strong);border:1px solid var(--surface-border);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:flex;flex-direction:column;gap:16px}.modal-brand{display:flex;gap:12px;align-items:center}.modal-logo{width:60px;height:60px;border-radius:16px;border:1px solid var(--surface-border);background:#f8fafff0;box-shadow:0 12px 28px #0d1b2e14;object-fit:contain}.upload-section-label{font-size:13px;font-weight:700;color:#334155}.upload-dropzone{border:2px dashed #c7cedd;border-radius:16px;padding:16px;text-align:center;cursor:pointer;background:#f8faffc7;display:block;transition:border-color .2s ease,background .2s ease,transform .1s ease}.upload-dropzone input{display:none}.upload-instructions{display:flex;flex-direction:column;color:#4b5563}.upload-dropzone.drag-active{border-color:#1d4ed8;background:#e8f0ff;transform:translateY(-2px)}.upload-dropzone.has-file{border-color:#22c55e;background:#f0fff4}.upload-alt-actions{display:flex;justify-content:flex-start}.primary-btn{padding:12px 16px;border-radius:12px;background:#1d4ed8;border:none;color:#fff;font-weight:700;font-size:15px;box-shadow:0 10px 25px #1d4ed859}.primary-btn:disabled{background:#cbd5e1;color:#64748b;cursor:not-allowed;box-shadow:none}.error-banner{margin-top:12px;padding:12px 14px;background:#ffe4e4;color:#a90c0c;border-radius:12px;border:1px solid #f7b6b6}@media(max-width:1024px){.layout{grid-template-columns:1fr}.assistant-panel{position:relative}}.burger{border:1px solid #e3e7ef;background:#fff;border-radius:10px;width:40px;height:40px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-direction:column;gap:4px;box-shadow:0 8px 16px #0f172a14}.burger-line{width:18px;height:2px;border-radius:999px;background:#0f172a}.ghost-btn{border:1px solid #d2d9e5;background:transparent;padding:8px 12px;border-radius:10px;font-weight:600;cursor:pointer;color:#0f172a}.sidebar-overlay{position:fixed;inset:0;background:#070e1a66;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:30}.sidebar{position:absolute;left:20px;top:20px;bottom:20px;width:min(320px,80vw);background:var(--surface-glass-strong);border-radius:24px;border:1px solid var(--surface-border);box-shadow:var(--surface-shadow-strong);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:flex;flex-direction:column;padding:16px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.sidebar-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto;padding-bottom:12px}.sidebar-item{border:1px solid var(--surface-border);background:#f8faffd6;padding:10px 12px;border-radius:14px;text-align:left;font-weight:600;cursor:pointer;box-shadow:0 10px 26px #0d1b2e0a}.sidebar-item.active{border-color:var(--accent-border);background:var(--accent-active)}.sidebar-item-content{display:flex;align-items:center;gap:8px}.sidebar-item-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-status-spinner{width:13px;height:13px;border-radius:50%;border:2px solid #bfdbfe;border-top-color:#2563eb;animation:spin .9s linear infinite;flex:0 0 auto}.sidebar-status-done{width:14px;height:14px;border-radius:50%;background:#16a34a;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:10px;line-height:1;flex:0 0 auto}.sidebar-status-idle{width:12px;height:12px;border-radius:50%;border:1px solid #cbd5e1;background:#f8fafc;flex:0 0 auto}.sidebar-item.add{background:#0f172a;color:#fff}.sidebar-item.general-chat{background:#0f766e;color:#f0fdfa;border-color:#0f766e}.sidebar-item.general-chat.active{background:#115e59;border-color:#115e59}.sidebar-item.knowledge{margin-top:auto;background:#eef3fb}.empty-state{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#64748b}.knowledge-panel{grid-column:1 / -1;background:var(--surface-glass);border-radius:24px;border:1px solid var(--surface-border);box-shadow:var(--surface-shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);padding:24px;min-height:70vh;position:relative}.knowledge-header h2{margin:0 0 4px}.knowledge-header p{margin:0 0 16px;color:var(--surface-muted)}.knowledge-progress-card{margin-bottom:16px;padding:14px 16px;border-radius:18px;border:1px solid rgba(27,63,109,.14);background:linear-gradient(145deg,#eff4fbf0,#e8eaf1d6);box-shadow:0 14px 32px #0d1b2e0f}.knowledge-progress-title{font-weight:700;color:#1e3a8a;margin-bottom:4px}.knowledge-progress-text{color:#1e293b}.knowledge-progress-warning{margin-top:6px;color:#9a3412;font-weight:600}.knowledge-table{display:flex;flex-direction:column;gap:10px}.knowledge-groups{display:flex;flex-direction:column;gap:12px}.knowledge-group{border:1px solid var(--surface-border);border-radius:18px;background:#f8faffd6;overflow:hidden}.knowledge-group-header{width:100%;border:none;background:#e8eaf1e0;padding:12px 14px;display:flex;justify-content:space-between;align-items:center;font-weight:700;color:#0f172a;box-shadow:none}.knowledge-group-header:hover{transform:none;box-shadow:none}.knowledge-row{display:grid;grid-template-columns:2fr 1fr 2fr .6fr;gap:12px;padding:12px 14px;border-radius:12px;border:1px solid #e5e8f0;align-items:center}.knowledge-empty{color:#64748b;padding:12px 4px}.knowledge-row.header{background:#f1f5f9;font-weight:700}.doc-status{display:flex;align-items:center;gap:10px;font-weight:600}.doc-status.ready{color:#15803d}.doc-status.failed{color:#b91c1c}.doc-status.processing{color:#1d4ed8}.doc-name{font-weight:600;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.doc-ai-title{font-weight:500;color:#94a3b8;font-size:.9rem}.knowledge-footer{position:sticky;bottom:0;padding-top:16px;background:linear-gradient(180deg,#fff9,#fff 60%);display:flex;justify-content:flex-end}.file-list{display:flex;flex-wrap:wrap;gap:8px}.file-pill{background:#eef2ff;border-radius:999px;padding:6px 8px 6px 10px;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:8px}.file-pill-name{min-width:0;overflow:hidden;text-overflow:ellipsis;max-width:280px}.upload-remove-row{margin-top:6px}.file-remove-btn{border:1px solid #cfd8e3;background:#fff;color:#0f172a;border-radius:999px;padding:3px 8px;font-size:11px;font-weight:700;cursor:pointer}.file-remove-btn:hover{background:#f8fafc}.modal-actions{display:flex;justify-content:space-between;gap:12px}.form-field{display:flex;flex-direction:column;gap:6px}.form-field input{border:1px solid #d2d9e5;border-radius:10px;padding:8px 10px}.login-modal{max-width:420px}@media(max-width:1024px){.knowledge-row{grid-template-columns:1fr}}.project-chat-fullwidth{grid-column:1 / -1;margin-top:14px}.general-chat-fullwidth{margin-top:0}.project-chat-shell{display:grid;grid-template-columns:280px 1fr;gap:14px;min-height:62vh;background:var(--surface-glass);border:1px solid var(--surface-border);border-radius:24px;box-shadow:var(--surface-shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);overflow:hidden}.project-chat-shell.sidebar-collapsed{grid-template-columns:74px 1fr}.project-chat-sidebar{border-right:1px solid rgba(13,27,46,.08);background:#e8eaf170;padding:12px;display:flex;flex-direction:column;gap:10px}.project-chat-sidebar.collapsed{width:74px}.project-chat-sidebar-head{display:flex;align-items:center;gap:8px}.project-chat-sidebar-head h3{margin:0}.chat-new-btn{width:100%}.project-chat-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto}.project-chat-list-item{border:1px solid var(--surface-border);background:#fefefec7;border-radius:14px;padding:10px 12px;text-align:left;font-weight:600;cursor:pointer;box-shadow:0 10px 26px #0d1b2e0a}.project-chat-list-item.active{border-color:var(--accent-border);background:var(--accent-active)}.project-chat-main{display:flex;flex-direction:column;min-height:62vh}.project-chat-header{border-bottom:1px solid rgba(13,27,46,.08);padding:12px 16px;background:#fefefe52}.project-chat-brand{display:flex;align-items:center;gap:10px}.project-chat-brand img{width:40px;height:40px;border-radius:14px;border:1px solid var(--surface-border);background:#f8fafff0;box-shadow:0 10px 24px #0d1b2e0f}.project-chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.project-chat-empty{color:#64748b;font-size:14px}.project-chat-message{display:flex}.project-chat-message.user{justify-content:flex-end}.project-chat-message.assistant{justify-content:flex-start}.project-chat-bubble{max-width:min(880px,90%);border-radius:18px;padding:12px 14px;border:1px solid var(--surface-border);background:#fefefec7;box-shadow:0 14px 32px #0d1b2e0f}.project-chat-message.user .project-chat-bubble{background:linear-gradient(160deg,#0d1b2e,#18314f);border-color:#0d1b2e;color:#f8fbff}.chat-status-line{display:flex;align-items:center;gap:10px;color:#334155}.project-chat-input-wrap{border-top:1px solid rgba(13,27,46,.08);padding:12px;display:flex;gap:10px;align-items:flex-end;background:#fefefe4d}.project-chat-input-wrap textarea{flex:1;border:1px solid var(--surface-border-strong);border-radius:14px;padding:10px 12px;resize:vertical;min-height:60px;font-family:inherit;background:#f8faffe6}.chat-scroll-btn{position:fixed;right:22px;bottom:22px;z-index:45;border:1px solid var(--surface-border);background:#fefefee0;border-radius:999px;padding:8px 12px 8px 8px;display:inline-flex;gap:8px;align-items:center;box-shadow:0 14px 30px #0d1b2e29;font-weight:700}.chat-scroll-btn img{width:30px;height:30px;border-radius:10px;border:1px solid var(--surface-border);background:#f8faffeb}.chat-scroll-arrow{font-size:16px;line-height:1}@media(max-width:1024px){.project-chat-shell{grid-template-columns:1fr}.project-chat-sidebar{border-right:none;border-bottom:1px solid #e5e8f0}.project-chat-sidebar.collapsed{width:auto}.project-chat-bubble{max-width:100%}}:root{font-family:Space Grotesk,Segoe UI,sans-serif;font-size:15px;line-height:1.5;font-weight:400;color:#0f172a;background:radial-gradient(circle at 10% 20%,#f2f7ff,#f7f9ff 25%,#eef2f7 70%);min-height:100vh}*,*:before,*:after{box-sizing:border-box}body{margin:0}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}
