:root{color:#1c2430;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f7f8fa;font-family:Inter,ui-sans-serif,system-ui,Segoe UI,Arial,sans-serif;font-size:15px;font-weight:400;line-height:1.45}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}#root{min-height:100vh}.app-shell{color:#172033;background:#f5f7fa;grid-template-rows:auto minmax(0,1fr);height:100vh;display:grid;overflow:hidden}.login-shell{color:#172033;background:#f5f7fa;min-height:100vh}.app-header,.login-header{background:#fff;border-bottom:1px solid #dbe2ea;grid-template-columns:minmax(260px,1fr) auto auto;align-items:center;gap:16px;min-height:64px;padding:10px 18px;display:grid}.brand-button{text-align:left;background:0 0;border:0;align-items:center;gap:10px;width:fit-content;padding:0;display:inline-flex}.brand-mark{color:#fff;background:#215f6b;border-radius:8px;place-items:center;width:36px;height:36px;font-weight:700;display:grid}.brand-button strong,.login-header h1{color:#111827;font-size:18px;line-height:1.2;display:block}.brand-button small,.login-header p{color:#64748b;margin-top:2px;font-size:13px;display:block}.login-header h1,.login-header p,.page-header h1,.page-header p,.chat-titlebar h1,.chat-titlebar p,.empty-state h1,.empty-state h2,.empty-state p,.welcome-panel h2,.welcome-panel p{margin:0}.header-status,.header-actions,.page-actions,.chat-title-actions,.prompt-row,.answer-meta,.chips,.modal-actions,.tab-strip{align-items:center;gap:8px;display:flex}.header-status{flex-wrap:wrap;justify-content:flex-end}.header-actions{justify-content:flex-end}.badge{color:#334155;white-space:nowrap;background:#f8fafc;border:1px solid #cbd5e1;border-radius:999px;align-items:center;min-height:24px;padding:3px 9px;font-size:12px;display:inline-flex}.badge.ok{color:#176249;background:#edf8f3;border-color:#9cc7b5}.badge.warn{color:#9a3412;background:#fff1f1;border-color:#e0a1a1}.badge.muted{color:#64748b}.dev-badge{color:#7a4a00;background:#fff8db;border-color:#e3b341}.user-pill{background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;min-width:150px;padding:6px 10px;display:grid}.user-pill strong{text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.user-pill span{color:#64748b;font-size:12px}button{color:#172033;font:inherit;cursor:pointer;background:#fff;border:1px solid #b7c3d0;border-radius:8px;padding:8px 12px}button:hover{border-color:#237080}button:disabled{cursor:not-allowed;opacity:.55}.primary-button{color:#fff;background:#236b79;border-color:#236b79}.primary-button:hover{background:#195866;border-color:#195866}.app-layout{grid-template-columns:280px minmax(0,1fr);min-height:0;display:grid;overflow:hidden}.left-nav{background:#fbfcfe;border-right:1px solid #dbe2ea;grid-template-rows:auto auto minmax(0,1fr);gap:16px;min-height:0;padding:16px;display:grid}.new-chat-button{color:#174e59;background:#eef8fa;border-color:#236b79;width:100%;font-weight:600}.main-nav{gap:5px;display:grid}.nav-item{text-align:left;background:0 0;border-color:#0000;width:100%}.nav-item.active,.nav-item:hover{background:#edf5f7;border-color:#c8d6df}.recent-section{min-height:0;overflow:hidden}.sidebar-heading{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.sidebar-heading h2{color:#475569;margin:0;font-size:13px}.sidebar-heading button{padding:5px 8px;font-size:12px}.session-list{gap:7px;max-height:100%;padding-right:2px;display:grid;overflow:auto}.session{text-align:left;gap:4px;width:100%;display:grid}.session strong{text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.session span,.article-row span,.sql-template-card span,.message-meta,.answer-meta,.attached-note,.muted-note,.result-card span{color:#64748b;font-size:12px}.session.active{background:#eef8f4;border-color:#2f8069}.content-area{min-width:0;min-height:0;overflow:hidden}.chat-page{background:#f7f9fb;grid-template-rows:auto minmax(0,1fr) auto;height:100%;min-height:0;display:grid;position:relative}.chat-titlebar{background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:flex-start;gap:16px;padding:18px 24px 12px;display:flex}.chat-titlebar h1,.page-header h1{color:#111827;font-size:22px;line-height:1.2}.chat-titlebar p,.page-header p{color:#64748b;margin-top:5px;font-size:14px}.chat-title-actions{flex-wrap:wrap;justify-content:flex-end}.toggle-line,.checkbox-label{color:#475569;align-items:center;gap:8px;display:inline-flex}.toggle-line input,.checkbox-label input{width:auto}.inline-warning,.alert{color:#7a4a00;background:#fff8e7;border:1px solid #e6bd76;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;margin:10px 24px 0;padding:10px 12px;display:flex}.alert{color:#8b2e2e;background:#fff1f1;border-color:#d88a8a}.conversation{min-height:0;padding:22px 24px;overflow:auto}.welcome-panel,.empty-state{background:#fff;border:1px solid #dbe2ea;border-radius:12px;max-width:720px;margin:24px auto;padding:24px}.welcome-panel h2,.empty-state h1,.empty-state h2{margin-bottom:8px;font-size:22px}.welcome-panel p,.empty-state p{color:#64748b;line-height:1.55}.message{background:#fff;border:1px solid #dbe2ea;border-radius:12px;max-width:980px;margin:0 auto 14px;padding:14px 16px}.message.user{background:#eff7fd;border-color:#c4d9ea;max-width:760px;margin-left:auto;margin-right:calc(50% - min(980px,100%)/2)}.message.assistant{background:#f3faf6;border-color:#cbded5}.message p,.article-row p,.result-card p,.article-preview p,.settings-card p{white-space:pre-wrap;margin:0;line-height:1.55}.answer-context{border-top:1px solid #d7e7de;gap:10px;margin-top:12px;padding-top:12px;display:grid}.answer-meta,.chips{flex-wrap:wrap}.answer-meta span,.chips button{color:#245b4a;background:#fff;border:1px solid #bdd3ca;border-radius:999px;padding:5px 9px;font-size:12px}.source-chip-label{color:#536579;font-size:12px;font-weight:700}.chips button.kb-source-chip{color:#165642;background:#f4fffa;border-color:#7bb89d}.source-action{justify-self:start;padding:6px 10px;font-size:12px}.chat-composer{background:#fff;border-top:1px solid #dbe2ea;gap:10px;padding:12px 24px 16px;display:grid}.prompt-row{flex-wrap:wrap}.prompt-row button{padding:6px 10px;font-size:13px}.composer-row{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:10px;width:100%;max-width:1040px;margin:0 auto;display:grid}.send-button{min-width:88px;min-height:48px}textarea,input,select{box-sizing:border-box;color:#172033;width:100%;font:inherit;background:#fff;border:1px solid #bdc8d5;border-radius:8px;padding:10px 11px}textarea{resize:vertical;min-height:92px}.chat-composer textarea{min-height:72px;max-height:160px}.attached-note{width:100%;max-width:1040px;margin:0 auto}.side-drawer{z-index:3;background:#fff;border-left:1px solid #dbe2ea;width:min(420px,92vw);padding:16px;position:absolute;top:0;bottom:0;right:0;overflow:auto;box-shadow:-18px 0 34px #0f172a24}.drawer-header{justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.drawer-header h2,.article-preview h2,.article-preview h3,.settings-card h2,.sql-card h2,.admin-card h2,.import-panel h2{margin:0}.drawer-list,.article-list,.template-list,.user-list{gap:9px;display:grid}.drawer-list article,.result-card,.admin-card,.sql-card,.settings-card,.import-panel{background:#fff;border:1px solid #dbe2ea;border-radius:12px;padding:14px}.drawer-list article{gap:5px;display:grid}.page-panel{height:100%;min-height:0;padding:24px;overflow:auto}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;max-width:1180px;margin:0 auto 18px;display:flex}.page-actions{flex-wrap:wrap;justify-content:flex-end}.kb-layout{grid-template-columns:minmax(280px,360px) minmax(0,1fr);align-items:start;gap:18px;max-width:1180px;margin:0 auto;display:grid}.kb-search-panel{gap:14px;display:grid}.stack-form{gap:12px;display:grid}.stack-form label,.article-modal label{color:#475569;gap:6px;font-size:13px;display:grid}.article-list{max-height:calc(100vh - 290px);overflow:auto}.article-row,.sql-template-card{text-align:left;background:#fff;gap:5px;width:100%;display:grid}.article-row.active{background:#eef8f4;border-color:#2f8069}.article-row strong,.sql-template-card strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.article-row p{color:#475569;-webkit-line-clamp:3;-webkit-box-orient:vertical;font-size:13px;display:-webkit-box;overflow:hidden}.article-preview{background:#fff;border:1px solid #dbe2ea;border-radius:12px;gap:16px;padding:20px;display:grid}.search-match-panel{background:#fff;border:1px solid #dbe2ea;border-radius:12px;gap:8px;padding:12px;display:grid}.search-match-panel h2{margin:0;font-size:14px}.search-match-panel article{border-top:1px solid #e2e8f0;gap:3px;padding-top:8px;display:grid}.search-match-panel span{color:#64748b;font-size:12px}.preview-title{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:flex-start;gap:14px;padding-bottom:14px;display:flex}.preview-title p{color:#64748b}.related-panel{background:#f8fafc;border-radius:10px;padding:14px}.article-image-preview,.article-images-panel{gap:12px;display:grid}.article-images-panel>div:first-child p{color:#64748b;margin:4px 0 0;font-size:13px}.import-panel{gap:10px;max-width:1180px;margin:18px auto 0;display:grid}.modal-backdrop{z-index:20;background:#0f172a61;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.article-modal{background:#fff;border-radius:14px;grid-template-rows:auto auto minmax(0,1fr) auto;gap:14px;width:min(980px,96vw);max-height:92vh;padding:18px;display:grid;overflow:hidden;box-shadow:0 24px 70px #0f172a47}.narrow-modal{width:min(720px,96vw)}.modal-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.modal-header h2{margin:0}.modal-header p{color:#64748b;margin:4px 0 0}.tab-strip{padding-bottom:2px;overflow-x:auto}.tab-strip button.active{color:#174f5a;background:#edf7f9;border-color:#236b79}.tab-body{min-height:0;padding-right:4px;overflow:auto}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.wide-field{grid-column:1/-1}.modal-actions{border-top:1px solid #e2e8f0;justify-content:flex-end;padding-top:12px}.sql-layout,.admin-layout,.settings-grid,.split-card{grid-template-columns:minmax(0,1fr) minmax(320px,.8fr);align-items:start;gap:18px;max-width:1180px;margin:0 auto;display:grid}.template-list{max-height:520px;overflow:auto}.sql-template-card code{color:#236b57;text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.safe-note{color:#236b57}.danger-note{color:#9a3a3a}.user-list article{border:1px solid #dbe2ea;border-radius:10px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px;display:grid}.user-list span{color:#64748b;font-size:12px;display:block}.user-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.danger-button{color:#8b2e2e;border-color:#d79b9b}.role-capabilities{gap:16px;max-width:1180px;margin:18px auto 0;display:grid}.role-capabilities h2,.role-capability-list h3{margin:0}.role-capabilities p,.role-capability-list p{color:#64748b;margin:4px 0 0}.role-capability-list{gap:10px;display:grid}.role-capability-list article{background:#fbfdff;border:1px solid #dbe2ea;border-radius:10px;gap:10px;padding:12px;display:grid}.permission-chip-list{flex-wrap:wrap;gap:6px;display:flex}.permission-chip-list span{color:#245b4a;background:#fff;border:1px solid #bdd3ca;border-radius:999px;padding:4px 8px;font-size:12px}.settings-card{grid-template-columns:150px minmax(0,1fr);gap:10px;display:grid}.settings-card dt{color:#64748b}.settings-card dd{word-break:break-word;margin:0}.settings-card h2,.settings-card p{grid-column:1/-1}.wide-settings{max-width:900px;margin:0 auto}.account-page{align-content:start;display:grid}.account-card{background:#fff;border:1px solid #dbe2ea;border-radius:12px;width:min(460px,100%);margin:0 auto;padding:18px}.login-shell{grid-template-rows:auto minmax(0,1fr);display:grid}.login-panel{place-items:center;padding:32px 16px;display:grid}.login-form{background:#fff;border:1px solid #dbe2ea;border-radius:14px;gap:12px;width:min(420px,100%);padding:24px;display:grid;box-shadow:0 18px 48px #0f172a14}.login-form h2{margin:0}.login-form label{color:#475569;gap:6px;display:grid}.login-form p{color:#64748b;margin:0;font-size:13px;line-height:1.45}pre{color:#e9f1f4;white-space:pre-wrap;background:#101820;border-radius:10px;margin:0;padding:12px;font-size:13px;line-height:1.5;overflow:auto}.image-band{gap:10px;margin-top:4px;display:grid}.image-band h3{margin:0;font-size:14px}.image-band p{color:#64748b;margin:0;font-size:13px}.image-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;display:grid}.image-grid figure{background:#fff;border:1px solid #dbe2ea;border-radius:10px;margin:0;overflow:hidden}.image-grid img{object-fit:contain;background:#f1f5f9;width:100%;height:180px;display:block}.image-grid figcaption{color:#475569;padding:8px;font-size:12px}@media (width<=1120px){.app-header,.login-header{grid-template-columns:minmax(220px,1fr)}.header-status,.header-actions{justify-content:flex-start}.app-layout{grid-template-columns:220px minmax(0,1fr)}.chat-titlebar,.page-header,.preview-title{display:grid}.kb-layout,.sql-layout,.admin-layout,.settings-grid,.split-card{grid-template-columns:minmax(0,1fr)}.article-list{max-height:340px}}@media (width<=760px){.app-layout{height:auto;min-height:0;display:block;overflow:auto}.left-nav{border-bottom:1px solid #dbe2ea;border-right:0;display:block}.main-nav{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:12px}.recent-section{display:none}.content-area,.chat-page,.page-panel{height:auto;min-height:680px;overflow:visible}.chat-page{padding-bottom:230px}.conversation{min-height:420px;padding-bottom:250px}.chat-composer{z-index:12;max-height:45vh;position:fixed;bottom:0;left:0;right:0;overflow:auto;box-shadow:0 -12px 30px #0f172a29}.composer-row,.form-grid{grid-template-columns:minmax(0,1fr)}.message.user{margin-right:0}.side-drawer{position:fixed}}
