:root{color-scheme:light;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;background:#f3f4f6;color:#111827}body{margin:0;min-height:100vh;display:flex;justify-content:center;align-items:stretch}#root{width:100%;height:100vh}.app-shell{display:grid;grid-template-columns:280px 1fr;gap:1px;background:#d1d5db;height:100%}.sidebar{background:#ffffff;display:flex;flex-direction:column;padding:16px;overflow:hidden}.sidebar-body{display:flex;flex-direction:column;gap:12px;flex:1;min-height:0}.sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.sidebar-header h1{font-size:18px;margin:0}.sidebar-header .primary{background:#2563eb;color:#fff;border:none;width:32px;height:32px;border-radius:8px;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer}.sidebar-header .primary:disabled{opacity:.5;cursor:not-allowed}.sidebar-actions{display:flex;gap:8px}.sidebar-actions .secondary{flex:1;justify-content:center}.sidebar-scroll{flex:1;min-height:0;overflow-y:auto;padding-right:4px;display:flex;flex-direction:column;gap:12px}.sidebar-search{position:sticky;top:0;background:#ffffff;padding:4px 0 12px}.sidebar-search input{width:100%;border:1px solid #cbd5f5;border-radius:10px;padding:8px 12px;font-size:14px;box-sizing:border-box}.sidebar-empty{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;color:#6b7280;text-align:center}.sidebar-footer{margin-top:auto;padding-top:16px;border-top:1px solid #e5e7eb;display:flex;justify-content:center;background:linear-gradient(to top,#ffffff 60%,rgba(255,255,255,0))}.secondary{background:#e2e8f0;color:#1f2937;border:none;border-radius:8px;padding:10px 14px;font-size:14px;cursor:pointer;width:100%}.secondary:hover{background:#cbd5f5}.danger{background:#fee2e2;color:#b91c1c}.danger:hover{background:#fecaca}.session-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.session-item{padding:12px 70px 12px 12px;border-radius:10px;background:#f9fafb;border:1px solid transparent;cursor:pointer;transition:border-color .15s ease,background .2s ease;position:relative}.session-item:hover{border-color:#d1d5db}.session-item.active{background:#e0f2fe;border-color:#38bdf8}.session-item.flagged{background:#fef2f2;border-color:#f87171}.session-item.flagged.active{background:#fee2e2;border-color:#ef4444}.session-item h2{font-size:14px;margin:0 0 4px}.session-title-row{display:flex;align-items:center;justify-content:flex-start;gap:8px}.session-select{display:flex;align-items:center;margin-right:6px}.session-title-main{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.session-unread-badge{min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#dc2626;color:#fff;font-size:11px;font-weight:600;display:inline-flex;align-items:center;justify-content:center}.session-meta-row{display:flex;align-items:center;justify-content:flex-start;margin-top:6px;gap:8px;flex-wrap:wrap}.session-flag-reason{margin-top:6px;font-size:11px;color:#b91c1c}.session-last-author{font-size:11px;font-weight:600;color:#475569}.session-ai-chip{font-size:11px;font-weight:600;color:#1d4ed8;background:rgba(59,130,246,.15);border:1px solid rgba(37,99,235,.4);border-radius:999px;padding:2px 8px}.session-id-row{margin-top:4px;display:flex;align-items:center;gap:8px;font-size:12px;color:#475569}.ai-disabled-hint{margin-top:6px;font-size:12px;color:#b91c1c}.session-select input{width:16px;height:16px;cursor:pointer}.session-actions{position:absolute;top:8px;right:8px;display:flex;gap:6px}.session-actions button{border:none;background:transparent;color:#9ca3af;font-size:16px;line-height:1;cursor:pointer;padding:2px 4px}.session-actions .copy{color:#0ea5e9}.session-actions .copy:hover{color:#38bdf8}.session-actions .backup{color:#16a34a}.session-actions .backup:hover{color:#22c55e}.session-actions .delete:hover{color:#f87171}.session-actions button:disabled{opacity:.4;cursor:not-allowed}.session-flag-chip{font-size:11px;font-weight:600;color:#b91c1c;background:rgba(248,113,113,.2);border:1px solid rgba(248,113,113,.6);border-radius:999px;padding:2px 8px}.session-item p{font-size:12px;color:#4b5563;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-panel{background:#ffffff;display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden}.main-pane{background:#ffffff;display:flex;flex-direction:column;min-height:0}.main-tabs{display:flex;border-bottom:1px solid #e5e7eb;background:#ffffff}.main-tab{border:none;background:transparent;padding:12px 20px;font-size:14px;font-weight:600;color:#6b7280;cursor:pointer}.main-tab.active{color:#111827;border-bottom:2px solid #2563eb}.main-content{flex:1;min-height:0;display:flex;background:#f1f5f9}.main-content>*{flex:1;min-height:0}.chat-main{flex:1;display:flex;flex-direction:column;min-height:0}.accordion{margin:12px 24px 0;border:1px solid #e5e7eb;border-radius:12px;background:#ffffff;overflow:hidden}.accordion:first-of-type{margin-top:16px}.accordion+.accordion{margin-top:12px}.accordion-toggle{width:100%;background:transparent;border:none;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer}.accordion-title{font-size:14px;font-weight:600;color:#0f172a}.accordion-description{font-size:12px;color:#6b7280;margin-top:2px}.accordion-icon{font-size:20px;color:#1d4ed8;width:20px;text-align:center}.accordion-content{border-top:1px solid #e5e7eb;background:#f8fafc;padding:16px}.chat-header .accordion{margin-left:0;margin-right:0}.chat-header .accordion:first-of-type{margin-top:12px}.knowledge-card{padding:0}.knowledge-form{display:flex;flex-direction:column;gap:12px;margin-top:12px}.knowledge-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#1f2937}.knowledge-form textarea{width:100%;border-radius:10px;border:1px solid #cbd5f5;padding:8px 10px;font-family:inherit;font-size:14px;resize:vertical}.knowledge-actions{display:flex;justify-content:flex-end}.knowledge-submit{background:#2563eb;border:none;color:#fff;padding:10px 16px;border-radius:10px;cursor:pointer;font-weight:600}.knowledge-submit:disabled{background:#93c5fd;cursor:not-allowed}.knowledge-error{margin-top:8px;color:#b91c1c;font-size:13px}.knowledge-success{margin-top:8px;color:#16a34a;font-size:13px}.knowledge-summary{margin-top:12px;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;font-size:13px;color:#1f2937}.knowledge-summary code{background:#e0e7ff;padding:2px 4px;border-radius:4px;font-size:12px}.knowledge-timestamp{grid-column:1 / -1;color:#6b7280}.settings-panel{flex:1;min-height:0;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:24px}.settings-card{background:#ffffff;border:1px solid #e5e7eb;border-radius:16px;padding:24px;box-shadow:0 12px 24px #0f172a0d}.settings-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.settings-card-header h2{margin:0;font-size:18px;color:#0f172a}.settings-card-header p,.settings-card-description{margin:4px 0 0;color:#6b7280;font-size:14px}.settings-header-button{border:1px solid #d1d5db;background:#f8fafc;color:#1f2937;border-radius:999px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer}.settings-header-button:disabled{opacity:.5;cursor:not-allowed}.system-prompt-form{display:flex;flex-direction:column;gap:12px;margin-top:16px}.system-prompt-form textarea{width:100%;min-height:180px;border-radius:12px;border:1px solid #cbd5f5;padding:12px;font-family:inherit;font-size:14px;resize:vertical}.system-prompt-meta{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:12px;font-size:13px;color:#374151}.system-prompt-source{font-weight:600;color:#0f172a}.system-prompt-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:flex-end;flex:1}.system-prompt-error{color:#b91c1c;font-weight:600}.system-prompt-success{color:#16a34a;font-weight:600}.settings-primary{background:#2563eb;color:#fff;border:none;border-radius:999px;padding:10px 18px;font-weight:600;cursor:pointer}.settings-primary:disabled{background:#93c5fd;cursor:not-allowed}.chat-header{padding:16px 24px 0}.chat-header h2{margin:0;font-size:18px}.chat-header small{display:block;color:#6b7280;margin-top:4px}.session-name-form{margin-top:12px;display:flex;gap:8px;align-items:center}.session-name-input{flex:1;border:1px solid #cbd5f5;border-radius:8px;padding:6px 10px;font-size:14px}.session-name-form button{background:#2563eb;border:none;color:#fff;padding:8px 12px;border-radius:8px;cursor:pointer;font-size:13px}.session-name-form button:disabled{background:#93c5fd;cursor:not-allowed}.session-ai-toggle{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:13px;color:#475569}.session-ai-toggle input{accent-color:#2563eb}.chat-body{flex:1;min-height:0;overflow-y:auto}.messages{padding:24px;display:flex;flex-direction:column;gap:12px}.bubble{max-width:70%;padding:12px 16px;border-radius:16px;line-height:1.5;font-size:14px}.bubble.visitor{align-self:flex-end;background:#2563eb;color:#fff}.bubble.assistant{align-self:flex-start;background:#f3f4f6;color:#111827}.bubble-author{font-size:10px;font-weight:600;text-transform:uppercase;margin-bottom:4px;letter-spacing:.05em;color:#1d4ed8}.bubble.assistant.fallback{background:#fff7ed;border:1px dashed #f97316;color:#9a3412}.bubble-text p{margin:0 0 8px}.bubble-text p:last-child{margin-bottom:0}.fallback-note{align-self:flex-start;background:#fff7ed;border:1px dashed #f97316;color:#9a3412;padding:12px 16px;border-radius:12px;font-size:12px}.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);padding:24px}.login-card{background:#ffffff;padding:32px;border-radius:16px;width:320px;display:flex;flex-direction:column;gap:16px;box-shadow:0 30px 60px #0f172a59}.login-card h1{margin:0;text-align:center;font-size:22px;color:#1e293b}.login-card label{display:flex;flex-direction:column;gap:6px;font-size:14px;color:#1f2937}.login-card input{border-radius:10px;border:1px solid #cbd5f5;padding:10px 12px;font-size:14px}.login-card button{background:#2563eb;color:#fff;border:none;border-radius:12px;padding:12px 16px;font-weight:600;cursor:pointer}.login-card button:disabled{background:#93c5fd;cursor:not-allowed}.login-error{color:#dc2626;font-size:13px;text-align:center}.manage-users-fab{position:fixed;left:24px;bottom:96px;background:#0f172a;color:#fff;border:none;border-radius:24px;padding:12px 18px;box-shadow:0 15px 35px #0f172a59;font-weight:600;cursor:pointer}.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);display:flex;align-items:center;justify-content:center;z-index:10000}.modal{width:420px;max-height:80vh;background:#ffffff;border-radius:16px;box-shadow:0 30px 60px #0f172a66;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#2563eb;color:#fff}.modal-header h2{margin:0;font-size:18px}.modal-header button{background:transparent;border:none;color:#fff;font-size:20px;cursor:pointer}.modal-body{padding:20px;display:flex;flex-direction:column;gap:20px;overflow-y:auto}.modal-loading,.modal-empty{text-align:center;color:#64748b}.user-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.user-list li{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:#f8fafc;border-radius:12px}.user-actions{display:flex;gap:8px}.user-actions button{border:none;border-radius:8px;padding:6px 10px;cursor:pointer}.user-actions .danger{background:#ef4444;color:#fff}.user-form{display:flex;flex-direction:column;gap:12px}.user-form label{display:flex;flex-direction:column;gap:6px}.user-form input{border-radius:8px;border:1px solid #cbd5f5;padding:8px 10px;font-size:14px}.user-form-actions{display:flex;gap:8px}.modal-error{color:#dc2626;font-size:13px}.composer{padding:16px;border-top:1px solid #e5e7eb;display:flex;gap:12px;flex-shrink:0}.composer textarea{flex:1;resize:none;border-radius:12px;border:1px solid #d1d5db;padding:12px;font-size:14px;font-family:inherit;min-height:80px}.composer-actions{display:flex;flex-direction:column;gap:10px;width:180px}.manual-toggle{display:flex;align-items:center;gap:6px;font-size:12px;color:#4b5563}.manual-toggle input{accent-color:#2563eb}.composer button{background:#2563eb;border:none;color:#fff;padding:10px 24px;border-radius:12px;cursor:pointer;font-weight:600}.composer button:disabled{background:#93c5fd;cursor:not-allowed}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#6b7280;gap:12px;padding:24px;text-align:center}.snippets{background:#f9fafb;border-top:1px solid #e5e7eb;padding:16px 24px 24px;font-size:12px;color:#374151}.snippet-item+.snippet-item{margin-top:8px}@media (max-width: 768px){body{align-items:stretch}#root{height:auto;min-height:100vh}.app-shell{display:flex;flex-direction:column;gap:12px;background:none;height:auto}.sidebar{border-bottom:1px solid #e5e7eb;padding:12px}.sidebar-body{gap:8px}.sidebar-actions{flex-direction:column}.sidebar-scroll{max-height:320px}.session-item{padding-right:48px}.session-item p{white-space:normal}.chat-panel{min-height:60vh}.accordion{margin:8px 0 0}.accordion:first-of-type{margin-top:8px}.chat-header{padding:12px}.chat-body{max-height:50vh}.messages,.snippets{padding:12px}.composer{padding:16px 12px;flex-direction:column}.composer textarea{min-height:60px}.composer-actions{width:100%;flex-direction:column}.manage-users-fab{left:16px;bottom:24px}.modal{width:95%;max-height:90vh}}
