:root{--bg: #1c1f26;--panel: #232730;--panel-2: #2a2f3a;--card: #2f3542;--card-hover: #353b49;--border: #353a46;--text: #e6e8ee;--text-dim: #9aa3b2;--text-mute: #6b7280;--accent: #4ea3ff;--accent-soft: rgba(78,163,255,.15);--green: #4ade80;--orange: #fb923c;--red: #f87171;--shadow: 0 6px 18px rgba(0,0,0,.35);--radius: 10px}*{box-sizing:border-box}html,body{height:100%;margin:0;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro,PingFang SC,Segoe UI,sans-serif;background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased;overflow:hidden}.app-shell{display:flex;height:100vh;overflow:hidden}.workspace{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}.sidebar{width:200px;flex-shrink:0;background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:14px 10px;overflow-y:auto}.sidebar-brand{font-size:18px;font-weight:700;color:var(--accent);padding:4px 8px 14px;letter-spacing:.5px}.sidebar-section{margin-bottom:18px}.sidebar-label{display:flex;align-items:center;justify-content:space-between;padding:0 8px 6px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-mute)}.sidebar-add{background:transparent;border:none;color:var(--text-mute);font-size:16px;line-height:1;cursor:pointer;padding:0 2px}.sidebar-add:hover{color:var(--accent)}.sidebar-list{list-style:none;margin:0;padding:0}.sidebar-item{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:6px;cursor:pointer;color:var(--text-dim);font-size:13px}.sidebar-item:hover{background:var(--panel-2);color:var(--text)}.sidebar-item.active{background:var(--accent-soft);color:var(--accent)}.sidebar-item .dot{width:7px;height:7px;border-radius:50%;background:var(--text-mute);flex-shrink:0}.sidebar-item.active .dot{background:var(--accent)}.sidebar-item .dot.dot-notes{border-radius:2px;background:var(--orange)}.sidebar-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-count{font-size:11px;color:var(--text-mute)}.sidebar-del{background:transparent;border:none;color:var(--text-mute);font-size:15px;line-height:1;cursor:pointer;padding:0 2px;opacity:0;transition:opacity .1s}.sidebar-item:hover .sidebar-del{opacity:1}.sidebar-del:hover{color:var(--red)}.notes{flex:1;display:flex;flex-direction:column;padding:16px 24px;min-height:0}.notes-area{flex:1;resize:none;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:16px 18px;font-size:14px;line-height:1.7;font-family:ui-monospace,SF Mono,PingFang SC,monospace;outline:none}.notes-area:focus{border-color:var(--accent)}.notes-footer{display:flex;justify-content:space-between;padding:8px 2px 0;font-size:11px;color:var(--text-mute)}.notes-saved{color:var(--green)}.topbar{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 24px 12px;border-bottom:1px solid var(--border);background:var(--bg)}.title-wrap h1{margin:0;font-size:28px;font-weight:700;color:var(--accent);outline:none;letter-spacing:.3px}.title-wrap h1:focus{background:var(--accent-soft);border-radius:4px}.title-wrap .meta{margin-top:4px;color:var(--text-mute);font-size:12px}.title-wrap .meta a{color:var(--accent);text-decoration:none}.title-wrap .meta a:hover{text-decoration:underline}.completed-toggle{background:transparent;border:none;color:var(--text-mute);font-size:12px;cursor:pointer;padding:0;font-family:inherit}.completed-toggle:hover{color:var(--text-dim)}.completed-toggle .caret{display:inline-block;transition:transform .15s;font-size:10px}.completed-toggle.open .caret{transform:rotate(90deg)}.completed-toggle .num{color:var(--green);font-weight:600}.completed-drawer{flex-shrink:0;display:grid;grid-template-rows:0fr;margin:0 24px;transition:grid-template-rows .28s ease,margin-bottom .28s ease}.completed-drawer.open{grid-template-rows:1fr;margin-bottom:20px}.completed-drawer-inner{overflow:hidden;min-height:0;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;max-height:38vh;opacity:0;transition:opacity .28s ease}.completed-drawer.open .completed-drawer-inner{opacity:1}.completed-drawer:not(.open) .completed-drawer-inner{border-width:0}.completed-drawer-head{padding:10px 14px;font-size:12px;font-weight:600;color:var(--text-dim);border-bottom:1px dashed var(--border)}.completed-list{list-style:none;margin:0;padding:6px;overflow-y:auto}.completed-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px}.completed-item:hover{background:var(--panel-2)}.completed-item .check{flex-shrink:0;width:14px;height:14px;border-radius:50%;cursor:pointer;background:var(--green);border:1.5px solid var(--green)}.completed-title{flex:1;font-size:13px;color:var(--text-mute);text-decoration:line-through;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.completed-date{font-size:11px;color:var(--text-mute)}.completed-del{background:transparent;border:none;color:var(--text-mute);font-size:15px;line-height:1;cursor:pointer;padding:0 2px;opacity:0;transition:opacity .1s}.completed-item:hover .completed-del{opacity:1}.completed-del:hover{color:var(--red)}.completed-empty{padding:20px;text-align:center;font-size:12px;color:var(--text-mute);font-style:italic}.actions{display:flex;align-items:center;gap:10px}.actions input[type=search]{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:6px 10px;border-radius:6px;width:200px;font-size:13px;outline:none}.actions input[type=search]:focus{border-color:var(--accent)}.actions button{background:var(--accent);color:#fff;border:none;padding:6px 12px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer}.actions button:hover{filter:brightness(1.1)}.big-count{color:var(--accent);font-size:28px;font-weight:700;margin-left:8px}.board{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:16px 24px 24px;overflow-x:auto;overflow-y:hidden;flex:1;min-height:0}.column{background:var(--panel);border-radius:var(--radius);display:flex;flex-direction:column;min-height:0;border:1px solid var(--border)}.column-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px 8px;border-bottom:1px dashed var(--border)}.column-head .name{font-weight:600;font-size:14px;color:var(--text)}.column-head .count{color:var(--text-mute);font-size:12px}.column-head .add-here{background:transparent;color:var(--text-mute);border:none;font-size:16px;cursor:pointer;padding:0 4px;line-height:1}.column-head .add-here:hover{color:var(--accent)}.cards{padding:10px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:8px}.cards.drag-over{background:var(--accent-soft);border-radius:0 0 var(--radius) var(--radius)}.card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:10px 12px;cursor:grab;transition:background .15s,transform .15s;position:relative}.card:hover{background:var(--card-hover)}.card.dragging{opacity:.4}.card.done .card-title{text-decoration:line-through;color:var(--text-mute)}.card-title{font-weight:600;font-size:13.5px;margin-bottom:4px;display:flex;align-items:flex-start;gap:8px;line-height:1.4}.card-title .check{flex-shrink:0;width:14px;height:14px;border:1.5px solid var(--text-mute);border-radius:50%;margin-top:2px;cursor:pointer}.card.done .card-title .check{background:var(--green);border-color:var(--green)}.card-desc{color:var(--text-dim);font-size:12px;line-height:1.5;white-space:pre-wrap;word-break:break-word;margin:4px 0 6px 22px;max-height:80px;overflow:hidden}.card-meta{display:flex;flex-wrap:wrap;gap:4px;margin-left:22px;align-items:center}.tag{font-size:10.5px;background:var(--panel-2);color:var(--text-dim);padding:2px 6px;border-radius:3px;border:1px solid var(--border)}.priority{font-size:10px;font-weight:600;padding:1px 5px;border-radius:3px;letter-spacing:.5px;text-transform:uppercase}.priority.high{background:#f871712e;color:var(--red)}.priority.med{background:#fb923c2e;color:var(--orange)}.priority.low{background:#4ade8026;color:var(--green)}.card-date{color:var(--text-mute);font-size:10.5px;margin-left:auto}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.modal.hidden{display:none}.modal-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);width:480px;max-width:92vw;box-shadow:var(--shadow);display:flex;flex-direction:column}.modal-card header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border)}.modal-card header h3{margin:0;font-size:15px;font-weight:600}.icon-btn{background:transparent;border:none;color:var(--text-mute);font-size:22px;cursor:pointer;line-height:1}.icon-btn:hover{color:var(--text)}.form{padding:16px 18px;display:flex;flex-direction:column;gap:12px}.form label{display:flex;flex-direction:column;font-size:12px;color:var(--text-dim);gap:4px}.form input,.form textarea{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:7px 10px;border-radius:6px;font-size:13px;font-family:inherit;outline:none}.form input:focus,.form textarea:focus{border-color:var(--accent)}.form .row{display:flex;gap:10px}.form .row label{flex:1}.hint{color:var(--text-mute);font-weight:400;font-size:11px}.select{position:relative}.select-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;background:var(--bg);border:1px solid var(--border);color:var(--text);padding:7px 10px;border-radius:6px;font-size:13px;font-family:inherit;cursor:pointer;outline:none;text-align:left}.select-trigger:hover{border-color:var(--text-mute)}.select.open .select-trigger{border-color:var(--accent)}.select-arrow{color:var(--text-mute);font-size:11px;margin-left:8px;transition:transform .15s}.select.open .select-arrow{transform:rotate(180deg)}.select-menu{list-style:none;margin:4px 0 0;padding:4px;position:absolute;top:100%;left:0;right:0;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;box-shadow:var(--shadow);z-index:10;max-height:220px;overflow-y:auto}.select-option{display:flex;align-items:center;gap:6px;padding:7px 9px;border-radius:4px;font-size:13px;color:var(--text);cursor:pointer}.select-option.active{background:var(--accent-soft)}.select-option.selected{color:var(--accent)}.select-check{width:12px;flex-shrink:0;color:var(--accent);font-size:11px}.select-menu::-webkit-scrollbar{width:8px}.select-menu::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.modal-card footer{display:flex;align-items:center;gap:8px;padding:12px 18px;border-top:1px solid var(--border)}.modal-card footer .spacer{flex:1}.modal-card button.primary{background:var(--accent);color:#fff;border:none;padding:6px 14px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500}.modal-card button.ghost{background:transparent;color:var(--text-dim);border:1px solid var(--border);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px}.modal-card button.ghost:hover{color:var(--text);border-color:var(--text-mute)}#deleteBtn{color:var(--red)}#deleteBtn:hover{background:#f871711a;border-color:var(--red)}.cards::-webkit-scrollbar,.board::-webkit-scrollbar{width:8px;height:8px}.cards::-webkit-scrollbar-thumb,.board::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.cards::-webkit-scrollbar-thumb:hover{background:var(--text-mute)}.cards:empty:before{content:"拖拽或点击 + 添加";color:var(--text-mute);font-size:12px;text-align:center;padding:20px 10px;display:block;font-style:italic}
