@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500&display=swap";pre code.hljs{padding:1em;display:block;overflow-x:auto}code.hljs{padding:3px 5px}.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}.v-enter-active,.v-leave-active{transition:opacity .25s}.v-enter-from,.v-leave-to{opacity:0}:root{--bg:#eef1f8;--bg-deep:#e7ebf5;--surface:#fff;--surface-2:#f3f5fb;--surface-3:#eaedf6;--border:#e2e6f0;--border-strong:#d2d7e6;--text:#161a28;--text-soft:#565d75;--text-faint:#969db5;--primary:#10b981;--primary-deep:#059669;--primary-soft:#e6f8f1;--accent:#14b8a6;--grad:linear-gradient(135deg, #10b981 0%, #14b8a6 55%, #06b6d4 100%);--grad-soft:linear-gradient(135deg, #e6f8f1 0%, #e4f7f6 100%);--danger:#ef4444;--shadow-xs:0 1px 2px #171a300d;--shadow-sm:0 1px 3px #171a300f, 0 1px 2px #171a300a;--shadow-md:0 4px 12px #171a3012, 0 2px 4px #171a300d;--shadow-lg:0 16px 40px #171a301f, 0 4px 12px #171a300f;--shadow-glow:0 6px 20px #10b9814d;--radius:16px;--radius-lg:20px;--radius-sm:11px;--font:"Calibri", "Segoe UI", system-ui, sans-serif;--mono:"JetBrains Mono", monospace}.dark{--bg:#0b0d15;--bg-deep:#07080e;--surface:#161925;--surface-2:#1d2130;--surface-3:#252a3b;--border:#282d3e;--border-strong:#353b50;--text:#eef0f7;--text-soft:#a7aec6;--text-faint:#6a7188;--primary:#34d399;--primary-deep:#10b981;--primary-soft:#102b22;--accent:#2dd4bf;--grad:linear-gradient(135deg, #10b981 0%, #14b8a6 55%, #06b6d4 100%);--grad-soft:linear-gradient(135deg, #122a22 0%, #10282a 100%);--danger:#f87171;--shadow-xs:0 1px 2px #0000004d;--shadow-sm:0 1px 3px #0006, 0 1px 2px #0000004d;--shadow-md:0 4px 14px #00000073, 0 2px 5px #00000059;--shadow-lg:0 18px 44px #0009, 0 5px 14px #0006;--shadow-glow:0 6px 22px #34d39959}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-feature-settings:"lnum" 1, "tnum" 0;-moz-font-feature-settings:"lnum" 1;font-variant-numeric:lining-nums}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea,select{color:var(--text);font-family:inherit}input::placeholder,textarea::placeholder{color:var(--text-faint);opacity:1}.app{background:var(--bg);background-image:radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--primary) 7%, transparent) 0%, transparent 38%), radial-gradient(circle at 0% 100%, #06b6d40f 0%, transparent 40%);grid-template-columns:270px 1fr;height:100vh;display:grid;overflow:hidden}.mobile-header,.mobile-nav{display:none}.sidebar{background:var(--surface);border-inline-end:1px solid var(--border);flex-direction:column;padding:22px 14px;display:flex;overflow-y:auto}.logo{border-bottom:1px solid var(--border);align-items:center;gap:13px;margin-bottom:4px;padding:4px 8px 24px;display:flex}.logo-mark{background:var(--grad);color:#fff;width:44px;height:44px;box-shadow:var(--shadow-glow);border-radius:13px;flex-shrink:0;place-items:center;display:grid}.logo h1{letter-spacing:-.01em;font-size:16.5px;font-weight:700;line-height:1.3}.logo p{color:var(--text-faint);margin-top:2px;font-size:11.5px}.nav-section{margin-top:6px}.nav-label{color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase;padding:16px 12px 8px;font-size:10.5px;font-weight:700}.nav-item{border-radius:var(--radius-sm);width:100%;color:var(--text-soft);text-align:start;align-items:center;gap:12px;padding:11px 13px;font-size:14px;font-weight:500;transition:all .18s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:var(--primary-soft);color:var(--primary-deep);font-weight:600}.nav-item.active:before{content:"";inset-inline-start:0;background:var(--grad);border-radius:0 3px 3px 0;width:3px;height:20px;position:absolute;top:50%;transform:translateY(-50%)}.dark .nav-item.active{color:var(--primary)}.nav-item .count{background:var(--surface-3);color:var(--text-soft);border-radius:20px;margin-inline-start:auto;padding:2px 9px;font-size:11.5px;font-weight:700}.nav-item.active .count{background:var(--primary);color:#fff}.sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding-top:16px}.theme-toggle{border-radius:var(--radius-sm);width:100%;color:var(--text-soft);align-items:center;gap:11px;padding:11px 13px;font-size:13.5px;font-weight:500;transition:all .16s;display:flex}.theme-toggle:hover{background:var(--surface-2);color:var(--text)}.main{min-width:0;padding:28px 34px;overflow:hidden auto}.page-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:28px;display:flex}.page-head h2{letter-spacing:-.02em;font-size:28px;font-weight:700;line-height:1.2}.page-head p{color:var(--text-soft);margin-top:6px;font-size:14.5px}.btn{border-radius:var(--radius-sm);white-space:nowrap;align-items:center;gap:8px;padding:11px 19px;font-size:14px;font-weight:600;transition:all .18s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--shadow-glow)}.btn-primary:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 8px 26px #10b9816b}.btn-primary:active{transform:translateY(0)}.btn-ghost{background:var(--surface);border:1px solid var(--border-strong);color:var(--text-soft);box-shadow:var(--shadow-xs)}.btn-ghost:hover{background:var(--surface-2);color:var(--text);border-color:var(--primary)}.btn-danger{color:var(--danger);border:1px solid var(--border-strong);background:0 0}.btn-danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-convert{background:var(--grad);color:#fff;box-shadow:var(--shadow-glow)}.btn-convert:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 8px 26px #10b9816b}.search{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);min-width:200px;color:var(--text-faint);box-shadow:var(--shadow-xs);flex:1;align-items:center;gap:9px;padding:0 14px;transition:all .18s;display:flex}.search:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);color:var(--primary)}.search input{color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:12px 0;font-size:14px}.filter-chips{flex-wrap:wrap;gap:7px;display:flex}.chip{background:var(--surface);border:1px solid var(--border-strong);color:var(--text-soft);box-shadow:var(--shadow-xs);border-radius:22px;padding:9px 16px;font-size:13px;font-weight:600;transition:all .18s cubic-bezier(.4,0,.2,1)}.chip:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}.chip.active{background:var(--grad);color:#fff;box-shadow:var(--shadow-glow);border-color:#0000}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:32px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px 22px;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s;position:relative;overflow:hidden}.stat-card:after{content:"";background:var(--grad-soft);opacity:0;pointer-events:none;transition:opacity .25s;position:absolute;inset:0}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.stat-card:hover:after{opacity:.5}.stat-card .icon{z-index:1;border-radius:12px;place-items:center;width:44px;height:44px;margin-bottom:14px;display:grid;position:relative}.stat-card .num{letter-spacing:-.02em;z-index:1;font-size:32px;font-weight:800;line-height:1;position:relative}.stat-card .lbl{color:var(--text-soft);z-index:1;margin-top:7px;font-size:13px;font-weight:500;position:relative}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;display:grid}@keyframes cardIn{0%{opacity:0;transform:translateY(12px)}}.projects-grid>*{animation:.4s cubic-bezier(.4,0,.2,1) backwards cardIn}.projects-grid>:first-child{animation-delay:20ms}.projects-grid>:nth-child(2){animation-delay:60ms}.projects-grid>:nth-child(3){animation-delay:.1s}.projects-grid>:nth-child(4){animation-delay:.14s}.projects-grid>:nth-child(5){animation-delay:.18s}.projects-grid>:nth-child(6){animation-delay:.22s}.stats-grid>*{animation:.4s cubic-bezier(.4,0,.2,1) backwards cardIn}.stats-grid>:first-child{animation-delay:20ms}.stats-grid>:nth-child(2){animation-delay:70ms}.stats-grid>:nth-child(3){animation-delay:.12s}.stats-grid>:nth-child(4){animation-delay:.17s}@media (prefers-reduced-motion:reduce){.projects-grid>*,.stats-grid>*{animation:none}}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);cursor:pointer;padding:22px;transition:all .22s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.project-card:before{content:"";background:var(--card-color,var(--primary));opacity:.9;width:100%;height:4px;position:absolute;inset-block-start:0;inset-inline-start:0}.project-card:hover{box-shadow:var(--shadow-lg);border-color:var(--card-color,var(--primary));transform:translateY(-4px)}.project-card h3{letter-spacing:-.01em;margin-bottom:9px;font-size:17px;font-weight:700}.pc-top{justify-content:flex-start;align-items:center;gap:10px;margin-bottom:14px;display:flex}.pc-stats{gap:8px;margin-top:14px;display:flex}.pc-stat{color:var(--text-soft);background:var(--surface-2);border-radius:8px;align-items:center;gap:5px;padding:4px 11px;font-size:12.5px;font-weight:600;display:inline-flex}.pc-stat-done{color:#0f9b6c;background:#10b9811f}.dark .pc-stat-done{color:#34d399}.project-card .desc{color:var(--text-soft);-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:38px;font-size:13px;line-height:1.65;display:-webkit-box;overflow:hidden}.status-badge{border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-size:12px;font-weight:700;display:inline-flex}.status-badge .dot{border-radius:50%;width:7px;height:7px;position:relative}.project-meta{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:18px;padding-top:16px;display:flex}.progress-mini{flex:1;margin-inline-end:12px}.progress-track{background:var(--surface-3);border-radius:10px;height:7px;overflow:hidden}.progress-fill{background-image:linear-gradient(90deg,#0000,#ffffff40);border-radius:10px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.progress-text{color:var(--text-faint);margin-top:6px;font-size:11.5px;font-weight:500}.tag-row{flex-wrap:wrap;gap:6px;margin-top:12px;display:flex}.tag{border-radius:6px;padding:3px 10px;font-size:11.5px;font-weight:500}.empty{text-align:center;color:var(--text-faint);padding:70px 20px}.empty .icon{background:var(--grad-soft);border:1px solid var(--border);width:72px;height:72px;color:var(--primary);box-shadow:var(--shadow-sm);border-radius:20px;place-items:center;margin:0 auto 20px;display:grid}.empty h3{color:var(--text);margin-bottom:7px;font-size:18px;font-weight:700}.empty p{max-width:380px;margin:0 auto 22px;font-size:14px;line-height:1.65}.items-list{flex-direction:column;gap:10px;display:flex}.item-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;box-shadow:var(--shadow-xs);align-items:center;gap:14px;padding:15px 17px;transition:all .18s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.item-row:before{content:"";inset-inline-start:0;background:var(--pr-color,transparent);opacity:.7;width:3px;position:absolute;top:0;bottom:0}.item-row:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translate(-3px)}.item-check{border:2px solid var(--border-strong);color:#0000;border-radius:8px;flex-shrink:0;place-items:center;width:23px;height:23px;transition:all .18s;display:grid}.item-check:hover{border-color:#10b981}.item-check.done{color:#fff;background:#10b981;border-color:#10b981}.item-body{flex:1;min-width:0}.item-title{font-size:14.5px;font-weight:600}.item-title.done{color:var(--text-faint);text-decoration:line-through}.item-sub{flex-wrap:wrap;align-items:center;gap:8px;margin-top:7px;display:flex}.mini-badge{border-radius:7px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.priority-chip{align-items:center;gap:5px;font-size:11px;font-weight:700;display:inline-flex}.priority-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:50;background:#080a1499;place-items:center;padding:24px;animation:.2s fade;display:grid;position:fixed;inset:0}@keyframes fade{0%{opacity:0}}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);flex-direction:column;width:100%;max-width:1100px;height:92vh;max-height:92vh;animation:.24s cubic-bezier(.34,1.4,.64,1) pop;display:flex;overflow:hidden}.modal.narrow{max-width:520px}@keyframes pop{0%{opacity:0;transform:scale(.95)translateY(10px)}}.modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:22px 26px;display:flex}.modal-head h2{letter-spacing:-.01em;font-size:19px;font-weight:700}.icon-btn{width:38px;height:38px;color:var(--text-soft);border-radius:10px;place-items:center;transition:all .16s;display:grid}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.modal-body{flex-direction:column;flex:1;gap:19px;min-height:0;padding:24px 26px;display:flex;overflow-y:auto}.modal-foot{border-top:1px solid var(--border);background:var(--surface-2);justify-content:space-between;align-items:center;gap:12px;padding:18px 26px;display:flex}.field{flex-direction:column;gap:8px;display:flex}.field label{color:var(--text-soft);font-size:13px;font-weight:700}.field input[type=text],.field textarea,.field select{background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);outline:none;padding:12px 14px;font-size:14px;transition:all .18s}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 3px var(--primary-soft)}.field-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.field-row-3{grid-template-columns:1fr 1fr 1fr;gap:14px;display:grid}.editor-area{font-family:var(--mono);resize:vertical;text-align:start;direction:ltr;min-height:240px;line-height:1.7}.color-picker{flex-wrap:wrap;gap:9px;display:flex}.color-swatch{border:3px solid #0000;border-radius:9px;width:32px;height:32px;transition:all .15s}.color-swatch.active{border-color:var(--text);transform:scale(1.1)}.tabs{background:var(--surface-2);border-radius:var(--radius-sm);gap:4px;padding:4px;display:flex}.tab{color:var(--text-soft);border-radius:8px;flex:1;padding:9px;font-size:13.5px;font-weight:600;transition:all .15s}.tab.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}.preview-pane{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);min-height:400px;padding:34px 44px;overflow-y:auto}.detail-head{align-items:flex-start;gap:16px;margin-bottom:8px;display:flex}.back-btn{color:var(--text-soft);align-items:center;gap:6px;margin-bottom:18px;font-size:14px;font-weight:500;display:inline-flex}.back-btn:hover{color:var(--primary)}.detail-layout{grid-template-columns:minmax(0,1fr) 340px;align-items:start;gap:22px;display:grid}.detail-main{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow-wrap:break-word;min-width:0;padding:28px 30px}.detail-side{flex-direction:column;gap:16px;display:flex}.dep-picker{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);flex-direction:column;gap:6px;max-height:200px;padding:8px;display:flex;overflow-y:auto}.dep-option{cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:9px 11px;font-size:14px;transition:background .12s;display:flex}.dep-option:hover{background:var(--surface)}.dep-option.checked{background:var(--primary-soft)}.dep-option input{cursor:pointer;width:17px;height:17px;accent-color:var(--primary)}.dep-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.dep-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.dep-status{color:var(--text-faint);flex-shrink:0;font-size:11.5px}.dep-hint{color:var(--text-faint);margin-top:6px;font-size:12px}.dep-group-label{color:var(--text-faint);margin-bottom:8px;font-size:12px;font-weight:600}.dep-chip{background:var(--surface-2);border:1px solid var(--border);width:100%;color:var(--text);text-align:start;border-radius:8px;align-items:center;gap:9px;margin-bottom:6px;padding:9px 11px;font-size:13.5px;transition:all .14s;display:flex}.dep-chip:hover{border-color:var(--primary);transform:translate(-2px)}.dep-chip-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.dep-done{color:#10b981;flex-shrink:0}.dep-tree-wrap{margin-top:22px}.tree-loading{color:var(--text-soft);justify-content:center;align-items:center;gap:10px;padding:60px 20px;font-size:14px;display:flex}.tree-legend{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;padding:0 4px 14px;display:flex}.tree-legend-item{color:var(--text-soft);align-items:center;gap:8px;font-size:12.5px;font-weight:600;display:inline-flex}.tree-legend-ring{border:2px solid var(--primary);border-radius:5px;width:14px;height:14px}.tree-legend-hint{color:var(--text-faint);font-size:12.5px}.tree-scroll{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);justify-content:center;padding:14px 4px 20px;display:flex;overflow-x:auto}.tree-node{cursor:pointer}.tree-node rect{transition:filter .18s,transform .18s}.tree-node:hover rect{filter:brightness(1.05)}.tree-node.current rect{filter:drop-shadow(0 4px 14px #10b98152)}.tree-title{font-size:13.5px;font-weight:700;font-family:var(--font)}.tree-status{font-size:12px;font-weight:600;font-family:var(--font)}.tree-count{font-size:13px;font-weight:800;font-family:var(--font);opacity:.85}.detail-tabs{border-bottom:1.5px solid var(--border);gap:6px;margin-top:22px;display:flex}.detail-tab{color:var(--text-soft);border-bottom:2.5px solid #0000;align-items:center;gap:8px;margin-bottom:-1.5px;padding:12px 18px;font-size:14.5px;font-weight:600;transition:all .15s;display:inline-flex}.detail-tab:hover{color:var(--text)}.detail-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-count{background:var(--surface-2);color:var(--text-soft);border-radius:20px;padding:1px 9px;font-size:12px;font-weight:700}.detail-tab.active .tab-count{background:var(--primary);color:#fff}.side-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px}.side-card h4{color:var(--text-faint);letter-spacing:.07em;text-transform:uppercase;margin-bottom:16px;font-size:11px;font-weight:700}.section-title{justify-content:space-between;align-items:center;margin:26px 0 14px;display:flex}.section-title h3{font-size:17px;font-weight:600}.markdown-body{color:var(--text);word-wrap:break-word;overflow-wrap:break-word;max-width:100%;font-size:15px;line-height:1.85}.markdown-body pre{max-width:100%;overflow-x:auto}.markdown-body h1,.markdown-body h2,.markdown-body h3{margin:1.3em 0 .6em;font-weight:700;line-height:1.35}.markdown-body h1{border-bottom:1px solid var(--border);padding-bottom:.3em;font-size:1.7em}.markdown-body h2{font-size:1.4em}.markdown-body h3{font-size:1.18em}.markdown-body p{margin:.8em 0}.markdown-body ul,.markdown-body ol{margin:.8em 0;padding-inline-start:1.6em}.markdown-body li{margin:.4em 0}.markdown-body a{color:var(--primary);text-decoration:none}.markdown-body a:hover{text-decoration:underline}.markdown-body blockquote{border-inline-start:4px solid var(--primary);background:var(--primary-soft);color:var(--text);border-radius:0 10px 10px 0;margin:1.2em 0;padding:16px 20px}.markdown-body hr{border:none;border-top:1px solid var(--border);margin:1.8em 0}.markdown-body code{font-family:var(--mono);background:var(--surface-2);border-radius:5px;padding:2px 7px;font-size:.88em}.markdown-body table{border-collapse:collapse;width:100%;margin:1em 0;font-size:14px}.markdown-body th,.markdown-body td{border:1px solid var(--border);text-align:start;padding:9px 13px}.markdown-body th{background:var(--surface-2);font-weight:600}.markdown-body img{border-radius:10px;max-width:100%}.code-block{border:1px solid var(--border);direction:ltr;border-radius:10px;margin:1.2em 0;overflow:hidden}.code-header{color:#94a3b8;font-size:12px;font-family:var(--mono);background:#1e2330;justify-content:space-between;align-items:center;padding:8px 14px;display:flex}.copy-code-btn{color:#cbd5e1;font-size:12px;font-family:var(--font);background:#ffffff14;border-radius:6px;padding:3px 11px}.copy-code-btn:hover{background:#ffffff29}.code-block pre{background:#0f1117;margin:0;padding:16px;overflow-x:auto}.code-block code{font-family:var(--mono);background:0 0;padding:0;font-size:13.5px;line-height:1.6}.toast{background:var(--grad);color:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow-glow), var(--shadow-lg);z-index:100;padding:14px 26px;font-size:14px;font-weight:600;animation:.3s cubic-bezier(.34,1.4,.64,1) slideUp;position:fixed;inset-block-end:28px;inset-inline-start:50%;transform:translate(50%)}@keyframes slideUp{0%{opacity:0;transform:translate(50%,20px)}}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=980px){.detail-layout{grid-template-columns:1fr}}@media (width<=760px){.app{grid-template-columns:1fr;height:100dvh}.sidebar{display:none}.mobile-header{background:var(--surface);border-bottom:1px solid var(--border);z-index:20;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.mobile-logo{align-items:center;gap:10px;display:flex}.mobile-logo .logo-mark{border-radius:10px;width:36px;height:36px}.mobile-logo h1{font-size:16px;font-weight:700}.mobile-theme{width:42px;height:42px;color:var(--text-soft);background:var(--surface-2);border-radius:11px;place-items:center;display:grid}.main{height:auto;padding:18px 16px 96px;overflow-y:visible}.mobile-nav{bottom:0;height:72px;padding-bottom:env(safe-area-inset-bottom,0);background:var(--surface);border-top:1px solid var(--border);z-index:40;justify-content:space-around;align-items:center;display:flex;position:fixed;inset-inline:0;box-shadow:0 -4px 20px #0000000f}.dark .mobile-nav{box-shadow:0 -4px 20px #0006}.mobile-nav-item{color:var(--text-faint);flex-direction:column;flex:1;align-items:center;gap:4px;padding:8px 0;font-size:11px;font-weight:600;transition:color .16s;display:flex}.mobile-nav-item.active{color:var(--primary)}.mobile-nav-fab{background:var(--grad);color:#fff;width:56px;height:56px;box-shadow:var(--shadow-glow);border-radius:18px;flex-shrink:0;place-items:center;margin-top:-24px;transition:transform .16s;display:grid}.mobile-nav-fab:active{transform:scale(.92)}.page-head{margin-bottom:20px}.page-head h2{font-size:23px}.page-head .btn-primary{display:none}.toolbar{flex-flow:row;align-items:center;gap:8px}.search{flex:1.4;min-width:0}.filter-dropdown{flex:1;min-width:0}.filter-trigger{gap:6px;width:100%;min-width:0;padding:0 12px}.filter-trigger>span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.filter-menu{min-width:200px;inset-inline:auto 0}.view-toggle{display:none!important}.field-row,.field-row-3{grid-template-columns:1fr}.backdrop{align-items:stretch;padding:0}.modal,.modal.narrow{border-radius:0;width:100%;max-width:100%;height:100dvh;max-height:100dvh;animation:.26s cubic-bezier(.4,0,.2,1) slideUpModal}@keyframes slideUpModal{0%{transform:translateY(100%)}}.modal-head{padding:16px 18px}.modal-body{padding:18px}.modal-foot{padding:14px 18px;padding-bottom:calc(14px + env(safe-area-inset-bottom,0))}.projects-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-card{text-align:start;grid-template-columns:auto 1fr;align-items:center;gap:12px;padding:16px;display:grid}.stat-card .icon{flex-shrink:0;grid-row:span 2;margin:0}.stat-card .num{text-align:start;align-self:end;margin:0;font-size:22px;line-height:1.1}.stat-card .lbl{text-align:start;align-self:start;margin:0;font-size:11px}.data-table-wrap{box-shadow:none;background:0 0;border:none}.data-table thead{display:none}.data-table,.data-table tbody,.data-table tr,.data-table td{width:100%;display:block}.data-table tr{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:10px;padding:14px 16px;position:relative;overflow:hidden}.data-table tbody tr:hover{background:var(--surface)}.data-table td{border:none;justify-content:space-between;align-items:center;gap:12px;min-height:0;padding:3px 0;display:flex}.data-table td:before{content:attr(data-label);color:var(--text-faint);flex-shrink:0;font-size:12px;font-weight:600}.data-table td:first-child{padding-bottom:10px;margin-bottom:8px;padding-inline-start:10px}.data-table td:first-child:before{display:none}.data-table td:first-child .dt-title{font-size:16px;font-weight:700}.data-table tr:before{content:"";background:var(--primary);opacity:.5;width:4px;position:absolute;inset-block:0;inset-inline-start:0}.data-table td .dt-dep-none{color:var(--text-faint)}.dt-progress{min-width:130px;max-width:60%}.item-row{padding:16px}.toast{bottom:88px}.detail-main{padding:20px 18px}.detail-tabs{border-bottom:none;flex-wrap:wrap;gap:6px;margin-top:18px;display:flex}.detail-tab{border:1px solid var(--border);background:var(--surface-2);border-radius:10px;flex:none;gap:6px;margin-bottom:0;padding:9px 13px;font-size:13px}.detail-tab svg{flex-shrink:0}.detail-tab.active{background:var(--primary-soft);border-color:var(--primary);color:var(--primary-deep)}.dark .detail-tab.active{color:var(--primary)}}.md-editor-wrap{flex-direction:column;flex:1;min-height:0;display:flex}.md-editor-wrap .editor-area,.md-editor-wrap .preview-pane,.field.field-grow{flex:1;min-height:0}.md-fullscreen{z-index:200;background:var(--bg);flex-direction:column;animation:.18s fade;display:flex;position:fixed;inset:0}.md-fullscreen-bar{border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;padding:14px 28px;display:flex}.md-fullscreen-bar .fs-title{color:var(--text-soft);align-items:center;gap:9px;font-size:15px;font-weight:600;display:flex}.md-fullscreen-body{background:var(--surface-2);flex:1;justify-content:center;padding:44px 24px 80px;display:flex;overflow-y:auto}.md-fullscreen-body .markdown-body{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:820px;box-shadow:var(--shadow-md);height:fit-content;padding:52px 60px;font-size:16px}.fs-toggle-btn{color:var(--text-soft);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);align-items:center;gap:7px;padding:8px 14px;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.fs-toggle-btn:hover{color:var(--primary);border-color:var(--primary)}.feas-wrap{flex-direction:column;gap:22px;margin-top:22px;display:flex}.feas-intro p{color:var(--text-soft);font-size:14px;line-height:1.6}.feas-score-card{border-radius:var(--radius);background:var(--surface-2);border:1px solid var(--border);align-items:center;gap:24px;padding:24px;display:flex;position:relative;overflow:hidden}.feas-score-card:before{content:"";background:var(--sc);width:100%;height:4px;position:absolute;inset-block-start:0;inset-inline-start:0}.feas-gauge{flex-shrink:0}.feas-score-num{font-size:30px;font-weight:800;font-family:var(--font)}.feas-score-of{font-size:11px;font-family:var(--font);fill:var(--text-faint)}.feas-verdict{flex:1}.feas-verdict-label{letter-spacing:-.01em;margin-bottom:6px;font-size:20px;font-weight:800}.feas-verdict-text{color:var(--text-soft);font-size:14px;line-height:1.65}.feas-criteria{flex-direction:column;gap:18px;display:flex}.feas-row{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);padding:16px 18px;transition:border-color .18s}.feas-row:hover{border-color:var(--border-strong)}.feas-row-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.feas-row-label{align-items:center;gap:9px;font-size:14.5px;font-weight:700;display:inline-flex}.feas-row-val{font-size:13px;font-weight:700}.feas-row-hint{color:var(--text-faint);margin:6px 0 14px;font-size:12.5px;line-height:1.55}.feas-scale{gap:10px;display:flex}.feas-dot{border:2px solid var(--border-strong);background:var(--surface-2);cursor:pointer;border-radius:10px;width:38px;height:38px;transition:all .16s cubic-bezier(.4,0,.2,1)}.feas-dot:hover{border-color:var(--primary);transform:translateY(-2px)}.feas-dot.sel{transform:scale(1.08)}.feas-actions{gap:10px;margin-top:4px;display:flex}.fin-wrap{flex-direction:column;gap:24px;margin-top:22px;display:flex}.fin-intro p{color:var(--text-soft);font-size:14px;line-height:1.6}.fin-section{flex-direction:column;gap:14px;display:flex}.fin-section>h4,.fin-section-head h4{color:var(--text);font-size:14px;font-weight:700}.fin-section-head{justify-content:space-between;align-items:center;display:flex}.fin-add-btn{color:var(--primary);border:1px solid var(--border-strong);background:var(--surface);border-radius:8px;align-items:center;gap:6px;padding:7px 13px;font-size:13px;font-weight:600;transition:all .16s;display:inline-flex}.fin-add-btn:hover{border-color:var(--primary);background:var(--primary-soft)}.fin-inputs{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px;display:grid}.fin-field{flex-direction:column;gap:8px;display:flex}.fin-field label{color:var(--text);align-items:center;gap:8px;font-size:13.5px;font-weight:700;display:inline-flex}.fin-field label svg{color:var(--primary)}.fin-input-wrap{align-items:center;display:flex;position:relative}.fin-input-wrap input{background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);font-size:15px;font-weight:600;font-family:var(--font);outline:none;padding:12px 14px;padding-inline-start:54px;transition:all .18s}.fin-input-wrap input:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 3px var(--primary-soft)}.fin-unit{text-align:center;width:46px;color:var(--text-faint);pointer-events:none;border-inline-end:1px solid var(--border);font-size:13px;font-weight:700;position:absolute;inset-inline-start:0}.fin-no-unit input{padding-inline-start:14px}.fin-hint{color:var(--text-faint);font-size:12px;line-height:1.5}.fin-costs{flex-direction:column;gap:10px;display:flex}.fin-cost-row{align-items:center;gap:10px;display:flex}.fin-cost-name{background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:var(--font);outline:none;flex:1;padding:11px 13px;transition:all .18s}.fin-cost-name:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 3px var(--primary-soft)}.fin-cost-amount{flex-shrink:0;width:160px}.fin-del-btn{width:38px;height:38px;color:var(--text-faint);border:1px solid var(--border);background:var(--surface);border-radius:9px;flex-shrink:0;place-items:center;transition:all .16s;display:grid}.fin-del-btn:hover{color:var(--danger);border-color:var(--danger)}.fin-cost-total{background:var(--surface-2);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;margin-top:4px;padding:13px 15px;font-size:14px;display:flex}.fin-cost-total strong{color:var(--text);font-size:16px;font-weight:800}.fin-costs-empty{text-align:center;color:var(--text-faint);background:var(--surface-2);border:1px dashed var(--border-strong);border-radius:var(--radius-sm);padding:24px;font-size:13.5px;line-height:1.6}.fin-results{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;display:grid}.fin-result-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px;position:relative;overflow:hidden}.fin-result-card:before{content:"";background:var(--rc);width:100%;height:4px;position:absolute;inset-block-start:0;inset-inline-start:0}.fin-result-label{color:var(--text-soft);margin-bottom:10px;font-size:12.5px;font-weight:600}.fin-result-val{letter-spacing:-.02em;font-size:24px;font-weight:800;line-height:1.1}.fin-result-cur{font-size:14px;font-weight:700}.fin-result-sub{color:var(--text-faint);margin-top:8px;font-size:12px}.fin-chart{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.fin-chart-axis{fill:var(--text-faint);font-size:11px;font-family:var(--font)}.fin-chart-cap{color:var(--text-faint);text-align:center;margin-top:8px;font-size:12px}.fin-table-scroll{border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto}.fin-table{border-collapse:collapse;width:100%;font-size:13.5px}.fin-table th{background:var(--surface-2);color:var(--text-soft);text-align:center;white-space:nowrap;padding:12px 14px;font-size:12.5px;font-weight:700}.fin-table td{text-align:center;border-top:1px solid var(--border);color:var(--text);white-space:nowrap;padding:11px 14px}.fin-table tbody tr:hover{background:var(--surface-2)}.fin-breakeven-row{background:#10b98114!important}.fin-breakeven-row td:first-child{font-weight:800;position:relative}.fin-summary{border-radius:var(--radius);background:var(--surface-2);border:1px solid var(--border);border-inline-start-width:4px;align-items:flex-start;gap:12px;padding:18px 20px;display:flex}.fin-summary p{color:var(--text);font-size:14px;line-height:1.7}.fin-actions{gap:10px;display:flex}.filter-bar{flex-wrap:wrap;gap:9px;margin-bottom:22px;display:flex}.filter-pill{background:var(--surface);border:1.5px solid var(--border);color:var(--text-soft);box-shadow:var(--shadow-xs);border-radius:11px;align-items:center;gap:8px;padding:9px 15px;font-size:13.5px;font-weight:600;transition:all .18s cubic-bezier(.4,0,.2,1);display:inline-flex}.filter-pill:hover{border-color:var(--primary);color:var(--text);transform:translateY(-1px)}.filter-pill.active{background:var(--grad);color:#fff;box-shadow:var(--shadow-glow);border-color:#0000}.filter-pill .filter-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.filter-pill.active .filter-dot{box-shadow:0 0 0 2px #ffffff80}.filter-num{background:var(--surface-3);color:var(--text-soft);text-align:center;border-radius:20px;min-width:20px;padding:1px 8px;font-size:12px;font-weight:800}.filter-pill.active .filter-num{color:#fff;background:#ffffff40}.toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:22px;display:flex}.filter-dropdown{position:relative}.filter-trigger{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border-strong);height:46px;color:var(--text);box-shadow:var(--shadow-xs);white-space:nowrap;justify-content:space-between;align-items:center;gap:9px;min-width:170px;padding:0 16px;font-size:14px;font-weight:600;transition:all .16s;display:inline-flex}.filter-trigger:hover{border-color:var(--primary)}.filter-trigger>span{text-align:start;flex:1}.filter-trigger svg:first-child{color:var(--primary)}.filter-menu{top:calc(100% + 6px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:220px;box-shadow:var(--shadow-lg);z-index:30;padding:6px;animation:.16s fadeDown;position:absolute;inset-inline-start:0}@keyframes fadeDown{0%{opacity:0;transform:translateY(-6px)}}.filter-option{width:100%;color:var(--text-soft);border-radius:9px;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;font-size:13.5px;font-weight:600;transition:all .14s;display:flex}.filter-option:hover{background:var(--surface-2);color:var(--text)}.filter-option.active{background:var(--primary-soft);color:var(--primary-deep)}.dark .filter-option.active{color:var(--primary)}.filter-opt-label{align-items:center;gap:9px;display:inline-flex}.filter-option .filter-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.filter-option .filter-num{background:var(--surface-3);color:var(--text-soft);text-align:center;border-radius:20px;min-width:22px;padding:1px 8px;font-size:12px;font-weight:800}.filter-option.active .filter-num{background:var(--primary);color:#fff}.view-toggle{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);gap:2px;margin-inline-start:auto;padding:3px;display:inline-flex}.view-toggle button{width:40px;height:38px;color:var(--text-faint);border-radius:8px;place-items:center;transition:all .16s;display:grid}.view-toggle button:hover{color:var(--text)}.view-toggle button.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}.data-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table thead th{background:var(--surface-2);color:var(--text-soft);text-align:start;white-space:nowrap;padding:14px 18px;font-size:12.5px;font-weight:700}.data-table tbody td{border-top:1px solid var(--border);color:var(--text);vertical-align:middle;padding:14px 18px}.data-table tbody tr{cursor:pointer;transition:background .14s}.data-table tbody tr:hover{background:var(--surface-2)}.dt-title{align-items:center;gap:11px;font-weight:700;display:flex}.dt-mark{color:#fff;border-radius:9px;flex-shrink:0;place-items:center;width:30px;height:30px;font-size:14px;font-weight:800;display:grid}.dt-check{border:2px solid var(--border-strong);color:#0000;border-radius:7px;flex-shrink:0;place-items:center;width:21px;height:21px;transition:all .16s;display:grid}.dt-check:hover{border-color:#10b981}.dt-check.done{color:#fff;background:#10b981;border-color:#10b981}.dt-done-text{color:var(--text-faint);text-decoration:line-through}.dt-progress{align-items:center;gap:10px;min-width:120px;display:flex}.dt-progress-track{background:var(--surface-3);border-radius:10px;flex:1;height:7px;overflow:hidden}.dt-progress-fill{border-radius:10px;height:100%;transition:width .4s}.dt-progress span{color:var(--text-soft);min-width:34px;font-size:12px;font-weight:700}.dt-deps{flex-wrap:wrap;gap:6px;display:flex}.dt-dep-chip{background:var(--surface-2);border:1px solid var(--border);color:var(--text-soft);border-radius:7px;align-items:center;gap:6px;max-width:160px;padding:4px 10px;font-size:12px;font-weight:600;transition:all .15s;display:inline-flex}.dt-dep-chip:hover{border-color:var(--dc);color:var(--text);transform:translateY(-1px)}.dt-dep-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.dt-dep-chip>:last-child,.dt-dep-chip{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.dt-dep-none{color:var(--text-faint);font-size:14px}.login-screen{background:var(--bg);background-image:radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--primary) 10%, transparent) 0%, transparent 42%), radial-gradient(circle at 0% 100%, #06b6d414 0%, transparent 45%);place-items:center;min-height:100dvh;padding:20px;display:grid}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-lg);padding:36px 30px}.login-logo{text-align:center;margin-bottom:28px}.login-logo .logo-mark{border-radius:16px;place-items:center;width:56px;height:56px;margin:0 auto 14px;display:grid}.login-logo h1{margin-bottom:6px;font-size:22px;font-weight:800}.login-logo p{color:var(--text-soft);font-size:13.5px}.login-form{flex-direction:column;gap:16px;display:flex}.login-field{flex-direction:column;gap:7px;display:flex}.login-field label{color:var(--text);font-size:13px;font-weight:700}.login-input-wrap{align-items:center;display:flex;position:relative}.login-input-wrap>svg:first-child{color:var(--text-faint);pointer-events:none;position:absolute;inset-inline-start:13px}.login-input-wrap input{background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);font-size:15px;font-family:var(--font);outline:none;padding:13px 44px;transition:all .18s}.login-input-wrap input:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 3px var(--primary-soft)}.login-eye{color:var(--text-faint);place-items:center;display:grid;position:absolute;inset-inline-end:12px}.login-eye:hover{color:var(--text)}.login-remember{color:var(--text-soft);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:9px;font-size:13.5px;display:flex}.login-remember input{width:17px;height:17px;accent-color:var(--primary);cursor:pointer}.login-error{background:color-mix(in srgb, var(--danger) 10%, transparent);color:var(--danger);border-radius:var(--radius-sm);border:1px solid color-mix(in srgb, var(--danger) 25%, transparent);padding:10px 14px;font-size:13px;font-weight:600}.login-submit{justify-content:center;margin-top:4px;padding:13px;font-size:15px}.logout-btn:hover{color:var(--danger)}.tree-mode-dropdown{margin-inline-start:auto;position:relative}.tree-mode-trigger{background:var(--surface);border:1px solid var(--border-strong);color:var(--text);box-shadow:var(--shadow-xs);border-radius:10px;align-items:center;gap:7px;padding:8px 13px;font-size:13px;font-weight:600;transition:all .16s;display:inline-flex}.tree-mode-trigger:hover{border-color:var(--primary)}.tree-mode-trigger svg:first-child{color:var(--primary)}.tree-mode-menu{top:calc(100% + 6px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:240px;box-shadow:var(--shadow-lg);z-index:30;padding:6px;animation:.16s fadeDown;position:absolute;inset-inline-end:0}.tree-mode-option{text-align:start;border-radius:9px;align-items:flex-start;gap:10px;width:100%;padding:10px 12px;transition:background .14s;display:flex}.tree-mode-option svg{color:var(--text-soft);flex-shrink:0;margin-top:2px}.tree-mode-option:hover{background:var(--surface-2)}.tree-mode-option.active{background:var(--primary-soft)}.tree-mode-option.active svg{color:var(--primary)}.tree-mode-text{flex-direction:column;gap:2px;display:flex}.tree-mode-text strong{color:var(--text);font-size:13.5px;font-weight:700}.tree-mode-text small{color:var(--text-faint);font-size:11.5px;line-height:1.4}.tree-mode-tip{color:var(--text-faint);text-align:center;margin:10px 0 0;font-size:12.5px}.tree-node.dimmed{opacity:.32}
