:root{--bg: #0c0c0f;--bg-2: #0f0f14;--bg-elev: #16161c;--panel: #1d1d25;--border: rgba(255, 255, 255, .07);--border-strong: rgba(255, 255, 255, .14);--fg: #f1f1f4;--fg-muted: rgba(241, 241, 244, .58);--fg-faint: rgba(241, 241, 244, .34);--accent: oklch(.72 .17 28);--accent-2: oklch(.66 .19 320);--accent-soft: oklch(.72 .17 28 / .15);--grad: linear-gradient(135deg, oklch(.74 .18 30), oklch(.66 .19 350));--green: oklch(.8 .16 150);--blue: #6ea8ff;--radius: 16px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--shadow: 0 12px 40px rgba(0, 0, 0, .45)}[data-theme=light]{--bg: #f4f3ef;--bg-2: #efeee9;--bg-elev: #ffffff;--panel: #f6f5f2;--border: rgba(0, 0, 0, .08);--border-strong: rgba(0, 0, 0, .15);--fg: #16161a;--fg-muted: rgba(20, 20, 24, .6);--fg-faint: rgba(20, 20, 24, .38);--accent: oklch(.58 .18 28);--accent-2: oklch(.55 .2 320);--accent-soft: oklch(.58 .18 28 / .1);--green: oklch(.62 .16 150);--shadow: 0 12px 40px rgba(0, 0, 0, .12)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;overscroll-behavior:none;background-image:radial-gradient(900px 500px at 12% -8%,oklch(.72 .17 28 / .1),transparent 60%),radial-gradient(800px 600px at 100% 0%,oklch(.66 .19 320 / .1),transparent 55%);background-attachment:fixed}button,input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}button{cursor:pointer;border:none;background:none}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--fg-faint)}.app{display:flex;height:100%}.sidebar{width:252px;flex-shrink:0;background:linear-gradient(180deg,var(--bg-elev),var(--bg-2));border-right:1px solid var(--border);display:flex;flex-direction:column;padding:18px 14px;gap:3px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.brand{font-weight:800;font-size:23px;letter-spacing:-.03em;padding:4px 8px 18px;display:flex;align-items:center;gap:10px;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.brand .dot{width:11px;height:11px;border-radius:50%;background:var(--accent);box-shadow:0 0 16px 2px var(--accent);flex-shrink:0}.proj-select{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:10px 12px;margin:0 4px 14px;width:calc(100% - 8px);outline:none;font-weight:500;transition:.15s}.proj-select:hover{border-color:var(--border-strong)}.nav{display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto}.nav button{display:flex;align-items:center;gap:12px;padding:9px 11px;border-radius:12px;color:var(--fg-muted);font-weight:500;text-align:left;width:100%;transition:.16s;position:relative}.nav button:hover{background:var(--panel);color:var(--fg)}.nav button.active{background:var(--accent-soft);color:var(--fg)}.nav button.active:before{content:"";position:absolute;left:-14px;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:3px;background:var(--grad)}.nav button .ico{font-size:15px;width:30px;height:30px;display:grid;place-items:center;background:var(--bg-elev);border:1px solid var(--border);border-radius:9px;flex-shrink:0}.nav button.active .ico{background:var(--accent-soft);border-color:transparent}.side-foot{display:flex;gap:8px;padding:10px 4px 0}.side-foot button{padding:9px 10px;border-radius:10px;color:var(--fg-muted);border:1px solid var(--border);flex:1;transition:.15s}.side-foot button:hover{background:var(--panel);color:var(--fg)}.main{flex:1;overflow-y:auto;padding:30px 36px 84px;position:relative}.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.page-head h1{font-size:30px;font-weight:800;letter-spacing:-.03em;line-height:1.05}.page-head .sub{color:var(--fg-muted);font-size:14px;margin-top:4px}.card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;transition:transform .16s,border-color .16s,box-shadow .16s}.card:hover{border-color:var(--border-strong)}.grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}.btn{background:var(--grad);color:#fff;padding:10px 17px;border-radius:12px;font-weight:600;box-shadow:0 6px 18px #f66e5c4d;transition:transform .12s,box-shadow .16s}.btn:hover{transform:translateY(-1px);box-shadow:0 9px 24px #f66e5c6b}.btn:active{transform:translateY(0)}.btn.ghost{background:var(--panel);color:var(--fg);border:1px solid var(--border);box-shadow:none}.btn.ghost:hover{border-color:var(--border-strong);background:var(--bg-elev)}.inp{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:11px 13px;width:100%;outline:none;transition:.15s}.inp:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.list-title{font-weight:700;font-size:16px;letter-spacing:-.01em;display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:8px}.item{display:flex;align-items:center;gap:11px;padding:8px 0;border-bottom:1px solid var(--border)}.item:last-child{border-bottom:none}.check{width:21px;height:21px;border-radius:7px;border:2px solid var(--border-strong);flex-shrink:0;display:grid;place-items:center;transition:.16s;font-size:12px;font-weight:700}.check.on{background:var(--green);border-color:var(--green);color:#06210f}.item.done .txt{color:var(--fg-faint);text-decoration:line-through}.item .txt{flex:1}.item .x{color:var(--fg-faint);opacity:0;padding:2px 6px;border-radius:6px;transition:.15s}.item:hover .x{opacity:1}.item .x:hover{background:var(--panel);color:var(--fg)}.add-row{display:flex;gap:8px;margin-top:14px}.chip{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.01em}.chip.done{background:var(--accent-soft);color:var(--accent)}.chip.upcoming{background:#6ea8ff29;color:var(--blue)}.chip.milestone{background:#ffc8502e;color:#ffcf66}.tl-item{display:flex;gap:14px;border-left:2px solid var(--border);padding:14px 0 14px 20px;margin-left:6px;position:relative}.tl-item:before{content:"";position:absolute;left:-7px;top:19px;width:12px;height:12px;border-radius:50%;background:var(--grad);box-shadow:0 0 10px var(--accent)}.empty{color:var(--fg-faint);text-align:center;padding:56px 0;font-size:15px;line-height:1.6}.gr-head{display:flex;align-items:flex-end;justify-content:space-between;padding:22px 28px 12px;gap:16px;flex-wrap:wrap}.gr-legend{display:flex;gap:14px;flex-wrap:wrap}.gr-leg{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--fg-muted);font-weight:500}.gr-leg i{width:10px;height:10px;border-radius:50%}.mobnav{display:none}@media(max-width:820px){.sidebar{display:none}.main{padding:18px 16px 92px}.mobnav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:50;background:color-mix(in srgb,var(--bg-elev) 88%,transparent);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--border);padding:9px 6px calc(9px + env(safe-area-inset-bottom));justify-content:space-around}.mobnav button{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--fg-faint);font-size:10px;padding:4px 8px;transition:.15s}.mobnav button.active{color:var(--accent)}.mobnav .ico{font-size:20px}.page-head h1{font-size:24px}.gr-head{padding:16px 16px 10px}.mob-proj{display:block;margin-bottom:16px}}.mob-proj{display:none}.bd-toolbar{position:absolute;top:16px;left:50%;transform:translate(-50%);z-index:20;display:flex;align-items:center;gap:4px;padding:8px 10px;background:color-mix(in srgb,var(--bg-elev) 90%,transparent);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);max-width:94%;overflow-x:auto}.bd-toolbar button{width:38px;height:38px;border-radius:12px;font-size:18px;display:grid;place-items:center;color:var(--fg);flex-shrink:0;transition:.12s}.bd-toolbar button:hover{background:var(--panel)}.bd-toolbar button.active{background:var(--grad);color:#fff;box-shadow:0 4px 14px #f66e5c66}.bd-sep{width:1px;height:26px;background:var(--border-strong);margin:0 5px;flex-shrink:0}.bd-color{width:24px;height:24px;border-radius:50%;border:2px solid var(--border-strong)!important;flex-shrink:0;transition:.12s}.bd-color.active{transform:scale(1.2);border-color:var(--fg)!important;box-shadow:0 0 0 2px var(--accent)}.bd-canvas{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;touch-action:none;background:var(--bg)}.bd-grid{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.5;background-image:radial-gradient(circle,var(--border-strong) 1px,transparent 1px)}.bd-world{position:absolute;top:0;left:0;transform-origin:0 0;will-change:transform}.bd-stroke{position:absolute;overflow:visible;pointer-events:stroke}.bd-card{position:absolute;border-radius:16px;box-shadow:0 10px 28px #0000004d;border:1px solid rgba(0,0,0,.1);display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .15s}.bd-card.sel{box-shadow:0 0 0 2px var(--accent),0 16px 36px #00000073}.bd-card-head{display:flex;align-items:center;justify-content:space-between;padding:7px 9px;cursor:grab;font-size:14px;opacity:.9;touch-action:none}.bd-card-head:active{cursor:grabbing}.bd-del{width:20px;height:20px;border-radius:6px;font-size:12px;opacity:0;color:inherit}.bd-card:hover .bd-del{opacity:.7}.bd-del:hover{background:#00000026;opacity:1}.bd-text{flex:1;resize:none;border:none;outline:none;background:transparent;padding:2px 13px 13px;font-size:14px;line-height:1.45;font-family:inherit}.bd-input{margin:6px 11px 11px;padding:9px;border-radius:9px;border:1px solid var(--border);background:var(--panel);color:var(--fg)}.bd-img{flex:1;width:100%;object-fit:cover;pointer-events:auto}.bd-resize{position:absolute;right:0;bottom:0;width:18px;height:18px;cursor:nwse-resize;background:linear-gradient(135deg,transparent 50%,var(--border-strong) 50%);touch-action:none}.bd-zoom{position:absolute;right:18px;bottom:100px;z-index:20;display:flex;flex-direction:column;gap:6px;background:color-mix(in srgb,var(--bg-elev) 90%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:14px;padding:6px;box-shadow:var(--shadow)}.bd-zoom button{padding:8px 11px;border-radius:9px;color:var(--fg);font-weight:600;font-size:13px;min-width:46px}.bd-zoom button:hover{background:var(--panel)}.bd-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--fg-faint);font-size:15px;max-width:340px;pointer-events:none;line-height:1.6}@media(min-width:821px){.bd-zoom{bottom:24px}}.bd-conn{position:absolute;right:-7px;top:50%;transform:translateY(-50%);width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-elev);cursor:crosshair;opacity:0;transition:.15s;touch-action:none;z-index:3;box-shadow:0 0 0 2px var(--accent-soft)}.bd-card:hover .bd-conn,.bd-card.sel .bd-conn{opacity:1}.bd-conn:hover{transform:translateY(-50%) scale(1.25)}.bd-edge:hover line[stroke="var(--accent)"]{stroke-width:3}.bd-ec{background:var(--bg-elev)!important;color:var(--fg);border:1px solid var(--border-strong)}.bd-ec-body{flex:1;overflow-y:auto;padding:2px 10px 10px;display:flex;flex-direction:column;gap:2px}.bd-ec-item{display:flex;align-items:center;gap:8px;font-size:13px;padding:3px 0}.bd-ec-dot{width:17px;height:17px;border-radius:5px;border:2px solid;flex-shrink:0;display:grid;place-items:center;font-size:10px;font-weight:700}.bd-ec-empty{color:var(--fg-faint);font-size:13px;padding:6px 0}.bd-ec-note{flex:1;overflow-y:auto;padding:4px 12px 12px;font-size:13px;line-height:1.45;white-space:pre-wrap}.bd-lib{position:absolute;top:74px;right:16px;width:300px;max-height:70vh;z-index:25;background:color-mix(in srgb,var(--bg-elev) 96%,transparent);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-strong);border-radius:16px;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden}.bd-lib-head{display:flex;align-items:center;justify-content:space-between;padding:13px 15px;font-weight:700;border-bottom:1px solid var(--border)}.bd-lib-head button{color:var(--fg-muted);font-size:15px}.bd-lib-body{overflow-y:auto;padding:8px}.bd-lib-group{margin-bottom:10px}.bd-lib-title{font-size:12px;color:var(--fg-muted);font-weight:600;padding:4px 8px}.bd-lib-item{display:block;width:100%;text-align:left;padding:9px 11px;border-radius:10px;color:var(--fg);font-size:13px;transition:.12s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bd-lib-item:hover{background:var(--accent-soft)}@media(max-width:820px){.bd-lib{right:8px;left:8px;width:auto}}.pulse-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.pulse-link{color:var(--accent);font-size:13px;font-weight:600;text-decoration:none}.pulse-link:hover{text-decoration:underline}.pulse-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1px;background:var(--border)}.pulse-stat{background:var(--bg-elev);padding:16px 18px}.pulse-val{font-size:26px;font-weight:800;letter-spacing:-.02em;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.pulse-lbl{font-size:13px;color:var(--fg-muted);margin-top:2px}.pulse-sub{font-size:12px;color:var(--green);margin-top:3px;font-weight:600}.pulse-feed{padding:6px 0;max-height:280px;overflow-y:auto}.pulse-ev{display:flex;align-items:center;gap:10px;padding:8px 20px;font-size:13px}.pulse-ev:hover{background:var(--panel)}.pulse-ev-ico{flex-shrink:0}.pulse-ev-txt{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pulse-ev-time{color:var(--fg-faint);font-size:12px;flex-shrink:0}.att-toggle{color:var(--fg-faint);font-size:12px;padding:2px 6px;border-radius:6px;opacity:0;transition:.15s}.item:hover .att-toggle,.att-toggle{opacity:.75}.att-toggle:hover{background:var(--panel);color:var(--accent);opacity:1}.att{margin:2px 0 10px 30px;padding:10px 12px;background:var(--panel);border-radius:10px;display:flex;flex-direction:column;gap:7px}.att-item{display:flex;align-items:center;gap:8px;font-size:13px}.att-item .x{color:var(--fg-faint);padding:2px 5px;border-radius:5px;opacity:.6}.att-item .x:hover{background:var(--bg-elev);opacity:1}.att-img{width:46px;height:46px;object-fit:cover;border-radius:8px;border:1px solid var(--border)}.att-link{color:var(--blue);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-decoration:none}.att-note{flex:1}.att-add{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.att-btn{font-size:12px;padding:5px 9px;border-radius:8px;background:var(--bg-elev);border:1px solid var(--border);color:var(--fg-muted)}.att-btn:hover{color:var(--fg);border-color:var(--border-strong)}.att-add .inp{flex:1;min-width:140px;padding:7px 10px}.att-add .btn{padding:7px 12px}
