.app-container[data-v-97514a9f]{display:flex;height:100vh;background:#f5f5f5}.app-container--authed[data-v-97514a9f]{flex-direction:column}.top-bar[data-v-97514a9f]{height:48px;background:#fff;border-bottom:1px solid #e8e8e8;display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0}.top-bar-title[data-v-97514a9f]{font-size:16px;color:#172b4d;margin:0}.top-bar-right[data-v-97514a9f]{display:flex;align-items:center;gap:12px}.user-name[data-v-97514a9f]{font-size:13px;color:#42526e;font-weight:500}.btn-logout[data-v-97514a9f]{padding:4px 10px;background:transparent;color:#999;border:1px solid #e8e8e8;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s}.btn-logout[data-v-97514a9f]:hover{color:#ff4d4f;border-color:#ff4d4f}.main-area[data-v-97514a9f]{flex:1;overflow:hidden}.login-page[data-v-2441a905]{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card[data-v-2441a905]{background:#fff;border-radius:12px;padding:40px 36px;width:360px;box-shadow:0 8px 40px #0000001f}.login-title[data-v-2441a905]{font-size:24px;color:#172b4d;text-align:center;margin-bottom:4px}.login-subtitle[data-v-2441a905]{font-size:14px;color:#8993a4;text-align:center;margin-bottom:28px}.form-group[data-v-2441a905]{margin-bottom:16px}.form-group input[data-v-2441a905]{width:100%;padding:10px 14px;border:1px solid #d9d9d9;border-radius:6px;font-size:14px;outline:none;transition:border-color .2s;box-sizing:border-box}.form-group input[data-v-2441a905]:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff1a}.error-msg[data-v-2441a905]{color:#ff4d4f;font-size:13px;margin-bottom:12px}.btn-submit[data-v-2441a905]{width:100%;padding:10px;background:#1890ff;color:#fff;border:none;border-radius:6px;font-size:15px;cursor:pointer;transition:background .2s}.btn-submit[data-v-2441a905]:hover{background:#40a9ff}.btn-submit[data-v-2441a905]:disabled{background:#b0d0f0;cursor:not-allowed}.switch-mode[data-v-2441a905]{text-align:center;margin-top:20px;font-size:13px;color:#8993a4}.switch-mode a[data-v-2441a905]{color:#1890ff;text-decoration:none;margin-left:4px}.switch-mode a[data-v-2441a905]:hover{text-decoration:underline}.todo-input-container[data-v-327b3619]{margin-bottom:20px}.input-wrapper[data-v-327b3619]{display:flex;gap:10px}.todo-input[data-v-327b3619]{flex:1;padding:10px 14px;border:1px solid #dfe1e6;border-radius:6px;font-size:14px;outline:none;transition:border-color .2s}.todo-input[data-v-327b3619]:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff1a}.todo-input[data-v-327b3619]:disabled{background:#f4f5f7}.btn-primary[data-v-327b3619]{padding:10px 20px;background:#1890ff;color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:background .2s;white-space:nowrap}.btn-primary[data-v-327b3619]:hover{background:#40a9ff}.btn-primary[data-v-327b3619]:disabled{background:#b0c4de;cursor:not-allowed}.time-panel[data-v-327b3619]{margin-top:12px;padding:16px;background:#f9f9f9;border:1px solid #e8e8e8;border-radius:6px}.time-row[data-v-327b3619]{display:flex;align-items:center;gap:10px;margin-bottom:10px}.time-row label[data-v-327b3619]{font-size:13px;color:#42526e;min-width:70px}.time-input[data-v-327b3619]{padding:8px 10px;border:1px solid #dfe1e6;border-radius:4px;font-size:13px;outline:none}.time-input[data-v-327b3619]:focus{border-color:#1890ff}.no-time-label[data-v-327b3619]{font-size:12px;color:#8993a4;min-width:auto;display:flex;align-items:center;gap:4px;cursor:pointer}.time-actions[data-v-327b3619]{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.btn-cancel[data-v-327b3619]{padding:8px 16px;background:#fff;color:#42526e;border:1px solid #dfe1e6;border-radius:6px;font-size:13px;cursor:pointer}.btn-cancel[data-v-327b3619]:hover{background:#f4f5f7}.todo-item[data-v-bd2a27ef]{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:#fff;border:1px solid #e8e8e8;border-radius:8px;margin-bottom:10px;transition:box-shadow .2s}.todo-item.pinned[data-v-bd2a27ef]{background:#fffbe6;border-color:#ffe58f}.todo-item.overdue[data-v-bd2a27ef]{background:#fff2f0;border-color:#ffccc7}.todo-item.overdue .todo-content[data-v-bd2a27ef]{color:#cf1322}.todo-item.overdue .meta-item[data-v-bd2a27ef]:first-child{color:#ff4d4f;font-weight:500}.todo-item[data-v-bd2a27ef]:hover{box-shadow:0 2px 8px #0000000f}.todo-item.completed[data-v-bd2a27ef]{opacity:.6}.todo-checkbox[data-v-bd2a27ef]{margin-top:3px;width:18px;height:18px;cursor:pointer;accent-color:#1890ff}.todo-body[data-v-bd2a27ef]{flex:1;min-width:0}.btn-edit[data-v-bd2a27ef]{padding:6px 10px;background:transparent;color:#999;border:1px solid #e8e8e8;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s;flex-shrink:0}.btn-edit[data-v-bd2a27ef]:hover{color:#1890ff;border-color:#1890ff}.btn-pin[data-v-bd2a27ef]{padding:6px 8px;background:transparent;color:#999;border:1px solid #e8e8e8;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s;flex-shrink:0;display:flex;align-items:center}.btn-pin[data-v-bd2a27ef]:hover{color:#ff4d4f;border-color:#ff4d4f}.btn-pin.active[data-v-bd2a27ef]{color:#ff4d4f;border-color:#ff4d4f;background:#fff1f0}.pin-icon[data-v-bd2a27ef]{width:14px;height:14px;margin-right:4px;flex-shrink:0}.todo-actions[data-v-bd2a27ef]{display:flex;gap:6px;flex-shrink:0}.todo-content[data-v-bd2a27ef]{font-size:14px;color:#172b4d;margin-bottom:6px;word-break:break-word}.completed .todo-content[data-v-bd2a27ef]{text-decoration:line-through;color:#999}.edit-input[data-v-bd2a27ef]{width:100%;padding:4px 8px;border:1px solid #1890ff;border-radius:4px;font-size:14px;color:#172b4d;margin-bottom:6px;outline:none}.todo-meta[data-v-bd2a27ef]{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:#8993a4}.meta-item[data-v-bd2a27ef]{display:flex;align-items:center;gap:4px}.meta-icon[data-v-bd2a27ef]{width:13px;height:13px}.meta-item.remind[data-v-bd2a27ef]{color:#fa8c16}.meta-item.no-due[data-v-bd2a27ef]{color:#b8b8b8}.remind-input[data-v-bd2a27ef]{padding:2px 4px;border:1px solid transparent;border-radius:3px;font-size:12px;color:#fa8c16;background:transparent;outline:none;width:140px}.remind-input[data-v-bd2a27ef]:hover,.remind-input[data-v-bd2a27ef]:focus{border-color:#dfe1e6;background:#fff}.btn-delete[data-v-bd2a27ef]{padding:6px 10px;background:transparent;color:#999;border:1px solid #e8e8e8;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s;flex-shrink:0}.btn-delete[data-v-bd2a27ef]:hover{color:#ff4d4f;border-color:#ff4d4f}.todo-page[data-v-5642cc6c]{height:100%}.page-header[data-v-5642cc6c]{display:flex;align-items:center;gap:12px;margin-bottom:16px}.page-header h2[data-v-5642cc6c]{font-size:20px;color:#172b4d}.tabs[data-v-5642cc6c]{display:flex;gap:0;margin-bottom:20px;border-bottom:1px solid #e8e8e8}.tab-item[data-v-5642cc6c]{padding:10px 20px;font-size:14px;color:#8993a4;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;display:flex;align-items:center;gap:6px;-webkit-user-select:none;user-select:none}.tab-item[data-v-5642cc6c]:hover{color:#172b4d}.tab-item.active[data-v-5642cc6c]{color:#1890ff;border-bottom-color:#1890ff}.tab-count[data-v-5642cc6c]{font-size:12px;color:#b8b8b8;background:#f4f5f7;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}.tab-item.active .tab-count[data-v-5642cc6c]{background:#e6f7ff;color:#1890ff}.todo-list[data-v-5642cc6c]{min-height:200px}.empty-state[data-v-5642cc6c]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#c1c1c1}.empty-state svg[data-v-5642cc6c]{width:64px;height:64px;margin-bottom:12px}.empty-state p[data-v-5642cc6c]{font-size:14px}.note-card[data-v-aa025e84]{background:#fffbe6;border:1px solid #f0e6b3;border-radius:8px;display:flex;flex-direction:column;position:absolute;box-shadow:0 1px 4px #0000000f;transition:box-shadow .2s}.note-card[data-v-aa025e84]:hover{box-shadow:0 3px 12px #0000001a}.note-titlebar[data-v-aa025e84]{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#f5eecc;border-radius:8px 8px 0 0;cursor:grab;-webkit-user-select:none;user-select:none;border-bottom:1px solid #e8ddb3}.note-titlebar[data-v-aa025e84]:active{cursor:grabbing}.note-time[data-v-aa025e84]{font-size:11px;color:#a89860}.note-actions[data-v-aa025e84]{display:flex;gap:4px}.btn-delete[data-v-aa025e84]{padding:2px 8px;background:transparent;color:#999;border:1px solid #ddd;border-radius:3px;font-size:11px;cursor:pointer;line-height:1.4}.btn-delete[data-v-aa025e84]:hover{color:#ff4d4f;border-color:#ff4d4f}.note-editor[data-v-aa025e84]{flex:1;padding:12px 14px;font-size:13px;color:#172b4d;outline:none;line-height:1.7;min-height:60px;word-break:break-word}.note-editor[data-v-aa025e84]:empty:before{content:attr(data-placeholder);color:#c1c1c1;pointer-events:none}.format-toolbar[data-v-aa025e84]{position:absolute;z-index:100;display:flex;align-items:center;gap:2px;background:#fff;border:1px solid #d9d9d9;border-radius:6px;padding:4px 6px;box-shadow:0 2px 8px #0000001f}.toolbar-btn[data-v-aa025e84]{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:4px;cursor:pointer;font-size:14px;transition:background .15s}.toolbar-btn[data-v-aa025e84]:hover{background:#f0f0f0}.bold-btn[data-v-aa025e84]{font-size:16px}.toolbar-divider[data-v-aa025e84]{width:1px;height:18px;background:#e8e8e8;margin:0 4px}.color-btn[data-v-aa025e84]{font-size:15px;font-weight:700}.resize-handle[data-v-aa025e84]{position:absolute;right:0;bottom:0;width:16px;height:16px;cursor:nwse-resize;opacity:.3;transition:opacity .2s}.resize-handle[data-v-aa025e84]:hover{opacity:.7}.resize-handle[data-v-aa025e84]:after{content:"";position:absolute;right:4px;bottom:4px;width:8px;height:8px;border-right:2px solid #999;border-bottom:2px solid #999}.notes-page[data-v-284014ac]{max-width:100%;margin:0 auto;height:100%;display:flex;flex-direction:column}.page-header[data-v-284014ac]{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-header h2[data-v-284014ac]{font-size:20px;color:#172b4d}.btn-add[data-v-284014ac]{padding:8px 16px;background:#1890ff;color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:background .2s}.btn-add[data-v-284014ac]:hover{background:#40a9ff}.notes-canvas[data-v-284014ac]{position:relative;min-height:600px;flex:1;overflow:auto}.empty-state[data-v-284014ac]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#c1c1c1}.empty-state svg[data-v-284014ac]{width:64px;height:64px;margin-bottom:12px}.empty-state p[data-v-284014ac]{font-size:14px}.split-view[data-v-60627982]{display:flex;height:100%}.split-panel[data-v-60627982]{flex:1;overflow-y:auto;padding:24px;min-width:0}.split-divider[data-v-60627982]{width:1px;background:#e8e8e8;flex-shrink:0}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;color:#172b4d}input,textarea,button{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}::-webkit-scrollbar-track{background:transparent}
