:root{color:#1f2933;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f4f0e8;font-family:Microsoft YaHei,PingFang SC,Segoe UI,system-ui,sans-serif}*{box-sizing:border-box}html,body,#root{min-width:320px;min-height:100vh;margin:0}body{overflow:hidden}@media (width<=760px){body{overflow:auto}}.app-shell{color:#efe8d4;background:#10130f;min-height:100vh}.topbar{background:#151a15;border-bottom:1px solid #2a332b;justify-content:space-between;align-items:center;height:72px;padding:0 16px 0 0;display:flex}.brand{align-items:center;min-width:0;display:flex}.brand-mark{color:#18140e;background:#b58a45;place-items:center;width:52px;height:72px;font-size:22px;font-weight:900;display:grid}.brand div{align-items:baseline;gap:14px;padding-left:16px;display:flex}.brand strong{color:#fff4da;letter-spacing:.3px;font-size:18px}.brand div span{color:#928873;font-size:13px}.top-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}button{color:#e9dec2;cursor:pointer;min-height:34px;font:inherit;background:#1a211b;border:1px solid #384438;border-radius:7px}button:hover{background:#222b22;border-color:#b58a45}button:disabled{cursor:not-allowed;opacity:.52}.top-actions button{color:#f2dfad;min-width:58px;padding:0 12px}.font-actions{background:#1a211b;border:1px solid #384438;border-radius:7px;grid-template-columns:auto auto auto;align-items:center;gap:4px;min-height:34px;padding:0 6px;display:grid}.font-actions button{color:#f2dfad;background:0 0;border:0;min-width:38px;min-height:26px;padding:0 6px}.font-actions button:hover{background:#222b22}.font-actions span{color:#928873;font-size:12px}.hidden-file-input{display:none}.settings-panel{z-index:10;background:#181e18;border:1px solid #5d4b2b;border-radius:10px;grid-template-columns:1fr 1fr 1fr auto;gap:10px;width:min(520px,100vw - 28px);padding:12px;display:grid;position:fixed;top:82px;right:14px;box-shadow:0 20px 70px #0000006b}.settings-panel>div{grid-column:1/-1;justify-content:space-between;align-items:baseline;gap:12px;display:flex}.settings-panel strong{color:#fff2d2;font-size:15px}.settings-panel span{color:#958a74;font-size:12px}.settings-panel label{color:#b8aa8e;grid-column:1/4;gap:6px;font-size:12px;display:grid}.settings-panel input{color:#efe8d4;width:100%;height:34px;font:inherit;background:#111610;border:1px solid #334033;border-radius:8px;padding:0 9px}.settings-panel button{color:#18140e;background:#b58a45;border-color:#b58a45;align-self:end;min-width:58px;font-weight:700}.service-status{background:#111610;border:1px solid #334033;border-radius:8px;grid-column:1/-1;gap:4px;padding:10px;display:grid}.service-status strong{font-size:13px}.service-status span{color:#b8aa8e}.service-status.online{background:#142014;border-color:#53754c}.service-status.online strong{color:#bfe7b4}.service-status.checking{border-color:#5d4b2b}.service-status.checking strong{color:#f0d891}.service-status.offline{background:#241612;border-color:#7a3f32}.service-status.offline strong{color:#ffc2b5}.modal-backdrop{z-index:20;background:#060806b3;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.new-project-panel{background:#181e18;border:1px solid #5d4b2b;border-radius:10px;gap:14px;width:min(620px,100%);padding:18px;display:grid;box-shadow:0 26px 90px #00000085}.modal-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.modal-header h2{color:#fff2d2;margin:0;font-size:20px}.modal-header button{min-width:58px}.new-project-panel label{color:#b8aa8e;gap:7px;font-size:13px;display:grid}.new-project-panel input,.new-project-panel textarea{color:#efe8d4;width:100%;font:inherit;background:#111610;border:1px solid #334033;border-radius:8px}.new-project-panel input{height:38px;padding:0 10px}.new-project-panel textarea{resize:vertical;min-height:118px;padding:10px;line-height:1.7}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.modal-actions{justify-content:flex-end;gap:10px;display:flex}.modal-actions button{min-width:84px;padding:0 14px}.modal-actions button:last-child{color:#18140e;background:#b58a45;border-color:#b58a45;font-weight:700}.workspace{box-sizing:border-box;grid-template-columns:216px 340px minmax(380px,1fr) 232px 304px;height:calc(100vh - 73px);display:grid}.focus-mode .workspace{grid-template-columns:minmax(0,1fr)}.focus-mode .sidebar,.focus-mode .assistant-panel,.focus-mode .directory-panel,.focus-mode .library-editor,.focus-mode .source-strip{display:none}.focus-mode .editor-panel{border-right:0}.focus-mode .manuscript{padding-inline:max(72px,50vw - 460px)}.panel{background:#151913;border-right:1px solid #2a332b;min-height:0;overflow:hidden}.sidebar,.assistant-panel,.directory-panel,.library-editor{flex-direction:column;min-height:0;display:flex}.sidebar,.directory-panel{box-sizing:border-box;padding:16px 10px;overflow:auto}.assistant-panel{background:#181e18}.chat-title{color:#f6ead0;border-bottom:1px solid #2a332b;align-items:center;height:52px;padding:0 18px;font-weight:700;display:flex}.quick-tools{border-bottom:1px solid #2a332b;grid-template-columns:repeat(4,minmax(0,1fr));display:grid}.quick-tools button{color:#9d927b;background:#1c231c;border:0;border-right:1px solid #2a332b;border-radius:0;min-width:0;height:42px;font-size:13px}.quick-tools button.active{color:#f5df9b;background:#273125}.welcome-card{text-align:center;align-content:center;justify-items:center;gap:12px;min-height:390px;padding:28px;display:grid}.app-glyph{color:#f6d88c;background:#252416;border:1px solid #b58a45b3;border-radius:18px;place-items:center;width:58px;height:58px;font-size:28px;display:grid}.welcome-card h2{color:#fff3d2;margin:4px 0 0;font-size:18px}.welcome-card p{color:#948b79;margin:0 0 10px;font-size:13px}.welcome-card button{min-width:126px;padding:0 16px}.ai-history{border-top:1px solid #2a332b;gap:7px;min-height:0;max-height:210px;padding:10px 12px;display:grid;overflow:auto}.ai-history-header{color:#f6ead0;justify-content:space-between;align-items:center;font-size:13px;font-weight:700;display:flex}.ai-history-header button{color:#f2d58b;min-height:26px;padding:0 8px;font-size:12px}.ai-history-item{grid-template-columns:minmax(0,1fr) auto;gap:6px;display:grid}.ai-history-open{text-align:left;gap:4px;width:100%;min-height:auto;padding:8px;display:grid}.ai-history-delete{color:#ffb6a6;min-height:auto;padding:0 8px;font-size:12px}.ai-history-open span,.ai-history-open small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.ai-history-open span{color:#f0d891;font-size:12px;font-weight:700}.ai-history-open small,.empty-history{color:#928873;font-size:12px}.empty-history{text-align:center;background:#111610;border:1px solid #334033;border-radius:8px;margin:0;padding:10px}.project-card{background:#1a211b;border:1px solid #334033;border-radius:10px;padding:12px}.project-card-header{justify-content:space-between;align-items:center;gap:10px;display:flex}.project-card-header button{color:#f2d58b;min-height:28px;padding:0 10px;font-size:12px}.eyebrow{color:#928873;margin-bottom:6px;font-size:12px;font-weight:700;display:block}.project-card h1{color:#fff0ca;margin:0;font-size:17px;line-height:1.25}.project-card p{color:#948b79;margin:7px 0 12px;font-size:12px}.project-premise{-webkit-line-clamp:3;-webkit-box-orient:vertical;line-height:1.55;display:-webkit-box;overflow:hidden}.writing-progress{gap:6px;margin:10px 0 12px;display:grid}.writing-progress div{background:0 0;justify-content:space-between;align-items:center;gap:8px;padding:0;display:flex}.writing-progress span,.writing-progress small{color:#928873;font-size:12px}.writing-progress strong{color:#f0d891;font-size:14px}.writing-progress progress{background:#111610;border:0;border-radius:999px;width:100%;height:8px;overflow:hidden}.writing-progress progress::-webkit-progress-bar{background:#111610}.writing-progress progress::-webkit-progress-value{background:#b58a45;border-radius:999px}.writing-progress progress::-moz-progress-bar{background:#b58a45;border-radius:999px}.project-meta-form{gap:9px;margin-bottom:12px;display:grid}.project-meta-form label{color:#b8aa8e;gap:5px;font-size:12px;display:grid}.project-meta-form input,.project-meta-form textarea{color:#efe8d4;width:100%;font:inherit;background:#111610;border:1px solid #334033;border-radius:8px}.project-meta-form input{height:32px;padding:0 9px}.project-meta-form textarea{resize:vertical;min-height:86px;padding:8px 9px;line-height:1.55}.project-card dl{grid-template-columns:1fr 1fr;gap:6px;margin:0;display:grid}.project-card div{background:#111610;border-radius:8px;padding:8px}dt,dd{margin:0}dt{color:#877b65;font-size:11px}dd{color:#f5df9b;margin-top:2px;font-size:16px;font-weight:700}.nav-section{margin-top:14px}.section-title{color:#f6ead0;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px;font-weight:700;display:flex}.section-title button{color:#f2d58b;width:28px;min-height:28px;padding:0}.project-list,.chapter-list,.template-list,.context-list,.library{gap:6px;display:grid}.chapter-list{margin:0;padding:0;list-style:none}.chapter-search{grid-template-columns:minmax(0,1fr) auto;gap:6px;margin-bottom:8px;display:grid}.chapter-search input{color:#efe8d4;width:100%;height:32px;font:inherit;background:#111610;border:1px solid #334033;border-radius:8px;padding:0 9px;font-size:12px}.chapter-search button{color:#f2d58b;min-height:32px;padding:0 9px;font-size:12px}.project-list-item,.chapter-list-item,.library button{text-align:left;flex-direction:column;align-items:flex-start;gap:4px;width:100%;padding:10px;display:flex}.project-list-item,.chapter-list-item{background:#1a211b;border:1px solid #384438;border-radius:7px}.project-list-item:hover,.chapter-list-item:hover{background:#222b22;border-color:#b58a45}.project-open-button,.chapter-open-button{text-align:left;background:0 0;border:0;gap:4px;width:100%;min-height:auto;padding:0;display:grid}.project-open-button:hover,.chapter-open-button:hover{background:0 0;border-color:#0000}.project-actions,.chapter-actions{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.project-actions button,.chapter-actions button{min-height:26px;padding:0 8px;font-size:12px}.project-actions button:last-child,.chapter-actions button:last-child{color:#ffb6a6}.library button{flex-direction:row;justify-content:space-between}.project-list-item.active,.chapter-list-item.active,.library button.active{background:#252a1d;border-color:#b58a45}.project-list span,.chapter-list span{text-overflow:ellipsis;white-space:nowrap;max-width:100%;overflow:hidden}.project-list small,.chapter-list small,.library small{color:#817764;font-size:12px}.empty-chapter-search{color:#928873;text-align:center;background:#1a211b;border:1px solid #334033;border-radius:8px;justify-items:center;gap:10px;padding:18px 8px;display:grid}.empty-chapter-search strong{color:#fff2d2}.empty-chapter-search button{min-height:30px;padding:0 12px}.editor-panel{background:#1a1712;grid-template-rows:auto auto minmax(0,1fr) auto;display:grid}.editor-header{background:#211d16;border-bottom:1px solid #322b20;justify-content:space-between;align-items:center;gap:16px;height:56px;padding:0 18px;display:flex}.chapter-title-input{color:#fff2d2;width:min(420px,48vw);font:inherit;background:0 0;border:0;outline:0;padding:0;font-size:15px;font-weight:700;display:block}.chapter-stats{color:#8e846f;flex-wrap:wrap;justify-content:flex-end;gap:8px;font-size:12px;display:flex}.chapter-stats span{background:#15140f;border-radius:999px;padding:4px 8px}.chapter-stats span:last-child{color:#f0d891;border:1px solid #41351f}.chapter-summary-editor{background:#1d1912;border-bottom:1px solid #322b20;padding:10px 18px}.summary-editor-header{justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px;display:flex}.summary-editor-header span{color:#928873;font-size:12px;font-weight:700}.summary-editor-header button{color:#f2d58b;min-height:28px;padding:0 10px;font-size:12px}.chapter-summary-editor textarea{resize:vertical;color:#efe8d4;width:100%;min-height:54px;max-height:112px;font:inherit;background:#15140f;border:1px solid #3d3323;border-radius:8px;padding:8px 10px;font-size:13px;line-height:1.55}.manuscript{resize:none;box-sizing:border-box;color:#2e2419;background:#f4ead8;border:0;outline:0;width:100%;min-width:0;height:100%;padding:38px clamp(28px,6vw,86px);font-family:Microsoft YaHei,PingFang SC,Segoe UI,sans-serif;font-size:18px;line-height:2}.empty-editor{color:#766852;background:#f4ead8;place-content:center;justify-items:center;gap:14px;min-height:0;display:grid}.empty-editor strong{color:#2e2419}.empty-editor button{color:#f8e5ae;background:#292417;border-color:#b58a45;padding:0 16px}.source-strip{background:#211d16;border-top:1px solid #322b20;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:10px;display:grid}.source-strip article,.prompt-preview{background:#17140f;border:1px solid #3d3323;border-radius:10px;min-width:0;padding:10px}.source-strip span,.prompt-preview span{color:#f0d891;margin-bottom:4px;font-size:12px;font-weight:700;display:block}.source-strip p,.prompt-preview p{color:#b8aa8e;margin:0;font-size:12px;line-height:1.5}.context-section{margin-top:14px}.context-list label{color:#d6cbb4;background:#1a211b;border:1px solid #334033;border-radius:8px;align-items:center;gap:8px;padding:8px 10px;font-size:13px;display:flex}.context-list input{accent-color:#b58a45;width:15px;height:15px}.ai-compose{border-top:1px solid #2a332b;gap:10px;margin-top:auto;padding:12px;display:grid}.prompt-preview small{color:#8b806b;margin-top:8px;display:block}.ai-result{background:#211d16;border:1px solid #5d4b2b;border-radius:10px;max-height:190px;padding:10px;overflow:auto}.ai-result span{color:#f0d891;margin-bottom:6px;font-size:12px;font-weight:700;display:block}.ai-result p{white-space:pre-wrap;color:#efe8d4;margin:0;font-size:13px;line-height:1.7}.assistant-error{color:#ffc2b5;background:#2c1712;border:1px solid #7a3f32;border-radius:8px;margin:0;padding:8px 10px;font-size:12px;line-height:1.5}.ai-compose textarea{resize:vertical;color:#efe8d4;min-height:76px;font:inherit;background:#111610;border:1px solid #334033;border-radius:10px;padding:10px;font-size:13px;line-height:1.6}.compose-actions{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.compose-actions button{min-width:0;padding:0 6px}.compose-actions button:first-child{color:#18140e;background:#b58a45;border-color:#b58a45;font-weight:700}.library-editor{background:#141914}.library-editor-header{border-bottom:1px solid #2a332b;justify-content:space-between;align-items:center;gap:12px;height:70px;padding:0 14px;display:flex}.library-editor-header h2{color:#fff2d2;margin:0;font-size:16px}.library-editor-header button{min-width:58px}.library-search{border-bottom:1px solid #2a332b;grid-template-columns:minmax(0,1fr) auto;gap:8px;padding:10px 12px;display:grid}.library-search input{color:#efe8d4;width:100%;height:34px;font:inherit;background:#111610;border:1px solid #334033;border-radius:8px;padding:0 10px}.library-search button{color:#f2d58b;min-width:54px;padding:0 10px}.library-card-list{align-content:start;gap:10px;min-height:0;padding:12px;display:grid;overflow:auto}.library-card-editor{background:#1a211b;border:1px solid #334033;border-radius:10px;gap:8px;padding:10px;display:grid}.library-card-editor input,.library-card-editor textarea{color:#efe8d4;width:100%;font:inherit;background:#111610;border:1px solid #334033;border-radius:8px}.library-card-editor input{height:34px;padding:0 9px;font-weight:700}.library-card-editor textarea{resize:vertical;min-height:118px;padding:9px;line-height:1.6}.danger-button{color:#ffb6a6;justify-self:end;min-width:56px}.empty-library{color:#928873;text-align:center;justify-items:center;gap:12px;padding:28px 12px;display:grid}.empty-library strong{color:#fff2d2}@media (width<=1180px){.workspace{grid-template-columns:220px minmax(320px,1fr) 260px}.assistant-panel,.library-editor{display:none}}@media (width<=820px){body{overflow:auto}.topbar{flex-direction:column;align-items:stretch;gap:10px;height:auto;padding:0 10px 10px 0}.settings-panel{grid-template-columns:1fr;width:auto;margin:10px;position:static}.settings-panel label{grid-column:auto}.workspace{grid-template-columns:1fr;height:auto}.form-row{grid-template-columns:1fr}.panel{border-bottom:1px solid #2a332b;border-right:0}.manuscript{min-height:58vh;padding:22px}.source-strip{grid-template-columns:1fr}}.auth-wall{background:#0f1610;justify-content:center;align-items:center;height:100vh;display:flex}.auth-card{background:#1a2419;border:1px solid #2a332b;border-radius:10px;flex-direction:column;gap:12px;width:320px;padding:32px 28px;display:flex}.auth-tabs{gap:8px;margin-bottom:4px;display:flex}.auth-tabs button{color:#8aaf8c;cursor:pointer;background:0 0;border:1px solid #2a332b;border-radius:6px;flex:1;padding:6px}.auth-tabs button.active{color:#c5e8c7;background:#2a4a2c;border-color:#4a7a4c}.auth-card input{color:#d4ebd4;background:#111e12;border:1px solid #2a332b;border-radius:6px;padding:8px 10px;font-size:14px}.auth-error{color:#e07070;margin:0;font-size:13px}.auth-submit{color:#d4ebd4;cursor:pointer;background:#2e6b30;border:none;border-radius:6px;margin-top:4px;padding:9px;font-size:14px}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-submit:hover:not(:disabled){background:#3a7e3c}
