.calendar[data-v-89fa01e3]{border:1px solid var(--color-border);background:var(--color-bg);display:flex;flex-direction:column;height:100%}.calendar-header[data-v-89fa01e3]{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-border);flex-shrink:0}.cal-month[data-v-89fa01e3]{font-size:17px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;transition:background .15s}.cal-month[data-v-89fa01e3]:hover{background:#f5f5f5}.cal-month-arrow[data-v-89fa01e3]{font-size:10px;color:var(--color-muted);margin-left:2px}.cal-picker-panel[data-v-89fa01e3]{flex-shrink:0;border-bottom:1px solid #eee}.cal-picker-header[data-v-89fa01e3]{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid #eee}.cal-picker-year[data-v-89fa01e3]{font-size:16px;font-weight:600}.cal-small-btn[data-v-89fa01e3]{width:28px;height:28px;font-size:14px}.cal-today-btn[data-v-89fa01e3]{font-size:14px;padding:0}.cal-month-picker[data-v-89fa01e3]{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:8px 16px 12px}.cal-month-option[data-v-89fa01e3]{text-align:center;padding:8px 0;font-size:14px;cursor:pointer;border-radius:4px;transition:background .15s}.cal-month-option[data-v-89fa01e3]:hover{background:#f5f5f5}.cal-month-active[data-v-89fa01e3]{background:var(--color-text);color:var(--color-bg);font-weight:600}.cal-nav-btn[data-v-89fa01e3]{width:32px;height:32px;border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;color:var(--color-text)}.cal-nav-btn[data-v-89fa01e3]:hover{background:#f5f5f5}.cal-weekdays[data-v-89fa01e3]{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;font-size:13px;color:var(--color-muted);border-bottom:1px solid #eee;padding:8px 0;flex-shrink:0}.cal-grid[data-v-89fa01e3]{display:grid;grid-template-columns:repeat(7,1fr);flex:1}.cal-cell[data-v-89fa01e3]{padding:6px;border-bottom:1px solid #eee;border-right:1px solid #eee;cursor:pointer;display:flex;flex-direction:column;align-items:flex-start;overflow:hidden;position:relative;width:100%;height:100%}.cal-cell[data-v-89fa01e3]:nth-child(7n){border-right:none}.cal-cell[data-v-89fa01e3]:nth-last-child(-n+7){border-bottom:none}.cal-empty[data-v-89fa01e3]{cursor:default;background:#fafafa}.cal-day[data-v-89fa01e3]{font-size:14px;line-height:1.4;flex-shrink:0}.cal-today[data-v-89fa01e3]{background:var(--color-bg)}.cal-today .cal-day[data-v-89fa01e3]{font-weight:700;border:1px solid var(--color-text);border-radius:50%;width:24px;height:24px;line-height:22px;text-align:center;display:block}.cal-selected[data-v-89fa01e3]{background:var(--color-text)!important}.cal-selected .cal-day[data-v-89fa01e3]{color:var(--color-bg)!important;font-weight:700}.cal-selected .cal-dot[data-v-89fa01e3]{border-color:var(--color-text)!important}.cal-dots[data-v-89fa01e3]{display:flex;gap:3px;flex-wrap:wrap;margin-top:4px;flex-shrink:0}.cal-dot[data-v-89fa01e3]{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dot-urgent_important[data-v-89fa01e3]{background:#dc3232}.dot-important[data-v-89fa01e3]{background:#dcb432}.dot-urgent[data-v-89fa01e3]{background:#32b464}.dot-none[data-v-89fa01e3]{background:var(--color-muted)}:root{--color-bg: #fff;--color-text: #111;--color-border: #333;--color-muted: #999;--color-done: #aaa;--color-urgent: rgba(220, 50, 50, .2);--color-important: rgba(220, 180, 50, .2);--color-urgent-light: rgba(50, 180, 100, .2);--font-family: "Noto Sans SC", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--max-width: 640px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{overscroll-behavior:none;-webkit-overflow-scrolling:touch}body{font-family:var(--font-family);color:var(--color-text);background:var(--color-bg);line-height:1.6;-webkit-font-smoothing:antialiased;touch-action:pan-y;-webkit-text-size-adjust:100%;overflow-x:hidden}body.drawer-open{overflow:hidden;position:fixed;width:100%;touch-action:none}#app{max-width:100%;margin:0 auto;padding:24px 16px;display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-root{display:flex;flex-direction:column;flex:1;min-height:0}.app-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--color-border)}.app-title{font-size:20px;font-weight:600;letter-spacing:2px}.header-actions{display:flex;gap:8px;align-items:center}.search-wrap{display:flex;margin-bottom:12px}.search-input{flex:1;padding:6px 12px;border:1px solid var(--color-border);border-radius:0;font-size:14px;font-family:var(--font-family);outline:none;background:var(--color-bg);color:var(--color-text)}.search-input:focus{border-color:#000}.search-btn{padding:6px 16px;border:1px solid var(--color-border);border-left:none;background:var(--color-bg);cursor:pointer;font-size:14px;font-family:var(--font-family)}.search-btn:hover{background:#f5f5f5}.filter-bar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}.filter-btn{padding:4px 12px;border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;font-size:13px;font-family:var(--font-family);transition:background .15s}.filter-btn:hover{background:#f5f5f5}.filter-btn.active{background:var(--color-text);color:var(--color-bg)}.section-divider{text-align:center;margin:24px 0 8px;color:var(--color-muted);font-size:12px;letter-spacing:2px;-webkit-user-select:none;user-select:none;font-weight:500}.todo-list{list-style:none}.todo-item{display:flex;align-items:center;padding:10px 4px;border-bottom:1px solid #eee;cursor:pointer;gap:8px;transition:background .1s}.todo-item:hover{background:#fafafa}.todo-item[data-completed="1"]{color:var(--color-done)}.todo-item[data-completed="1"] .todo-title{text-decoration:line-through}.priority-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dot-urgent_important{background:#dc3232}.dot-important{background:#dcb432}.dot-urgent{background:#32b464}.dot-none{background:var(--color-muted)}.todo-title{flex:1;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.todo-meta{display:flex;align-items:center;gap:6px;flex-shrink:0;font-size:12px;color:var(--color-muted)}.contact-icon{font-size:14px;color:var(--color-muted)}.pinned-icon{font-size:12px}.todo-item[data-urgency=urgent_important]{background:var(--color-urgent)}.todo-item[data-urgency=important]{background:var(--color-important)}.todo-item[data-urgency=urgent]{background:var(--color-urgent-light)}.todo-item[data-urgency=urgent_important]:hover,.todo-item[data-urgency=important]:hover,.todo-item[data-urgency=urgent]:hover{filter:brightness(.98)}.done-area{margin-top:24px;padding-top:12px;border-top:1px dashed var(--color-border)}.empty-hint{text-align:center;color:var(--color-muted);padding:40px 0;font-size:14px}.add-btn{display:flex;align-items:center;justify-content:center;width:100%;padding:12px;margin-top:20px;border:1px dashed var(--color-border);background:transparent;cursor:pointer;font-size:15px;font-family:var(--font-family);color:var(--color-text)}.add-btn:hover{background:#f5f5f5}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:100;display:flex;align-items:flex-end;justify-content:center}.drawer{width:100%;max-width:var(--max-width);background:var(--color-bg);border:1px solid var(--color-border);border-bottom:none;padding:24px 20px;max-height:80vh;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.drawer::-webkit-scrollbar{display:none}.drawer-title{font-size:18px;font-weight:600;margin-bottom:16px}.form-group{margin-bottom:14px}.form-label{display:block;font-size:13px;color:var(--color-muted);margin-bottom:4px}.form-input,.form-textarea,.form-select{width:100%;padding:8px 10px;border:1px solid var(--color-border);font-size:14px;font-family:var(--font-family);outline:none;background:var(--color-bg);color:var(--color-text);font-size:16px}.form-textarea{resize:vertical;min-height:60px}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1}.form-check{display:flex;align-items:center;gap:8px;font-size:14px}.form-actions{display:flex;gap:8px;margin-top:20px}.btn-primary{flex:1;padding:10px;background:var(--color-text);color:var(--color-bg);border:none;cursor:pointer;font-size:14px;font-family:var(--font-family)}.btn-primary:hover{opacity:.85}.btn-secondary{padding:10px 20px;background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);cursor:pointer;font-size:14px;font-family:var(--font-family)}.btn-danger{padding:10px 20px;background:#dc3232;color:#fff;border:none;cursor:pointer;font-size:14px;font-family:var(--font-family)}.btn-pin{padding:10px 20px;background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);cursor:pointer;font-size:14px;font-family:var(--font-family)}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:200;display:flex;align-items:center;justify-content:center}.dialog{background:var(--color-bg);border:1px solid var(--color-border);padding:24px;max-width:360px;width:90%;text-align:center}.dialog p{margin-bottom:20px;font-size:15px}.dialog-actions{display:flex;gap:8px}.dialog-actions button{flex:1}.detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:150;display:flex;align-items:center;justify-content:center}.detail-card{background:var(--color-bg);border:1px solid var(--color-border);padding:24px;max-width:420px;width:90%}.detail-card h3{font-size:17px;margin-bottom:12px}.detail-row{display:flex;justify-content:space-between;padding:6px 0;font-size:14px;border-bottom:1px solid #eee}.detail-row .label{color:var(--color-muted)}.detail-actions{display:flex;gap:8px;margin-top:16px}.export-btn{padding:4px 10px;border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;font-size:13px;font-family:var(--font-family)}.export-btn:hover{background:#f5f5f5}.error-toast{background:#dc3232;color:#fff;padding:8px 14px;margin-bottom:12px;font-size:13px;border-radius:4px;display:flex;align-items:center;justify-content:space-between}.error-close{background:none;border:none;color:#fff;cursor:pointer;font-size:16px;padding:0 0 0 12px;opacity:.8}.error-close:hover{opacity:1}.todo-actions{display:flex;gap:4px;flex-shrink:0;opacity:0;transition:opacity .15s}.todo-item:hover .todo-actions{opacity:1}.action-btn{width:22px;height:22px;border:none;border-radius:3px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--color-muted);transition:background .1s,color .1s}.action-btn:hover{background:#eee;color:var(--color-text)}.action-complete:hover{color:#32b464}.action-delete:hover{color:#dc3232}.action-undo:hover{color:#32b464}.collapsible-section .section-divider{cursor:pointer;-webkit-user-select:none;user-select:none}.collapse-arrow{display:inline-block;font-size:8px;margin-right:4px;transition:transform .15s;vertical-align:middle}.collapse-arrow.collapsed{transform:rotate(0)}.collapse-arrow:not(.collapsed){transform:rotate(90deg)}.main-layout{display:flex;gap:16px;align-items:stretch;flex:1;min-height:0}.todo-panel{flex:0 0 40%;min-width:0;overflow-y:auto}.calendar-panel{flex:0 0 60%;min-width:0;display:flex;flex-direction:column}.selected-date-bar{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;margin-bottom:8px;background:var(--color-text);color:var(--color-bg);font-size:13px;border-radius:3px}.selected-date-close{background:none;border:none;color:var(--color-bg);cursor:pointer;font-size:16px;padding:0;opacity:.7}.selected-date-close:hover{opacity:1}@media(max-width:768px){#app{padding:16px 12px}.app-header{flex-wrap:wrap;gap:8px}.todo-title{font-size:14px}.drawer{max-height:90vh}.form-row{flex-direction:column;gap:0}.form-row .form-group{flex:none}.form-input,.form-select{-moz-appearance:none;appearance:none;-webkit-appearance:none}.todo-actions{opacity:1}.main-layout{flex-direction:column}.calendar-panel{display:none}}
