:root{--bg:#f7f8fa;--surface:#fff;--surface-2:#f4f5f7;--surface-3:#eceef1;--border:#e4e7ec;--border-strong:#d0d5dd;--text:#101828;--text-secondary:#475467;--text-muted:#98a2b3;--accent:#4f46e5;--accent-hover:#4338ca;--accent-soft:#eef2ff;--accent-border:#c7d2fe;--danger:#d92d20;--danger-hover:#b42318;--danger-soft:#fef3f2;--draft:#667085;--draft-soft:#f2f4f7;--draft-border:#e4e7ec;--progress:#f79009;--progress-text:#b54708;--progress-soft:#fffaeb;--progress-border:#fedf89;--done:#17b26a;--done-text:#067647;--done-soft:#ecfdf3;--done-border:#abefc6;--shadow-xs:0 1px 2px #1018280d;--shadow-sm:0 1px 2px #1018280f, 0 1px 3px #1018281a;--shadow-md:0 4px 8px -2px #1018281a, 0 2px 4px -2px #1018280f;--shadow-lg:0 12px 16px -4px #10182814, 0 4px 6px -2px #10182808;--shadow-xl:0 20px 24px -4px #10182814, 0 8px 8px -4px #10182808;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--font:"Inter", "Segoe UI", system-ui, -apple-system, sans-serif}*{box-sizing:border-box}html,body{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;font-size:14px;line-height:1.5;overflow:hidden}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;background:0 0;border:0;padding:0}::selection{background:var(--accent-soft);color:var(--accent-hover)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background-clip:padding-box;background-color:var(--border-strong);border:3px solid #0000;border-radius:8px}::-webkit-scrollbar-thumb:hover{background-color:var(--text-muted)}.btn{border-radius:var(--radius-md);white-space:nowrap;justify-content:center;align-items:center;gap:7px;height:36px;padding:0 14px;font-size:13.5px;font-weight:600;transition:background-color .13s,border-color .13s,color .13s,box-shadow .13s,transform 80ms;display:inline-flex}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{cursor:default;opacity:.5}.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-xs)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary.btn-danger-action{background:var(--danger)}.btn-primary.btn-danger-action:hover:not(:disabled){background:var(--danger-hover)}.btn-secondary{border:1px solid var(--border-strong);background:var(--surface);color:var(--text-secondary);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--surface-3);color:var(--text)}.btn-link{color:var(--accent);background:0 0;font-weight:600}.btn-link:hover{color:var(--accent-hover);text-decoration:underline}.icon-btn{border-radius:var(--radius-sm);width:30px;height:30px;color:var(--text-muted);flex:none;justify-content:center;align-items:center;transition:background-color .13s,color .13s;display:inline-flex}.icon-btn:hover:not(:disabled){background:var(--surface-3);color:var(--text)}.icon-btn.danger:hover:not(:disabled){background:var(--danger-soft);color:var(--danger)}.icon-btn:disabled{cursor:default;opacity:.4}.input,.textarea{border:1px solid var(--border-strong);border-radius:var(--radius-md);background:var(--surface);width:100%;color:var(--text);box-shadow:var(--shadow-xs);padding:8px 12px;font-size:14px;transition:border-color .13s,box-shadow .13s}.input{height:36px}.input::placeholder,.textarea::placeholder{color:var(--text-muted)}.input:focus,.textarea:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #4f46e521}.textarea{resize:vertical;min-height:96px;line-height:1.55}.field{gap:6px;display:grid}.field-label{color:var(--text-secondary);font-size:13px;font-weight:600}.loading-screen{background:var(--bg);place-items:center;min-height:100vh;display:grid}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.auth-page{background:radial-gradient(ellipse 60% 40% at 50% -10%, #4f46e521, transparent), var(--bg);place-items:center;min-height:100vh;padding:24px;display:grid}.auth-card{border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--surface);width:min(400px,100%);box-shadow:var(--shadow-xl);padding:36px 32px 28px}.auth-brand{align-items:center;gap:10px;margin-bottom:24px;display:flex}.brand-mark{color:#fff;width:36px;height:36px;box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#6366f1,#4338ca);border-radius:10px;flex:none;place-items:center;display:grid}.auth-brand h1,.app-brand h1{letter-spacing:-.02em;margin:0;font-size:18px;font-weight:700}.auth-card h2{letter-spacing:-.02em;margin:0 0 4px;font-size:20px;font-weight:700}.auth-subtitle{color:var(--text-secondary);margin:0 0 24px}.auth-form{gap:16px;display:grid}.auth-form .btn{height:40px;margin-top:4px}.auth-switch{border-top:1px solid var(--border);color:var(--text-secondary);justify-content:center;align-items:center;gap:6px;margin-top:20px;padding-top:18px;font-size:13.5px;display:flex}.app-shell{grid-template-columns:var(--sidebar-width,288px) minmax(0, 1fr);height:100vh;display:grid;position:relative;overflow:hidden}.sidebar-resizer{top:0;bottom:0;left:var(--sidebar-width,288px);z-index:10;cursor:col-resize;touch-action:none;width:10px;position:absolute;transform:translate(-5px)}.sidebar-resizer:before{content:"";background:0 0;width:2px;transition:background-color .15s 80ms;position:absolute;top:0;bottom:0;left:4px}.sidebar-resizer:hover:before,body.sidebar-resizing .sidebar-resizer:before{background:var(--accent)}body.sidebar-resizing{cursor:col-resize;-webkit-user-select:none;user-select:none}body.sidebar-resizing .sidebar,body.sidebar-resizing .workspace{pointer-events:none}.sidebar{border-right:1px solid var(--border);background:var(--surface);flex-direction:column;min-width:0;display:flex;overflow:hidden}.sidebar-top{flex:none;justify-content:space-between;align-items:center;gap:8px;padding:16px 14px 12px;display:flex}.app-brand{align-items:center;gap:10px;min-width:0;display:flex}.app-brand .brand-mark{border-radius:8px;width:30px;height:30px}.sidebar-section-title{color:var(--text-muted);letter-spacing:.07em;text-transform:uppercase;flex:none;justify-content:space-between;align-items:center;padding:8px 18px 6px;font-size:11px;font-weight:700;display:flex}.project-tree{flex:auto;min-height:0;padding:2px 8px 16px;overflow-y:auto}.tree-empty{border:1px dashed var(--border-strong);border-radius:var(--radius-lg);color:var(--text-muted);text-align:center;justify-items:center;gap:10px;margin:28px 12px;padding:22px 16px;font-size:13px;display:grid}.tree-project{margin-bottom:2px}.tree-project-row{border-radius:var(--radius-md);align-items:center;gap:2px;min-height:34px;padding:2px 4px;transition:background-color .12s;display:flex}.tree-project-row:hover{background:var(--surface-2)}.tree-project-row .icon-btn{opacity:0;width:26px;height:26px;transition:opacity .12s,background-color .12s,color .12s}.tree-project-row:hover .icon-btn,.tree-document-row:hover .icon-btn{opacity:1}.tree-caret{border-radius:var(--radius-sm);width:22px;height:26px;color:var(--text-muted);flex:0 0 22px;place-items:center;display:grid}.tree-caret:hover{color:var(--text)}.tree-project-name{min-width:0;color:var(--text);text-align:left;flex:1;align-items:center;gap:8px;padding:4px 2px;font-size:13.5px;font-weight:600;display:flex;overflow:hidden}.tree-project-name svg{color:var(--text-muted);flex:none}.tree-project-name span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.tree-count{color:var(--text-muted);flex:none;padding:0 4px;font-size:12px;font-weight:500}.tree-documents{gap:1px;margin:1px 0 4px;padding-left:18px;display:grid}.tree-document-row{border-radius:var(--radius-md);min-height:32px;color:var(--text-secondary);align-items:center;gap:8px;padding:4px 4px 4px 10px;transition:background-color .12s,color .12s;display:flex;position:relative}.tree-document-row:before{content:"";background:var(--border);width:1px;position:absolute;top:4px;bottom:4px;left:-8px}.tree-document-row:hover{background:var(--surface-2);color:var(--text)}.tree-document-row.active{background:var(--accent-soft);color:var(--accent-hover)}.tree-document-row.active .tree-document-name{font-weight:600}.tree-document-row .icon-btn{opacity:0;width:24px;height:24px}.tree-document-name{min-width:0;color:inherit;text-align:left;text-overflow:ellipsis;white-space:nowrap;flex:1;padding:0;font-size:13px;overflow:hidden}.status-dot{background:var(--border-strong);border-radius:50%;flex:none;width:7px;height:7px}.status-dot.progress{background:var(--progress)}.status-dot.done{background:var(--done)}.sidebar-footer{border-top:1px solid var(--border);flex:none;align-items:center;gap:10px;padding:12px 14px;display:flex}.user-avatar{background:var(--accent-soft);width:32px;height:32px;color:var(--accent);text-transform:uppercase;border-radius:50%;flex:none;place-items:center;font-size:13px;font-weight:700;display:grid}.user-info{flex:1;min-width:0}.user-info p{text-overflow:ellipsis;white-space:nowrap;margin:0;overflow:hidden}.user-email{font-size:13px;font-weight:600}.user-role{color:var(--text-muted);font-size:12px}.workspace{flex-direction:column;min-width:0;height:100vh;display:flex;overflow:hidden}.workspace-toolbar{border-bottom:1px solid var(--border);background:var(--surface);flex:none;justify-content:space-between;align-items:center;gap:16px;min-height:64px;padding:12px 24px;display:flex}.toolbar-heading{flex:auto;min-width:0}.breadcrumb{color:var(--text-muted);white-space:nowrap;align-items:center;gap:6px;margin:0 0 1px;font-size:12.5px;display:flex;overflow:hidden}.breadcrumb svg{flex:none}.document-title{letter-spacing:-.01em;text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:18px;font-weight:700;overflow:hidden}.document-title.placeholder{color:var(--text-muted);font-weight:500}.document-title-input{border:1px solid var(--border-strong);border-radius:var(--radius-md);background:var(--surface);width:100%;max-width:560px;height:36px;box-shadow:var(--shadow-xs);padding:0 12px;font-size:16px;font-weight:700}.document-title-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #4f46e521}.toolbar-actions{flex-wrap:wrap;flex:none;justify-content:flex-end;align-items:center;gap:8px;display:flex}.toolbar-divider{background:var(--border);width:1px;height:24px;margin:0 4px}.document-controls{border-bottom:1px solid var(--border);background:var(--surface);flex-wrap:wrap;flex:none;align-items:center;gap:10px;padding:10px 24px;display:flex}.search-box{flex:0 280px;min-width:180px;position:relative}.search-box svg{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-box .input{height:34px;padding-left:34px}.segmented{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-2);flex:none;gap:2px;padding:2px;display:flex}.segmented button{border-radius:var(--radius-sm);height:28px;color:var(--text-secondary);padding:0 12px;font-size:13px;font-weight:500;transition:background-color .13s,color .13s,box-shadow .13s}.segmented button:hover{color:var(--text)}.segmented button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-xs);font-weight:600}.controls-spacer{flex:auto}.doc-status-control{color:var(--text-muted);flex:none;align-items:center;gap:8px;font-size:13px;display:flex}.status-select{flex:none;position:relative}.status-pill{border:1px solid;border-radius:999px;align-items:center;gap:6px;height:28px;padding:0 10px;font-size:12.5px;font-weight:600;transition:box-shadow .13s,filter .13s;display:inline-flex}.status-pill:not(:disabled):hover{box-shadow:var(--shadow-sm)}.status-pill:disabled{cursor:default}.status-pill .pill-dot{background:currentColor;border-radius:50%;width:7px;height:7px}.status-pill.draft{border-color:var(--draft-border);background:var(--draft-soft);color:var(--draft)}.status-pill.progress{border-color:var(--progress-border);background:var(--progress-soft);color:var(--progress-text)}.status-pill.done{border-color:var(--done-border);background:var(--done-soft);color:var(--done-text)}.status-menu{z-index:30;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);min-width:160px;box-shadow:var(--shadow-lg);padding:4px;animation:.12s pop-in;position:absolute;top:calc(100% + 6px);right:0}@keyframes pop-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.status-menu button{border-radius:var(--radius-sm);width:100%;height:32px;color:var(--text-secondary);text-align:left;align-items:center;gap:9px;padding:0 10px;font-size:13px;font-weight:500;display:flex}.status-menu button:hover{background:var(--surface-2);color:var(--text)}.status-menu button.selected{background:var(--accent-soft);color:var(--accent-hover);font-weight:600}.status-menu .menu-dot{border-radius:50%;flex:none;width:8px;height:8px}.menu-dot.draft{background:var(--draft)}.menu-dot.progress{background:var(--progress)}.menu-dot.done{background:var(--done)}.progress-block{flex:none;align-items:center;gap:10px;min-width:200px;display:flex}.progress-track{background:var(--surface-3);border-radius:999px;flex:auto;width:140px;height:8px;position:relative;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#34d399,#17b26a);border-radius:999px;height:100%;transition:width .35s}.progress-label{color:var(--text-secondary);font-variant-numeric:tabular-nums;white-space:nowrap;flex:none;font-size:12.5px;font-weight:600}.document-area{flex:auto;min-height:0;padding:24px 32px 48px;overflow-y:auto}.document-list{gap:10px;width:min(100%,1100px);margin:0 auto;display:grid}.empty-state{text-align:center;justify-items:center;gap:6px;max-width:360px;margin:80px auto 0;display:grid}.empty-state-icon{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);width:52px;height:52px;color:var(--text-muted);box-shadow:var(--shadow-xs);place-items:center;margin-bottom:8px;display:grid}.empty-state h3{margin:0;font-size:16px;font-weight:700}.empty-state p{color:var(--text-muted);margin:0 0 14px;font-size:13.5px}.add-root{width:max-content;margin:0 auto 4px 0}.requirement-item{margin-left:calc(var(--indent) * 26px)}.requirement-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-xs);padding:12px 16px 12px 18px;transition:border-color .13s,box-shadow .13s;position:relative}.requirement-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.requirement-card:before{content:"";background:var(--border-strong);border-radius:0 3px 3px 0;width:3px;position:absolute;top:10px;bottom:10px;left:0}.requirement-item.status-progress>.requirement-card:before{background:var(--progress)}.requirement-item.status-done>.requirement-card:before{background:var(--done)}.requirement-item.status-done>.requirement-card .requirement-title{color:var(--text-secondary)}.requirement-header{align-items:center;gap:8px;display:flex}.requirement-toggle-spacer{flex:0 0 26px;width:26px;height:26px}.requirement-header .icon-btn.caret{width:26px;height:26px}.requirement-number{border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text-secondary);font-variant-numeric:tabular-nums;flex:none;padding:1px 7px;font-size:12px;font-weight:700}.requirement-title{flex:1;min-width:0;margin:0;font-size:14.5px;font-weight:600;line-height:1.4}.requirement-header .input{flex:1;height:32px;font-weight:600}.children-badge{color:var(--text-muted);white-space:nowrap;flex:none;font-size:12px}.requirement-content{color:var(--text-secondary);margin:8px 0 2px 34px;font-size:13.5px;line-height:1.6;overflow-x:auto}.requirement-content p{margin:0 0 8px}.requirement-content p:last-child{margin-bottom:0}.requirement-content table{border-collapse:collapse;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);width:100%;max-width:100%;margin:12px 0;font-size:13px}.requirement-content th,.requirement-content td{border:1px solid var(--border);vertical-align:top;padding:8px 12px}.requirement-content th{background:var(--surface-2);color:var(--text);text-align:left;font-weight:600}.requirement-card .textarea{width:calc(100% - 34px);margin:10px 0 0 34px}.requirement-actions{justify-content:flex-end;align-items:center;gap:6px;margin-top:10px;display:flex}.requirement-children{gap:10px;margin-top:10px;display:grid}mark{color:inherit;background:#fde272;border-radius:3px;padding:0 1px}.modal-overlay{z-index:50;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#10182873;place-items:center;animation:.14s fade-in;display:grid;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-panel{border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--surface);width:min(420px,100vw - 32px);box-shadow:var(--shadow-xl);padding:24px;animation:.16s modal-in}@keyframes modal-in{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:none}}.modal-icon{border-radius:50%;place-items:center;width:44px;height:44px;margin-bottom:14px;display:grid}.modal-icon.info{background:var(--accent-soft);color:var(--accent)}.modal-icon.warning{background:var(--progress-soft);color:var(--progress-text)}.modal-icon.danger{background:var(--danger-soft);color:var(--danger)}.modal-panel h2{margin:0 0 6px;font-size:17px;font-weight:700}.modal-panel p{color:var(--text-secondary);margin:0;font-size:13.5px;line-height:1.55}.modal-input{margin-top:14px}.modal-actions{justify-content:flex-end;gap:8px;margin-top:22px;display:flex}.toast-stack{z-index:60;gap:8px;width:min(360px,100vw - 40px);display:grid;position:fixed;bottom:20px;right:20px}.toast{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-lg);align-items:flex-start;gap:10px;padding:12px 14px;animation:.2s toast-in;display:flex}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.toast svg{flex:none;margin-top:1px}.toast.success svg{color:var(--done)}.toast.error svg{color:var(--danger)}.toast.info svg{color:var(--accent)}.toast-body{flex:1;min-width:0}.toast-title{margin:0;font-size:13.5px;font-weight:600}.toast-message{color:var(--text-secondary);overflow-wrap:anywhere;margin:1px 0 0;font-size:13px;line-height:1.45}.toast .icon-btn{width:24px;height:24px}.cp-locked{background:var(--bg);place-items:center;min-height:100vh;padding:24px;display:grid}.cp-locked .btn{text-decoration:none}.cp-shell{background:var(--bg);flex-direction:column;height:100vh;display:flex;overflow:hidden}.cp-header{border-bottom:1px solid var(--border);background:var(--surface);flex:none;justify-content:space-between;align-items:center;gap:16px;min-height:60px;padding:10px 24px;display:flex}.cp-header-badge{border:1px solid var(--accent-border);background:var(--accent-soft);color:var(--accent-hover);white-space:nowrap;border-radius:999px;margin-left:6px;padding:2px 10px;font-size:12px;font-weight:600}.cp-header-right{align-items:center;gap:12px;display:flex}.cp-header-right .btn{text-decoration:none}.cp-header-user{color:var(--text-secondary);font-size:13px}.cp-tabs{border-bottom:1px solid var(--border);background:var(--surface);flex:none;gap:4px;padding:0 24px;display:flex}.cp-tabs button{height:42px;color:var(--text-secondary);align-items:center;gap:7px;padding:0 14px;font-size:13.5px;font-weight:500;transition:color .13s;display:inline-flex;position:relative}.cp-tabs button:hover{color:var(--text)}.cp-tabs button.active{color:var(--accent);font-weight:600}.cp-tabs button.active:after{content:"";background:var(--accent);border-radius:2px 2px 0 0;height:2px;position:absolute;bottom:-1px;left:8px;right:8px}.cp-content{flex:auto;min-height:0;padding:20px 24px 40px;overflow-y:auto}.cp-panel{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);max-width:1200px;box-shadow:var(--shadow-xs);margin:0 auto;padding:18px 20px}.cp-panel-plain{box-shadow:none;background:0 0;border:0;padding:0}.cp-panel-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;display:flex}.cp-panel-header h2{margin:0;font-size:16px;font-weight:700}.cp-panel-actions{align-items:center;gap:12px;display:flex}.cp-muted{color:var(--text-muted);font-size:12.5px}.cp-error{border-radius:var(--radius-md);background:var(--danger-soft);color:var(--danger);border:1px solid #fecdca;margin:0 0 12px;padding:10px 12px;font-size:13px}.cp-placeholder{min-height:120px;color:var(--text-muted);place-items:center;display:grid}.cp-table-wrap{border:1px solid var(--border);border-radius:var(--radius-md);overflow-x:auto}.cp-table{border-collapse:collapse;width:100%;font-size:13px}.cp-table th{border-bottom:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);text-align:left;white-space:nowrap;padding:9px 12px;font-weight:600;position:sticky;top:0}.cp-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:8px 12px}.cp-table tbody tr:last-child td{border-bottom:0}.cp-table tbody tr:hover{background:var(--surface-2)}.cp-nowrap{white-space:nowrap}.cp-monospace{color:var(--text-secondary);font-family:Consolas,Courier New,monospace;font-size:12px}.cp-log-dot{background:var(--done);vertical-align:middle;border-radius:50%;width:7px;height:7px;margin-right:8px;display:inline-block}.cp-log-dot.warning{background:var(--progress)}.cp-log-dot.error{background:var(--danger)}.cp-log-row.error td{background:var(--danger-soft)}.cp-toggle{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:7px;font-size:13px;display:inline-flex}.cp-toggle input{accent-color:var(--accent);cursor:pointer;width:15px;height:15px}.cp-refresh-note{margin:12px 2px 0}.cp-meters{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;max-width:1200px;margin-bottom:12px;display:grid}.cp-meter-card,.cp-info-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-xs);padding:16px}.cp-meter-card header,.cp-info-card header{color:var(--text-secondary);align-items:center;gap:8px;margin-bottom:12px;display:flex}.cp-meter-card h3,.cp-info-card h3{color:var(--text);margin:0;font-size:13.5px;font-weight:600}.cp-meter-value{font-variant-numeric:tabular-nums;color:var(--done-text);margin-left:auto;font-size:16px;font-weight:700}.cp-meter-value.high{color:var(--progress-text)}.cp-meter-value.critical{color:var(--danger)}.cp-meter-track{background:var(--surface-3);border-radius:999px;height:8px;margin-bottom:10px;overflow:hidden}.cp-meter-fill{background:linear-gradient(90deg,#34d399,#17b26a);border-radius:999px;height:100%;transition:width .4s}.cp-meter-fill.high{background:linear-gradient(90deg,#fdb022,#f79009)}.cp-meter-fill.critical{background:linear-gradient(90deg,#f97066,#d92d20)}.cp-meter-card p{margin:0}.cp-info-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px 20px;margin:0;display:grid}.cp-info-grid dt{color:var(--text-muted);font-size:12px}.cp-info-grid dd{margin:2px 0 0;font-size:13.5px;font-weight:500}@media (width<=980px){body{overflow:auto}.app-shell{grid-template-columns:1fr;height:auto}.sidebar-resizer{display:none}.sidebar{border-right:0;border-bottom:1px solid var(--border);height:auto;max-height:45vh}.workspace{height:auto;min-height:55vh}.workspace-toolbar{flex-wrap:wrap}.document-area{padding:16px 16px 40px;overflow:visible}.progress-block{flex:100%;min-width:0}}
