.toast[data-v-c1bf705c]{position:fixed;top:24px;left:50%;transform:translate(-50%);z-index:var(--z-index-toast);display:flex;align-items:center;gap:10px;padding:14px 20px 0 18px;min-width:280px;max-width:520px;border-radius:28px;background:var(--md-inverse-surface);color:var(--md-inverse-on-surface);font-size:14px;font-weight:500;box-shadow:0 4px 16px #0000002e;overflow:hidden;animation:toast-slide-in-c1bf705c .3s cubic-bezier(.2,0,0,1) both}.toast-icon[data-v-c1bf705c]{font-size:20px;flex-shrink:0;margin-top:1px}.toast-message[data-v-c1bf705c]{flex:1;line-height:1.4;padding-right:8px}.toast-close[data-v-c1bf705c]{width:28px;height:28px;border:none;background:transparent;cursor:pointer;color:#fff9;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;transition:background .15s ease,color .15s ease}.toast-close[data-v-c1bf705c]:hover{background:#ffffff1f;color:var(--md-inverse-on-surface)}.toast-close .material-symbols-outlined[data-v-c1bf705c]{font-size:18px}.toast-progress[data-v-c1bf705c]{position:absolute;bottom:0;left:0;right:0;height:4px;background:#ffffff1a}.toast-progress-bar[data-v-c1bf705c]{height:100%;border-radius:0 0 28px 28px;animation:progress-c1bf705c 5s linear forwards}.bar-info[data-v-c1bf705c],.bar-success[data-v-c1bf705c]{background:var(--md-primary)}.bar-error[data-v-c1bf705c]{background:var(--md-error)}.toast-success[data-v-c1bf705c]{background:var(--md-toast-success-bg);color:var(--md-toast-success-text)}.toast-success .toast-icon[data-v-c1bf705c]{color:var(--md-primary)}.toast-success .toast-close[data-v-c1bf705c]{color:color-mix(in srgb,var(--md-toast-success-text) 50%,transparent)}.toast-success .toast-close[data-v-c1bf705c]:hover{background:#4c7d331f}.toast-success .toast-progress[data-v-c1bf705c]{background:#4c7d3326}.toast-error[data-v-c1bf705c]{background:var(--md-toast-error-bg);color:var(--md-toast-error-text)}.toast-error .toast-icon[data-v-c1bf705c]{color:var(--md-error)}.toast-error .toast-close[data-v-c1bf705c]{color:color-mix(in srgb,var(--md-toast-error-text) 50%,transparent)}.toast-error .toast-close[data-v-c1bf705c]:hover,.toast-error .toast-progress[data-v-c1bf705c]{background:#b3261e1a}@keyframes toast-slide-in-c1bf705c{0%{opacity:0;transform:translate(-50%) translateY(-16px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes progress-c1bf705c{0%{width:100%}to{width:0%}}.toast-fade-enter-active[data-v-c1bf705c]{animation:toast-slide-in-c1bf705c .3s cubic-bezier(.2,0,0,1) both}.toast-fade-leave-active[data-v-c1bf705c]{animation:toast-fade-out-c1bf705c .3s cubic-bezier(.2,0,0,1) both}@keyframes toast-fade-out-c1bf705c{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-16px)}}.settings-overlay[data-v-53df9a87]{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000052;z-index:var(--z-index-modal);display:flex;align-items:center;justify-content:center;animation:fadeIn-53df9a87 .2s ease}@keyframes fadeIn-53df9a87{0%{opacity:0}to{opacity:1}}.settings-card[data-v-53df9a87]{background:var(--md-surface);border-radius:28px;padding:32px;width:90%;max-width:400px;max-height:80vh;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:0 12px 48px #00000014;animation:popIn-53df9a87 .3s cubic-bezier(.2,0,0,1);pointer-events:auto}@keyframes popIn-53df9a87{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.settings-header[data-v-53df9a87]{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.settings-header h2[data-v-53df9a87]{font-size:22px;font-weight:500;color:var(--md-on-surface);margin:0;line-height:28px}.settings-close-btn[data-v-53df9a87]{width:36px;height:36px;border:none;background:transparent;border-radius:50%;cursor:pointer;color:var(--md-on-surface-variant);display:flex;align-items:center;justify-content:center;transition:background .15s ease}.settings-close-btn[data-v-53df9a87]:hover{background:#0000000f}.settings-section[data-v-53df9a87]{margin-bottom:24px}.settings-section[data-v-53df9a87]:last-child{margin-bottom:0}.settings-section-title[data-v-53df9a87]{font-size:13px;font-weight:600;color:var(--md-on-surface-variant);margin:0 0 12px;letter-spacing:.02em}.segmented-btns[data-v-53df9a87]{display:flex;gap:4px;background:var(--md-surface-container-high);border-radius:12px;padding:4px}.seg-btn[data-v-53df9a87]{flex:1;border:none;background:transparent;border-radius:8px;padding:10px 16px;cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-family);color:var(--md-on-surface-variant);transition:all .15s ease;display:flex;align-items:center;justify-content:center;min-height:40px}.seg-btn[data-v-53df9a87]:hover{color:var(--md-on-surface)}.seg-btn.active[data-v-53df9a87]{background:var(--md-surface);color:var(--md-on-surface);font-weight:600;box-shadow:0 2px 8px #0000000f}.seg-icon[data-v-53df9a87]{font-size:18px;margin-right:4px}.data-actions[data-v-53df9a87]{display:flex;gap:8px}.data-btn[data-v-53df9a87]{flex:1;border:none;background:var(--md-surface-container-low);border-radius:12px;padding:12px 16px;cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-family);color:var(--md-on-surface);display:flex;align-items:center;justify-content:center;gap:8px;transition:all .15s ease}.data-btn[data-v-53df9a87]:hover{background:var(--md-surface-container);box-shadow:0 2px 8px #0000000a}.data-btn[data-v-53df9a87]:active{transform:scale(.97)}.data-btn-icon[data-v-53df9a87]{font-size:18px;color:var(--md-primary)}.hidden-file[data-v-53df9a87]{display:none}@media(max-width:768px){.settings-card[data-v-53df9a87]{border-radius:var(--md-radius-lg-inc);padding:20px;max-height:85vh;width:92%}.settings-header h2[data-v-53df9a87]{font-size:18px}.data-actions[data-v-53df9a87]{flex-direction:column}}.account-overlay[data-v-aa8f0951]{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000052;z-index:var(--z-index-modal);display:flex;align-items:center;justify-content:center;animation:fadeIn-aa8f0951 .2s ease}@keyframes fadeIn-aa8f0951{0%{opacity:0}to{opacity:1}}.account-card[data-v-aa8f0951]{background:var(--md-surface);border-radius:28px;padding:32px;width:90%;max-width:420px;max-height:80vh;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:0 12px 48px #00000014;animation:popIn-aa8f0951 .3s cubic-bezier(.2,0,0,1);pointer-events:auto}@keyframes popIn-aa8f0951{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.account-header[data-v-aa8f0951]{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.account-header h2[data-v-aa8f0951]{font-size:22px;font-weight:500;color:var(--md-on-surface);margin:0;line-height:28px}.account-close-btn[data-v-aa8f0951]{width:36px;height:36px;border:none;background:transparent;border-radius:50%;cursor:pointer;color:var(--md-on-surface-variant);display:flex;align-items:center;justify-content:center;transition:background .15s ease}.account-close-btn[data-v-aa8f0951]:hover{background:#0000000f}.account-section[data-v-aa8f0951]{margin-bottom:24px}.account-section[data-v-aa8f0951]:last-child{margin-bottom:0}.account-section-title[data-v-aa8f0951]{font-size:13px;font-weight:600;color:var(--md-on-surface-variant);margin:0 0 12px;letter-spacing:.02em}.account-id-display[data-v-aa8f0951]{display:flex;align-items:center;gap:10px;background:var(--md-surface-container-low);border-radius:12px;padding:14px 16px}.account-id-icon[data-v-aa8f0951]{font-size:20px;color:var(--md-primary)}.account-id-value[data-v-aa8f0951]{font-size:15px;font-weight:500;color:var(--md-on-surface);font-family:"Noto Sans SC",var(--font-family)}.account-form[data-v-aa8f0951]{display:flex;flex-direction:column;gap:10px}.account-input[data-v-aa8f0951]{width:100%;padding:14px 16px;border:1.5px solid var(--md-outline-variant);border-radius:12px;font-size:15px;font-family:var(--font-family);background:var(--md-surface-container-low);color:var(--md-on-surface);outline:none;transition:border-color .15s ease,background .15s ease;box-sizing:border-box}.account-input[data-v-aa8f0951]:focus{border-color:var(--md-primary);background:#4c7d330a}.account-input[data-v-aa8f0951]::placeholder{color:var(--md-on-surface-variant);opacity:.5}.account-input[data-v-aa8f0951]:disabled{opacity:.5;cursor:not-allowed}.account-submit-btn[data-v-aa8f0951]{width:100%;height:44px;border:none;border-radius:999px;font-size:14px;font-weight:600;font-family:var(--font-family);background:var(--md-primary);color:var(--md-on-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:box-shadow .15s ease,transform .15s ease,opacity .15s ease}.account-submit-btn[data-v-aa8f0951]:hover:not(:disabled){box-shadow:var(--md-elevation-1)}.account-submit-btn[data-v-aa8f0951]:active:not(:disabled){transform:scale(.98)}.account-submit-btn[data-v-aa8f0951]:disabled{opacity:.6;cursor:not-allowed}.account-error[data-v-aa8f0951]{width:100%;text-align:center;font-size:13px;color:var(--md-error);background:#b3261e0f;padding:10px 12px;border-radius:10px}@media(max-width:768px){.account-card[data-v-aa8f0951]{border-radius:20px;padding:20px;max-height:85vh;width:92%}.account-header h2[data-v-aa8f0951]{font-size:18px}}:root{--md-primary: #4C7D33;--md-on-primary: #FFFFFF;--md-primary-container: #D7F7B7;--md-on-primary-container: #102300;--app-max-width: 1400px;--app-h-padding: 32px;--md-secondary: #5C6252;--md-on-secondary: #FFFFFF;--md-secondary-container: #DDE5D1;--md-on-secondary-container: #151E0D;--md-tertiary: #5C6252;--md-on-tertiary: #FFFFFF;--md-tertiary-container: #E0E8D7;--md-error: #B3261E;--md-on-error: #FFFFFF;--md-error-container: #F9DEDC;--md-on-error-container: #410E0B;--md-background: #F7F8FC;--md-surface: #FFFFFF;--md-on-surface: #1D1D1F;--md-on-surface-variant: #6E6E73;--md-outline: #E5E5EA;--md-outline-variant: #F0F0F4;--md-surface-container-lowest: #FFFFFF;--md-surface-container-low: #F9FAFB;--md-surface-container: #F5F5F7;--md-surface-container-high: #F0F0F2;--md-surface-container-highest: #E8E8ED;--md-priority-urgent_important: #DC3232;--md-priority-important: #D4A017;--md-priority-urgent: #2E7D32;--md-priority-none: var(--md-primary);--md-on-surface-secondary: #86868B;--md-outline-variant-darker: #AEAEB2;--md-on-surface-disabled: #D1D1D6;--md-inverse-surface: #E3E3E3;--md-inverse-on-surface: #1D1D1F;--md-app-header-bg: #EFF2E8;--md-on-surface-emphasis: #1A1C18;--md-db-status-text: #2D4A1A;--md-primary-container-hover: #C5ED9A;--md-toast-success-bg: #F4F9EC;--md-toast-success-text: #102300;--md-toast-error-bg: #FCEDEA;--md-toast-error-text: #410E0B;--font-family: "Noto Sans", "Noto Sans SC", sans-serif;--max-width: 640px;--md-radius-none: 0px;--md-radius-xs: 4px;--md-radius-sm: 6px;--md-radius-md: 8px;--md-radius-lg: 12px;--md-radius-lg-inc: 16px;--md-radius-xl: 28px;--md-radius-full: 9999px;--md-spacing-2: 2px;--md-spacing-4: 4px;--md-spacing-6: 6px;--md-spacing-8: 8px;--md-spacing-12: 12px;--md-spacing-16: 16px;--md-spacing-20: 20px;--md-spacing-24: 24px;--md-spacing-32: 32px;--md-spacing-48: 48px;--md-state-hover: rgba(76, 125, 51, .08);--md-state-pressed: rgba(76, 125, 51, .12);--md-state-focus: rgba(76, 125, 51, .16);--md-elevation-0: none;--md-elevation-1: 0 1px 3px 1px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .03);--md-elevation-2: 0 2px 8px 4px rgba(0, 0, 0, .04), 0 1px 3px rgba(0, 0, 0, .02);--md-elevation-3: 0 4px 12px 6px rgba(0, 0, 0, .05), 0 1px 4px rgba(0, 0, 0, .03);--md-easing-standard: cubic-bezier(.2, 0, 0, 1);--md-easing-emphasized: cubic-bezier(.2, 0, 0, 1);--md-duration-fast: .15s;--md-duration-normal: .25s;--md-duration-slow: .35s;--z-index-header: 1000;--z-index-drawer: 2000;--z-index-modal: 3000;--z-index-toast: 4000}[data-theme=dark]{--md-primary: #9CD67D;--md-on-primary: #1A3A0A;--md-primary-container: #345A1F;--md-on-primary-container: #D7F7B7;--md-primary-container-hover: #3E6B26;--md-secondary: #BFCAB2;--md-on-secondary: #2A3322;--md-secondary-container: #3F4A36;--md-on-secondary-container: #D7E2CC;--md-tertiary: #BFCAB2;--md-on-tertiary: #2A3322;--md-tertiary-container: #3F4A36;--md-error: #F2B8B5;--md-on-error: #601410;--md-error-container: #8C1D18;--md-on-error-container: #F9DEDC;--md-background: #121212;--md-surface: #1E1E1E;--md-on-surface: #E3E3E3;--md-on-surface-variant: #A8A8AD;--md-on-surface-secondary: #A8A8AD;--md-outline: #404045;--md-outline-variant: #2C2C30;--md-outline-variant-darker: #5C5C60;--md-on-surface-disabled: #45454A;--md-surface-container-lowest: #0E0E0E;--md-surface-container-low: #242424;--md-surface-container: #282828;--md-surface-container-high: #2C2C2C;--md-surface-container-highest: #343434;--md-inverse-surface: #1D1D1F;--md-inverse-on-surface: #E3E3E3;--md-app-header-bg: #2A2D25;--md-on-surface-emphasis: #E8EAE3;--md-db-status-text: #9CD67D;--md-toast-success-bg: #1A3A0A;--md-toast-success-text: #D7F7B7;--md-toast-error-bg: #601410;--md-toast-error-text: #F9DEDC;--md-state-hover: rgba(156, 214, 125, .08);--md-state-pressed: rgba(156, 214, 125, .12);--md-state-focus: rgba(156, 214, 125, .16);--md-elevation-1: 0 1px 3px 1px rgba(0, 0, 0, .2), 0 1px 2px rgba(0, 0, 0, .3);--md-elevation-2: 0 2px 8px 4px rgba(0, 0, 0, .2), 0 1px 3px rgba(0, 0, 0, .1);--md-elevation-3: 0 4px 12px 6px rgba(0, 0, 0, .3), 0 1px 4px rgba(0, 0, 0, .2);--md-priority-urgent_important: #F2B8B5;--md-priority-important: #F0C66D;--md-priority-urgent: #7FD69D;--md-priority-none: var(--md-primary)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;height:100dvh;margin:0;padding:0;overflow:hidden;overscroll-behavior:none;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}body{font-family:var(--font-family);color:var(--md-on-surface);background:var(--md-background);line-height:1.6;-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%}body.drawer-open{overflow:hidden;position:fixed;width:100%;height:100%;touch-action:none}body.modal-open{overflow:hidden;touch-action:none}#app{max-width:var(--app-max-width);margin:0 auto;padding:20px var(--app-h-padding);display:flex;flex-direction:column;height:100%;height:100dvh;overflow:hidden}.app-root{display:flex;flex-direction:column;flex:1;min-height:0}.app-content{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.main-layout{display:flex;gap:24px;align-items:stretch;flex:1;min-height:0;margin:4px auto 0;width:100%}.module-panel{max-width:var(--app-max-width);margin:4px auto 0;padding:24px 24px 32px;width:100%;box-sizing:border-box;background:var(--md-surface);border-radius:24px;box-shadow:0 10px 40px #0000000a;flex:1;min-height:0;overflow-y:auto}.todo-panel{max-width:var(--app-max-width);margin:0;padding:24px var(--app-h-padding) 80px;width:100%;box-sizing:border-box;background:var(--md-surface);border-radius:24px;box-shadow:0 10px 40px #0000000a;flex:1 1 auto;min-width:0;overflow-y:auto;position:relative}.calendar-panel{align-self:stretch;flex:0 0 calc(60% - 12px);min-width:0;display:flex;flex-direction:column;overflow:hidden;background:var(--md-surface);border-radius:24px;box-shadow:0 10px 40px #0000000a;padding:32px 32px 16px;gap:0}.calendar-panel>.calendar{flex:1 1 auto;min-height:200px;overflow-y:auto;will-change:height}.gantt-container{min-height:180px;max-height:700px;overflow:hidden;margin-top:0;padding-top:0;display:flex;flex-direction:column;position:relative;will-change:height;contain:size layout}.gantt-container.is-resizing{transition:none!important}.gantt-slide-enter-active,.gantt-slide-leave-active{transition:all .4s cubic-bezier(.4,0,.2,1)}.gantt-resize-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;cursor:row-resize;background:transparent;pointer-events:auto}.gantt-slide-enter-from,.gantt-slide-leave-to{opacity:0;transform:translateY(-10px)}.module-panel .gantt-chart{height:100%!important;border-radius:20px;background:var(--md-surface);box-shadow:0 10px 40px #0000000a;overflow:hidden}.module-panel .gantt-chart .gantt-resize-handle{display:none}.module-panel .gantt-body{height:auto!important;flex:1;overflow:auto}.todo-list{padding-bottom:0!important}.app-header{margin-bottom:24px;border-radius:16px;background:var(--md-app-header-bg);border-bottom:1px solid rgba(0,0,0,.04);box-shadow:none;transition:none}.header-scrolled{box-shadow:none}.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:var(--app-max-width);margin:0 auto;padding:8px var(--app-h-padding);min-height:52px;gap:12px;width:100%;box-sizing:border-box}.header-left{display:flex;align-items:center;gap:var(--md-spacing-12);min-width:0;flex-shrink:0}.header-brand-icon{font-size:24px;color:var(--md-primary);flex-shrink:0;transition:transform var(--md-duration-normal) var(--md-easing-standard)}.header-inner:hover .header-brand-icon{transform:scale(1.05)}.app-title{font-size:20px;font-weight:700;letter-spacing:-.02em;color:var(--md-on-surface-emphasis);line-height:1.4;white-space:nowrap}.db-status{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;background:var(--md-primary-container);border-radius:999px;font-size:11px;font-weight:600;color:var(--md-db-status-text);letter-spacing:.02em}@media(min-width:769px){.header-clock{display:block}}.db-dot{width:6px;height:6px;border-radius:50%;background:var(--md-primary);animation:dbPulse 2s ease-in-out infinite}@keyframes dbPulse{0%,to{opacity:1;box-shadow:0 0 #4c7d3366}50%{opacity:.7;box-shadow:0 0 0 3px #4c7d3300}}.header-clock{font-family:JetBrains Mono,Roboto Mono,ui-monospace,monospace;font-size:13px;color:var(--md-on-surface-variant);background:#00000008;padding:4px 10px;border-radius:4px;white-space:nowrap;-webkit-user-select:none;user-select:none;letter-spacing:.02em;font-variant-numeric:tabular-nums;display:none}.header-right{display:flex;gap:2px;align-items:center;flex-shrink:0;background:transparent;border-radius:999px;padding:0}.header-icon-btn{width:40px;height:40px;border:none;border-radius:var(--md-radius-full);background:transparent;cursor:pointer;color:var(--md-on-surface-variant);display:flex;align-items:center;justify-content:center;transition:background var(--md-duration-fast) var(--md-easing-standard)}.header-icon-btn:hover{background:#4c7d3326}.header-icon-btn:active{background:#4c7d3340}.header-avatar{width:32px;height:32px;border-radius:50%;background:var(--md-primary-container);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--md-on-primary-container);letter-spacing:.02em;cursor:pointer;transition:transform var(--md-duration-fast) var(--md-easing-standard),box-shadow var(--md-duration-fast) var(--md-easing-standard);flex-shrink:0}.header-avatar:hover{transform:scale(1.1);box-shadow:var(--md-elevation-1)}.user-menu{position:relative;margin-left:6px}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:240px;background:var(--md-surface);border-radius:16px;box-shadow:0 8px 32px #0000001f;padding:8px 0;z-index:var(--z-index-header);animation:dropIn .2s cubic-bezier(.2,0,0,1)}@keyframes dropIn{0%{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.menu-fade-enter-active,.menu-fade-leave-active{transition:all .15s cubic-bezier(.2,0,0,1)}.menu-fade-enter-from,.menu-fade-leave-to{opacity:0;transform:translateY(-6px) scale(.97)}.dropdown-header{display:flex;align-items:center;gap:10px;padding:12px 16px}.dropdown-avatar{width:40px;height:40px;border-radius:50%;background:var(--md-primary-container);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--md-on-primary-container);flex-shrink:0}.dropdown-info{min-width:0}.dropdown-name{font-size:14px;font-weight:600;color:var(--md-on-surface);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-id{font-size:12px;color:var(--md-on-surface-variant);margin-top:2px}.dropdown-divider{height:1px;background:#0000000f;margin:4px 0}.dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;border:none;background:transparent;cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font-family);color:var(--md-on-surface);transition:background .15s ease}.dropdown-item:hover{background:#0000000a}.dropdown-item:active{background:#00000012}.dropdown-item-icon{font-size:20px;color:var(--md-on-surface-variant)}.dropdown-item-logout,.dropdown-item-logout .dropdown-item-icon{color:var(--md-error)}.module-segmented{position:relative;display:flex;background:#0000000a;border-radius:999px;padding:3px;flex-shrink:0}.module-btn{position:relative;z-index:2;display:flex;align-items:center;gap:4px;padding:6px 14px;border:none;background:transparent;border-radius:999px;cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-family);color:var(--md-on-surface-variant);transition:color .3s cubic-bezier(.2,0,0,1);white-space:nowrap}.module-btn .module-icon{font-size:18px;transition:color .3s cubic-bezier(.2,0,0,1)}.module-btn-active{color:var(--md-on-surface-emphasis)!important;font-weight:600}.module-segmented:after{content:"";position:absolute;top:3px;height:calc(100% - 6px);background:var(--md-surface);border-radius:999px;box-shadow:0 2px 6px #00000014;transition:left .3s cubic-bezier(.2,0,0,1),width .3s cubic-bezier(.2,0,0,1);z-index:1}.module-segmented[data-active="0"]:after{left:3px;width:80px}.module-segmented[data-active="1"]:after{left:83px;width:60px}.module-segmented[data-active="2"]:after{left:143px;width:60px}.header-search{display:flex;align-items:center;height:36px;padding:0 4px;background:#ffffffa6;border-radius:12px;flex-shrink:0;transition:background .15s ease}.header-search:focus-within{background:var(--md-surface)}.header-search-input{border:none;background:transparent;outline:none;font-size:13px;font-family:var(--font-family);color:var(--md-on-surface);padding:0 8px;width:160px;height:100%}.header-search-input::placeholder{color:var(--md-on-surface-variant);opacity:.5}.header-search-btn{width:30px;height:30px;border:none;border-radius:8px;background:transparent;cursor:pointer;color:var(--md-on-surface-variant);display:flex;align-items:center;justify-content:center;transition:background .15s ease}.header-search-btn .material-symbols-outlined{font-size:18px}.header-search-btn:hover{background:#0000000d}.material-symbols-outlined{font-family:Material Symbols Outlined;font-size:22px;font-weight:400;line-height:1;font-style:normal;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-smoothing:antialiased}.search-wrap{display:flex;margin-bottom:var(--md-spacing-8);background:var(--md-surface-container-high);border-radius:var(--md-radius-md);overflow:hidden}.search-input{flex:1;padding:0 var(--md-spacing-16);border:none;border-radius:var(--md-radius-md) 0 0 var(--md-radius-md);font-size:15px;font-family:var(--font-family);outline:none;background:transparent;color:var(--md-on-surface);height:40px;transition:background var(--md-duration-fast) var(--md-easing-standard)}.search-input:focus{background:#4c7d330f}.search-input::placeholder{color:var(--md-on-surface-variant);opacity:.6}.search-btn{padding:0 var(--md-spacing-16);border:none;background:transparent;cursor:pointer;font-size:14px;font-family:var(--font-family);color:var(--md-on-surface-variant);height:40px;border-radius:0 var(--md-radius-md) var(--md-radius-md) 0;transition:background var(--md-duration-fast) var(--md-easing-standard),color var(--md-duration-fast) var(--md-easing-standard)}.search-btn:hover{background:#1c1b1f0f;color:var(--md-on-surface)}.search-btn:active{background:#1c1b1f1a}.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}.filter-btn{padding:0 16px;border:none;border-radius:999px;background:var(--md-surface-container-high);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-family);color:var(--md-on-surface-secondary);display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease;white-space:nowrap;height:40px;line-height:1}.filter-btn:hover{background:var(--md-outline-variant)}.filter-btn:active{background:var(--md-surface-container-highest)}.filter-btn.active{background:var(--md-primary-container);color:var(--md-on-primary-container);font-weight:600}.filter-btn.active:hover{background:var(--md-primary-container-hover)}.section-divider{font-size:12px;font-weight:600;color:var(--md-on-surface-variant);padding:6px 0 2px;letter-spacing:.8px;line-height:20px;cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:var(--md-spacing-6);text-transform:uppercase;opacity:.7}.section-divider:hover{color:var(--md-on-surface);opacity:1}.collapse-arrow{display:inline-block;font-size:8px;transition:transform var(--md-duration-normal) var(--md-easing-standard);vertical-align:middle;color:var(--md-on-surface-variant);opacity:.5}.collapse-arrow.collapsed{transform:rotate(0)}.collapse-arrow:not(.collapsed){transform:rotate(90deg)}.todo-list{list-style:none;padding:0;margin:0}.todo-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;margin-bottom:8px;border-radius:var(--md-radius-sm);cursor:pointer;background:transparent;border-left:2px solid transparent;transition:background var(--md-duration-fast) var(--md-easing-standard),opacity var(--md-duration-normal) var(--md-easing-standard);min-height:44px}.todo-item:hover{background:var(--md-surface-container-low)}.todo-item:active{background:var(--md-surface-container)}.todo-item.is-completed{opacity:.5}.todo-item.is-completed .todo-title{text-decoration:line-through;color:var(--md-on-surface-variant)}.todo-content{display:flex;align-items:center;gap:var(--md-spacing-12);flex:1;min-width:0}.todo-left{display:flex;align-items:center;gap:var(--md-spacing-8);flex:1;min-width:0}.todo-item[data-urgency=urgent_important]{border-left-color:var(--md-priority-urgent_important)}.todo-item[data-urgency=important]{border-left-color:var(--md-priority-important)}.todo-item[data-urgency=urgent]{border-left-color:var(--md-priority-urgent)}.todo-item[data-urgency=none]{border-left-color:var(--md-primary)}.priority-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.dot-urgent_important{background:var(--md-priority-urgent_important)}.dot-important{background:var(--md-priority-important)}.dot-urgent{background:var(--md-priority-urgent)}.dot-none{background:var(--md-primary)}.todo-title{flex:1;font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;line-height:20px;color:var(--md-on-surface);transition:color var(--md-duration-fast) var(--md-easing-standard)}.todo-meta{display:flex;align-items:center;gap:var(--md-spacing-6);flex-shrink:0;font-size:12px;color:var(--md-on-surface-secondary);line-height:16px}.due-date{font-size:12px;color:var(--md-on-surface-secondary);white-space:nowrap}.contact-icon{display:inline-flex;align-items:center;color:var(--md-primary);flex-shrink:0}.contact-icon .material-symbols-outlined{font-size:16px}.pinned-icon{display:inline-flex;align-items:center;flex-shrink:0}.pinned-icon .material-symbols-outlined{font-size:16px;color:var(--md-primary);transform:rotate(45deg)}.todo-actions{display:flex;gap:var(--md-spacing-2);flex-shrink:0;opacity:0;transition:opacity var(--md-duration-fast) var(--md-easing-standard)}.todo-item:hover .todo-actions{opacity:1}.action-btn{width:28px;height:28px;border:none;border-radius:var(--md-radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--md-on-surface-variant);transition:background var(--md-duration-fast) var(--md-easing-standard),color var(--md-duration-fast) var(--md-easing-standard)}.action-btn .material-symbols-outlined{font-size:18px;line-height:1}.action-btn:hover{background:var(--md-state-hover);color:var(--md-on-surface)}.action-complete:hover{color:var(--md-priority-urgent)}.action-delete:hover{color:var(--md-error)}.action-undo:hover{color:var(--md-priority-urgent)}.empty-hint{text-align:center;color:var(--md-on-surface-secondary);padding:var(--md-spacing-48) 0;font-size:13px;line-height:20px}.add-btn-flow{display:flex;align-items:center;justify-content:center;width:100%;padding:0 24px;margin-top:var(--md-spacing-24);border:none;border-radius:28px;background:#4c7d3314;cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font-family);color:var(--md-primary);letter-spacing:.1px;height:56px;gap:8px;transition:all .2s cubic-bezier(.2,0,0,1)}.add-btn-flow:hover{background:#4c7d3324}.add-btn-flow:active{transform:scale(.98)}.add-btn-flow .fab-icon{font-size:24px}.filter-action-bar{display:flex;align-items:center;gap:10px;margin-bottom:16px}.add-todo-btn{width:40px;height:40px;min-width:40px;padding:0;border:none;border-radius:50%;background:var(--md-primary);color:var(--md-on-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:box-shadow .15s ease,transform .15s ease;flex-shrink:0;margin-left:auto;margin-top:-5px}.add-todo-btn:hover{box-shadow:var(--md-elevation-1)}.add-todo-btn:active{transform:scale(.92)}.add-todo-btn .material-symbols-outlined{font-size:24px}.form-group{margin-bottom:var(--md-spacing-16)}.form-label{display:block;font-size:12px;font-weight:500;color:var(--md-on-surface-variant);margin-bottom:var(--md-spacing-8);letter-spacing:.4px}.form-input,.form-textarea,.form-select{width:100%;padding:var(--md-spacing-12) var(--md-spacing-16);border:1px solid transparent;border-radius:var(--md-radius-sm);font-size:16px;font-family:var(--font-family);outline:none;background:var(--md-surface-container);color:var(--md-on-surface);transition:background var(--md-duration-fast) var(--md-easing-standard),border-color var(--md-duration-fast) var(--md-easing-standard);min-height:48px}.form-input:focus,.form-textarea:focus,.form-select:focus{background:#4c7d330f;border-color:#4c7d334d}.form-input::placeholder{color:var(--md-on-surface-variant);opacity:.5}.form-textarea{resize:vertical;min-height:80px;line-height:1.5}.form-select{cursor:pointer}.form-row{display:flex;gap:var(--md-spacing-12)}.form-row .form-group{flex:1}.form-check{display:flex;align-items:center;gap:var(--md-spacing-8);font-size:14px;color:var(--md-on-surface);cursor:pointer;min-height:48px}.form-check input[type=checkbox]{width:18px;height:18px;accent-color:var(--md-primary);cursor:pointer}.form-actions{display:flex;gap:var(--md-spacing-8);margin-top:var(--md-spacing-24)}.btn-primary{flex:1;padding:0 var(--md-spacing-24);background:var(--md-primary);color:var(--md-on-primary);border:none;border-radius:var(--md-radius-full);cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font-family);letter-spacing:.1px;height:40px;transition:box-shadow var(--md-duration-fast) var(--md-easing-standard),transform var(--md-duration-fast) var(--md-easing-standard)}.btn-primary:hover{box-shadow:var(--md-elevation-1)}.btn-primary:active{transform:scale(.98)}.btn-secondary{padding:0 var(--md-spacing-24);background:var(--md-secondary-container);color:var(--md-on-secondary-container);border:none;border-radius:var(--md-radius-full);cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font-family);letter-spacing:.1px;height:40px;transition:box-shadow var(--md-duration-fast) var(--md-easing-standard),transform var(--md-duration-fast) var(--md-easing-standard)}.btn-secondary:hover{box-shadow:var(--md-elevation-1)}.btn-secondary:active{transform:scale(.98)}.btn-danger{padding:0 var(--md-spacing-24);background:var(--md-error);color:var(--md-on-error);border:none;border-radius:var(--md-radius-full);cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font-family);letter-spacing:.1px;height:40px;transition:box-shadow var(--md-duration-fast) var(--md-easing-standard)}.btn-danger:hover{box-shadow:var(--md-elevation-1)}.btn-pin{padding:0 var(--md-spacing-24);background:transparent;color:var(--md-primary);border:1px solid var(--md-outline);border-radius:var(--md-radius-full);cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font-family);letter-spacing:.1px;height:40px;transition:background var(--md-duration-fast) var(--md-easing-standard)}.btn-pin:hover{background:var(--md-state-hover)}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000052;z-index:var(--z-index-modal);display:flex;align-items:center;justify-content:center;animation:fadeIn var(--md-duration-fast) var(--md-easing-standard)}.dialog{background:var(--md-surface);border:none;border-radius:var(--md-radius-xl);padding:var(--md-spacing-24);max-width:360px;width:90%;max-height:80vh;overflow-y:auto;-webkit-overflow-scrolling:touch;animation:popIn var(--md-duration-normal) var(--md-easing-emphasized);box-shadow:var(--md-elevation-3)}@keyframes popIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.dialog p{margin-bottom:var(--md-spacing-24);font-size:15px;line-height:20px;color:var(--md-on-surface)}.dialog-actions{display:flex;gap:var(--md-spacing-8)}.dialog-actions button{flex:1}.detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000052;z-index:var(--z-index-modal);display:flex;align-items:center;justify-content:center;animation:fadeIn var(--md-duration-fast) var(--md-easing-standard)}.detail-card{background:var(--md-surface);border:none;border-radius:var(--md-radius-xl);padding:var(--md-spacing-24);max-width:420px;width:90%;max-height:80vh;overflow-y:auto;-webkit-overflow-scrolling:touch;animation:popIn var(--md-duration-normal) var(--md-easing-emphasized);box-shadow:var(--md-elevation-3)}.detail-card h3{font-size:20px;font-weight:600;margin-bottom:var(--md-spacing-16);color:var(--md-on-surface);line-height:28px}.detail-row{display:flex;justify-content:space-between;padding:var(--md-spacing-12) 0;font-size:13px;line-height:20px;border-bottom:1px solid var(--md-outline-variant);color:var(--md-on-surface-variant)}.detail-row:last-of-type{border-bottom:none}.detail-row .label{color:var(--md-on-surface-secondary);font-weight:500}.detail-actions{display:flex;gap:var(--md-spacing-8);margin-top:var(--md-spacing-16);flex-wrap:wrap}.detail-subtask-section{margin-top:12px;padding-top:12px;border-top:1px solid rgba(0,0,0,.06)}.detail-subtask-header{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--md-on-surface-variant);margin-bottom:8px}.detail-subtask-icon{font-size:16px;color:var(--md-primary)}.detail-subtask-progress{display:flex;align-items:center;gap:10px;margin-bottom:10px}.progress-bar-bg{flex:1;height:3px;background:#4c7d331f;border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--md-primary);border-radius:2px;transition:width .3s ease}.progress-text{font-size:12px;font-weight:600;color:var(--md-on-surface-secondary);white-space:nowrap;min-width:36px;text-align:right}.detail-subtask-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}.detail-subtask-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;cursor:pointer;transition:background .1s ease}.detail-subtask-item:hover{background:#00000008}.detail-subtask-item.subtask-done .subtask-text{text-decoration:line-through;color:var(--md-on-surface-variant)}.subtask-radio{font-size:20px;color:var(--md-outline-variant-darker);flex-shrink:0;transition:color .15s ease}.detail-subtask-item.subtask-done .subtask-radio{color:var(--md-primary)}.subtask-text{font-size:13px;color:var(--md-on-surface);line-height:1.4}.selected-date-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--md-spacing-6) var(--md-spacing-12);margin-bottom:var(--md-spacing-8);background:var(--md-primary-container);color:var(--md-on-primary-container);font-size:12px;border-radius:var(--md-radius-sm);font-weight:500}.selected-date-close{background:none;border:none;color:var(--md-on-surface-variant);cursor:pointer;font-size:18px;padding:var(--md-spacing-4);border-radius:var(--md-radius-full);opacity:.6}.selected-date-close:hover{opacity:1;background:var(--md-state-hover)}*{scrollbar-width:thin;scrollbar-color:rgba(76,125,51,.2) transparent}.todo-panel::-webkit-scrollbar,.calendar-panel>.calendar::-webkit-scrollbar,.gantt-body::-webkit-scrollbar,.gantt-scroll-area::-webkit-scrollbar,.gantt-row-canvas::-webkit-scrollbar{width:6px;height:6px}.todo-panel::-webkit-scrollbar-track,.calendar-panel>.calendar::-webkit-scrollbar-track,.gantt-body::-webkit-scrollbar-track,.gantt-scroll-area::-webkit-scrollbar-track,.gantt-row-canvas::-webkit-scrollbar-track{background:transparent}.todo-panel::-webkit-scrollbar-thumb,.calendar-panel>.calendar::-webkit-scrollbar-thumb,.gantt-body::-webkit-scrollbar-thumb,.gantt-scroll-area::-webkit-scrollbar-thumb,.gantt-row-canvas::-webkit-scrollbar-thumb{background:#4c7d3300;border-radius:10px;transition:background .2s ease}.todo-panel::-webkit-scrollbar-thumb:hover,.calendar-panel>.calendar::-webkit-scrollbar-thumb:hover,.gantt-body::-webkit-scrollbar-thumb:hover,.gantt-scroll-area::-webkit-scrollbar-thumb:hover,.gantt-row-canvas::-webkit-scrollbar-thumb:hover{background:#4c7d338c!important}.todo-panel:hover::-webkit-scrollbar-thumb{background:#4c7d3340}.calendar-panel>.calendar:hover::-webkit-scrollbar-thumb{background:#4c7d3340}.gantt-body:hover::-webkit-scrollbar-thumb{background:#4c7d3340}.gantt-scroll-area:hover::-webkit-scrollbar-thumb{background:#4c7d3340}.gantt-row-canvas:hover::-webkit-scrollbar-thumb{background:#4c7d3340}.todo-panel,.calendar-panel>.calendar,.gantt-body,.gantt-scroll-area,.gantt-row-canvas{scroll-behavior:smooth}@media(max-width:768px){html,body{width:100vw;overflow-x:hidden}#app{padding:0!important;width:100vw;max-width:none;margin:0;align-items:stretch!important}.app-root{min-height:0;flex:1;width:100%;align-items:stretch!important}.main-layout{gap:0;flex-direction:column;width:100%;margin:0;align-items:stretch!important}body{background:var(--md-background)}.module-panel{margin:0;padding:16px;width:100%;border-radius:0;min-height:auto;box-shadow:none}.app-header{margin-bottom:0;border-radius:0}.header-inner{padding:4px 12px;min-height:52px}.header-brand-icon{font-size:18px}.app-title{font-size:13px}.db-status{display:none}.header-clock{display:none!important}.header-right{padding:2px 6px 2px 2px}.header-icon-btn{width:34px;height:34px}.header-icon-btn .material-symbols-outlined{font-size:18px}.header-avatar{width:28px;height:28px;font-size:10px}.module-segmented,.header-search{display:none}.todo-panel{flex:1;min-height:0;width:100%;max-width:none;box-sizing:border-box;padding:10px 12px!important;padding-bottom:calc(48px + env(safe-area-inset-bottom))!important;border-radius:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.filter-action-bar{flex-wrap:wrap}.calendar-panel{display:none}.search-wrap{margin-bottom:2px;border-radius:var(--md-radius-sm)}.search-input{height:34px;padding:0 var(--md-spacing-12);font-size:14px}.search-btn{height:34px;padding:0 var(--md-spacing-12);font-size:12px}.filter-bar{margin-bottom:2px;gap:4px}.filter-btn{padding:4px 8px;font-size:12px;height:28px;line-height:1}.section-divider{margin-top:4px;padding:0 0 4px;font-size:11px}.todo-list{padding-bottom:0;list-style:none;margin:0}.todo-title{font-size:14px}.todo-card{padding:10px 12px;margin-bottom:6px;gap:8px}.icon-block{width:34px;height:34px;border-radius:8px}.icon-symbol{font-size:17px}.card-content{gap:2px;padding-top:0}.meta-chip{font-size:11px}.drawer{max-height:90vh;border-radius:var(--md-radius-lg-inc) var(--md-radius-lg-inc) 0 0;padding:var(--md-spacing-20)}.drawer-title{font-size:20px}.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}.detail-card{width:95%;padding:var(--md-spacing-20)}.detail-actions{flex-direction:column}.detail-actions button{height:44px}}
