.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-sm);height:28px}.btn--md{padding:var(--space-2) var(--space-4);font-size:var(--font-size-base);height:32px}.btn--lg{padding:var(--space-3) var(--space-5);font-size:var(--font-size-md);height:40px}.btn--primary{background-color:var(--color-primary);color:#fff}.btn--primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn--secondary{background-color:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn--secondary:hover:not(:disabled){background-color:var(--color-bg-tertiary)}.btn--ghost{background-color:transparent;color:var(--color-text-primary)}.btn--ghost:hover:not(:disabled){background-color:var(--color-hover-bg)}.btn--danger{background-color:var(--color-error);color:#fff}.btn--danger:hover:not(:disabled){background-color:#b03a32}.btn--full-width{width:100%}.btn__icon{display:inline-flex;align-items:center}.btn__icon svg{width:16px;height:16px}.btn__loader{width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.input-wrapper{display:flex;flex-direction:column;gap:var(--space-2)}.input-wrapper--full-width{width:100%}.input__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.input-container{position:relative;display:flex;align-items:center}.input{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.input:hover{border-color:var(--color-text-tertiary)}.input:focus{border-color:var(--color-primary);outline:none}.input::placeholder{color:var(--color-text-tertiary)}.input--with-icon-left{padding-left:var(--space-8)}.input--with-icon-right{padding-right:var(--space-8)}.input__icon{position:absolute;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary)}.input__icon--left{left:var(--space-3)}.input__icon--right{right:var(--space-3)}.input__icon svg{width:16px;height:16px}.input-container--error .input{border-color:var(--color-error)}.input__error{font-size:var(--font-size-sm);color:var(--color-error)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg)}.auth-container{display:flex;width:100%;max-width:1200px;min-height:600px;margin:var(--space-4);background:var(--color-bg);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}.auth-content{flex:1;padding:var(--space-10);display:flex;flex-direction:column;max-width:480px}.auth-header{margin-bottom:var(--space-6)}.auth-logo{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-6)}.auth-logo-text{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary)}.auth-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.auth-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-base)}.auth-providers{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.auth-provider-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast)}.auth-provider-btn:hover{background:var(--color-bg-secondary);border-color:var(--color-text-tertiary)}.auth-divider{display:flex;align-items:center;gap:var(--space-4);margin:var(--space-4) 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.auth-divider span{color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-error{padding:var(--space-3);background:#d1453b1a;border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-sm)}.password-field{position:relative}.password-toggle{position:absolute;right:var(--space-3);top:50%;transform:translateY(25%);background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;padding:var(--space-1);display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:var(--color-text-secondary)}.password-strength{display:flex;align-items:center;gap:var(--space-3)}.password-strength-bar{display:flex;gap:4px;flex:1}.password-strength-segment{flex:1;height:4px;background:var(--color-border);border-radius:2px;transition:background-color var(--transition-fast)}.password-strength-segment.active{background:var(--color-text-tertiary)}.password-strength-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.forgot-password{color:var(--color-primary);font-size:var(--font-size-sm);text-align:center}.forgot-password:hover{text-decoration:underline}.auth-terms{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-align:center;line-height:var(--line-height-relaxed)}.auth-terms a{color:var(--color-primary)}.auth-terms a:hover{text-decoration:underline}.auth-footer{margin-top:auto;padding-top:var(--space-6);text-align:center;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.auth-footer a{color:var(--color-primary);font-weight:var(--font-weight-medium)}.auth-footer a:hover{text-decoration:underline}.auth-illustration{flex:1;background:linear-gradient(135deg,#fef5f8,#fff0f5);display:none;align-items:center;justify-content:center;padding:var(--space-8)}@media(min-width:900px){.auth-illustration{display:flex}}.illustration-content{position:relative;width:100%;max-width:400px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xl)}.illustration-image{width:100%;height:300px;object-fit:cover}.illustration-overlay{padding:var(--space-6);background:#fff}.illustration-overlay h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.illustration-overlay p{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.sidebar{width:var(--sidebar-width);height:100%;background-color:var(--color-sidebar-bg);border-right:1px solid var(--color-border-light);display:flex;flex-direction:column;overflow:hidden;transition:transform var(--transition-base),width var(--transition-base);z-index:100}@media(max-width:768px){.sidebar{position:fixed;left:0;top:0;bottom:0;transform:translate(-100%);width:85%;max-width:320px;box-shadow:var(--shadow-xl)}.sidebar--mobile-open{transform:translate(0)}}.sidebar--collapsed{width:60px}.sidebar__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-3) var(--space-2)}.user-menu{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast);flex:1;min-width:0}.user-menu:hover{background-color:var(--color-hover-bg)}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);flex-shrink:0;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);flex:1;min-width:0}.user-chevron{color:var(--color-text-tertiary);flex-shrink:0}.sidebar__actions{display:flex;gap:var(--space-1)}.sidebar__icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast)}.sidebar__icon-btn:hover{background-color:var(--color-hover-bg);color:var(--color-text-primary)}.sidebar__add-task{display:flex;align-items:center;gap:var(--space-2);padding:0 var(--space-3) var(--space-2)}.add-task-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);color:var(--color-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);transition:background-color var(--transition-fast);flex:1}.add-task-btn:hover{background-color:var(--color-primary-light)}.sidebar__nav{display:flex;flex-direction:column;padding:0 var(--space-2)}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-base);text-align:left;transition:background-color var(--transition-fast);width:100%}.nav-item:hover{background-color:var(--color-hover-bg)}.nav-item--active{background-color:var(--color-primary-light)}.nav-item__icon{display:flex;align-items:center;color:var(--color-text-secondary);flex-shrink:0}.nav-item--active .nav-item__icon{color:var(--color-primary)}.nav-item__label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-item__count{font-size:var(--font-size-sm);color:var(--color-primary);font-weight:var(--font-weight-medium)}.sidebar__projects{flex:1;overflow-y:auto;padding:var(--space-4) 0}.projects-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;width:100%;text-align:left}.projects-header:hover{color:var(--color-text-primary)}.projects-list{padding:0 var(--space-2)}.projects-loading,.projects-empty{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.add-project-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);color:var(--color-text-secondary);font-size:var(--font-size-sm);border-radius:var(--radius-md);width:100%;text-align:left}.add-project-btn:hover{background-color:var(--color-hover-bg);color:var(--color-text-primary)}.sidebar__footer{border-top:1px solid var(--color-border-light);padding:var(--space-2)}.sidebar__footer-btn{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);color:var(--color-text-secondary);font-size:var(--font-size-sm);border-radius:var(--radius-md);width:100%;text-align:left}.sidebar__footer-btn:hover{background-color:var(--color-hover-bg);color:var(--color-text-primary)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fadeIn var(--transition-fast)}.modal{background:var(--color-bg);border-radius:var(--radius-lg);width:90%;max-width:400px;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-xl);animation:slideIn var(--transition-base)}.modal--wide{max-width:500px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-light)}.modal__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.modal__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast)}.modal__close:hover{background:var(--color-hover-bg);color:var(--color-text-primary)}.modal__content{padding:var(--space-5);overflow-y:auto;max-height:calc(90vh - 120px)}.modal__footer{display:flex;justify-content:flex-end;gap:var(--space-2);margin-top:var(--space-5);padding-top:var(--space-4);border-top:1px solid var(--color-border-light)}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.color-picker{display:flex;flex-wrap:wrap;gap:var(--space-2)}.color-option{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.color-option:hover{transform:scale(1.1)}.color-option--active{border-color:var(--color-text-primary);box-shadow:0 0 0 2px var(--color-bg)}.checkbox-container{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-primary)}.checkbox-container input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary)}.settings-user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.settings-user__avatar{width:48px;height:48px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);overflow:hidden}.settings-user__avatar img{width:100%;height:100%;object-fit:cover}.settings-user__info{display:flex;flex-direction:column}.settings-user__name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.settings-user__email{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.settings-section{margin-bottom:var(--space-4)}.settings-section__title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-2)}.settings-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3);border-radius:var(--radius-md);text-align:left;transition:background-color var(--transition-fast)}.settings-item:hover{background:var(--color-hover-bg)}.settings-item--danger{color:var(--color-error)}.settings-item--danger:hover{background:#d1453b1a}.settings-item__icon{display:flex;color:var(--color-text-secondary)}.settings-item--danger .settings-item__icon{color:var(--color-error)}.settings-item__content{display:flex;flex-direction:column}.settings-item__label{font-size:var(--font-size-base);color:var(--color-text-primary)}.settings-item--danger .settings-item__label{color:var(--color-error)}.settings-item__description{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.modal--task{max-width:520px}.modal__header-actions{display:flex;align-items:center;gap:var(--space-2)}.modal__action-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast)}.modal__action-btn:hover{background:#dc35451a;color:var(--color-error)}.task-modal__input{width:100%;font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);color:var(--color-text-primary);background:transparent;border:none;outline:none;padding:var(--space-2) 0;margin-bottom:var(--space-2)}.task-modal__input::placeholder{color:var(--color-text-tertiary)}.task-modal__description{width:100%;font-size:var(--font-size-base);color:var(--color-text-secondary);background:transparent;border:none;outline:none;resize:none;line-height:1.5;margin-bottom:var(--space-4)}.task-modal__description::placeholder{color:var(--color-text-tertiary)}.task-modal__options{display:flex;flex-wrap:wrap;gap:var(--space-2)}.task-modal__option{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.task-modal__option:hover{background:var(--color-hover-bg);border-color:var(--color-text-tertiary)}.task-modal__option--active{color:var(--color-primary);border-color:var(--color-primary);background:var(--color-primary-light)}.dropdown-item--input input{width:100%;padding:var(--space-2);font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.dropdown-divider{height:1px;background:var(--color-border-light);margin:var(--space-1) 0}.theme-selector{display:flex;gap:var(--space-2);padding:var(--space-2) var(--space-4);margin-bottom:var(--space-2)}.theme-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-3);border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.theme-option:hover{border-color:var(--color-primary);color:var(--color-primary)}.theme-option--active{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}.theme-option span{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.toggle{position:relative;display:inline-block;width:44px;height:24px}.toggle input{opacity:0;width:0;height:0}.toggle__slider{position:absolute;cursor:pointer;inset:0;background:var(--color-border);border-radius:24px;transition:var(--transition-fast)}.toggle__slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:var(--transition-fast)}.toggle input:checked+.toggle__slider{background:var(--color-primary)}.toggle input:checked+.toggle__slider:before{transform:translate(20px)}.settings-item__right{margin-left:auto;flex-shrink:0}.settings-section__subtitle{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-bottom:var(--space-3)}.shortcuts-list{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-3)}.shortcut-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3);background:var(--color-bg-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:2px solid transparent}.shortcut-item:hover{background:var(--color-hover-bg)}.shortcut-item--editing{border-color:var(--color-primary);background:var(--color-primary-light)}.shortcut-item__info{display:flex;flex-direction:column;gap:var(--space-1)}.shortcut-item__label{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.shortcut-item__description{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.shortcut-item__key{display:inline-flex;align-items:center;justify-content:center;min-width:40px;padding:var(--space-1) var(--space-2);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-mono, monospace);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);box-shadow:0 1px 2px #0000001a}.shortcut-item--editing .shortcut-item__key{background:var(--color-primary);border-color:var(--color-primary);color:#fff;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.shortcuts-reset-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.shortcuts-reset-btn:hover{background:var(--color-hover-bg);color:var(--color-text-primary)}.task-panel-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fadeIn var(--transition-fast)}.task-panel{background:var(--color-bg);border-radius:var(--radius-lg);width:90%;max-width:800px;max-height:85vh;max-height:85dvh;overflow:hidden;box-shadow:var(--shadow-xl);animation:slideIn var(--transition-base);display:flex;flex-direction:column;transform:translateZ(0)}.task-panel__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-light)}.task-panel__breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.task-panel__actions{display:flex;align-items:center;gap:var(--space-1)}.task-panel__action{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast)}.task-panel__action:hover{background:var(--color-hover-bg);color:var(--color-text-primary)}.task-panel__body{display:flex;flex:1;overflow:hidden}.task-panel__main{flex:1;padding:var(--space-6);overflow-y:auto;border-right:1px solid var(--color-border-light)}.task-panel__sidebar{width:240px;padding:var(--space-4);background:var(--color-bg-secondary);overflow-y:auto}.task-panel__task{display:flex;gap:var(--space-4)}.task-panel__checkbox{width:22px;height:22px;min-width:22px;min-height:22px;border:2px solid var(--color-border);border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);background:transparent;cursor:pointer;appearance:none;-webkit-appearance:none;padding:0;margin:6px 0 0}.task-panel__checkbox:hover{background:#8080801a}.task-panel__checkbox--completed{background:var(--color-text-tertiary);border-color:var(--color-text-tertiary);color:#fff}.task-panel__content{flex:1;min-width:0}.task-panel__title{width:100%;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);background:transparent;border:none;outline:none;padding:var(--space-2) 0;margin-bottom:var(--space-2)}.task-panel__title:focus{outline:none;border:none;box-shadow:none}.task-panel__title::placeholder{color:var(--color-text-tertiary)}.task-panel__title--completed{text-decoration:line-through;color:var(--color-text-tertiary)}.task-panel__description-row{display:flex;gap:var(--space-3);align-items:flex-start;margin-top:var(--space-2)}.description-icon{color:var(--color-text-tertiary);margin-top:6px;flex-shrink:0}.task-panel__description{flex:1;font-size:var(--font-size-base);color:var(--color-text-secondary);background:transparent;border:none;outline:none;resize:none;line-height:1.6;padding:var(--space-2) 0}.task-panel__description:focus{outline:none;border:none;box-shadow:none}.task-panel__description::placeholder{color:var(--color-text-tertiary)}.task-panel__field{margin-bottom:var(--space-4);position:relative}.task-panel__field label{display:block;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.5px}.task-panel__field-btn{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left}.task-panel__field-btn:hover{border-color:var(--color-text-tertiary)}.task-panel__dropdown{position:absolute;top:100%;left:0;right:0;margin-top:var(--space-1);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:10;padding:var(--space-1)}.task-panel__dropdown--right{left:auto;right:0;min-width:160px}.task-panel__dropdown--date{min-width:240px;padding:var(--space-2)}.task-panel__dropdown .dropdown-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:left;border-radius:var(--radius-sm);transition:background-color var(--transition-fast);border:none;background:none;cursor:pointer}.task-panel__dropdown .dropdown-item:hover{background:var(--color-hover-bg)}.task-panel__dropdown .dropdown-item--selected{background:var(--color-primary-light);color:var(--color-primary)}.date-picker__quick{margin-bottom:var(--space-2)}.date-picker__divider{height:1px;background:var(--color-border-light);margin:var(--space-2) 0}.date-picker__calendar,.date-picker__time{margin-bottom:var(--space-2)}.date-picker__label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-bottom:var(--space-1)}.date-picker__input{width:100%;padding:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.date-picker__input:focus{outline:none;border-color:var(--color-primary)}.task-panel__field--danger{margin-top:auto;padding-top:var(--space-4);border-top:1px solid var(--color-border-light)}.task-panel__delete-btn{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-error);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.task-panel__delete-btn:hover{background:#dc35451a}@keyframes slideIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media(max-width:768px){.task-panel__body{flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch;min-height:0}.task-panel__main{overflow:visible;border-right:none;border-bottom:1px solid var(--color-border-light);padding:var(--space-4)}.task-panel__sidebar{width:100%;overflow:visible;background:var(--color-bg)}}.search-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-start;justify-content:center;padding-top:10vh;z-index:var(--z-modal);animation:fadeIn var(--transition-fast)}@media(max-width:768px){.search-modal-overlay{padding-top:0;align-items:flex-start}.search-modal{width:100%;height:100%;max-height:100vh;max-height:100dvh;border-radius:0}.search-modal__content{max-height:calc(100vh - 120px);max-height:calc(100dvh - 120px)}}.search-modal{background:var(--color-bg);border-radius:var(--radius-lg);width:90%;max-width:600px;max-height:70vh;max-height:70dvh;overflow:hidden;box-shadow:var(--shadow-xl);animation:slideDown var(--transition-base)}.search-modal__header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-bottom:1px solid var(--color-border-light)}.search-modal__icon{color:var(--color-text-tertiary);flex-shrink:0}.search-modal__input{flex:1;font-size:var(--font-size-base);color:var(--color-text-primary);background:transparent;border:none;outline:none}.search-modal__input::placeholder{color:var(--color-text-tertiary)}.search-modal__shortcut{display:flex;gap:var(--space-1)}.search-modal__shortcut kbd{padding:var(--space-1) var(--space-2);font-size:var(--font-size-xs);color:var(--color-text-tertiary);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:inherit}.search-modal__content{overflow-y:auto;max-height:calc(70vh - 60px)}.search-modal__section{padding:var(--space-2)}.search-modal__section-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;padding:var(--space-2) var(--space-3)}.search-modal__item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:left;border-radius:var(--radius-md);transition:background-color var(--transition-fast);cursor:pointer;border:none;background:none}.search-modal__item:hover,.search-modal__item--selected{background:var(--color-hover-bg)}.search-modal__item--selected{background:var(--color-primary-light)}.search-modal__item-icon{color:var(--color-text-secondary);flex-shrink:0}.search-modal__item-label{flex:1}.search-modal__item-shortcut{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.search-modal__task-checkbox{width:14px;height:14px;border:2px solid var(--color-border);border-radius:50%;flex-shrink:0}.search-modal__empty{padding:var(--space-8);text-align:center;color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.quick-add-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-start;justify-content:center;padding-top:15vh;z-index:var(--z-modal);animation:fadeIn var(--transition-fast)}.quick-add-modal{background:var(--color-bg);border-radius:var(--radius-lg);width:90%;max-width:480px;box-shadow:var(--shadow-xl);animation:slideDown var(--transition-base)}.quick-add__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-light)}.quick-add__project-select{position:relative}.quick-add__project-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.quick-add__project-btn:hover{background:var(--color-hover-bg)}.quick-add__project-select .dropdown-menu{position:absolute;top:100%;left:0;margin-top:var(--space-1);min-width:180px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;padding:var(--space-1)}.quick-add__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast)}.quick-add__close:hover{background:var(--color-hover-bg);color:var(--color-text-primary)}.quick-add__content{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.quick-add__title{width:100%;font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);color:var(--color-text-primary);background:transparent;border:none;outline:none;padding:var(--space-2) 0}.quick-add__title:focus{outline:none!important;box-shadow:none!important}.quick-add__title::placeholder{color:var(--color-text-tertiary)}.quick-add__description{width:100%;font-size:var(--font-size-base);color:var(--color-text-secondary);background:transparent;border:none;outline:none;resize:none;line-height:1.5;padding:var(--space-1) 0}.quick-add__description:focus{outline:none!important;box-shadow:none!important}.quick-add__description::placeholder{color:var(--color-text-tertiary)}.quick-add__options{display:flex;gap:var(--space-2);padding:0 var(--space-4) var(--space-4)}.quick-add__option{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.quick-add__option:hover{background:var(--color-hover-bg);border-color:var(--color-text-tertiary)}.quick-add__option--active{color:var(--color-primary);border-color:var(--color-primary);background:var(--color-primary-light)}.quick-add__footer{display:flex;justify-content:flex-end;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border-light);background:var(--color-bg-secondary);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.dropdown-container .dropdown-menu{position:absolute;top:100%;left:0;margin-top:var(--space-1);min-width:160px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;padding:var(--space-1)}.dropdown-container .dropdown-menu--date{min-width:240px;padding:var(--space-2)}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.app-layout{display:flex;position:absolute;inset:0;height:100%;width:100%;overflow:hidden;background-color:var(--color-bg)}.app-main{flex:1;overflow-y:auto;background-color:var(--color-bg);display:flex;flex-direction:column}.mobile-header{display:none;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background-color:var(--color-primary);color:#fff;height:var(--header-height)}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;color:#fff;padding:var(--space-1);border-radius:var(--radius-md)}.mobile-header-title{font-weight:var(--font-weight-semibold);font-size:var(--font-size-lg)}@media(max-width:768px){.mobile-header{display:flex}}.task-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background-color var(--transition-fast)}.task-item:hover{background-color:var(--color-hover-bg)}.task-item--completed{opacity:.6}.task-item--completed .task-item__title{text-decoration:line-through;color:var(--color-text-secondary)}.task-item__checkbox{width:18px;height:18px;min-width:18px;min-height:18px;border:2px solid var(--color-border);border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:2px;transition:all var(--transition-fast);background:transparent;appearance:none;-webkit-appearance:none}.task-item__checkbox:hover{background-color:#8080801a}.task-item--completed .task-item__checkbox{background-color:var(--color-text-secondary);border-color:var(--color-text-secondary);color:#fff}.task-item__content{flex:1;min-width:0}.task-item__title{display:block;font-size:var(--font-size-base);color:var(--color-text-primary);line-height:1.4}.task-item__description{display:block;font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-top:var(--space-1);line-height:1.4}.task-item__meta{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-2)}.task-item__due-date{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--color-success);padding:2px 6px;border-radius:var(--radius-sm);background:transparent}.task-item__due-date--overdue{color:var(--color-error)}.task-item__due-date--today{color:var(--color-success)}.task-item__project{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.task-item__actions{display:none;gap:var(--space-1)}.task-item:hover .task-item__actions{display:flex}.task-item__action{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--color-text-tertiary);transition:all var(--transition-fast)}.task-item__action:hover{background-color:var(--color-hover-bg);color:var(--color-text-primary)}.task-item__actions .dropdown-container{position:relative}.task-item__actions .dropdown-menu{position:absolute;top:100%;right:0;margin-top:var(--space-1);min-width:160px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;padding:var(--space-1);animation:dropdownFadeIn .15s ease}.task-item__actions .dropdown-menu--right{right:0;left:auto}.task-item__actions .dropdown-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:left;border-radius:var(--radius-sm);transition:background-color var(--transition-fast);cursor:pointer;border:none;background:none}.task-item__actions .dropdown-item:hover{background:var(--color-hover-bg)}.task-item__actions .dropdown-item--selected{background:var(--color-primary-light);color:var(--color-primary)}.task-item__actions .dropdown-item--danger{color:var(--color-error)}.task-item__actions .dropdown-item--danger:hover{background:#dc35451a}.task-item__actions .dropdown-item--input{padding:var(--space-1)}.task-item__actions .dropdown-item--input input{width:100%;padding:var(--space-2);font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.task-item__actions .dropdown-divider{height:1px;background:var(--color-border-light);margin:var(--space-1) 0}.add-task-form{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:visible;background:var(--color-bg)}.add-task-form--inline{margin:var(--space-3) 0}.add-task-form__content{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.add-task-form__input{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);background:transparent;border:none;outline:none;width:100%;padding:var(--space-2) 0}.add-task-form__input:focus{outline:none!important;border:none!important;box-shadow:none!important}.add-task-form__input::placeholder{color:var(--color-text-tertiary);font-weight:var(--font-weight-normal)}.add-task-form__description{font-size:var(--font-size-sm);color:var(--color-text-secondary);background:transparent;border:none;outline:none;width:100%;resize:none;line-height:1.5;padding:var(--space-1) 0}.add-task-form__description:focus{outline:none!important;border:none!important;box-shadow:none!important}.add-task-form__description::placeholder{color:var(--color-text-tertiary)}.add-task-form__options{display:flex;gap:var(--space-2);padding:0 var(--space-4) var(--space-4);flex-wrap:wrap}.add-task-form__option{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast);background:var(--color-bg);cursor:pointer}.add-task-form__option:hover{background:var(--color-hover-bg);border-color:var(--color-text-tertiary)}.add-task-form__option--active{color:var(--color-primary);border-color:var(--color-primary);background:var(--color-primary-light)}.option-clear{margin-left:var(--space-1);opacity:.6}.option-clear:hover{opacity:1}.add-task-form__footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border-light);background:var(--color-bg-secondary);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.add-task-form__project-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.add-task-form__project-btn:hover{border-color:var(--color-text-tertiary)}.project-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.add-task-form__actions{display:flex;gap:var(--space-2)}.dropdown-container{position:relative}.dropdown-menu{position:absolute;top:100%;left:0;margin-top:var(--space-1);min-width:180px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;padding:var(--space-1);animation:dropdownFadeIn .15s ease}.dropdown-menu--up{top:auto;bottom:100%;margin-top:0;margin-bottom:var(--space-1)}.dropdown-menu--date{min-width:240px;padding:var(--space-2)}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:left;border-radius:var(--radius-sm);transition:background-color var(--transition-fast);cursor:pointer;border:none;background:none}.dropdown-item:hover{background:var(--color-hover-bg)}.dropdown-item--selected{background:var(--color-primary-light);color:var(--color-primary)}.dropdown-item--input{padding:var(--space-1)}.dropdown-item--input input{width:100%;padding:var(--space-2);font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);background:var(--color-bg)}.dropdown-item--input input:focus{outline:none;border-color:var(--color-primary)}.dropdown-divider{height:1px;background:var(--color-border-light);margin:var(--space-2) 0}.date-picker__quick-options{margin-bottom:var(--space-1)}.date-picker__calendar-section,.date-picker__time-section{margin-bottom:var(--space-3)}.date-picker__section-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-bottom:var(--space-1)}.date-picker__calendar-input,.date-picker__time-input{width:100%;padding:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.date-picker__calendar-input:focus,.date-picker__time-input:focus{outline:none;border-color:var(--color-primary)}.date-picker__actions{display:flex;justify-content:flex-end;padding-top:var(--space-2);border-top:1px solid var(--color-border-light)}.add-task-form input:focus,.add-task-form textarea:focus{outline:none!important;box-shadow:none!important}.view-page{max-width:900px;margin:0;padding:var(--space-8) var(--space-10);position:relative;min-height:calc(100vh - 100px)}.view-header{margin-bottom:var(--space-6)}.view-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.view-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.task-count{color:var(--color-text-tertiary)}.view-loading{text-align:center;padding:var(--space-10);color:var(--color-text-secondary)}.view-empty{text-align:center;padding:var(--space-10) var(--space-6);display:flex;flex-direction:column;align-items:center;justify-content:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;max-width:400px}.view-empty__illustration{margin-bottom:var(--space-6)}.view-empty__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.view-empty__text{font-size:var(--font-size-base);color:var(--color-text-secondary);max-width:300px;margin:0 auto var(--space-6);line-height:var(--line-height-relaxed)}.view-empty__add-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-primary);color:#fff;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.view-empty__add-btn:hover{background:var(--color-primary-hover)}.add-task-trigger{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);color:var(--color-text-secondary);font-size:var(--font-size-base);width:100%;text-align:left;border-radius:var(--radius-md);transition:color var(--transition-fast)}.add-task-trigger:hover{color:var(--color-primary)}.add-task-trigger:hover svg{background:var(--color-primary);color:#fff;border-radius:50%}.task-section{margin-bottom:var(--space-4)}.task-section__header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;width:100%;text-align:left}.task-section__header--static{cursor:default}.section-chevron{color:var(--color-text-tertiary);transition:transform var(--transition-fast)}.section-chevron.collapsed{transform:rotate(-90deg)}.section-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.section-title--overdue{color:var(--color-text-primary)}.section-date{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.reschedule-btn{margin-left:auto;font-size:var(--font-size-sm);color:var(--color-primary);font-weight:var(--font-weight-medium)}.reschedule-btn:hover{text-decoration:underline}.upcoming-calendar{display:flex;gap:var(--space-2);padding:var(--space-2) 0 var(--space-4);border-bottom:1px solid var(--color-border-light);margin-bottom:var(--space-4);overflow-x:auto}.calendar-day{display:flex;flex-direction:column;align-items:center;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);min-width:60px;cursor:pointer;transition:background-color var(--transition-fast)}.calendar-day:hover{background:var(--color-hover-bg)}.calendar-day--active{background:var(--color-primary);color:#fff}.calendar-day__name{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.calendar-day--active .calendar-day__name{color:#fffc}.calendar-day__number{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.calendar-day__dot{width:4px;height:4px;border-radius:50%;background:var(--color-primary);margin-top:var(--space-1)}.calendar-day--active .calendar-day__dot{background:#fff}.calendar-day--today{border:2px solid var(--color-primary)}.upcoming-nav{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3)}.upcoming-nav-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast)}.upcoming-nav-btn:hover{background:var(--color-hover-bg);color:var(--color-text-primary)}.upcoming-nav-label{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.upcoming-today-btn{margin-left:auto;padding:var(--space-1) var(--space-3);font-size:var(--font-size-sm);color:var(--color-primary);background:var(--color-primary-light);border-radius:var(--radius-md);font-weight:var(--font-weight-medium)}.upcoming-today-btn:hover{background:var(--color-primary);color:#fff}.upcoming-empty{text-align:center;padding:var(--space-6);color:var(--color-text-secondary)}.upcoming-tasks{margin-top:var(--space-4)}.section-count{margin-left:auto;font-size:var(--font-size-sm);color:var(--color-text-tertiary);font-weight:var(--font-weight-normal)}.view-header-row{display:flex;align-items:center;gap:var(--space-2)}.view-icon{color:var(--color-primary)}.view-header-action{margin-left:auto;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast)}.view-header-action:hover{background:var(--color-hover-bg);color:var(--color-text-primary)}.filters-page{max-width:600px}.filters-section{margin-bottom:var(--space-6)}.filters-section__header{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-1);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);text-align:left;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast)}.filters-section__header:hover{background:var(--color-hover-bg)}.filters-section__icon{color:var(--color-text-secondary)}.filters-section__title{flex:1}.filters-section__count{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-weight:var(--font-weight-normal)}.filters-section__add{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-text-tertiary);transition:all var(--transition-fast)}.filters-section__add:hover{background:var(--color-hover-bg);color:var(--color-text-primary)}.filters-list{padding-left:var(--space-6)}.filters-empty{padding:var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.filter-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:background-color var(--transition-fast);position:relative}.filter-item:hover{background:var(--color-hover-bg)}.filter-item__name{flex:1;font-size:var(--font-size-sm);color:var(--color-text-primary)}.filter-item__actions{display:flex;align-items:center;gap:var(--space-1)}.filter-item__action{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-text-tertiary);transition:all var(--transition-fast)}.filter-item__action:hover{background:var(--color-bg);color:var(--color-text-primary)}.add-label-form{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);margin-top:var(--space-2)}.add-label-form__header{display:flex;align-items:center;justify-content:space-between;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-3)}.add-label-form__header button{color:var(--color-text-tertiary)}.add-label-form__header button:hover{color:var(--color-text-primary)}.add-label-form__input{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-3)}.add-label-form__input:focus{outline:none;border-color:var(--color-primary)}.add-label-form__colors{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-bottom:var(--space-3)}.add-label-form__colors .color-option{width:24px;height:24px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.add-label-form__colors .color-option:hover{transform:scale(1.1)}.add-label-form__colors .color-option--active{border-color:var(--color-text-primary);box-shadow:0 0 0 2px var(--color-bg)}.add-label-form__actions{display:flex;justify-content:flex-end;gap:var(--space-2)}.filter-item .dropdown-container{position:relative}.filter-item .dropdown-menu{position:absolute;top:100%;right:0;margin-top:var(--space-1);min-width:200px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;padding:var(--space-1)}.filter-item .dropdown-menu--right{right:0;left:auto}.filter-item .dropdown-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:left;border-radius:var(--radius-sm);transition:background-color var(--transition-fast);border:none;background:none;cursor:pointer}.filter-item .dropdown-item:hover{background:var(--color-hover-bg)}.filter-item .dropdown-item--danger{color:var(--color-error)}.filter-item .dropdown-item--danger:hover{background:#dc35451a}.filter-item .dropdown-divider{height:1px;background:var(--color-border-light);margin:var(--space-1) 0}.stats-widget{display:flex;gap:1rem;margin-bottom:1.5rem}.stats-card{flex:1;background-color:var(--color-bg-secondary);border-radius:12px;padding:1rem;border:1px solid var(--color-border-light);box-shadow:0 1px 2px #0000000d;display:flex;flex-direction:column;justify-content:center}.stats-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.stats-icon-wrapper{padding:.5rem;border-radius:8px;display:flex;align-items:center;justify-content:center}.stats-icon-wrapper.blue{background-color:#3b82f61a;color:#3b82f6}.stats-icon-wrapper.red{background-color:#ef44441a;color:#ef4444}.stats-icon-wrapper.emerald{background-color:#10b9811a;color:#10b981}.stats-label{font-size:.875rem;font-weight:500;color:var(--color-text-tertiary)}.stats-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);display:flex;align-items:baseline;gap:.25rem}.stats-unit{font-size:.875rem;font-weight:400;color:var(--color-text-tertiary)}.progress-bar-container{display:flex;align-items:center;gap:.75rem;width:100%}.progress-bar-bg{flex:1;height:6px;background-color:var(--color-border-light);border-radius:999px;overflow:hidden}.progress-bar-fill{height:100%;background-color:#10b981;border-radius:999px}@media(max-width:640px){.stats-widget{flex-direction:column}}.calendar-view-page{padding:2rem;max-width:100%;height:100%;display:flex;flex-direction:column}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.calendar-header-left{display:flex;align-items:center;gap:1.5rem}.calendar-title{font-size:1.75rem;font-weight:700;color:var(--color-text-primary);min-width:200px}.calendar-nav{display:flex;align-items:center;gap:.5rem}.calendar-nav-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--color-text-secondary);background:transparent;transition:all var(--transition-fast)}.calendar-nav-btn:hover{background:var(--color-hover-bg);color:var(--color-text-primary)}.calendar-today-btn{padding:0 1rem;height:32px;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;color:var(--color-text-primary);background:transparent;border:1px solid var(--color-border)}.calendar-today-btn:hover{background:var(--color-hover-bg)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:auto repeat(5,1fr);background-color:var(--color-border);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;flex:1;gap:1px}.calendar-day-header{background-color:var(--color-bg-secondary);padding:1rem;text-align:center;font-weight:600;font-size:.9rem;color:var(--color-text-secondary);text-transform:uppercase}.calendar-cell{background-color:var(--color-bg);min-height:120px;padding:.5rem;display:flex;flex-direction:column;cursor:pointer;transition:background-color var(--transition-fast);position:relative}.calendar-cell:hover{background-color:var(--color-hover-bg)}.calendar-cell.other-month{background-color:var(--color-bg-secondary);color:var(--color-text-tertiary);opacity:.8}.calendar-cell.is-today{background-color:var(--color-bg);box-shadow:inset 0 0 0 2px var(--color-primary)}.calendar-cell .day-number{font-weight:500;font-size:.95rem;color:var(--color-text-primary);padding:2px}.calendar-cell.is-today .day-number{background-color:var(--color-primary);color:#fff;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.calendar-cell.other-month .day-number{color:var(--color-text-tertiary)}.calendar-cell-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.task-count-badge{font-size:.75rem;background-color:var(--color-bg-secondary);padding:2px 6px;border-radius:999px;color:var(--color-text-secondary);border:1px solid var(--color-border)}.calendar-cell-content{flex:1;display:flex;flex-direction:column;gap:2px}.calendar-task-dot{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--color-text-primary);padding:2px 4px;border-radius:4px;overflow:hidden;white-space:nowrap}.calendar-task-dot:hover{background-color:var(--color-hover-bg)}.calendar-task-dot .dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.task-preview{overflow:hidden;text-overflow:ellipsis}.more-tasks{font-size:.75rem;color:var(--color-text-tertiary);padding-left:4px}.calendar-task-summary{display:flex;align-items:center;gap:6px;font-size:.85rem;padding:2px 4px;border-radius:4px;color:var(--color-text-secondary)}.calendar-task-summary.done{color:var(--color-text-secondary);opacity:.8}.calendar-task-summary.pending{color:var(--color-text-primary);font-weight:500}.calendar-task-summary .dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.plan-day-btn{margin-top:auto;width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:6px;font-size:.8rem;font-weight:500;color:var(--color-primary);background-color:var(--color-primary-light);border-radius:var(--radius-sm);opacity:0;transform:translateY(4px);transition:all .2s ease}.calendar-cell:hover .plan-day-btn{opacity:1;transform:translateY(0)}.plan-day-btn:hover{background-color:var(--color-primary);color:#fff}.planner-header{display:flex;justify-content:space-between;align-items:flex-end;padding:0 0 var(--space-4) 0;margin-bottom:var(--space-6);border-bottom:1px solid var(--color-border-light)}.planner-header-left{display:flex;flex-direction:column;gap:var(--space-1)}.planner-title{margin:0;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:var(--line-height-tight)}.planner-date-display{display:flex;align-items:baseline;gap:var(--space-2)}.planner-day-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary)}.planner-full-date{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.planner-controls{display:flex;align-items:center;gap:var(--space-2)}.planner-nav-btn{background:transparent;border:1px solid transparent;width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-secondary);transition:all var(--transition-fast)}.planner-nav-btn:hover{background-color:var(--color-hover-bg);color:var(--color-text-primary)}.planner-today-btn{background:transparent;border:1px solid var(--color-border);padding:0 var(--space-3);height:32px;border-radius:var(--radius-md);display:flex;align-items:center;gap:var(--space-2);cursor:pointer;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:all var(--transition-fast)}.planner-today-btn:hover{background-color:var(--color-hover-bg);color:var(--color-text-primary);border-color:var(--color-text-secondary)}.planner-today-btn.active{background-color:var(--color-primary-light);color:var(--color-primary);border-color:transparent}.day-planner-grid{display:flex;flex-direction:column;width:100%;flex:1;overflow:hidden;min-height:0}.planner-loading{padding:var(--space-8);text-align:center;color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.planner-columns-container{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);width:100%;flex:1;overflow:hidden;min-height:0}.planner-column{display:flex;flex-direction:column;min-width:0;overflow-y:auto;overflow-x:hidden;padding-bottom:var(--space-4)}.planner-column::-webkit-scrollbar{width:6px}.planner-column::-webkit-scrollbar-track{background:transparent}.planner-column::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.planner-column::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.planner-column-header{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2);border-bottom:2px solid var(--color-border-light);position:sticky;top:0;background-color:var(--color-bg);z-index:10;box-shadow:0 2px 4px #0000000d}.planner-row{display:flex;position:relative;transition:background-color var(--transition-fast);min-height:40px;border-bottom:1px solid var(--color-border-light)}.planner-row:last-child{border-bottom:none}.planner-row:hover{background-color:var(--color-hover-bg)}.planner-row.focused{background-color:var(--color-bg-secondary)}.planner-time-col{width:70px;flex-shrink:0;display:flex;justify-content:flex-end;padding:var(--space-2) var(--space-3) var(--space-2) 0;align-items:flex-start;border-right:1px solid var(--color-border-light);background-color:var(--color-bg-secondary)}.planner-time-label{font-size:var(--font-size-sm);color:var(--color-text-tertiary);font-family:var(--font-mono);font-weight:var(--font-weight-medium)}.planner-row:hover .planner-time-label{color:var(--color-text-secondary)}.planner-input-col{flex:1;position:relative;display:flex;align-items:flex-start;padding:var(--space-2) var(--space-3);min-width:0}.planner-input{width:100%;padding:2px 32px 2px 0;border:none;background:transparent;font-size:var(--font-size-sm);color:var(--color-text-primary);outline:none;font-family:var(--font-sans);resize:none;overflow:hidden;line-height:1.5;min-height:24px}.planner-input::placeholder{color:transparent;transition:color var(--transition-fast)}.planner-row:hover .planner-input::placeholder{color:var(--color-text-tertiary)}.planner-row.focused .planner-input::placeholder{color:var(--color-text-secondary)}.planner-row-actions{position:absolute;right:var(--space-2);top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:flex-end;height:20px;pointer-events:none}.status-container{display:flex;align-items:center;gap:4px;padding:2px 6px;background:#ffffffe6;border-radius:4px;font-size:11px;font-weight:500}.status-container.saving{color:var(--color-warning)}.status-container.saved{color:var(--color-success)}.status-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:800px){.planner-columns-container{grid-template-columns:1fr;gap:var(--space-6);overflow-y:auto}.planner-column{overflow-y:visible}}.day-planner-page{padding:2rem;max-width:100%;margin:0 auto;height:100%;display:flex;flex-direction:column;box-sizing:border-box}html,body{background:transparent!important}.widget-container{width:100%;height:100vh;background:#282828d9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);-webkit-app-region:drag;border-radius:24px;padding:20px;display:flex;flex-direction:column;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;box-shadow:0 10px 30px #0000004d;border:1px solid rgba(255,255,255,.1);overflow:hidden;-webkit-user-select:none;user-select:none}.widget-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4px}.widget-count{font-size:32px;font-weight:700;line-height:1}.widget-icon{width:32px;height:32px;background:#ff9f0a;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.widget-category{font-size:14px;font-weight:600;color:#ff9f0a;margin-bottom:12px}.widget-divider{height:1px;background:#ffffff26;margin-bottom:12px}.widget-list{flex:1;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.widget-item{display:flex;align-items:center;gap:12px;font-size:14px;color:#ffffffe6}.priority-circle{width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,.4)}.priority-circle.p4{border-color:#dc2626}.priority-circle.p3{border-color:#eb8909}.widget-task-content{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-action{opacity:.6;cursor:pointer}.widget-empty{display:flex;align-items:center;gap:8px;color:#ffffff80;font-size:14px}:root{--color-primary: #667eea;--color-primary-hover: #5a6fd9;--color-primary-light: #eef2ff;--priority-1: #d1453b;--priority-2: #eb8909;--priority-3: #246fe0;--priority-4: #808080;--color-bg: #ffffff;--color-bg-secondary: #fafafa;--color-bg-tertiary: #f5f5f5;--color-border: #e5e5e5;--color-border-light: #f0f0f0;--color-sidebar-bg: #fafafa;--color-text-primary: #202020;--color-text-secondary: #808080;--color-text-tertiary: #b8b8b8;--color-hover-bg: #f5f5f5;--color-active-bg: #ebebeb;--color-focus-ring: rgba(234, 76, 137, .3);--color-success: #058527;--color-warning: #eb8909;--color-error: #d1453b;--color-info: #246fe0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-mono: "Monaco", "Courier New", monospace;--font-size-xs: 11px;--font-size-sm: 13px;--font-size-base: 14px;--font-size-md: 15px;--font-size-lg: 16px;--font-size-xl: 18px;--font-size-2xl: 20px;--font-size-3xl: 24px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-relaxed: 1.7;--radius-sm: 3px;--radius-md: 5px;--radius-lg: 8px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .12);--shadow-xl: 0 8px 24px rgba(0, 0, 0, .15);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--z-dropdown: 1000;--z-modal: 2000;--z-tooltip: 3000;--sidebar-width: 305px;--header-height: 54px}[data-theme=dark]{--color-primary: #818cf8;--color-primary-hover: #6366f1;--color-primary-light: rgba(129, 140, 248, .15);--color-bg: #1a1a2e;--color-bg-secondary: #16162a;--color-bg-tertiary: #0f0f1a;--color-border: #2d2d44;--color-border-light: #252538;--color-sidebar-bg: #16162a;--color-text-primary: #e4e4e7;--color-text-secondary: #a1a1aa;--color-text-tertiary: #71717a;--color-hover-bg: #252538;--color-active-bg: #2d2d44;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 2px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .5);--shadow-xl: 0 8px 24px rgba(0, 0, 0, .6)}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden}body{font-family:var(--font-sans);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;outline:none}button:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;border:none;outline:none}input:focus,textarea:focus,select:focus{outline:2px solid var(--color-focus-ring);outline-offset:-1px;border-radius:var(--radius-sm)}a{color:inherit;text-decoration:none}@media(max-width:768px){button,a,input,select,.nav-item,.task-item{min-height:44px;touch-action:manipulation}.sidebar__icon-btn,.filter-btn{width:44px;height:44px}}ul,ol{list-style:none}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:6px;border:3px solid var(--color-bg)}::-webkit-scrollbar-thumb:hover{background-color:var(--color-text-tertiary)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fade-in{animation:fadeIn var(--transition-base)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.slide-in{animation:slideIn var(--transition-base)}@keyframes slideIn{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.electron-app body{background-color:transparent!important}.electron-app #root{background-color:#ffffffd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:10px;height:100vh;display:flex;flex-direction:column}[data-theme=dark] .electron-app #root{background-color:#16162ad9}
