.app-shell{display:flex;grid-template-columns:320px 1fr;height:100%}.main-area{display:flex;flex:1;flex-direction:column;min-width:0;min-height:0;background:#fbfcfe}.topbar{position:sticky;top:0;z-index:4;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 24px;border-bottom:1px solid var(--line);background:#ffffffe0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.topbar .caption{margin:0;font-size:12px;color:var(--text-subtle)}.topbar h2{margin:4px 0 0;font-size:22px;font-weight:700}.title-row{display:flex;align-items:center;gap:10px}.title-editor{display:flex;align-items:center;gap:6px}.title-input{border:1px solid var(--line);border-radius:10px;padding:6px 10px;min-width:200px}.title-save,.title-cancel{border:1px solid var(--line);background:#fff;border-radius:8px;padding:6px 10px;cursor:pointer}.topbar-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:10px;min-width:0}.backend-settings{border:1px solid var(--line);background:#fff;color:var(--text-main);border-radius:10px;padding:6px;display:inline-flex;align-items:center;gap:6px;min-width:0}.backend-url-field{display:inline-flex;align-items:center;gap:6px;color:var(--text-subtle);font-size:12px}.backend-url-field input{width:clamp(150px,15vw,190px);border:1px solid #d7e1ef;border-radius:8px;padding:5px 8px;color:var(--text-main)}.backend-url-field input:focus{outline:2px solid #d8e6ff;border-color:#acc6f6}.backend-status{border-radius:999px;padding:3px 8px;display:inline-flex;align-items:center;gap:4px;font-size:12px;white-space:nowrap}.backend-status.connected{color:#1f6f43;background:#eaf8ef}.backend-status.checking{color:#725a13;background:#fff7d6}.backend-status.disconnected{color:#9a3412;background:#fff1e8}.language-select{border:1px solid var(--line);background:#fff;color:var(--text-main);border-radius:10px;padding:6px 8px;display:inline-flex;align-items:center;gap:8px;font-size:13px}.language-select select{border:none;background:transparent;color:var(--text-main);font:inherit;cursor:pointer;outline:none}.novel-select{border:1px solid var(--line);background:#fff;color:var(--text-main);border-radius:10px;padding:8px 10px;min-width:160px}.topbar-actions button{border:1px solid var(--line);background:#fff;color:var(--text-main);border-radius:10px;padding:8px 12px;display:inline-flex;align-items:center;gap:6px;cursor:pointer}.topbar-actions button:hover{border-color:#cdd8e8;background:#f8fbff}.topbar-actions button:disabled{cursor:not-allowed;opacity:.5}.content-grid{padding:20px 24px;display:grid;align-content:start;grid-auto-rows:max-content;gap:14px;overflow-y:auto;flex:1;min-height:0}.content-card{background:var(--bg-main);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:16px}.section-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.section-title-row h2{margin:0;font-size:19px}.section-hint{margin:4px 0 0;color:var(--text-subtle);font-size:13px;line-height:1.45}.section-actions{display:inline-flex;align-items:center;gap:8px}.section-actions button{border:1px solid #d4dfef;background:#fff;color:#34507d;border-radius:10px;height:32px;padding:0 12px;display:inline-flex;align-items:center;gap:6px;cursor:pointer}.primary-action,.secondary-action{border:1px solid #d4dfef;background:#fff;color:#34507d;border-radius:10px;min-height:34px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer}.primary-action{border-color:#2855b6;background:#2d5dbf;color:#fff}.primary-action:disabled,.secondary-action:disabled{cursor:not-allowed;opacity:.55}.workflow-tabs{display:flex;flex-wrap:wrap;gap:8px;padding:12px 24px 0;background:#fbfcfe}.workflow-tab{border:1px solid #d7e1ef;background:#fff;color:#324766;border-radius:10px;min-height:38px;padding:0 14px;font-weight:600;cursor:pointer;flex:1 1 150px}.workflow-tab.active{border-color:#2d5dbf;background:#eef4ff;color:#214da8}.assembly-tags{display:flex;flex-wrap:wrap;gap:10px}.assembly-tag{border-radius:999px;padding:8px 12px;font-size:13px;color:#29406c;background:#edf3ff;border:1px solid #d8e6ff}.status-footer{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;border-top:1px solid var(--line);background:#fff;padding:12px 24px;color:var(--text-subtle);font-size:13px}.status-highlight{color:#2453c0;font-weight:600}.status-error{color:#b42318}@media (max-width: 1100px){.app-shell{grid-template-columns:280px 1fr}.topbar{align-items:flex-start;flex-direction:column;gap:12px}.backend-settings{width:100%;flex-wrap:wrap}.backend-url-field{flex:1}.backend-url-field input{width:100%}.status-footer{grid-template-columns:repeat(2,minmax(0,1fr))}}.sidebar{border-right:1px solid var(--line);background:linear-gradient(180deg,#eef2f8,#f5f8fd);display:flex;flex-direction:column;padding:16px;gap:14px}.sidebar-top{display:flex;flex-direction:column;gap:14px}.brand-row{display:flex;align-items:center;gap:10px}.brand-icon{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:linear-gradient(135deg,#4285f4,#34a853 42%,#fbbc05 70%,#ea4335);color:#fff;box-shadow:0 8px 18px #4285f43d}.brand-row h1{margin:0;font-size:26px;line-height:1}.brand-name{display:inline-flex;align-items:baseline;font-weight:800;letter-spacing:0}.brand-letter{display:inline-block}.brand-space{width:.28em}.brand-letter.color-0,.brand-letter.color-6{color:#4285f4}.brand-letter.color-1,.brand-letter.color-7{color:#ea4335}.brand-letter.color-2{color:#fbbc05}.brand-letter.color-3{color:#4285f4}.brand-letter.color-4{color:#34a853}.brand-row p{margin:4px 0 0;color:var(--text-subtle);font-size:12px}.nav-list{display:grid;gap:8px}.nav-block{display:grid;gap:1px}.nav-button{border:1px solid #d2dded;border-radius:12px;height:42px;background:#fffc;color:#2c3e66;font-weight:600;display:inline-flex;align-items:center;gap:8px;padding:0 12px;cursor:pointer}.nav-button.primary{background:linear-gradient(180deg,#3d66c2,#2852ae);border-color:#2f56af;color:#fff}.nav-button:hover{background:#f4f8ff}.nav-button.primary:hover{background:linear-gradient(180deg,#4871cd,#2c57b7)}.sidebar-panels{overflow-y:auto;flex:1;min-height:0;width:250px}.sidebar-panel{padding:0}.panel-body{padding:10px;display:grid;gap:6px}.chapter-item,.novel-title{width:100%;border:1px solid #e4e9f1;background:#fbfdff;color:#2c3e66;border-radius:10px;padding:6px 8px;display:flex;justify-content:space-between;align-items:center;cursor:pointer}.chapter-item.active,.novel-item.active .novel-title{border-color:#2f56af;background:#eef3ff}.chapter-id,.novel-id{font-size:11px;color:#8b9bb5}.chapter-empty,.novel-empty{margin:0;font-size:12px;color:#8b9bb5}.novel-item{display:grid;gap:6px}.novel-input{border:1px solid #d6e1f1;border-radius:8px;padding:6px 8px;font-size:12px}.novel-action{border:1px solid #d6e1f1;background:#fff;color:#2c3e66;border-radius:8px;padding:4px 8px;cursor:pointer}.sidebar-settings{margin-top:auto;border:1px solid #d7e0ef;background:#fff;color:#35486f;border-radius:10px;height:40px;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer}.sidebar-settings:hover{border-color:#c6d3e6}.panel-card{border:1px solid var(--line);border-radius:12px;background:#fff;overflow:hidden}.panel-card.long-memory{margin-top:12px}.panel-header{width:100%;border:none;background:#f8fbff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:10px;cursor:pointer}.panel-title-wrap{display:flex;gap:8px;align-items:flex-start}.panel-title-wrap h3{margin:0;font-size:15px;color:#203459}.panel-title-wrap p{margin:2px 0 0;color:#6e7d96;font-size:12px}.chevron{transition:transform .2s ease;color:#5f6f89}.chevron.collapsed{transform:rotate(-90deg)}.short-memory-list,.long-memory-list{margin:0;padding:10px;list-style:none;display:grid;gap:8px}.short-memory-item{padding:10px;border-radius:10px;border:1px solid #e7edf6;background:#fcfdff}.short-memory-item p{margin:6px 0;font-size:13px;line-height:1.45;color:#1f2c43}.memory-round{font-size:12px;color:#6f7f9a}.status-tag{display:inline-flex;align-items:center;font-size:12px;border-radius:999px;background:#eef3fb;color:#2f4773;padding:2px 8px}.status-tag.latest{background:#deebff;color:#204fb1}.long-memory-item{border:1px solid #e7edf6;border-radius:10px;padding:10px;display:grid;gap:10px;background:#fcfdff}.memory-headline{display:flex;align-items:center;gap:8px}.memory-headline h4{margin:0;font-size:14px}.entry-count{font-size:12px;color:#677894;background:#f0f4fb;border-radius:999px;padding:2px 8px}.locked-badge{font-size:11px;color:#8e2e2e;background:#ffe9e9;border:1px solid #ffc9c9;border-radius:999px;padding:2px 8px}.memory-main p{margin:6px 0 0;font-size:12px;color:#5e6f8b;line-height:1.35}.memory-edit{width:100%;border:1px solid #d9e4f3;border-radius:10px;padding:8px;font-size:12px;color:#2a3b57;line-height:1.4;background:#fbfdff}.memory-edit:focus{outline:2px solid #d8e6ff;border-color:#a9c3f7}.memory-controls{display:flex;gap:8px;flex-wrap:wrap}.lock-button{border:1px solid #d5e1f1;background:#fff;color:#35507e;border-radius:8px;height:30px;padding:0 10px;font-size:12px;display:inline-flex;align-items:center;gap:6px;cursor:pointer}.lock-button.active{background:#f1f6ff;color:#1f4eb1}.switch{border:1px solid #d4dfef;background:#f5f8ff;color:#486187;border-radius:999px;height:30px;padding:0 10px;min-width:132px;display:inline-flex;align-items:center;justify-content:space-between;gap:6px;font-size:12px;cursor:pointer}.switch .switch-knob{width:18px;height:18px;border-radius:50%;background:#adb9cd;transition:transform .2s ease,background .2s ease}.switch.on{background:#e7f0ff;border-color:#bdd0f5;color:#1f4eb1}.switch.on .switch-knob{background:#2e5bbd;transform:translate(2px)}.switch:disabled{cursor:not-allowed;opacity:.55}.chapter-goal-card .goal-main-text{font-size:21px;font-weight:700;line-height:1.45;margin-bottom:12px}.goal-editor{display:grid;gap:10px;margin-bottom:12px}.goal-input{width:100%;resize:vertical;border:1px solid #d6e2f2;background:#fbfdff;border-radius:12px;padding:10px;color:#1f2d45;line-height:1.5}.goal-input:focus,.goal-edit-row input:focus{outline:2px solid #d8e6ff;border-color:#acc6f6}.goal-edit-row{display:flex;flex-wrap:wrap;gap:10px}.goal-edit-row label{display:grid;gap:4px;font-size:12px;color:#5f6f89}.goal-edit-row input{border:1px solid #d6e2f2;border-radius:10px;padding:7px 10px;min-width:120px;color:#1f2d45}.goal-meta-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.meta-pill{font-size:12px;color:#385480;background:#edf4ff;border:1px solid #d8e6ff;border-radius:999px;padding:4px 10px}.progress-track{height:8px;border-radius:999px;background:#edf1f8;overflow:hidden}.progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#3f6ece,#2551b1)}.user-input{width:100%;resize:vertical;border:1px solid #dae4f1;border-radius:12px;padding:12px;line-height:1.6;min-height:125px;color:var(--text-main)}.user-input:focus{outline:2px solid #d9e6ff;border-color:#a9c3f7}.input-actions{margin-top:12px;display:flex;justify-content:space-between;gap:12px}.assist-actions{display:flex;flex-wrap:wrap;gap:8px}.assist-actions button{border:1px solid #d6e1f1;background:#fff;color:#3d5276;border-radius:10px;padding:7px 12px;cursor:pointer}.assist-actions button:disabled{cursor:not-allowed;opacity:.5}.generate-btn{border:1px solid #2855b6;background:linear-gradient(180deg,#3f6cca,#2450b0);color:#fff;border-radius:12px;padding:8px 16px;display:inline-flex;align-items:center;gap:7px;cursor:pointer;box-shadow:0 8px 18px #2655b547}.generate-btn:hover{filter:brightness(1.05)}.generated-panel .novel-content{max-width:fit-content;padding:0 5px;box-shadow:0 1px 2px #0000000a,0 8px 24px #0000000a;border-radius:12px;max-height:500px;overflow-y:auto}.generated-block+.generated-block{margin-top:16px}.generated-block h3{margin:0 0 10px;font-size:15px;color:#2b3f65}.novel-content p{margin:0 0 1em;font-size:17px;line-height:1.9;letter-spacing:.01em;color:#202d42}.draft-editor{border-top:1px dashed #d8e2f2;padding-top:14px}.draft-input{width:100%;resize:vertical;border:1px solid #d6e2f2;background:#fbfdff;border-radius:12px;padding:12px;color:#1f2d45;line-height:1.7;min-height:160px}.draft-input:focus{outline:2px solid #d8e6ff;border-color:#acc6f6}.draft-actions{margin-top:10px;display:flex;gap:10px}.draft-actions button{border:1px solid #d5e0f1;background:#fff;color:#34507d;border-radius:10px;height:34px;padding:0 12px;display:inline-flex;align-items:center;gap:6px;cursor:pointer}.draft-actions button:disabled{opacity:.55;cursor:not-allowed}.draft-actions .confirm-btn{border-color:#2553b2;background:#2c5cc0;color:#fff}.fact-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.fact-group{border:1px solid #e4eaf3;border-radius:10px;background:#fbfdff;padding:10px}.fact-group h3{margin:0 0 8px;font-size:14px;display:inline-flex;align-items:center;gap:6px}.fact-group ul{margin:0;padding-left:18px;color:#334869;font-size:13px;display:grid;gap:5px}.warning-box{margin-top:10px;border:1px solid var(--danger-line);background:var(--danger-soft);color:var(--danger-text);border-radius:10px;display:flex;align-items:flex-start;gap:8px;padding:10px;font-size:13px}.fact-actions{margin-top:12px;display:flex;align-items:center;gap:10px}.fact-actions button{height:34px;border-radius:10px;border:1px solid #d3deef;background:#fff;color:#334a72;padding:0 12px;cursor:pointer}.fact-actions button:disabled{cursor:not-allowed;opacity:.55}.fact-actions button.primary{background:#2a57b7;color:#fff;border-color:#2a57b7}.check-pass{margin-left:auto;font-size:13px;color:#2a7d4f;display:inline-flex;align-items:center;gap:6px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.field-label{display:grid;gap:6px;color:#5f6f89;font-size:12px;font-weight:600}.field-label.wide{grid-column:1 / -1}.field-label.compact{align-self:end}.field-label input,.field-label textarea,.field-label select,.bible-section textarea,.final-content-input,.export-result textarea{width:100%;border:1px solid #d6e2f2;background:#fbfdff;border-radius:10px;padding:9px 10px;color:#1f2d45;line-height:1.5}.field-label textarea,.bible-section textarea,.final-content-input,.export-result textarea{resize:vertical}.field-label input:focus,.field-label textarea:focus,.field-label select:focus,.bible-section textarea:focus,.final-content-input:focus,.export-result textarea:focus{outline:2px solid #d8e6ff;border-color:#acc6f6}.bible-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.bible-section{border:1px solid #e3eaf4;background:#fcfdff;border-radius:10px;padding:12px}.bible-section-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.bible-section h3{margin:0;font-size:15px;color:#223657}.icon-state{border:1px solid #d7e1ef;background:#fff;color:#4d607d;border-radius:8px;width:30px;height:30px;display:grid;place-items:center;cursor:pointer}.icon-state.active{color:#8e2e2e;background:#fff1f1;border-color:#f4caca}.outline-list{display:grid;gap:12px}.outline-card{border:1px solid #e1e8f2;background:#fcfdff;border-radius:10px;padding:12px}.outline-card.active{border-color:#2d5dbf;background:#f5f8ff}.outline-card-head{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:12px}.outline-card-head>div{display:inline-flex;align-items:center;gap:8px;min-width:0}.outline-order{width:28px;height:28px;display:grid;place-items:center;border-radius:8px;background:#edf3ff;color:#244ea8;font-weight:700}.outline-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.final-content-input{min-height:260px;line-height:1.8;font-size:15px}.dashboard-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.metric-tile{border:1px solid #e1e8f2;border-radius:10px;background:#fcfdff;padding:12px}.metric-tile span{color:#64748f;font-size:12px}.metric-tile strong{display:block;margin:6px 0;color:#20365d;font-size:24px}.metric-tile p,.empty-note{margin:0;color:#64748f;font-size:13px}.quality-list{display:grid;gap:10px}.quality-item{border:1px solid #e1e8f2;border-radius:10px;padding:10px;background:#fcfdff}.quality-item.pass{border-color:#bfe6cf;background:#f2fbf5}.quality-item.warning{border-color:#f1d6a8;background:#fff8ec}.quality-item strong{color:#253854}.quality-item p{margin:5px 0 0;color:#56677f;font-size:13px;line-height:1.45}.export-result{display:grid;gap:10px}.export-meta{display:flex;flex-wrap:wrap;gap:8px}.export-meta span{border:1px solid #dce5f1;background:#f8fbff;color:#3c5274;border-radius:999px;padding:4px 10px;font-size:12px}@media (max-width: 1320px){.fact-grid,.form-grid,.bible-grid,.outline-fields,.dashboard-grid{grid-template-columns:1fr}.outline-card-head{align-items:stretch;flex-direction:column}}:root{--bg-main: #ffffff;--bg-subtle: #f3f6fa;--bg-soft: #f8fafc;--line: #e4e9f1;--text-main: #162033;--text-subtle: #5e6b82;--brand: #2359d4;--brand-soft: #dce8ff;--danger-soft: #fff1f1;--danger-line: #f8c8c8;--danger-text: #b53a3a;--radius: 14px;--shadow-card: 0 8px 24px rgba(23, 34, 52, .06)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:linear-gradient(120deg,#f6f8fc,#fff 35%,#f8fafc);color:var(--text-main)}button,input,textarea{font:inherit}
