.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)}}.pwd-input{position:relative;display:flex;align-items:center;width:100%}.pwd-input__field{padding-right:40px!important;width:100%}.pwd-input__toggle{position:absolute;right:4px;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:color .18s var(--ease-out),background-color .18s var(--ease-out)}.pwd-input__toggle:hover{color:var(--text-primary);background:var(--surface-2)}.pwd-input__toggle:active{background:var(--surface-3)}@media (prefers-reduced-motion: reduce){.pwd-input__toggle{transition:none}}.animated-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:auto;z-index:0}.animated-bg__canvas{display:block;width:100%;height:100%}.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)}.login-links{margin-top:var(--space-5);display:flex;align-items:center;justify-content:center;gap:var(--space-3);font-size:var(--text-body)}.login-link{color:var(--accent);text-decoration:none;font-weight:500;transition:color var(--duration-fast) var(--ease-spring)}.login-link:hover{color:var(--accent-strong, var(--accent));text-decoration:underline}.login-links-sep{color:var(--text-secondary);opacity:.5}.login-card--wide{max-width:440px}.login-success{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);text-align:center;padding:var(--space-3) 0}.login-success-icon{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border)}.login-success-text{font-size:var(--text-body);color:var(--text-secondary);line-height:var(--leading-relaxed);max-width:320px}.login-success-text strong{color:var(--text-primary);font-weight:600}.pwd-rules{list-style:none;margin:var(--space-2) 0 0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:var(--space-1) var(--space-3)}.pwd-rule{display:flex;align-items:center;gap:6px;font-size:var(--text-caption);transition:color var(--duration-fast) var(--ease-spring)}.pwd-rule--ok{color:var(--accent)}.pwd-rule--bad{color:var(--text-secondary);opacity:.7}.pwd-mismatch{margin:var(--space-2) 0 0;font-size:var(--text-caption);color:var(--danger)}@media (max-width: 600px){.pwd-rules{grid-template-columns:1fr}}@media (max-width: 900px){.login-hero{display:none}.login-form-side{flex:1 1 100%}}@media (max-width: 600px){.login-page{padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px)}}.login-mode-back{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.login-mode-back__hint{font-size:var(--text-caption);color:var(--text-secondary);opacity:.8}.login-mode-back__btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:var(--text-caption);font-weight:600;color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--duration-fast) var(--ease-spring)}.login-mode-back__btn:hover:not(:disabled){background:var(--surface-2)}.login-mode-back__btn:disabled{opacity:.5;cursor:not-allowed}.verify-spin{animation:verify-spin .9s linear infinite}@keyframes verify-spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.verify-spin{animation:none}}.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)}.tag-chip{display:inline-flex;align-items:center;gap:2px;padding:1px 6px;font-size:var(--text-micro);font-weight:500;line-height:1.45;border:1px solid currentColor;border-radius:var(--radius-full);background:transparent;text-decoration:none;cursor:pointer;font-family:inherit;-webkit-user-select:none;user-select:none;transition:background-color var(--duration-fast),color var(--duration-fast)}.tag-chip--md{padding:2px 8px;font-size:var(--text-caption);gap:4px}.tag-chip__name{white-space:nowrap}.tag-chip__remove{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;margin-left:2px;padding:0;background:none;border:none;color:currentColor;font-size:14px;line-height:1;cursor:pointer;border-radius:50%;opacity:.6;transition:opacity var(--duration-fast)}.tag-chip__remove:hover{opacity:1}.tag-chip--accent{color:var(--accent)}.tag-chip--info{color:var(--info, #3b82f6)}.tag-chip--warning{color:var(--warning, #f59e0b)}.tag-chip--danger{color:var(--danger)}.tag-chip:hover,.tag-chip--active{background-color:color-mix(in srgb,currentColor 12%,transparent)}.task-item-wrapper{position:relative}.task-item-wrapper.is-leaving{overflow:hidden;animation:task-leave .28s var(--ease-standard, ease) forwards;pointer-events:none}@keyframes task-leave{0%{opacity:1;max-height:240px;transform:none}35%{opacity:.55}to{opacity:0;max-height:0;transform:translateY(-6px)}}.task-item--completing .task-title{text-decoration:line-through;color:var(--text-secondary);transition:color var(--duration-fast)}@media (prefers-reduced-motion: reduce){.task-item-wrapper.is-leaving{animation:none}}.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)}@media (max-width: 600px){.task-item{gap:var(--space-3);padding:var(--space-4) var(--space-3) var(--space-4) var(--space-5);min-height:var(--mobile-tap-target)}.task-checkbox{width:20px;height:20px;min-width:20px;position:relative}.task-checkbox:before{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px}.task-stripe{width:4px}.task-title{font-size:var(--text-lg);-webkit-line-clamp:3}.task-due,.task-deadline,.task-recurrence,.task-project-label{font-size:var(--text-caption)}.task-delete,.task-subtask-btn{opacity:1;color:var(--text-tertiary);padding:var(--space-3);min-width:var(--mobile-tap-target);min-height:var(--mobile-tap-target);display:flex;align-items:center;justify-content:center}.task-progress-bar{max-width:80px}.subtask-form-wrap{margin-left:0}.subtask-add-btn{margin-left:0;padding:var(--space-3) var(--space-4);min-height:var(--mobile-tap-target)}}.task-item--projected{opacity:.62}.task-item--projected .task-checkbox{cursor:default;opacity:.7}.task-item--projected .task-stripe{opacity:.6}.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:"▼ "}@media (max-width: 600px){.project-header{padding:16px 16px 12px}.project-content{padding:12px 16px 24px}.project-title{font-size:var(--text-h2)}.btn-add-task{padding:12px 0;min-height:var(--mobile-tap-target);font-size:15px}.completed-section summary{padding:12px 0;min-height:var(--mobile-tap-target);display:flex;align-items:center}}.today-streak{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap}.today-streak-done{font-size:var(--text-caption);font-weight:600;color:var(--accent)}.today-streak-flame{font-size:var(--text-caption);font-weight:700;color:var(--warning);background:var(--warning-bg);padding:2px 9px;border-radius:var(--radius-full);cursor:default;-webkit-user-select:none;user-select:none}.today-streak-flame--risk{color:var(--text-tertiary);background:var(--surface-2);filter:grayscale(.7)}.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-month--btn{display:inline-flex;align-items:center;gap:4px;background:none;border:1px solid transparent;padding:4px 8px;border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);font-family:inherit;font-size:var(--text-body);font-weight:500;transition:background-color var(--duration-fast),color var(--duration-fast)}.smart-view-month--btn:hover{background:var(--surface-2);color:var(--text-primary)}.smart-view-month--btn.is-open{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-border)}.month-cal-popup{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-3);width:280px;animation:cal-pop-in var(--duration-fast) var(--ease-spring)}@keyframes cal-pop-in{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.month-cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.month-cal-nav-title{font-size:var(--text-body);font-weight:600;color:var(--text-primary)}.month-cal-nav-btn{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer}.month-cal-nav-btn:hover{background:var(--surface-1);color:var(--text-primary)}.month-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.month-cal-wd{font-size:10px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;text-align:center;padding:4px 0;letter-spacing:.04em}.month-cal-day{background:none;border:1px solid transparent;font-family:inherit;font-size:var(--text-body);color:var(--text-primary);font-variant-numeric:tabular-nums;height:32px;border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--duration-fast)}.month-cal-day:hover{background:var(--surface-1)}.month-cal-day.is-outside{color:var(--text-tertiary);opacity:.5}.month-cal-day.is-in-week{background:var(--accent-bg);color:var(--accent)}.month-cal-day.is-today{background:var(--accent);color:var(--text-on-accent);font-weight:600}.month-cal-day.is-today:hover{background:var(--accent-hover, var(--accent))}.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--drop-target{background-color:var(--accent-bg);outline:2px dashed var(--accent);outline-offset:-2px;border-radius:var(--radius-md);transition:background-color var(--duration-fast)}.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-task-drag[draggable=true]{cursor:grab}.upcoming-task-drag[draggable=true]:active{cursor:grabbing}.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,.upcoming-mini-cal,.upcoming-mini-cal-month{display:none}@media (max-width: 600px){.smart-view-header{padding:var(--space-5) var(--space-5) 0}.smart-view-content{padding:var(--space-4) var(--space-4) var(--space-7)}.smart-view-title{font-size:var(--text-h2)}.smart-view--upcoming .smart-view-content{overflow-x:hidden;overflow-y:auto;padding:0 var(--space-4) var(--space-4)}.upcoming-week{flex-direction:column;gap:var(--space-5);height:auto;min-width:0;align-items:stretch}.upcoming-col{flex:0 0 auto;width:100%;max-width:none;min-height:0}.upcoming-col-tasks{overflow-y:visible;padding:var(--space-2) 0}.upcoming-col--today .upcoming-col-header{border-bottom-color:var(--accent-border)}.smart-view-header-upcoming .smart-view-week-nav,.smart-view-month--btn{display:none}.upcoming-mini-cal-month{display:block;font-size:var(--text-body);color:var(--text-secondary);font-weight:600;padding:var(--space-4) var(--space-4) 0;text-transform:capitalize}.upcoming-mini-cal{display:flex;align-items:center;gap:var(--space-1);margin:var(--space-2) 0 0;padding:0 var(--space-1) var(--space-4);border-bottom:1px solid var(--border-subtle)}.mini-cal-arrow{flex-shrink:0;width:32px;height:44px;display:inline-flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer}.mini-cal-arrow:disabled{opacity:.35}.mini-cal-arrow:active{background:var(--surface-2)}.mini-cal-days{flex:1;display:grid;grid-template-columns:repeat(7,1fr);gap:2px;min-width:0}.mini-cal-day{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;padding:2px 0 8px;background:none;border:none;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;min-width:0}.mini-cal-day:active{background:var(--surface-2)}.mini-cal-wd{font-size:10px;color:var(--text-tertiary);letter-spacing:.04em;text-transform:uppercase}.mini-cal-num{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;font-size:var(--text-body);font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums;border-radius:50%}.mini-cal-day.is-today .mini-cal-num{background:var(--accent);color:var(--text-on-accent)}.mini-cal-dot{position:absolute;bottom:2px;width:4px;height:4px;border-radius:50%;background:var(--accent)}.mini-cal-day.is-today .mini-cal-dot{background:var(--text-on-accent)}}.smart-view-month--static{padding:4px 8px}.cal-mode-toggle{display:inline-flex;gap:2px;margin-left:auto;padding:3px;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.cal-mode-opt{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--text-secondary);font-family:inherit;font-size:var(--text-caption);font-weight:500;cursor:pointer;transition:color var(--duration-fast),background-color var(--duration-fast)}.cal-mode-opt:hover:not(.is-active){color:var(--text-primary)}.cal-mode-opt.is-active{background:var(--surface-0);color:var(--accent);box-shadow:var(--shadow-sm)}.month-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-auto-rows:minmax(96px,1fr);gap:1px;background:var(--border-subtle);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;margin:var(--space-5) var(--space-7)}.month-grid-wd{background:var(--surface-1);padding:8px 10px;font-size:var(--text-micro);font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-tertiary);text-align:left;grid-row:1}.month-cell{min-width:0;background:var(--surface-1);min-height:96px;padding:4px 5px 6px;display:flex;flex-direction:column;gap:3px;cursor:pointer;transition:background-color var(--duration-fast)}.month-cell:hover{background:var(--surface-2)}.month-cell.is-outside{background:var(--surface-0)}.month-cell.is-outside .month-cell-num{color:var(--text-disabled)}.month-cell.is-drop{background:var(--accent-bg);outline:2px dashed var(--accent-border);outline-offset:-3px}.month-cell-num{align-self:flex-start;min-width:22px;height:22px;padding:0 5px;border:none;background:transparent;border-radius:var(--radius-full);color:var(--text-secondary);font-family:inherit;font-size:var(--text-caption);font-weight:600;cursor:pointer;transition:background-color var(--duration-fast),color var(--duration-fast)}.month-cell-num:hover{background:var(--surface-3);color:var(--text-primary)}.month-cell.is-today .month-cell-num{background:var(--accent);color:var(--text-on-accent)}.month-cell-tasks{display:flex;flex-direction:column;gap:2px;min-width:0}.month-chip{display:flex;align-items:center;gap:5px;padding:2px 5px;border-radius:var(--radius-sm);background:var(--surface-2);cursor:pointer;transition:background-color var(--duration-fast)}.month-chip:hover{background:var(--surface-3)}.month-chip--projected{opacity:.6}.month-chip-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.month-chip-title{font-size:var(--text-micro);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.month-cell-more{align-self:flex-start;border:none;background:transparent;color:var(--text-tertiary);font-family:inherit;font-size:var(--text-micro);font-weight:600;cursor:pointer;padding:1px 5px;border-radius:var(--radius-sm)}.month-cell-more:hover{color:var(--accent);background:var(--surface-2)}@media (max-width: 600px){.cal-mode-toggle{margin-left:0}.month-grid{margin:var(--space-3) var(--space-3);grid-auto-rows:minmax(58px,1fr)}.month-grid-wd{padding:5px 6px}.month-cell{min-height:58px;padding:3px}.month-chip-title{display:none}.month-chip{width:7px;height:7px;padding:0;border-radius:50%;background:transparent}.month-chip .month-chip-dot{width:7px;height:7px}.month-cell-tasks{flex-direction:row;flex-wrap:wrap;gap:3px}.month-cell-more{font-size:9px;padding:0 3px}}.day-pop{display:flex;flex-direction:column;background:var(--surface-3);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.day-pop-head{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.day-pop-date{font-size:var(--text-body);font-weight:600;color:var(--text-primary)}.day-pop-close{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;background:transparent;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:color var(--duration-fast),background-color var(--duration-fast)}.day-pop-close:hover{color:var(--text-primary);background:var(--surface-2)}.day-pop-list{overflow-y:auto;padding:6px;display:flex;flex-direction:column;gap:2px}.day-pop-item{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--duration-fast)}.day-pop-item:hover{background:var(--surface-2)}.day-pop-item--projected{opacity:.6}.day-pop-item-title{font-size:var(--text-body);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.day-pop-add{display:flex;align-items:center;gap:6px;padding:9px 12px;border:none;border-top:1px solid var(--border-subtle);background:transparent;color:var(--text-secondary);font-family:inherit;font-size:var(--text-caption);font-weight:500;cursor:pointer;flex-shrink:0;transition:color var(--duration-fast),background-color var(--duration-fast)}.day-pop-add:hover{color:var(--accent);background:var(--surface-2)}.mdp{background:var(--surface-1);border:1px solid var(--accent-border);border-radius:var(--radius-lg);padding:16px;margin-bottom:20px;max-width:560px}.mdp-head{display:flex;align-items:center;justify-content:space-between}.mdp-title{display:inline-flex;align-items:center;gap:8px;font-size:var(--text-md);font-weight:600;color:var(--text-primary)}.mdp-close{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:color var(--duration-fast),background-color var(--duration-fast)}.mdp-close:hover{color:var(--text-primary);background:var(--surface-2)}.mdp-hint{margin:4px 0 12px;font-size:var(--text-caption);color:var(--text-secondary)}.mdp-groups{display:flex;flex-direction:column;gap:14px}.mdp-group{display:flex;flex-direction:column;gap:4px}.mdp-group-label{font-size:var(--text-micro);font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:2px}.mdp-row{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--duration-fast)}.mdp-row:hover{background:var(--surface-2)}.mdp-check-input{position:absolute;opacity:0;width:0;height:0}.mdp-check{flex-shrink:0;width:18px;height:18px;border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;color:var(--text-on-accent);transition:background-color var(--duration-fast),border-color var(--duration-fast)}.mdp-check.is-on{background:var(--accent);border-color:var(--accent)}.mdp-row-title{flex:1;font-size:var(--text-body);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.mdp-tag{flex-shrink:0;font-size:var(--text-micro);font-weight:600;padding:1px 7px;border-radius:var(--radius-full)}.mdp-tag--carryover{color:var(--info);background:var(--info-bg)}.mdp-tag--overdue{color:var(--danger);background:var(--danger-bg)}.mdp-tag--today{color:var(--accent);background:var(--accent-bg)}.mdp-actions{display:flex;gap:10px;margin-top:16px}.mdp-btn{padding:8px 16px;border-radius:var(--radius-md);font-family:inherit;font-size:var(--text-body);font-weight:500;cursor:pointer;border:1px solid transparent;transition:background-color var(--duration-fast),color var(--duration-fast)}.mdp-btn:disabled{opacity:.5;cursor:not-allowed}.mdp-btn--primary{background:var(--accent);color:var(--text-on-accent)}.mdp-btn--primary:hover:not(:disabled){background:var(--accent-hover)}.mdp-btn--ghost{background:transparent;color:var(--text-secondary)}.mdp-btn--ghost:hover:not(:disabled){color:var(--text-primary);background:var(--surface-2)}@media (max-width: 600px){.mdp{max-width:none}}.myday-head{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:4px}.myday-progress{font-size:var(--text-caption);font-weight:600;color:var(--accent);background:var(--accent-bg);padding:2px 10px;border-radius:var(--radius-full)}.myday-subtitle{margin-top:2px;font-size:var(--text-body);color:var(--text-secondary)}.myday-capacity{margin-top:12px;display:flex;flex-direction:column;gap:5px;max-width:420px}.myday-capacity-bar{height:6px;border-radius:var(--radius-full);background:var(--surface-2);overflow:hidden}.myday-capacity-fill{height:100%;border-radius:var(--radius-full);background:var(--accent);transition:width var(--duration-base) var(--ease-out)}.myday-capacity-label{font-size:var(--text-caption);color:var(--text-tertiary)}.myday-capacity--over .myday-capacity-fill{background:var(--warning)}.myday-capacity--over .myday-capacity-label{color:var(--warning)}@media (max-width: 600px){.myday-capacity{max-width:none}}.review-view{flex:1;display:flex;flex-direction:column;overflow-y:auto}.review-header{padding:16px 24px;border-bottom:1px solid var(--border-subtle)}.review-title{display:flex;align-items:center;gap:8px;font-size:var(--text-h1);color:var(--text-primary)}.review-subtitle{margin-top:4px;color:var(--text-secondary);font-size:var(--text-body)}.review-content{padding:24px;max-width:620px;width:100%;display:flex;flex-direction:column;gap:24px}.review-summary{display:flex;gap:14px;flex-wrap:wrap}.review-stat{flex:1;min-width:160px;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:16px 18px;display:flex;flex-direction:column;gap:4px}.review-stat-num{display:inline-flex;align-items:center;gap:6px;font-size:var(--text-h1);font-weight:700;color:var(--accent)}.review-stat--streak .review-stat-num{color:var(--warning)}.review-stat-label{font-size:var(--text-caption);color:var(--text-secondary)}.review-section-title{font-size:var(--text-md);font-weight:600;color:var(--text-primary);margin-bottom:12px}.review-clear{display:flex;flex-direction:column;align-items:center;gap:10px;padding:32px;color:var(--accent);text-align:center}.review-clear p,.review-empty{color:var(--text-secondary);font-size:var(--text-body)}.review-list{display:flex;flex-direction:column;gap:2px;margin-bottom:14px}.review-row{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius-md);transition:background-color var(--duration-fast)}.review-row:hover{background:var(--surface-2)}.review-check{flex-shrink:0;width:18px;height:18px;border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);background:transparent;display:inline-flex;align-items:center;justify-content:center;color:var(--text-on-accent);cursor:pointer;transition:background-color var(--duration-fast),border-color var(--duration-fast)}.review-check.is-on{background:var(--accent);border-color:var(--accent)}.review-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.review-row-title{flex:1;font-size:var(--text-body);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;cursor:pointer}.review-row-title:hover{color:var(--accent)}.review-row-date{flex-shrink:0;font-size:var(--text-micro);color:var(--danger)}.review-actions{display:flex;gap:10px;flex-wrap:wrap}.review-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:var(--radius-md);font-family:inherit;font-size:var(--text-body);font-weight:500;cursor:pointer;border:1px solid transparent;transition:background-color var(--duration-fast),color var(--duration-fast)}.review-btn:disabled{opacity:.5;cursor:not-allowed}.review-btn--primary{background:var(--accent);color:var(--text-on-accent)}.review-btn--primary:hover:not(:disabled){background:var(--accent-hover)}.review-btn--ghost{background:var(--surface-2);color:var(--text-secondary)}.review-btn--ghost:hover:not(:disabled){color:var(--text-primary);background:var(--surface-3)}@media (max-width: 600px){.review-header{padding:12px 16px}.review-content{padding:16px}}.habits-view{flex:1;display:flex;flex-direction:column;overflow-y:auto}.habits-header{padding:16px 24px;border-bottom:1px solid var(--border-subtle)}.habits-title{display:flex;align-items:center;gap:8px;font-size:var(--text-h1);color:var(--text-primary)}.habits-subtitle{margin-top:4px;color:var(--text-secondary);font-size:var(--text-body)}.habits-content{padding:24px;max-width:680px;width:100%}.habits-add{display:flex;align-items:center;gap:10px;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:8px 10px;margin-bottom:20px}.habits-add-colors{display:inline-flex;gap:5px}.habits-swatch{width:16px;height:16px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;opacity:.5;transition:opacity var(--duration-fast),transform var(--duration-fast)}.habits-swatch:hover{opacity:.85}.habits-swatch.is-active{opacity:1;border-color:var(--surface-0);box-shadow:0 0 0 2px var(--border-strong)}.habits-add-input{flex:1;border:none;background:transparent;outline:none;color:var(--text-primary);font-size:var(--text-body);min-width:0}.habits-add-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-md);background:var(--accent);color:var(--text-on-accent);cursor:pointer}.habits-add-btn:disabled{opacity:.5;cursor:not-allowed}.habits-loading{color:var(--text-secondary)}.habits-list{display:flex;flex-direction:column;gap:4px}.habit-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-md);background:var(--surface-1);border:1px solid var(--border-subtle)}.habit-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.habit-name{flex:1;font-size:var(--text-md);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.habit-streak{display:inline-flex;align-items:center;gap:3px;flex-shrink:0;font-size:var(--text-caption);font-weight:700;color:var(--warning)}.habit-week{display:inline-flex;gap:4px;flex-shrink:0}.habit-day{width:26px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:var(--surface-2);color:var(--text-tertiary);cursor:pointer;padding:0;display:inline-flex;align-items:center;justify-content:center;transition:background-color var(--duration-fast),border-color var(--duration-fast)}.habit-day:hover{border-color:var(--border-strong)}.habit-day.is-done{color:var(--text-on-accent)}.habit-day.is-today{box-shadow:0 0 0 2px var(--accent-bg)}.habit-day-wd{font-size:9px;font-weight:600;text-transform:uppercase}.habit-delete{flex-shrink:0;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:inline-flex;transition:color var(--duration-fast),background-color var(--duration-fast)}.habit-delete:hover{color:var(--danger);background:var(--surface-2)}@media (max-width: 600px){.habits-header{padding:12px 16px}.habits-content{padding:16px}.habit-day{width:22px;height:28px}.habit-name{font-size:var(--text-body)}}.stepper{display:inline-flex;align-items:stretch;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;height:36px}.stepper:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg)}.stepper__btn{display:inline-flex;align-items:center;justify-content:center;width:34px;flex-shrink:0;padding:0;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:color .15s var(--ease-out),background-color .15s var(--ease-out)}.stepper__btn:hover:not(:disabled){color:var(--accent);background:var(--surface-3)}.stepper__btn:active:not(:disabled){background:var(--accent-bg)}.stepper__btn:disabled{color:var(--text-tertiary, var(--text-secondary));opacity:.4;cursor:not-allowed}.stepper__field-wrap{position:relative;display:inline-flex;align-items:center;border-left:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle);background:var(--surface-1)}.stepper__field{width:56px;height:100%;padding:0 8px;text-align:center;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:var(--text-md);font-weight:600;font-variant-numeric:tabular-nums;-moz-appearance:textfield}.stepper__field::-webkit-outer-spin-button,.stepper__field::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.stepper__field-wrap:has(.stepper__suffix) .stepper__field{width:44px;padding-right:0;text-align:right}.stepper__suffix{padding:0 10px 0 4px;color:var(--text-secondary);font-size:var(--text-caption);pointer-events:none;-webkit-user-select:none;user-select:none}@media (prefers-reduced-motion: reduce){.stepper__btn{transition:none}}.mode-switcher{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.mode-switcher__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.mode-switcher__title{font-size:var(--text-md);font-weight:600;color:var(--text-primary)}.mode-switcher__badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;font-size:var(--text-caption);font-weight:600;border-radius:var(--radius-sm);letter-spacing:.02em}.mode-switcher__badge--local{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border)}.mode-switcher__badge--remote{background:var(--info-bg);color:var(--info);border:1px solid var(--info-border)}.mode-switcher__hint{margin:0;font-size:var(--text-body);color:var(--text-secondary);line-height:1.5}.mode-switcher__note{margin:0;font-size:var(--text-caption);color:var(--text-tertiary, var(--text-secondary));line-height:1.45;opacity:.8}.theme-toggle{display:inline-flex;gap:4px;padding:4px;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.theme-toggle__opt{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-body);font-weight:500;cursor:pointer;transition:color .15s var(--ease-out),background-color .15s var(--ease-out)}.theme-toggle__opt:hover:not(.theme-toggle__opt--active){color:var(--text-primary)}.theme-toggle__opt--active{background:var(--surface-0);color:var(--accent);box-shadow:var(--shadow-sm)}@media (max-width: 600px){.theme-toggle{width:100%}.theme-toggle__opt{flex:1;justify-content:center;min-height:var(--mobile-tap-target)}}@media (prefers-reduced-motion: reduce){.theme-toggle__opt{transition: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:32px;max-width:520px}.settings-group{display:flex;flex-direction:column;gap:18px}.settings-group-label{font-size:var(--text-micro);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary)}.settings-section{display:flex;flex-direction:column;gap:16px;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:18px}.settings-section--danger{border:1px solid var(--danger-border, #7f1d1d);border-radius:var(--radius-lg, 10px);padding:16px;background:var(--danger-bg, rgba(239, 68, 68, .06))}.settings-section--danger .settings-section-title{color:var(--danger, #ef4444)}.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}@media (max-width: 600px){.settings-header{padding:16px 16px 12px}.settings-content{padding:20px 16px;gap:28px;max-width:none}.settings-info-row{flex-direction:column;align-items:flex-start;gap:4px}.settings-info-label{min-width:0}.settings-field input{font-size:16px;padding:12px 14px;min-height:var(--mobile-tap-target)}.settings-form .ui-btn{width:100%;min-height:var(--mobile-tap-target)}}.wrapped-view{min-height:100%;display:flex;flex-direction:column}.wrapped-header{display:flex;align-items:center;gap:12px;padding:16px 24px;border-bottom:1px solid var(--border-subtle)}.wrapped-back{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer}.wrapped-back:hover{background:var(--surface-2);color:var(--text-primary)}.wrapped-brand{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--accent)}.wrapped-years{margin-left:auto;display:flex;gap:6px}.wrapped-year-btn{padding:4px 12px;border-radius:var(--radius-md);border:1px solid var(--border-subtle);color:var(--text-secondary);font-size:var(--text-body);cursor:pointer;transition:all var(--duration-fast) var(--ease-spring)}.wrapped-year-btn--active{background:var(--accent);color:#06240f;border-color:var(--accent);font-weight:600}.wrapped-content{flex:1;padding:24px;max-width:880px;width:100%;margin:0 auto}.wrapped-loading{color:var(--text-secondary)}.wrapped-hero{text-align:center;padding:32px 16px 40px;background:radial-gradient(120% 120% at 50% 0%,var(--accent-bg) 0%,transparent 70%);border-radius:var(--radius-xl);margin-bottom:24px}.wrapped-hero-num{font-size:72px;font-weight:800;line-height:1;color:var(--accent);letter-spacing:-2px}.wrapped-hero-label{margin-top:12px;font-size:var(--text-lg);color:var(--text-secondary)}.wrapped-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.wrapped-card{background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:18px;display:flex;flex-direction:column;gap:6px;transition:transform var(--duration-fast) var(--ease-spring)}.wrapped-card:hover{transform:translateY(-2px)}.wrapped-card-icon{color:var(--accent)}.wrapped-card-label{font-size:var(--text-caption);color:var(--text-tertiary, var(--text-secondary));text-transform:none}.wrapped-card-value{font-size:var(--text-h2);font-weight:700;color:var(--text-primary)}.wrapped-card-sub{font-size:var(--text-caption);color:var(--text-secondary)}.wrapped-footer{margin-top:28px;display:flex;justify-content:center}@media (max-width: 600px){.wrapped-header{padding:12px 16px}.wrapped-content{padding:16px}.wrapped-hero-num{font-size:56px}.wrapped-grid{grid-template-columns:1fr}}.search-view{display:flex;flex-direction:column;height:100%}.search-header{padding:16px 24px;border-bottom:1px solid var(--border-subtle)}.search-box{display:flex;align-items:center;gap:8px;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:8px 12px;max-width:560px}.search-box:focus-within{border-color:var(--accent)}.search-box-icon{color:var(--text-secondary);flex-shrink:0}.search-input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:var(--text-md)}.search-clear{display:inline-flex;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm)}.search-clear:hover{color:var(--text-primary)}.search-content{flex:1;overflow-y:auto;padding:16px 24px;max-width:720px;width:100%}.search-hint{color:var(--text-secondary);font-size:var(--text-body)}.search-results{list-style:none;display:flex;flex-direction:column;gap:2px}.search-result{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--duration-fast) var(--ease-spring)}.search-result:hover{background:var(--surface-2)}.search-result-check{width:16px;height:16px;margin-top:2px;border:1.5px solid var(--border-strong, var(--text-tertiary));border-radius:50%;flex-shrink:0}.search-result-check.is-done{background:var(--accent);border-color:var(--accent)}.search-result-body{display:flex;flex-direction:column;gap:3px;min-width:0}.search-result-title{color:var(--text-primary);font-size:var(--text-md);line-height:1.3}.search-result--done .search-result-title{text-decoration:line-through;color:var(--text-secondary)}.search-result-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:var(--text-caption);color:var(--text-secondary)}.search-result-project{display:inline-flex;align-items:center;gap:5px}.search-result-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.search-result-badge{color:var(--accent);font-size:var(--text-micro);text-transform:uppercase;letter-spacing:.04em}@media (max-width: 600px){.search-header,.search-content{padding:12px 16px}}.fi{position:relative;flex-shrink:0;width:132px;min-height:96px;border-radius:var(--radius-lg);padding:12px;display:flex;flex-direction:column;gap:8px;overflow:hidden;color:#e8fff1}.fi-icon{opacity:.95}.fi--accent{background:linear-gradient(135deg,#166534,#052e16);color:#bbf7d0}.fi--info{background:linear-gradient(135deg,#0c4a6e,#082f49);color:#bae6fd}.fi--amber{background:linear-gradient(135deg,#854d0e,#422006);color:#fde68a}.fi--violet{background:linear-gradient(135deg,#4c1d95,#2e1065);color:#ddd6fe}.fi--danger{background:linear-gradient(135deg,#7f1d1d,#450a0a);color:#fecaca}.fi-bar{display:flex;flex-wrap:wrap;gap:4px}.fi-chip{font-size:9px;line-height:1.4;padding:1px 6px;border-radius:999px;background:#ffffff29;white-space:nowrap}.fi-chip--proj{background:#22c55e59}.fi-chip--tag{background:#38bdf859}.fi-rows{display:flex;flex-direction:column;gap:4px}.fi-row{display:flex;align-items:center;gap:5px;font-size:9px;line-height:1.3;background:#ffffff1a;border-radius:5px;padding:3px 5px}.fi-row--sub{margin-left:8px}.fi-check{width:9px;height:9px;border-radius:50%;border:1.4px solid currentColor;flex-shrink:0;opacity:.8}.fi-check--done{background:currentColor}.fi-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.fi-tag{font-size:9px;padding:1px 6px;border-radius:999px;border:1px solid currentColor}.fi-tag--accent{color:#86efac}.fi-tag--info{color:#7dd3fc}.fi-tag--warning{color:#fcd34d}.fi-progress{height:6px;border-radius:999px;background:#ffffff2e;overflow:hidden}.fi-progress i{display:block;height:100%;background:currentColor;opacity:.85}.fi-ring{align-self:flex-start;width:48px;height:48px;border-radius:50%;border:3px solid currentColor;border-top-color:transparent;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;transform:rotate(-30deg)}.fi-ring{transform:none}.fi-searchbar{font-size:9px;padding:3px 6px;border-radius:5px;background:#ffffff29}.fi-bignum{display:flex;flex-direction:column;line-height:1;font-size:28px;font-weight:800}.fi-bignum span{font-size:9px;font-weight:500;opacity:.85;margin-top:2px}@media (max-width: 600px){.fi{width:100%;min-height:84px;flex-direction:row;align-items:center;gap:12px}.fi-icon{flex-shrink:0}}.help-view{display:flex;flex-direction:column;height:100%}.help-header{padding:16px 24px;border-bottom:1px solid var(--border-subtle)}.help-title{display:flex;align-items:center;gap:8px;font-size:var(--text-h1);color:var(--text-primary)}.help-subtitle{margin-top:4px;color:var(--text-secondary);font-size:var(--text-body)}.help-content{flex:1;overflow-y:auto;padding:24px;max-width:820px;width:100%}.help-cards{display:flex;flex-direction:column;gap:14px}.help-card{background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:row;align-items:flex-start;gap:16px}.help-card-text{display:flex;flex-direction:column;gap:6px;min-width:0}.help-card-title{font-size:var(--text-md);font-weight:600;color:var(--text-primary)}.help-card-body{font-size:var(--text-body);color:var(--text-secondary);line-height:1.45}.help-card-example{font-size:var(--text-caption);color:var(--text-secondary);background:var(--surface-2);border-radius:var(--radius-md);padding:8px 10px;line-height:1.4}.help-changelog{margin-top:32px}.help-section-title{display:flex;align-items:center;gap:8px;font-size:var(--text-md);color:var(--text-primary);margin-bottom:12px}.help-cl-list{list-style:none;display:flex;flex-direction:column;gap:12px}.help-cl-item{display:flex;gap:10px}.help-cl-badge{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;flex-shrink:0;margin-top:2px}.help-cl-badge--feature{color:var(--accent);background:var(--accent-bg)}.help-cl-badge--fix{color:var(--info, #38bdf8);background:var(--info-bg, rgba(56,189,248,.12))}.help-cl-body{display:flex;flex-direction:column;gap:2px}.help-cl-title{font-weight:600;color:var(--text-primary);font-size:var(--text-body)}.help-cl-meta{font-size:var(--text-micro);color:var(--text-tertiary, var(--text-secondary))}.help-cl-desc{font-size:var(--text-caption);color:var(--text-secondary);line-height:1.4}@media (max-width: 600px){.help-header{padding:12px 16px}.help-content{padding:16px}.help-card{flex-direction:column}}.wn-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal, 1000);padding:16px}.wn-modal{background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);width:100%;max-width:460px;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg, 0 16px 48px rgba(0,0,0,.4))}.wn-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-subtle)}.wn-title{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--accent)}.wn-close{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm)}.wn-close:hover{color:var(--text-primary)}.wn-list{overflow-y:auto;padding:8px 20px;display:flex;flex-direction:column;gap:18px}.wn-entry{display:flex;flex-direction:column;gap:5px}.wn-entry:first-child{margin-top:8px}.wn-entry .fi{width:100%;min-height:104px;margin-bottom:4px;flex-direction:row;align-items:center;gap:14px}.wn-badge{display:inline-flex;align-items:center;gap:4px;align-self:flex-start;font-size:var(--text-micro);text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:var(--radius-sm)}.wn-badge--feature{color:var(--accent);background:var(--accent-bg)}.wn-badge--fix{color:var(--info, #38bdf8);background:var(--info-bg, rgba(56,189,248,.12))}.wn-entry-title{font-size:var(--text-md);font-weight:600;color:var(--text-primary)}.wn-entry-body{font-size:var(--text-body);color:var(--text-secondary);line-height:1.4}.wn-entry-example{font-size:var(--text-caption);color:var(--text-secondary);background:var(--surface-2);border-radius:var(--radius-md);padding:8px 10px;line-height:1.4}.wn-footer{padding:16px 20px;border-top:1px solid var(--border-subtle);display:flex;justify-content:flex-end}.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}@media (max-width: 600px){.adm-header{padding:16px 16px 0}.adm-header-body{flex-wrap:wrap;gap:10px}.adm-content{padding:16px 16px 24px}.adm-title{font-size:18px}.adm-action-btn{width:var(--mobile-tap-target);height:var(--mobile-tap-target)}.adm-table th,.adm-table td{padding:10px;font-size:13px}.adm-modal{width:calc(100vw - 24px);max-width:calc(100vw - 24px)}.adm-modal-form{gap:16px;padding:18px 16px}.adm-input{font-size:16px;padding:12px 14px;min-height:var(--mobile-tap-target)}.adm-role-btn{padding:10px 14px;min-height:var(--mobile-tap-target)}.adm-modal-actions{flex-direction:column-reverse}.adm-modal-actions .ui-btn{width:100%;min-height:var(--mobile-tap-target)}}.adm-content--audit{margin-top:24px}.adm-section-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 14px}.adm-audit-table{font-size:13px}.adm-cell-ts{color:var(--text-secondary);font-size:12px;white-space:nowrap}.adm-cell-ip{color:var(--text-secondary);font-family:var(--font-mono, ui-monospace, monospace);font-size:12px}.adm-op-badge{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:5px;white-space:nowrap}.adm-op-badge--user_create{background:#22c55e26;color:#22c55e}.adm-op-badge--user_delete{background:#ef444426;color:#ef4444}.adm-op-badge--user_reset_password{background:#eab30826;color:#eab308}.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-item--drop-target{background-color:var(--accent-bg);outline:2px dashed var(--accent);outline-offset:-2px;transition:background-color var(--duration-fast),outline-color var(--duration-fast)}.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)}.tag-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-5);cursor:pointer;transition:background-color var(--duration-fast);-webkit-user-select:none;user-select:none;position:relative}.tag-item:hover{background-color:var(--surface-2)}.tag-item--active{background-color:var(--surface-2);color:var(--accent)}.tag-item-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.tag-item-dot--accent{background:var(--accent)}.tag-item-dot--info{background:var(--info, #3b82f6)}.tag-item-dot--warning{background:var(--warning, #f59e0b)}.tag-item-dot--danger{background:var(--danger)}.tag-item-name{flex:1;font-size:var(--text-body);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tag-item:hover .tag-item-name,.tag-item--active .tag-item-name{color:var(--text-primary)}.tag-item-delete{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-tertiary);border-radius:var(--radius-sm);cursor:pointer;opacity:0;transition:opacity var(--duration-fast),color var(--duration-fast),background-color var(--duration-fast)}.tag-item:hover .tag-item-delete{opacity:1}.tag-item-delete:hover{color:var(--danger);background:var(--danger-bg)}@media (max-width: 600px){.tag-item-delete{opacity:.7}}.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}@media (max-width: 600px){.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--mobile-drawer-width);max-width:85vw;min-height:0;z-index:var(--z-modal);transform:translate(-100%);transition:transform var(--duration-base) var(--ease-out);box-shadow:var(--shadow-lg);padding-top:env(safe-area-inset-top,0px);overflow-y:auto;visibility:hidden}.sidebar--open{transform:translate(0);visibility:visible}}.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-section-label{font-size:var(--text-caption);font-weight:600;color:var(--text-tertiary);padding:8px 16px 4px;letter-spacing:.02em}.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}@media (max-width: 600px){.sidebar-nav{flex:0 1 auto;overflow:visible;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px))}.sidebar-footer{flex:1 1 auto}.sidebar-user{margin-top:auto}}.bottom-nav{display:none}@media (max-width: 600px){.bottom-nav{display:flex;box-sizing:border-box;position:fixed;bottom:calc(0px - env(safe-area-inset-bottom,0px));left:0;right:0;height:calc(var(--mobile-bottomnav-height) + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--surface-1);border-top:1px solid var(--border-subtle);align-items:stretch;justify-content:space-around;z-index:var(--z-sticky)}}.bn-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--text-secondary);text-decoration:none;position:relative;transition:color var(--duration-fast);min-height:var(--mobile-tap-target);background:none;border:none;cursor:pointer;font-family:inherit;padding:6px 4px;-webkit-tap-highlight-color:transparent}.bn-item:active{background:var(--surface-2)}.bn-item--active{color:var(--accent)}.bn-label{font-size:11px;line-height:1;font-weight:500}.bn-badge{position:absolute;top:4px;left:calc(50% + 4px);background:var(--accent);color:var(--text-on-accent);font-size:10px;font-weight:700;padding:1px 5px;border-radius:var(--radius-full);min-width:16px;text-align:center;line-height:1.3}.bn-fab{flex:0 0 56px;width:56px;height:56px;min-height:56px;border-radius:50%;background:var(--accent);color:var(--text-on-accent);align-self:center;margin:0 8px;box-shadow:var(--shadow-md);padding:0;transition:background-color var(--duration-fast),transform var(--duration-fast)}.bn-fab:active{background:var(--accent-hover);transform:scale(.94)}.bn-fab .bn-label{display:none}.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}@media (max-width: 600px){.dp-trigger{padding:10px 12px;font-size:14px;min-height:var(--mobile-tap-target);min-width:0}.dp-popup{position:fixed!important;bottom:0!important;left:0!important;right:0!important;top:auto!important;width:100vw;min-width:100vw;max-width:100vw;border-radius:14px 14px 0 0;padding:16px 12px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));z-index:var(--z-modal);box-shadow:0 -8px 32px #00000080;animation:dp-sheet-up var(--duration-base) var(--ease-out)}@keyframes dp-sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.dp-nav{margin-bottom:16px}.dp-nav-title{font-size:16px}.dp-nav-btn{width:var(--mobile-tap-target);height:var(--mobile-tap-target)}.dp-grid{gap:4px}.dp-weekday{font-size:12px;padding:4px 0 8px}.dp-day{font-size:15px;min-height:40px}.dp-shortcut{font-size:13px;padding:10px 14px;min-height:var(--mobile-tap-target)}}.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}@media (max-width: 600px){.tp-trigger{padding:10px 12px;font-size:14px;min-height:var(--mobile-tap-target);min-width:0}.tp-popup{position:fixed!important;bottom:0!important;left:0!important;right:0!important;top:auto!important;width:100vw;max-width:100vw;border-radius:14px 14px 0 0;padding:16px 12px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));z-index:var(--z-modal);box-shadow:0 -8px 32px #00000080;animation:tp-sheet-up var(--duration-base) var(--ease-out)}@keyframes tp-sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.tp-columns{justify-content:center;gap:12px}.tp-col{max-height:60vh;gap:4px;flex:0 0 96px}.tp-col-label{font-size:12px;padding-bottom:8px}.tp-sep{font-size:28px;padding-top:32px}.tp-item{width:96px;padding:12px 0;font-size:20px;min-height:var(--mobile-tap-target)}}.desc-editor{display:flex;flex-direction:column;gap:6px}.desc-editor-toolbar{display:flex;gap:4px;flex-wrap:wrap;align-items:center}.desc-editor-tool-sep{width:1px;align-self:stretch;margin:2px 4px;background:var(--border-subtle)}.desc-editor-tool{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer;transition:color var(--duration-fast),border-color var(--duration-fast),background-color var(--duration-fast)}.desc-editor-tool:hover{color:var(--accent);border-color:var(--accent);background:#22c55e14}.desc-editor-tool--active{color:var(--accent);border-color:var(--accent);background:#22c55e29}.desc-editor-hint{margin:0;font-size:var(--text-micro);line-height:1.4;color:var(--text-tertiary)}.desc-editor-textarea{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:72px;transition:border-color .15s}.desc-editor-textarea:focus{outline:none;border-color:var(--accent)}.desc-editor-textarea::placeholder{color:var(--text-secondary);opacity:.5}.desc-editor-rendered{width:100%;background:var(--bg-hover);border:1px solid transparent;border-radius:var(--radius);color:var(--text-primary);font-size:13px;padding:10px 12px;line-height:1.5;min-height:72px;cursor:text;transition:border-color .15s}.desc-editor-rendered:hover{border-color:var(--border-subtle)}.desc-editor-rendered .md-p{margin:0 0 8px}.desc-editor-rendered .md-p:last-child{margin-bottom:0}.desc-editor-rendered .md-ul,.desc-editor-rendered .md-ol{margin:0 0 8px;padding-left:20px}.desc-editor-rendered .md-ul li,.desc-editor-rendered .md-ol li{margin:2px 0}.desc-editor-rendered .md-quote{margin:0 0 8px;padding:4px 0 4px 12px;border-left:3px solid var(--accent);color:var(--text-secondary);font-style:italic}.desc-editor-rendered .md-code{background:var(--surface-3, rgba(255, 255, 255, .08));border-radius:var(--radius-sm);padding:1px 5px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.92em}.desc-editor-rendered strong{font-weight:600}.desc-editor-rendered em{font-style:italic}.desc-editor-rendered .md-pre{margin:0 0 8px;padding:10px 12px;background:var(--surface-3, rgba(255, 255, 255, .08));border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow-x:auto}.desc-editor-rendered .md-pre code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9em;color:var(--text-primary);white-space:pre}.desc-editor-rendered .md-h{font-weight:700;color:var(--text-primary);margin:12px 0 6px;line-height:1.3}.desc-editor-rendered .md-h:first-child{margin-top:0}.desc-editor-rendered .md-h1{font-size:var(--text-lg)}.desc-editor-rendered .md-h2{font-size:var(--text-md)}.desc-editor-rendered .md-h3{font-size:var(--text-body);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.desc-editor-rendered .md-link{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.desc-editor-rendered .md-link:hover{color:var(--accent-hover)}.desc-editor-rendered .md-ul--tasks{list-style:none;padding-left:2px}.desc-editor-rendered .md-task{display:flex;align-items:flex-start;gap:8px}.desc-editor-rendered .md-task--done{color:var(--text-tertiary);text-decoration:line-through}.desc-editor-rendered .md-checkbox{flex-shrink:0;width:15px;height:15px;margin-top:2px;border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);position:relative}.desc-editor-rendered .md-checkbox--checked{background:var(--accent);border-color:var(--accent)}.desc-editor-rendered .md-checkbox--checked:after{content:"";position:absolute;left:4px;top:1px;width:4px;height:8px;border:solid var(--text-on-accent);border-width:0 2px 2px 0;transform:rotate(45deg)}.tag-picker{position:relative;width:100%}.tag-picker__field{display:flex;flex-wrap:wrap;align-items:center;gap:4px;padding:6px 8px;min-height:32px;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:text;transition:border-color var(--duration-fast)}.tag-picker__field:focus-within{border-color:var(--accent)}.tag-picker__icon{color:var(--text-tertiary);flex-shrink:0}.tag-picker__placeholder{color:var(--text-tertiary);font-size:var(--text-body)}.tag-picker__input{flex:1;min-width:80px;background:transparent;border:none;outline:none;color:var(--text-primary);font-family:inherit;font-size:var(--text-body);padding:0}.tag-picker__menu{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:var(--z-popover, 1000);max-height:240px;overflow-y:auto;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:4px}.tag-picker__option{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;background:none;border:none;color:var(--text-primary);font-family:inherit;font-size:var(--text-body);text-align:left;cursor:pointer;border-radius:var(--radius-sm)}.tag-picker__option:hover{background:var(--surface-3, var(--surface-1))}.tag-picker__option--create{color:var(--accent);border-top:1px solid var(--border-subtle);margin-top:2px;padding-top:8px}.tag-picker__swatch{width:10px;height:10px;border-radius:50%;flex-shrink:0}.tag-picker__swatch--accent{background:var(--accent)}.tag-picker__swatch--info{background:var(--info, #3b82f6)}.tag-picker__swatch--warning{background:var(--warning, #f59e0b)}.tag-picker__swatch--danger{background:var(--danger)}.tag-picker__option-name{flex:1}.tag-picker__empty{padding:8px;color:var(--text-tertiary);font-size:var(--text-caption);text-align:center}.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-subtasks{margin-top:8px}.task-form-subtask-list{list-style:none;margin:0 0 6px;padding:0;display:flex;flex-direction:column;gap:2px}.task-form-subtask-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-primary);padding:3px 4px;border-radius:var(--radius-sm)}.task-form-subtask-item:hover{background:var(--surface-2)}.task-form-subtask-icon{color:var(--accent);flex-shrink:0}.task-form-subtask-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-form-subtask-remove{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:2px;border-radius:var(--radius-sm);opacity:.6}.task-form-subtask-remove:hover{opacity:1;color:var(--danger)}.task-form-subtask-add{display:flex;align-items:center;gap:6px}.task-form-subtask-input{flex:1;font-size:13px;color:var(--text-primary);background:transparent;border:none;border-bottom:1px dashed var(--border-subtle);outline:none;padding:4px 2px;font-family:inherit}.task-form-subtask-input::placeholder{color:var(--text-secondary);opacity:.45}.task-form-subtask-addbtn{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--accent);cursor:pointer;padding:4px;flex-shrink:0}.task-form-subtask-addbtn:disabled{opacity:.4;cursor:not-allowed}.task-form-subtask-addbtn:not(:disabled):hover{background:var(--surface-2)}.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)}@media (max-width: 600px){.task-form-body{padding:16px 16px 8px;gap:8px}.task-form-title{font-size:16px;min-height:32px}.task-form-desc{font-size:14px;min-height:48px}.task-form-toolbar{padding:10px 12px;gap:6px}.task-form-toolbar-btn,.task-form-toolbar .dp-trigger,.task-form-toolbar .tp-trigger{padding:8px 12px;font-size:13px;min-height:36px}.task-form-footer{padding:12px 14px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));gap:10px}.task-form-project-btn{padding:8px 12px;min-height:40px;flex-shrink:0}.task-form-footer-actions{flex:1;justify-content:flex-end}.task-form-footer-actions .ui-btn{min-height:var(--mobile-tap-target)}}.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}@media (max-width: 600px){.qa-modal{top:auto;left:0;right:0;bottom:0;transform:none;width:100vw;max-width:100vw;animation:qa-slide-up var(--duration-base) var(--ease-out)}@keyframes qa-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.qa-modal .task-form{border-radius:14px 14px 0 0;border-bottom:none;padding-bottom:env(safe-area-inset-bottom,0px)}}.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-mobile-bar{display:none}.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-block{display:flex;flex-direction:column;gap:6px}.tdp-desc-toolbar{display:flex;gap:4px;flex-wrap:wrap;align-items:center}.tdp-desc-tool-sep{width:1px;align-self:stretch;margin:2px 4px;background:var(--border-subtle)}.tdp-desc-tool{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer;transition:color var(--duration-fast),border-color var(--duration-fast),background-color var(--duration-fast)}.tdp-desc-tool:hover{color:var(--accent);border-color:var(--accent);background:#22c55e14}.tdp-desc-tool--active{color:var(--accent);border-color:var(--accent);background:#22c55e29}.tdp-desc-hint{margin:0;font-size:var(--text-micro);line-height:1.4;color:var(--text-tertiary)}.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-desc-rendered{width:100%;background:var(--bg-hover);border:1px solid transparent;border-radius:var(--radius);color:var(--text-primary);font-size:13px;padding:10px 12px;line-height:1.5;min-height:80px;cursor:text;transition:border-color .15s}.tdp-desc-rendered:hover{border-color:var(--border-subtle)}.tdp-desc-rendered .md-p{margin:0 0 8px}.tdp-desc-rendered .md-p:last-child{margin-bottom:0}.tdp-desc-rendered .md-ul,.tdp-desc-rendered .md-ol{margin:0 0 8px;padding-left:20px}.tdp-desc-rendered .md-ul li,.tdp-desc-rendered .md-ol li{margin:2px 0}.tdp-desc-rendered .md-quote{margin:0 0 8px;padding:4px 0 4px 12px;border-left:3px solid var(--accent);color:var(--text-secondary);font-style:italic}.tdp-desc-rendered .md-code{background:var(--surface-3, rgba(255, 255, 255, .08));border-radius:var(--radius-sm);padding:1px 5px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.92em}.tdp-desc-rendered strong{font-weight:600}.tdp-desc-rendered em{font-style:italic}.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);cursor:text;min-width:0;border-radius:var(--radius-sm);padding:1px 3px;margin:-1px -3px}.tdp-subtask-title:hover{background:var(--surface-2)}.tdp-subtask-edit-input{flex:1;min-width:0;background:var(--bg-primary);border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;font-family:inherit;padding:3px 6px}.tdp-subtask-edit-input:focus{outline:none}.tdp-subtask-edit,.tdp-subtask-delete{display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0;border:none;background:none;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;opacity:0;transition:opacity var(--duration-fast),color var(--duration-fast),background-color var(--duration-fast)}.tdp-subtask:hover .tdp-subtask-edit,.tdp-subtask:hover .tdp-subtask-delete{opacity:1}.tdp-subtask-edit:hover{color:var(--text-primary);background:var(--surface-3)}.tdp-subtask-delete:hover{color:var(--danger);background:var(--danger-bg)}@media (max-width: 600px){.tdp-subtask-edit,.tdp-subtask-delete{opacity:1}}.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}@media (max-width: 600px){.tdp-modal{top:auto;left:0;right:0;bottom:0;transform:none;width:100vw;max-width:100vw;height:calc(100vh - 80px - env(safe-area-inset-top,0px));max-height:calc(100vh - 80px - env(safe-area-inset-top,0px));height:calc(100dvh - 80px - env(safe-area-inset-top,0px));max-height:calc(100dvh - 80px - env(safe-area-inset-top,0px));border-radius:14px 14px 0 0;animation:tdp-slide-up var(--duration-base) var(--ease-out);padding-top:0}.tdp-modal:before{content:"";display:block;position:absolute;top:6px;left:50%;transform:translate(-50%);width:40px;height:4px;background:var(--text-tertiary);border-radius:var(--radius-full);opacity:.45;z-index:1;pointer-events:none}@keyframes tdp-slide-up{0%{transform:translateY(100%);opacity:.8}to{transform:translateY(0);opacity:1}}.tdp-columns{flex-direction:column}.tdp-left{flex:1 1 auto;border-right:none;border-bottom:1px solid var(--border-subtle);padding:24px 16px 16px}.tdp-right{flex:0 0 auto;width:100%;border-radius:0;padding:16px;gap:16px}.tdp-title{font-size:20px}.tdp-footer{position:sticky;bottom:0;background:var(--surface-1);border-top:1px solid var(--border-subtle);padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));gap:10px}.tdp-footer>.ui-btn,.tdp-footer>span{flex:1}.tdp-footer .ui-btn{width:100%;min-height:var(--mobile-tap-target)}.tdp-close,.tdp-mobile-bar,.tdp-mobile-close{display:none}.tdp-left{padding-top:20px}.tdp-subtask-form{gap:8px}.tdp-subtask-input{flex:1 1 100%;min-height:var(--mobile-tap-target)}.tdp-subtask-save-btn,.tdp-subtask-form .ui-btn{flex:1}.tdp-complete-btn{width:24px;height:24px;min-width:24px}.tdp-subtask-check{width:20px;height:20px;min-width:20px}.tdp-subtask{padding:10px 0}.tdp-recurrence-btn{padding:8px 14px;font-size:12px}.tdp-priority-trigger{padding:6px 14px;font-size:13px}}.tdp-myday-toggle{padding:5px 12px;border:1px solid var(--border-subtle);background:var(--surface-2);border-radius:var(--radius-md);color:var(--text-secondary);font-family:inherit;font-size:var(--text-caption);font-weight:500;cursor:pointer;transition:color var(--duration-fast),background-color var(--duration-fast),border-color var(--duration-fast)}.tdp-myday-toggle:hover{color:var(--text-primary)}.tdp-myday-toggle.is-on{color:var(--accent);background:var(--accent-bg);border-color:var(--accent-border)}.tdp-estimate-row{display:flex;align-items:center;gap:10px}.tdp-estimate-add{padding:5px 12px;border:1px dashed var(--border-strong);background:transparent;border-radius:var(--radius-md);color:var(--text-secondary);font-family:inherit;font-size:var(--text-caption);cursor:pointer;transition:color var(--duration-fast),border-color var(--duration-fast)}.tdp-estimate-add:hover{color:var(--accent);border-color:var(--accent-border)}.tdp-estimate-clear{border:none;background:transparent;color:var(--text-tertiary);font-family:inherit;font-size:var(--text-micro);cursor:pointer;text-decoration:underline}.tdp-estimate-clear:hover{color:var(--danger)}.tdp-estimate-col{display:flex;flex-direction:column;gap:6px;align-items:flex-end}.tdp-fact{font-size:var(--text-micro);color:var(--text-tertiary)}.tdp-fact--over{color:var(--warning)}.focus-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;display:flex;align-items:center;justify-content:center;padding:var(--space-6);animation:focus-fade-in .2s ease-out}.focus-overlay__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000c7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@keyframes focus-fade-in{0%{opacity:0}to{opacity:1}}.focus-overlay__card{position:relative;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-7) var(--space-6) var(--space-6);max-width:420px;width:100%;display:flex;flex-direction:column;align-items:center;gap:var(--space-5);box-shadow:var(--shadow-lg);animation:focus-card-pop .24s var(--ease-spring)}@keyframes focus-card-pop{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.focus-overlay__close{position:absolute;top:var(--space-3);right:var(--space-3);width:32px;height:32px;border-radius:var(--radius-md);background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background-color var(--duration-fast),color var(--duration-fast)}.focus-overlay__close:hover{color:var(--text-primary);background:var(--surface-2)}.focus-overlay__kind{display:inline-flex;align-items:center;gap:6px;font-size:var(--text-caption);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.focus-overlay__task{font-size:var(--text-md);color:var(--text-primary);text-align:center;font-weight:500;max-width:360px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.focus-overlay__timer{position:relative;width:220px;height:220px;display:flex;align-items:center;justify-content:center}.focus-overlay__ring{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;transform:rotate(-90deg)}.focus-overlay__ring-track{fill:none;stroke:var(--surface-2);stroke-width:4}.focus-overlay__ring-progress{fill:none;stroke:var(--accent);stroke-width:4;stroke-linecap:round;transition:stroke-dasharray 1s linear}.focus-overlay__timer.is-overrun .focus-overlay__ring-progress{stroke:var(--warning, #f59e0b)}.focus-overlay__timer.is-paused .focus-overlay__ring-progress{opacity:.5}.focus-overlay__time{font-size:52px;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.focus-overlay__timer.is-overrun .focus-overlay__time{color:var(--warning, #f59e0b)}.focus-overlay__timer.is-paused .focus-overlay__time{opacity:.55}.focus-overlay__actions{display:flex;flex-wrap:wrap;gap:var(--space-2);justify-content:center}.focus-overlay__hint{font-size:var(--text-caption);color:var(--text-tertiary);text-align:center;max-width:320px}@media (max-width: 600px){.focus-overlay__card{padding:var(--space-6) var(--space-5) var(--space-5);gap:var(--space-4)}.focus-overlay__timer{width:180px;height:180px}.focus-overlay__time{font-size:42px}}@media (prefers-reduced-motion: reduce){.focus-overlay,.focus-overlay__card{animation:none}.focus-overlay__ring-progress{transition:none}}.cmdp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--surface-overlay);display:flex;align-items:flex-start;justify-content:center;padding-top:12vh;z-index:var(--z-modal, 1000)}.cmdp{width:100%;max-width:560px;background:var(--surface-3);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden;display:flex;flex-direction:column;max-height:60vh}.cmdp-input-row{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.cmdp-input-icon{color:var(--text-tertiary);flex-shrink:0}.cmdp-input{flex:1;border:none;background:transparent;outline:none;color:var(--text-primary);font-size:var(--text-lg)}.cmdp-input::placeholder{color:var(--text-tertiary)}.cmdp-esc{font-size:var(--text-micro);color:var(--text-tertiary);background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:1px 6px}.cmdp-list{overflow-y:auto;padding:6px}.cmdp-empty{padding:24px;text-align:center;color:var(--text-secondary);font-size:var(--text-body)}.cmdp-group{margin-bottom:4px}.cmdp-group-label{font-size:var(--text-micro);font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-tertiary);padding:8px 10px 4px}.cmdp-item{width:100%;display:flex;align-items:center;gap:10px;padding:8px 10px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:var(--text-body);text-align:left;cursor:pointer}.cmdp-item--active{background:var(--accent-bg)}.cmdp-item-icon{color:var(--text-secondary);flex-shrink:0}.cmdp-item--active .cmdp-item-icon{color:var(--accent)}.cmdp-item-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cmdp-item-enter{color:var(--accent);flex-shrink:0}@media (max-width: 600px){.cmdp-overlay{padding-top:8vh;padding-left:12px;padding-right:12px}}.sch-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--surface-overlay);display:flex;align-items:center;justify-content:center;padding:16px;z-index:var(--z-modal, 1000)}.sch{width:100%;max-width:420px;background:var(--surface-3);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden}.sch-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-subtle)}.sch-title{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--text-primary)}.sch-close{color:var(--text-secondary);cursor:pointer;border:none;background:transparent;border-radius:var(--radius-sm);display:inline-flex}.sch-close:hover{color:var(--text-primary)}.sch-list{padding:8px 10px 12px}.sch-row{display:flex;align-items:center;justify-content:space-between;padding:7px 8px;border-radius:var(--radius-sm)}.sch-row:hover{background:var(--surface-2)}.sch-label{font-size:var(--text-body);color:var(--text-secondary)}.sch-keys{display:inline-flex;gap:4px}.sch-kbd{min-width:22px;text-align:center;font-size:var(--text-caption);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--text-primary);background:var(--surface-1);border:1px solid var(--border-strong);border-bottom-width:2px;border-radius:var(--radius-sm);padding:2px 6px}.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}.drawer-backdrop{display:none}@media (max-width: 600px){.drawer-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:var(--surface-overlay);z-index:calc(var(--z-modal) - 1);animation:drawer-backdrop-fade var(--duration-base) var(--ease-out)}@keyframes drawer-backdrop-fade{0%{opacity:0}to{opacity:1}}}@media (max-width: 600px){.app-layout{padding-top:env(safe-area-inset-top,0px)}.app-main{padding-bottom:calc(var(--mobile-bottomnav-height) + env(safe-area-inset-bottom,0px))}}: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;--mobile-bottomnav-height: 64px;--mobile-tap-target: 44px;--mobile-drawer-width: 280px;--bg-primary: var(--surface-0);--bg-secondary: var(--surface-1);--bg-hover: var(--surface-2);--border: var(--border-subtle);--radius: var(--radius-md)}:root[data-theme=light]{--surface-0: #eceff3;--surface-1: #ffffff;--surface-2: #eef1f6;--surface-3: #ffffff;--surface-overlay: rgba(15, 22, 35, .42);--border-subtle: rgba(15, 22, 35, .09);--border-strong: rgba(15, 22, 35, .16);--border-focus: var(--accent);--text-primary: #1a2230;--text-secondary: #51607a;--text-tertiary: #8593a8;--text-disabled: #aab3c2;--text-on-accent: #ffffff;--accent: #16a34a;--accent-hover: #15803d;--accent-bg: rgba(22, 163, 74, .12);--accent-border: rgba(22, 163, 74, .3);--danger: #dc2626;--danger-hover: #b91c1c;--danger-bg: rgba(220, 38, 38, .1);--danger-border: rgba(220, 38, 38, .3);--warning: #d97706;--warning-hover: #b45309;--warning-bg: rgba(217, 119, 6, .12);--warning-border: rgba(217, 119, 6, .3);--info: #2563eb;--info-hover: #1d4ed8;--info-bg: rgba(37, 99, 235, .1);--info-border: rgba(37, 99, 235, .3);--shadow-sm: 0 1px 2px rgba(15, 22, 35, .08);--shadow-md: 0 4px 12px rgba(15, 22, 35, .1);--shadow-lg: 0 24px 64px rgba(15, 22, 35, .18)}*: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):not(.pwd-input__toggle):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}button,a,input,textarea,select,[role=button]{touch-action:manipulation;-webkit-tap-highlight-color:transparent}html,body{overscroll-behavior-y:none}@media (max-width: 600px){html{background-color:var(--surface-1)}}
