.ui-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-3);font-family:inherit;font-weight:600;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;white-space:nowrap;transition:background-color var(--duration-fast) var(--ease-standard),border-color var(--duration-fast) var(--ease-standard),color var(--duration-fast) var(--ease-standard),opacity var(--duration-fast) var(--ease-standard);-webkit-user-select:none;user-select:none}.ui-btn--sm{height:28px;padding:0 var(--space-4);font-size:var(--text-caption)}.ui-btn--md{height:34px;padding:0 var(--space-5);font-size:var(--text-body)}.ui-btn--full{width:100%}.ui-btn--primary{background:var(--accent);color:#fff}.ui-btn--primary:hover:not(:disabled){background:var(--accent-hover)}.ui-btn--secondary{background:var(--surface-2);color:var(--text-primary);border-color:var(--border-subtle)}.ui-btn--secondary:hover:not(:disabled){background:var(--surface-3);border-color:var(--border-strong)}.ui-btn--ghost{background:transparent;color:var(--text-secondary)}.ui-btn--ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text-primary)}.ui-btn--danger{background:var(--danger);color:#fff}.ui-btn--danger:hover:not(:disabled){background:var(--danger-hover)}.ui-btn--danger.ui-btn--outline{background:transparent;color:var(--danger);border-color:var(--danger)}.ui-btn--danger.ui-btn--outline:hover:not(:disabled){background:var(--danger-bg)}.ui-btn--subtle{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-border)}.ui-btn--subtle:hover:not(:disabled){background:#22c55e33}.ui-btn:disabled{opacity:.5;cursor:not-allowed}.ui-btn:not(:disabled):active{transform:scale(.97);transition:transform var(--duration-fast)}.ui-btn-icon{display:inline-flex;align-items:center;justify-content:center}.ui-btn-label{display:inline-flex;align-items:center}.ui-btn-spinner{width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:ui-btn-spin .6s linear infinite;opacity:.85}@keyframes ui-btn-spin{to{transform:rotate(360deg)}}.login-page{display:flex;height:100%;background:var(--surface-0)}.login-hero{flex:1 1 50%;position:relative;display:flex;align-items:center;justify-content:center;padding:var(--space-9);overflow:hidden}.login-hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 50% at 20% 80%,rgba(34,197,94,.25),transparent 60%),radial-gradient(ellipse 50% 40% at 80% 20%,rgba(59,130,246,.18),transparent 65%),var(--surface-0);z-index:0}.login-hero-content{position:relative;z-index:1;max-width:420px;display:flex;flex-direction:column;gap:var(--space-5);animation:slide-up var(--duration-slow) var(--ease-out)}.login-logo{display:inline-flex;align-items:center;gap:var(--space-3);color:var(--accent);font-size:var(--text-h1);font-weight:700}.login-wordmark{letter-spacing:-.02em}.login-wordmark-dot{color:var(--accent)}.login-hero-title{font-size:32px;font-weight:700;line-height:1.2;color:var(--text-primary);letter-spacing:-.01em}.login-hero-subtitle{font-size:var(--text-lg);color:var(--text-secondary);line-height:var(--leading-relaxed)}.login-form-side{flex:1 1 50%;display:flex;align-items:center;justify-content:center;padding:var(--space-8);background:var(--surface-0)}.login-card{background-color:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-8);width:100%;max-width:380px;box-shadow:var(--shadow-md);animation:pop-in var(--duration-slow) var(--ease-spring)}.login-title{font-size:var(--text-h1);font-weight:700;color:var(--text-primary);text-align:center;margin-bottom:var(--space-7);letter-spacing:-.01em}.login-form{display:flex;flex-direction:column;gap:var(--space-5)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-group label{font-size:var(--text-body);color:var(--text-secondary);font-weight:500}.login-error{color:var(--danger);background:var(--danger-bg);border:1px solid var(--danger-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-body);text-align:center}.login-form .ui-btn{margin-top:var(--space-3)}@media (max-width: 900px){.login-hero{display:none}.login-form-side{flex:1 1 100%}}.confirm-dialog{position:fixed;z-index:var(--z-popover);width:280px;padding:var(--space-4);background:var(--surface-3);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:var(--space-4);animation:pop-in var(--duration-fast) var(--ease-spring)}.confirm-message{font-size:var(--text-body);color:var(--text-primary);line-height:var(--leading-base)}.confirm-actions{display:flex;justify-content:flex-end;gap:var(--space-3)}.ctx-menu{position:fixed;z-index:var(--z-popover);min-width:220px;padding:var(--space-2);background:var(--surface-3);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:1px;animation:pop-in var(--duration-fast) var(--ease-spring);-webkit-user-select:none;user-select:none}.ctx-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-3);background:none;border:none;font-family:inherit;font-size:var(--text-body);color:var(--text-primary);cursor:pointer;text-align:left;border-radius:var(--radius-md);transition:background-color var(--duration-fast)}.ctx-item:hover:not(:disabled),.ctx-item--active{background:var(--surface-2)}.ctx-item:disabled{opacity:.5;cursor:not-allowed}.ctx-item--danger{color:var(--danger)}.ctx-item--danger:hover:not(:disabled){background:var(--danger-bg)}.ctx-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;color:var(--text-secondary);flex-shrink:0}.ctx-item--danger .ctx-icon{color:var(--danger)}.ctx-label{flex:1;white-space:nowrap}.ctx-shortcut{font-size:var(--text-micro);color:var(--text-tertiary);letter-spacing:.02em}.ctx-arrow{color:var(--text-tertiary);flex-shrink:0}.ctx-separator{height:1px;background:var(--border-subtle);margin:var(--space-1) 0}.ctx-project-dot{display:inline-block;width:10px;height:10px;border-radius:var(--radius-full)}.ctx-row{padding:var(--space-2) var(--space-3) var(--space-3)}.ctx-row-header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-1) var(--space-2);font-size:var(--text-caption)}.ctx-row-label{color:var(--text-secondary);font-weight:500}.ctx-row-buttons{display:flex;gap:var(--space-2);align-items:center}.ctx-row-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--surface-2);color:var(--text-secondary);cursor:pointer;font-family:inherit;transition:transform var(--duration-fast) var(--ease-out),border-color var(--duration-fast),background-color var(--duration-fast)}.ctx-row-btn:hover{border-color:var(--border-strong);background:var(--surface-3);transform:scale(1.05)}.ctx-row-btn:active{transform:scale(.95)}.ctx-row-btn.is-active{border-color:currentColor;background:color-mix(in srgb,currentColor 15%,transparent)}.ctx-row-btn.is-danger:hover{color:var(--danger);border-color:var(--danger);background:var(--danger-bg)}.subtask-item{display:flex;align-items:center;gap:8px;padding:5px 0 5px 8px;border-left:2px solid var(--border);margin-left:30px}.subtask-item--completed .subtask-title{text-decoration:line-through;color:var(--text-secondary)}.subtask-checkbox{width:14px;height:14px;border:1.5px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background-color .15s,border-color .15s}.subtask-checkbox:hover{background-color:var(--bg-hover)}.subtask-check{font-size:9px;color:var(--accent);font-weight:700}.subtask-title{flex:1;font-size:13px;color:var(--text-secondary)}.subtask-delete{opacity:0;color:var(--text-secondary);font-size:16px;line-height:1;transition:opacity .1s,color .1s}.subtask-item:hover .subtask-delete{opacity:1}.subtask-delete:hover{color:var(--danger)}.task-item-wrapper{position:relative}.task-item{position:relative;display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-3) var(--space-3) var(--space-5);border-radius:var(--radius-md);transition:background-color var(--duration-fast) var(--ease-standard)}.task-item:hover{background-color:var(--surface-2)}.task-item--overdue{background-color:var(--danger-bg)}.task-item--overdue:hover{background-color:#ef44442e}.task-item--completed .task-title{text-decoration:line-through;color:var(--text-secondary)}.task-stripe{position:absolute;left:0;top:10px;bottom:10px;width:3px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;pointer-events:none}.task-item--completed .task-stripe{opacity:.35}.task-checkbox{width:18px;height:18px;min-width:18px;border:2px solid var(--border-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background-color var(--duration-fast),border-color var(--duration-fast);cursor:pointer}.task-checkbox:hover{border-color:var(--accent);background-color:var(--accent-bg)}.task-checkbox--done{background:var(--accent);border-color:var(--accent)}.task-checkbox--popping{animation:checkbox-pop .22s var(--ease-spring)}.task-checkbox-check{color:#fff;display:flex;animation:fade-in var(--duration-fast) var(--ease-out)}.task-content{flex:1;display:flex;flex-direction:column;gap:var(--space-1);cursor:pointer;min-width:0}.task-title{font-size:var(--text-md);line-height:var(--leading-tight);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.task-meta{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;margin-top:var(--space-1)}.task-due{font-size:var(--text-micro);color:var(--text-secondary)}.task-time{font-variant-numeric:tabular-nums;color:var(--text-primary);font-weight:500}.task-deadline{font-size:var(--text-micro);color:var(--warning);font-weight:500;display:inline-flex;align-items:center;gap:3px}.task-deadline--overdue{color:var(--danger);font-weight:600}.task-recurrence{font-size:var(--text-micro);display:inline-flex;align-items:center;color:var(--text-secondary)}.task-project-label{font-size:var(--text-micro);color:var(--text-tertiary);display:inline-flex;align-items:center;gap:var(--space-2)}.task-project-dot{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}.task-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.task-priority{font-size:var(--text-micro);font-weight:700;font-variant-numeric:tabular-nums}.task-delete{opacity:0;color:var(--text-tertiary);display:flex;align-items:center;padding:var(--space-1);border-radius:var(--radius-sm);transition:opacity var(--duration-fast),color var(--duration-fast),background-color var(--duration-fast)}.task-item:hover .task-delete{opacity:1}.task-delete:hover{color:var(--danger);background-color:var(--danger-bg)}.task-subtask-progress{display:flex;align-items:center;gap:var(--space-3);cursor:pointer;margin-top:var(--space-1)}.task-progress-bar{flex:1;max-width:100px;height:6px;background:var(--surface-2);border-radius:var(--radius-full);overflow:hidden}.task-item:hover .task-progress-bar,.task-item--overdue .task-progress-bar{background:var(--surface-3)}.task-progress-fill{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width var(--duration-base) var(--ease-out)}.task-progress-label{font-size:var(--text-micro);color:var(--text-secondary);font-variant-numeric:tabular-nums}.task-subtask-btn{opacity:0;color:var(--text-tertiary);display:flex;align-items:center;padding:var(--space-1);border-radius:var(--radius-sm);transition:opacity var(--duration-fast),color var(--duration-fast),background-color var(--duration-fast)}.task-item:hover .task-subtask-btn{opacity:1}.task-subtask-btn:hover{color:var(--accent);background-color:var(--accent-bg)}.subtask-list{padding:var(--space-1) 0 var(--space-3) var(--space-5)}.subtask-form-wrap{margin-left:30px;margin-top:var(--space-2)}.subtask-add-btn{margin-left:38px;margin-top:var(--space-2);font-size:var(--text-caption);color:var(--text-secondary);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);transition:color var(--duration-fast),background-color var(--duration-fast);display:flex;align-items:center;gap:var(--space-2)}.subtask-add-btn:hover{color:var(--accent);background-color:var(--surface-2)}.task-list{display:flex;flex-direction:column}.task-dnd-row{position:relative;cursor:grab;animation:slide-up var(--duration-base) var(--ease-out) backwards}.task-dnd-row:active{cursor:grabbing}.task-dnd-row--over:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);border-radius:1px;z-index:10}.task-item--dragging{opacity:.4}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-9) var(--space-5);gap:var(--space-3);max-width:420px;margin:0 auto;animation:slide-up var(--duration-slow) var(--ease-out)}.empty-state-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--surface-1);border-radius:var(--radius-full);color:var(--text-tertiary);margin-bottom:var(--space-3)}.empty-state-title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);line-height:var(--leading-tight)}.empty-state-description{font-size:var(--text-body);color:var(--text-secondary);line-height:var(--leading-base)}.empty-state-action{margin-top:var(--space-4)}.skeleton{display:block;background:linear-gradient(90deg,var(--surface-1) 0%,var(--surface-2) 50%,var(--surface-1) 100%);background-size:200% 100%;animation:shimmer 1.4s ease-in-out infinite}.skeleton--r-sm{border-radius:var(--radius-sm)}.skeleton--r-md{border-radius:var(--radius-md)}.skeleton--r-full{border-radius:var(--radius-full)}@media (prefers-reduced-motion: reduce){.skeleton{animation:none;opacity:.6}}.skeleton-task-list{display:flex;flex-direction:column;gap:var(--space-3)}.skeleton-task-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);animation:fade-in var(--duration-base) var(--ease-out) backwards}.skeleton-task-body{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.skeleton-task-detail{display:flex;gap:var(--space-7);padding:var(--space-7);flex:1}.skeleton-task-detail-left{flex:1 1 55%;display:flex;flex-direction:column;gap:var(--space-4)}.skeleton-task-detail-right{flex:0 0 220px;display:flex;flex-direction:column;gap:var(--space-3)}.project-view{flex:1;display:flex;flex-direction:column;overflow:hidden}.project-header{padding:24px 32px 16px}.project-header-body{max-width:720px;margin:0 auto}.project-title{font-size:var(--text-h1);font-weight:700}.project-content{flex:1;overflow-y:auto;padding:20px 32px 32px}.project-content-body{max-width:720px;margin:0 auto}.project-loading{color:var(--text-secondary);font-size:14px}.task-list{margin-bottom:8px}.task-list--completed{opacity:.6}.btn-add-task{color:var(--text-secondary);font-size:14px;padding:8px 0;margin-top:4px;text-align:left;width:100%;transition:color .15s;display:flex;align-items:center;gap:6px}.btn-add-task:hover{color:var(--accent)}.completed-section{margin-top:24px}.completed-section summary{cursor:pointer;font-size:13px;color:var(--text-secondary);padding:8px 0;-webkit-user-select:none;user-select:none;list-style:none}.completed-section summary:before{content:"▶ ";font-size:10px}.completed-section[open] summary:before{content:"▼ "}.smart-view{flex:1;display:flex;flex-direction:column;min-height:0}.smart-view-header{padding:var(--space-7) var(--space-8) 0}.smart-view-body{max-width:720px;margin:0 auto;display:flex;align-items:center;gap:var(--space-4)}.smart-view-title{font-size:var(--text-h1);font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.smart-view-month{font-size:var(--text-body);color:var(--text-secondary);font-weight:500}.smart-view-count{background:var(--surface-2);color:var(--text-secondary);font-size:var(--text-caption);font-weight:600;padding:2px var(--space-3);border-radius:var(--radius-full)}.smart-view-content{flex:1;overflow-y:auto;padding:var(--space-5) var(--space-8) var(--space-8)}.smart-view-content .smart-view-body{display:flex;flex-direction:column;align-items:stretch;gap:0}.smart-view-loading,.smart-view-empty{color:var(--text-secondary);font-size:var(--text-md);padding:var(--space-8) 0;text-align:center}.smart-section{margin-bottom:var(--space-6)}.smart-section-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-caption);font-weight:600;padding-bottom:var(--space-3);margin-bottom:var(--space-1);border-bottom:1px solid var(--border-subtle);letter-spacing:.02em}.smart-section-label--overdue{color:var(--danger)}.smart-section-label--today{color:var(--accent)}.smart-view--upcoming .smart-view-content{padding:var(--space-5) var(--space-8) var(--space-8);overflow-y:hidden;overflow-x:auto}.smart-view-header-upcoming{display:flex;align-items:center;justify-content:space-between;gap:var(--space-5);flex-wrap:wrap}.smart-view-title-row{display:flex;align-items:baseline;gap:var(--space-4)}.smart-view-week-nav{display:inline-flex;align-items:center;gap:var(--space-1);background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:2px}.week-nav-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:none;border:none;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:background-color var(--duration-fast),color var(--duration-fast)}.week-nav-btn:hover:not(:disabled){background:var(--surface-2);color:var(--text-primary)}.week-nav-btn:disabled{opacity:.35;cursor:not-allowed}.week-nav-today{background:none;border:none;font-family:inherit;font-size:var(--text-caption);font-weight:600;color:var(--text-secondary);cursor:pointer;padding:4px var(--space-3);border-radius:var(--radius-sm);transition:background-color var(--duration-fast),color var(--duration-fast)}.week-nav-today:hover:not(:disabled){background:var(--surface-2);color:var(--text-primary)}.week-nav-today.is-current{color:var(--text-tertiary);cursor:default}.upcoming-week{display:flex;gap:var(--space-2);height:100%;min-width:min-content;align-items:stretch}.upcoming-col{flex:0 0 280px;display:flex;flex-direction:column;min-height:0}.upcoming-col--today .upcoming-col-date,.upcoming-col--today .upcoming-col-suffix{color:var(--accent)}.upcoming-col-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-2) var(--space-3) var(--space-3);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.upcoming-col-label{display:inline-flex;align-items:baseline;gap:var(--space-2);font-size:var(--text-body);color:var(--text-primary);font-weight:600;min-width:0}.upcoming-col-label--overdue{color:var(--danger);align-items:center}.upcoming-col-date{white-space:nowrap}.upcoming-col-sep{color:var(--text-tertiary)}.upcoming-col-suffix{color:var(--text-secondary);font-weight:400}.upcoming-col-count{color:var(--text-tertiary);font-size:var(--text-caption);font-weight:500;font-variant-numeric:tabular-nums}.upcoming-col--overdue .upcoming-col-count{color:var(--danger)}.upcoming-col-tasks{flex:1;overflow-y:auto;padding:var(--space-2);display:flex;flex-direction:column;gap:var(--space-1)}.upcoming-col-add{background:none;border:none;color:var(--text-tertiary);font-size:var(--text-caption);padding:var(--space-3) var(--space-3);margin-top:var(--space-2);border-radius:var(--radius-md);text-align:left;cursor:pointer;display:flex;align-items:center;gap:var(--space-2);transition:color var(--duration-fast),background-color var(--duration-fast)}.upcoming-col-add:hover{color:var(--accent);background:var(--accent-bg)}.upcoming-col-tasks .task-item{padding:var(--space-2) var(--space-2) var(--space-2) var(--space-4)}.upcoming-col-tasks .task-item .task-priority,.upcoming-col-tasks .task-item .task-subtask-btn{display:none}.settings-view{flex:1;display:flex;flex-direction:column;overflow-y:auto}.settings-loading{padding:40px;color:var(--text-secondary)}.settings-header{padding:24px 32px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.settings-title{font-size:20px;font-weight:600;color:var(--text-primary)}.settings-content{padding:28px 32px;display:flex;flex-direction:column;gap:36px;max-width:480px}.settings-section{display:flex;flex-direction:column;gap:16px}.settings-section-title{font-size:14px;font-weight:600;color:var(--text-primary);padding-bottom:10px;border-bottom:1px solid var(--border)}.settings-info-row{display:flex;align-items:center;gap:12px}.settings-info-label{font-size:13px;color:var(--text-secondary);min-width:120px}.settings-info-value{font-size:13px;color:var(--text-primary);font-weight:500}.settings-form{display:flex;flex-direction:column;gap:14px}.settings-field{display:flex;flex-direction:column;gap:6px}.settings-field-label{font-size:12px;color:var(--text-secondary);font-weight:500}.settings-field input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);padding:9px 12px;font-size:13px;width:100%;transition:border-color .15s}.settings-field input:focus{outline:none;border-color:var(--accent)}.settings-msg{font-size:13px;padding:8px 12px;border-radius:var(--radius)}.settings-msg--ok{background:#22c55e1f;color:var(--accent);border:1px solid rgba(34,197,94,.3)}.settings-msg--err{background:#ef44441f;color:var(--danger);border:1px solid rgba(239,68,68,.3)}.settings-notif-status{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-body);font-weight:500;color:var(--text-primary)}.settings-notif-status-icon{color:var(--text-tertiary)}.settings-notif-status-icon--ok{color:var(--accent)}.settings-notif-status-icon--off{color:var(--danger)}.settings-notif-hint{font-size:var(--text-caption);color:var(--text-secondary);line-height:var(--leading-relaxed);max-width:480px}.adm-view{flex:1;display:flex;flex-direction:column;min-height:0}.adm-header{padding:24px 32px 0}.adm-header-body{max-width:860px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px}.adm-title{display:flex;align-items:center;gap:8px;font-size:20px;font-weight:700;color:var(--text-primary)}.adm-content{flex:1;overflow-y:auto;padding:20px 32px 32px}.adm-content-body{max-width:860px;margin:0 auto}.adm-empty{color:var(--text-secondary);font-size:14px;padding:32px 0;text-align:center}.adm-error{color:var(--danger);font-size:13px}.adm-success{display:flex;align-items:center;gap:6px;color:var(--accent);font-size:13px}.adm-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}.adm-table{width:100%;border-collapse:collapse;font-size:13px}.adm-table th{text-align:left;padding:10px 14px;background:var(--bg-hover);color:var(--text-secondary);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)}.adm-table td{padding:11px 14px;border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle}.adm-table tbody tr:last-child td{border-bottom:none}.adm-table tbody tr:hover{background:var(--bg-hover)}.adm-row--current{background:#22c55e0a}.adm-cell-id{color:var(--text-secondary);font-size:12px;width:50px}.adm-cell-username{display:flex;align-items:center;gap:6px;font-weight:500}.adm-badge-me{font-size:10px;background:var(--bg-hover);color:var(--text-secondary);padding:1px 5px;border-radius:4px}.adm-role-badge{display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;border-radius:5px;letter-spacing:.03em}.adm-role-badge--admin{background:#ef444426;color:#ef4444}.adm-role-badge--user{background:var(--bg-hover);color:var(--text-secondary)}.adm-cell-actions{display:flex;gap:6px}.adm-action-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.adm-action-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-secondary)}.adm-action-btn--danger:hover:not(:disabled){background:#ef44441f;color:#ef4444;border-color:#ef4444}.adm-action-btn:disabled{opacity:.3;cursor:not-allowed}.adm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:400;display:flex;align-items:center;justify-content:center}.adm-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:calc(var(--radius) * 1.5);width:440px;max-width:calc(100vw - 32px);box-shadow:0 20px 60px #00000080;animation:adm-pop-in .15s ease}@keyframes adm-pop-in{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.adm-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border)}.adm-modal-title{font-size:15px;font-weight:600;color:var(--text-primary)}.adm-modal-close{display:flex;align-items:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px}.adm-modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.adm-modal-form{display:flex;flex-direction:column;gap:14px;padding:18px 20px}.adm-label{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:500;color:var(--text-secondary)}.adm-input{font-size:14px;padding:8px 10px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);outline:none;transition:border-color .15s}.adm-input:focus{border-color:var(--accent)}.adm-role-btns{display:flex;gap:6px;margin-top:2px}.adm-role-btn{padding:5px 14px;border-radius:6px;font-size:12px;font-weight:600;border:1.5px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;transition:border-color .15s,color .15s,background .15s}.adm-role-btn:hover{border-color:var(--accent);color:var(--accent)}.adm-role-btn--active{border-color:var(--accent);color:var(--accent);background:#22c55e1a}.adm-modal-actions{display:flex;gap:8px;padding-top:4px}.adm-modal--sm{width:360px}.adm-confirm-text{font-size:14px;color:var(--text-primary);line-height:1.5}.color-picker{display:flex;flex-wrap:wrap;gap:var(--space-2)}.color-swatch{display:inline-flex;align-items:center;justify-content:center;border:2px solid transparent;border-radius:var(--radius-full);cursor:pointer;color:#fff;transition:transform var(--duration-fast) var(--ease-out),border-color var(--duration-fast);padding:0}.color-picker--md .color-swatch{width:24px;height:24px}.color-picker--sm .color-swatch{width:18px;height:18px}.color-swatch:hover{transform:scale(1.1)}.color-swatch:active{transform:scale(.95)}.color-swatch--active{border-color:var(--text-primary)}.project-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-5);cursor:pointer;border-radius:0;transition:background-color var(--duration-fast);-webkit-user-select:none;user-select:none;position:relative}.project-item:hover{background-color:var(--surface-2)}.project-item--active{background-color:var(--surface-2);color:var(--accent)}.project-dot{width:10px;height:10px;border-radius:var(--radius-full);flex-shrink:0;border:none;padding:0;cursor:default;transition:transform var(--duration-fast) var(--ease-out)}.project-dot--editable{cursor:pointer}.project-dot--editable:hover{transform:scale(1.3)}.project-name{flex:1;font-size:var(--text-body);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-delete{opacity:0;color:var(--text-tertiary);font-size:18px;line-height:1;padding:0 var(--space-1);border-radius:var(--radius-sm);transition:opacity var(--duration-fast),color var(--duration-fast);display:inline-flex;align-items:center}.project-item:hover .project-delete{opacity:1}.project-delete:hover{color:var(--danger)}.project-color-popover{position:fixed;z-index:var(--z-popover);padding:var(--space-3);background:var(--surface-3);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);animation:pop-in var(--duration-fast) var(--ease-spring)}.notif-bell{position:relative;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);color:var(--text-tertiary);background:none;border:none;cursor:pointer;transition:color var(--duration-fast),background-color var(--duration-fast)}.notif-bell:hover{color:var(--text-primary);background:var(--surface-2)}.notif-bell.has-unread{color:var(--accent)}.notif-bell-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;background:var(--accent);color:var(--text-on-accent);font-size:10px;font-weight:700;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center;line-height:1;border:2px solid var(--surface-1)}.notif-popover{position:fixed;z-index:var(--z-popover);width:340px;max-height:480px;background:var(--surface-3);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;animation:pop-in var(--duration-fast) var(--ease-spring)}.notif-popover-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-4) var(--space-4) var(--space-3);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.notif-popover-title{font-size:var(--text-md);font-weight:600;color:var(--text-primary)}.notif-popover-actions{display:inline-flex;align-items:center;gap:var(--space-1)}.notif-popover-action{display:inline-flex;align-items:center;gap:var(--space-1);background:none;border:none;font-family:inherit;font-size:var(--text-caption);color:var(--text-secondary);cursor:pointer;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:color var(--duration-fast),background-color var(--duration-fast)}.notif-popover-action:hover{color:var(--text-primary);background:var(--surface-2)}.notif-popover-list{flex:1;overflow-y:auto;padding:var(--space-2);display:flex;flex-direction:column;gap:1px}.notif-popover-empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-7) var(--space-5);color:var(--text-tertiary);text-align:center}.notif-popover-empty p{font-size:var(--text-body);color:var(--text-secondary);font-weight:500;margin:var(--space-1) 0 0}.notif-popover-empty span{font-size:var(--text-caption);color:var(--text-tertiary)}.notif-item{display:flex;align-items:stretch;border-radius:var(--radius-md);transition:background-color var(--duration-fast);position:relative}.notif-item:hover{background:var(--surface-2)}.notif-item-body{flex:1;display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3);background:none;border:none;font-family:inherit;cursor:pointer;text-align:left;color:var(--text-primary);min-width:0}.notif-item-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-full);background:var(--accent-bg);color:var(--accent);flex-shrink:0}.notif-item.is-read .notif-item-icon{background:var(--surface-2);color:var(--text-tertiary)}.notif-item-text{flex:1;min-width:0}.notif-item-title{font-size:var(--text-body);font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-item.is-read .notif-item-title{color:var(--text-secondary);font-weight:400}.notif-item-meta{display:flex;align-items:center;gap:var(--space-2);margin-top:2px;font-size:var(--text-micro);color:var(--text-tertiary)}.notif-item-time{font-variant-numeric:tabular-nums;font-weight:600;color:var(--text-secondary)}.notif-item-dot{position:absolute;top:8px;right:32px;width:6px;height:6px;border-radius:var(--radius-full);background:var(--accent)}.notif-item-dismiss{display:inline-flex;align-items:center;justify-content:center;width:28px;align-self:stretch;background:none;border:none;color:var(--text-tertiary);cursor:pointer;opacity:0;transition:opacity var(--duration-fast),color var(--duration-fast),background-color var(--duration-fast)}.notif-item:hover .notif-item-dismiss{opacity:1}.notif-item-dismiss:hover{color:var(--danger);background:var(--danger-bg);border-radius:0 var(--radius-md) var(--radius-md) 0}.sidebar{width:240px;min-height:100%;background-color:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:var(--space-6) var(--space-4) var(--space-3);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.sidebar-logo{font-size:var(--text-lg);font-weight:700;color:var(--accent);display:flex;align-items:center;gap:var(--space-2)}.sidebar-wordmark{letter-spacing:-.01em}.sidebar-wordmark-dot{color:var(--accent);margin-left:1px}.sidebar-quick-add{padding:10px 12px 6px}.sidebar-smart-nav{padding:8px 0 4px}.sidebar-smart-item{display:flex;align-items:center;gap:8px;padding:7px 16px;font-size:13px;color:var(--text-secondary);border-radius:0;transition:background-color .1s,color .1s;text-decoration:none;cursor:pointer}.sidebar-smart-item:hover{background-color:var(--bg-hover);color:var(--text-primary)}.sidebar-smart-item--active{color:var(--accent);background-color:#22c55e14}.sidebar-smart-icon{width:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-smart-label{flex:1}.sidebar-smart-count{background:var(--accent);color:#000;font-size:11px;font-weight:700;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}.sidebar-divider{height:1px;background:var(--border);margin:4px 0}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.btn-new-project{color:var(--text-secondary);font-size:13px;padding:6px 8px;border-radius:var(--radius);text-align:left;transition:color .15s,background-color .15s;width:100%;display:flex;align-items:center;gap:6px}.btn-new-project:hover{color:var(--accent);background-color:var(--bg-hover)}.btn-settings{display:flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:12px;padding:6px 8px;border-radius:var(--radius);text-align:left;transition:color .15s,background-color .15s;width:100%;text-decoration:none}.btn-settings:hover{color:var(--text-primary);background-color:var(--bg-hover)}.btn-settings--active{color:var(--accent)}.btn-logout{color:var(--text-tertiary);padding:var(--space-2);border-radius:var(--radius-sm);transition:color var(--duration-fast),background-color var(--duration-fast);display:inline-flex;align-items:center;justify-content:center}.btn-logout:hover{color:var(--danger);background:var(--danger-bg)}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-2);margin-top:var(--space-2);border-top:1px solid var(--border-subtle);padding-top:var(--space-4)}.sidebar-user-info{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0}.sidebar-avatar{width:28px;height:28px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent),var(--info));color:var(--text-on-accent);font-size:var(--text-caption);font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-username{font-size:var(--text-body);color:var(--text-primary);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.new-project-form{display:flex;flex-direction:column;gap:8px}.new-project-actions{display:flex;gap:8px}.dp-wrap{display:flex;flex-direction:column;gap:4px;position:relative}.dp-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.dp-trigger{display:flex;align-items:center;gap:6px;padding:7px 10px;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:border-color .15s,color .15s;white-space:nowrap;min-width:130px}.dp-trigger:hover{border-color:var(--accent);color:var(--text-primary)}.dp-trigger--open{border-color:var(--accent)}.dp-trigger-icon{flex-shrink:0;display:flex}.dp-trigger-text{flex:1}.dp-trigger-clear{color:var(--text-secondary);opacity:.6;transition:opacity .1s;padding:0 2px;display:flex;align-items:center}.dp-trigger-clear:hover{opacity:1;color:var(--danger)}.dp-popup{background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:10px;padding:14px;box-shadow:0 8px 32px #0006;min-width:260px}.dp-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.dp-nav-title{font-size:14px;font-weight:600;color:var(--text-primary)}.dp-nav-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;color:var(--text-secondary);transition:background-color .1s,color .1s}.dp-nav-btn:hover{background:var(--surface-2);color:var(--text-primary)}.dp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.dp-weekday{text-align:center;font-size:11px;color:var(--text-secondary);padding:2px 0 6px;font-weight:600}.dp-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:13px;border-radius:50%;color:var(--text-primary);border:2px solid transparent;transition:background-color .1s,color .1s,border-color .1s;cursor:pointer}.dp-day:hover{background:var(--surface-2)}.dp-day--outside{color:var(--text-secondary);opacity:.4}.dp-day--today{border-color:var(--accent);color:var(--accent);font-weight:600}.dp-day--selected{color:#fff!important;font-weight:700}.dp-shortcuts{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px;padding-top:10px;border-top:1px solid var(--border-subtle)}.dp-shortcut{font-size:12px;color:var(--text-secondary);padding:4px 8px;border-radius:6px;background:var(--surface-2);transition:color .1s,background-color .1s;display:inline-flex;align-items:center;gap:4px}.dp-shortcut:hover{color:var(--accent);background:#22c55e1f}.dp-shortcut--clear{color:var(--danger)}.dp-shortcut--clear:hover{color:var(--danger);background:#ef44441f}.tp-wrap{display:flex;flex-direction:column;gap:4px;position:relative}.tp-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.tp-trigger{display:flex;align-items:center;gap:6px;padding:7px 10px;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:border-color .15s,color .15s;white-space:nowrap;min-width:100px}.tp-trigger:hover{border-color:var(--accent);color:var(--text-primary)}.tp-trigger--open{border-color:var(--accent)}.tp-icon{flex-shrink:0;display:flex}.tp-text{flex:1;font-variant-numeric:tabular-nums}.tp-clear{color:var(--text-secondary);opacity:.6;transition:opacity .1s;padding:0 2px;display:flex;align-items:center}.tp-clear:hover{opacity:1;color:var(--danger)}.tp-popup{background:var(--surface-1);border:1px solid var(--border-strong);border-radius:var(--radius-lg);padding:var(--space-3);box-shadow:var(--shadow-md);animation:pop-in var(--duration-fast) var(--ease-spring)}.tp-columns{display:flex;gap:4px;align-items:flex-start}.tp-col{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:2px;scrollbar-width:thin;scrollbar-color:var(--surface-2) transparent;padding-right:2px}.tp-col::-webkit-scrollbar{width:3px}.tp-col::-webkit-scrollbar-track{background:transparent}.tp-col::-webkit-scrollbar-thumb{background:var(--surface-2);border-radius:99px}.tp-col::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.tp-col-label{font-size:10px;color:var(--text-secondary);text-align:center;font-weight:600;letter-spacing:.5px;padding-bottom:4px;position:sticky;top:0;background:var(--surface-1)}.tp-sep{font-size:18px;color:var(--text-secondary);font-weight:700;padding:22px 2px 0;align-self:flex-start}.tp-item{width:40px;padding:5px 0;text-align:center;font-size:14px;font-variant-numeric:tabular-nums;font-weight:500;border-radius:6px;color:var(--text-primary);transition:background-color .1s;cursor:pointer}.tp-item:hover{background:var(--surface-2)}.tp-item--selected{font-weight:700}.task-form{background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.task-form-body{padding:14px 16px 4px;display:flex;flex-direction:column;gap:6px}.task-form-title{font-size:15px;font-weight:500;color:var(--text-primary);background:transparent;border:none;outline:none;width:100%;font-family:inherit;line-height:1.4}.task-form-title::placeholder{color:var(--text-secondary);opacity:.7}.task-form-desc{resize:vertical;min-height:40px;font-size:13px;color:var(--text-secondary);background:transparent;border:none;outline:none;width:100%;font-family:inherit;line-height:1.4}.task-form-desc::placeholder{color:var(--text-secondary);opacity:.45}.task-form-smart-hint{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--accent);background:#22c55e1a;border-radius:var(--radius-md);padding:3px 8px;width:fit-content;border:1px solid rgba(34,197,94,.3)}.task-form-smart-dismiss{display:flex;align-items:center;color:var(--accent);opacity:.6;cursor:pointer;background:none;border:none;padding:0;margin-left:2px}.task-form-smart-dismiss:hover{opacity:1}.task-form-toolbar{display:flex;align-items:center;gap:4px;padding:8px 12px;border-top:1px solid var(--border-subtle);flex-wrap:wrap}.task-form-toolbar-date{display:flex;align-items:center;gap:4px}.task-form-toolbar .dp-trigger,.task-form-toolbar .tp-trigger{padding:4px 9px;font-size:12px}.task-form-toolbar-btn{display:flex;align-items:center;gap:5px;padding:4px 9px;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:transparent;color:var(--text-secondary);cursor:pointer;font-size:12px;font-family:inherit;white-space:nowrap;transition:border-color .15s,color .15s,background-color .15s}.task-form-toolbar-btn:hover{background:var(--surface-2);color:var(--text-primary);border-color:var(--text-secondary)}.task-form-toolbar-btn--active{background:var(--surface-2)}.task-form-toolbar-label{color:var(--text-secondary);font-size:12px}.task-form-dropdown{position:relative}.task-form-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:185px;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:0 8px 24px #00000073;z-index:600;overflow:hidden;animation:tf-fade-down .12s ease}@keyframes tf-fade-down{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.task-form-dropdown-menu--up{top:auto;bottom:calc(100% + 4px);animation:tf-fade-up .12s ease}@keyframes tf-fade-up{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.task-form-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;font-size:13px;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit;color:var(--text-primary);transition:background-color .1s}.task-form-dropdown-item:hover{background:var(--surface-2)}.task-form-dropdown-item--active{background:#22c55e1a;color:var(--accent)}.task-form-footer{display:flex;align-items:center;padding:10px 14px;border-top:1px solid var(--border-subtle);gap:8px}.task-form-footer-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.task-form-project-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;background:none;border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px;cursor:pointer;font-family:inherit;white-space:nowrap;transition:color .15s,border-color .15s,background-color .15s}.task-form-project-btn:hover{color:var(--text-primary);background:var(--surface-2);border-color:var(--text-secondary)}.task-form-project-hash{color:var(--accent);font-weight:700}.task-form-error{color:var(--danger);font-size:12px}.priority-btn{padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;border:1.5px solid transparent;background:var(--surface-2);transition:border-color .15s,background-color .15s;cursor:pointer}.priority-btn:hover,.priority-btn--active{background:var(--surface-0)}.qa-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:400;animation:qa-fade-in .18s ease}@keyframes qa-fade-in{0%{opacity:0}to{opacity:1}}.qa-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:401;width:560px;max-width:calc(100vw - 32px);animation:qa-pop-in .2s ease}@keyframes qa-pop-in{0%{opacity:0;transform:translate(-50%,-52%) scale(.97)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.qa-modal .task-form{border-radius:12px;box-shadow:0 20px 60px #0000008c}.tdp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:300;animation:tdp-fade-in .18s ease}@keyframes tdp-fade-in{0%{opacity:0}to{opacity:1}}.tdp-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:301;width:760px;max-width:calc(100vw - 40px);max-height:calc(100vh - 64px);background:var(--bg-secondary);border:1px solid var(--border);border-radius:14px;box-shadow:0 24px 64px #0009;display:flex;flex-direction:column;animation:tdp-pop-in .2s ease;overflow:hidden}@keyframes tdp-pop-in{0%{opacity:0;transform:translate(-50%,-52%) scale(.97)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.tdp-close{position:absolute;top:var(--space-3);right:var(--space-3);z-index:2;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-tertiary);background:none;border:none;cursor:pointer;transition:color var(--duration-fast),background-color var(--duration-fast)}.tdp-close:hover{color:var(--text-primary);background:var(--surface-3)}.tdp-loading{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--text-secondary);font-size:13px}.tdp-columns{display:flex;flex:1;overflow:hidden;min-height:0}.tdp-left{flex:1 1 55%;padding:28px 24px 20px;overflow-y:auto;display:flex;flex-direction:column;gap:16px;background:var(--surface-1);border-right:1px solid var(--border-subtle);scrollbar-width:thin;scrollbar-color:var(--surface-2) transparent}.tdp-left::-webkit-scrollbar{width:3px}.tdp-left::-webkit-scrollbar-track{background:transparent}.tdp-left::-webkit-scrollbar-thumb{background:var(--surface-2);border-radius:99px}.tdp-left::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.tdp-right{flex:0 0 260px;padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:20px;background:var(--surface-2);border-radius:0 14px 0 0;scrollbar-width:thin;scrollbar-color:var(--surface-3) transparent}.tdp-right::-webkit-scrollbar{width:3px}.tdp-right::-webkit-scrollbar-track{background:transparent}.tdp-right::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:99px}.tdp-right::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.tdp-title-row{display:flex;align-items:flex-start;gap:12px}.tdp-complete-btn{width:20px;height:20px;min-width:20px;border-radius:50%;border:2px solid var(--border);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;margin-top:4px;transition:background-color .15s,border-color .15s;color:#fff}.tdp-complete-btn--done{background:var(--accent);border-color:var(--accent)}.tdp-complete-btn:hover{border-color:var(--accent)}.tdp-title{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:18px;font-weight:600;resize:none;line-height:1.4;padding:0;font-family:inherit;overflow:hidden}.tdp-title:focus{outline:none}.tdp-title--done{text-decoration:line-through;color:var(--text-secondary);opacity:.6}.tdp-desc{width:100%;background:var(--bg-hover);border:1px solid transparent;border-radius:var(--radius);color:var(--text-primary);font-size:13px;resize:vertical;padding:10px 12px;font-family:inherit;line-height:1.5;min-height:80px;transition:border-color .15s}.tdp-desc:focus{outline:none;border-color:var(--accent)}.tdp-desc::placeholder{color:var(--text-secondary);opacity:.5}.tdp-subtasks-section{display:flex;flex-direction:column;gap:8px}.tdp-subtasks-header{display:flex;align-items:center;gap:8px}.tdp-subtasks-title{font-size:var(--text-caption);font-weight:600;color:var(--text-secondary)}.tdp-subtasks-count{font-size:11px;background:var(--bg-hover);color:var(--text-secondary);padding:1px 7px;border-radius:10px}.tdp-subtasks-list{display:flex;flex-direction:column;gap:2px}.tdp-subtask{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid var(--border)}.tdp-subtask:last-of-type{border-bottom:none}.tdp-subtask--done .tdp-subtask-title{text-decoration:line-through;color:var(--text-secondary);opacity:.6}.tdp-subtask-check{width:16px;height:16px;border:2px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;background:transparent;transition:background-color .15s,border-color .15s,color .15s;color:#fff}.tdp-subtask--done .tdp-subtask-check{background:var(--accent);border-color:var(--accent)}.tdp-subtask-check:hover{border-color:var(--accent)}.tdp-subtask-title{font-size:13px;flex:1;color:var(--text-primary)}.tdp-add-subtask{font-size:12px;color:var(--text-secondary);padding:5px 0;text-align:left;display:flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;transition:color .1s}.tdp-add-subtask:hover{color:var(--accent)}.tdp-subtask-form{display:flex;gap:6px;align-items:center;margin-top:4px;flex-wrap:wrap}.tdp-subtask-input{flex:1;min-width:0;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:13px;padding:6px 10px;font-family:inherit}.tdp-subtask-input:focus{outline:none;border-color:var(--accent)}.tdp-subtask-save-btn{font-size:12px;padding:5px 12px}.tdp-prop{display:flex;flex-direction:column;gap:6px}.tdp-prop-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-caption);color:var(--text-secondary);font-weight:600}.tdp-prop-project{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--text-primary)}.tdp-project-hash{color:var(--accent);font-weight:700}.tdp-date-row{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.tdp-priority-btns{display:flex;gap:5px;flex-wrap:wrap}.tdp-priority-dropdown{position:relative;display:inline-block}.tdp-priority-trigger{display:inline-flex;align-items:center;padding:3px 10px;font-size:12px;font-weight:700;border:1px solid currentColor;border-radius:var(--radius);background:transparent;cursor:pointer;font-family:inherit;opacity:.85;transition:opacity .15s}.tdp-priority-trigger:hover{opacity:1}.tdp-priority-menu{position:absolute;top:calc(100% + 4px);left:0;z-index:500;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0006;min-width:110px;overflow:hidden}.tdp-priority-option{display:flex;align-items:center;gap:7px;width:100%;padding:7px 12px;font-size:12px;font-weight:600;background:transparent;border:none;cursor:pointer;font-family:inherit;text-align:left;transition:background-color .1s}.tdp-priority-option:hover,.tdp-priority-option--active{background:var(--bg-hover)}.tdp-recurrence-btns{display:flex;gap:4px;flex-wrap:wrap}.tdp-recurrence-btn{padding:4px 10px;font-size:11px;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);background:transparent;cursor:pointer;transition:border-color .15s,color .15s,background-color .15s}.tdp-recurrence-btn:hover{border-color:var(--accent);color:var(--accent)}.tdp-recurrence-btn--active{border-color:var(--accent);color:var(--accent);background:#22c55e1a}.tdp-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;flex-shrink:0}.toast-stack{position:fixed;bottom:var(--space-5);right:var(--space-5);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-3);max-width:calc(100vw - var(--space-8));pointer-events:none}.toast-stack>.toast{pointer-events:auto}.toast{display:flex;align-items:center;gap:var(--space-3);min-width:260px;max-width:420px;padding:var(--space-3) var(--space-4);background:var(--surface-3);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);color:var(--text-primary);font-size:var(--text-body);animation:slide-in-right var(--duration-base) var(--ease-out)}.toast--leaving{animation:fade-in var(--duration-fast) reverse forwards}.toast-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-full);flex-shrink:0}.toast--success .toast-icon{background:var(--accent-bg);color:var(--accent)}.toast--error .toast-icon{background:var(--danger-bg);color:var(--danger)}.toast--warning .toast-icon{background:var(--warning-bg);color:var(--warning)}.toast--info .toast-icon{background:var(--info-bg);color:var(--info)}.toast--success{border-left:3px solid var(--accent)}.toast--error{border-left:3px solid var(--danger)}.toast--warning{border-left:3px solid var(--warning)}.toast--info{border-left:3px solid var(--info)}.toast-message{flex:1;line-height:var(--leading-base)}.toast-action{background:none;border:none;color:var(--accent);font-family:inherit;font-size:var(--text-body);font-weight:600;cursor:pointer;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);white-space:nowrap;transition:background-color var(--duration-fast)}.toast-action:hover{background:var(--accent-bg)}.toast-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;transition:color var(--duration-fast),background-color var(--duration-fast)}.toast-close:hover{color:var(--text-primary);background:var(--surface-2)}.app-layout{display:flex;height:100%;overflow:hidden}.app-main{flex:1;overflow:hidden;display:flex;flex-direction:column}.app-loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);font-size:14px}:root{--surface-0: #0f1623;--surface-1: #1a2332;--surface-2: #232f42;--surface-3: #2c3a52;--surface-overlay: rgba(7, 11, 19, .72);--border-subtle: rgba(255, 255, 255, .06);--border-strong: rgba(255, 255, 255, .12);--border-focus: var(--accent);--text-primary: #f3f6fb;--text-secondary: #a8b3c7;--text-tertiary: #6b7892;--text-disabled: #4a5468;--text-on-accent: #0a1612;--accent: #22c55e;--accent-hover: #16a34a;--accent-bg: rgba(34, 197, 94, .12);--accent-border: rgba(34, 197, 94, .35);--danger: #ef4444;--danger-hover: #dc2626;--danger-bg: rgba(239, 68, 68, .12);--danger-border: rgba(239, 68, 68, .35);--warning: #f97316;--warning-hover: #ea580c;--warning-bg: rgba(249, 115, 22, .12);--warning-border: rgba(249, 115, 22, .35);--info: #3b82f6;--info-hover: #2563eb;--info-bg: rgba(59, 130, 246, .12);--info-border: rgba(59, 130, 246, .35);--space-0: 0;--space-1: 2px;--space-2: 4px;--space-3: 8px;--space-4: 12px;--space-5: 16px;--space-6: 20px;--space-7: 24px;--space-8: 32px;--space-9: 48px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 10px;--radius-xl: 14px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .25);--shadow-md: 0 4px 12px rgba(0, 0, 0, .35);--shadow-lg: 0 24px 64px rgba(0, 0, 0, .55);--shadow-focus: 0 0 0 2px var(--surface-0), 0 0 0 4px var(--accent);--duration-fast: .12s;--duration-base: .2s;--duration-slow: .32s;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.32, .72, 0, 1);--ease-standard: cubic-bezier(.4, 0, .2, 1);--text-micro: 11px;--text-caption: 12px;--text-body: 13px;--text-md: 14px;--text-lg: 16px;--text-h2: 18px;--text-h1: 22px;--leading-tight: 1.3;--leading-base: 1.5;--leading-relaxed: 1.6;--z-sticky: 100;--z-overlay: 300;--z-modal: 400;--z-popover: 500;--z-toast: 600;--z-tooltip: 700;--bg-primary: var(--surface-0);--bg-secondary: var(--surface-1);--bg-hover: var(--surface-2);--border: var(--border-subtle);--radius: var(--radius-md)}*:focus{outline:none}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}input:focus-visible,textarea:focus-visible,select:focus-visible{outline:none}button:not(:disabled):not(.ui-btn):not(.task-checkbox):not(.color-swatch):not(.tdp-complete-btn):not(.tdp-subtask-check):not(.dp-day):not(.tp-item):active{transform:scale(.97);transition:transform var(--duration-fast)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes slide-in-right{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:none}}@keyframes pop-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes checkbox-pop{0%{transform:scale(1)}50%{transform:scale(1.25)}to{transform:scale(1)}}@keyframes check-draw{0%{stroke-dashoffset:16}to{stroke-dashoffset:0}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes collapse-row{to{opacity:0;transform:translate(-8px);max-height:0;padding-top:0;padding-bottom:0}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--surface-0);color:var(--text-primary);font-size:var(--text-md);line-height:var(--leading-base)}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}input,textarea,select{font:inherit;color:inherit;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);outline:none;width:100%}input:focus,textarea:focus,select:focus{border-color:var(--accent)}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-2);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}*{scrollbar-width:thin;scrollbar-color:var(--surface-2) transparent}
