:root{--bg: #0a0e1a;--surface: #131a2c;--surface-2: #1c2440;--border: rgba(255, 255, 255, .07);--border-strong: rgba(255, 255, 255, .14);--text: #f3f4f8;--text-muted: #8b94a8;--accent: #818cf8;--accent-strong: #6366f1;--accent-soft: rgba(129, 140, 248, .16);--inbox: #818cf8;--work: #f59e0b;--reading: #06b6d4;--youtube: #f43f5e;--template: #a855f7;--today: #22c55e;--today-soft: rgba(34, 197, 94, .12);--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .12);--shadow: 0 4px 20px rgba(0, 0, 0, .35);color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}button{font:inherit;cursor:pointer}input,select,textarea{font:inherit;color:inherit}.app{display:grid;grid-template-rows:auto 1fr;height:100vh}.main{overflow-y:auto;padding:32px 40px 60px}.sidebar{background:var(--surface);border-bottom:1px solid var(--border);display:flex;flex-direction:row;align-items:center;padding:12px 24px 0;gap:24px;flex-wrap:wrap}.sidebar-brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:17px;padding:0 0 12px;letter-spacing:-.01em;flex-shrink:0}.sidebar-brand-icon{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-strong) 100%);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;box-shadow:0 4px 12px #6366f159}.sidebar-nav{display:flex;flex-direction:row;gap:4px;flex:1;flex-wrap:wrap}.sidebar-item{position:relative;display:flex;align-items:center;gap:8px;padding:10px 14px 12px;border-radius:6px 6px 0 0;border:none;background:transparent;color:var(--text);text-align:left;font-size:14px;transition:background 80ms ease,color 80ms ease}.sidebar-item:hover{background:var(--surface-2);color:var(--text)}.sidebar-item.active{background:transparent;color:var(--accent);font-weight:600}.sidebar-item.active:after{content:"";position:absolute;left:12px;right:12px;bottom:-1px;height:2px;background:var(--accent);border-radius:1px}.sidebar-icon{width:18px;text-align:center}.sidebar-label{white-space:nowrap}.sidebar-count{font-size:11px;color:var(--text-muted);background:var(--surface-2);padding:1px 7px;border-radius:999px;min-width:20px;text-align:center}.sidebar-item.active .sidebar-count{background:#818cf833;color:var(--accent)}.sidebar-footer{margin-left:auto;padding:0 0 12px;flex-shrink:0}.import-export{display:flex;flex-direction:row;gap:4px}.link-btn{background:transparent;border:none;color:var(--text-muted);padding:6px 10px;text-align:left;border-radius:6px;font-size:13px}.link-btn:hover{background:var(--surface-2);color:var(--text)}.view{max-width:720px;margin:0 auto}.view-header{margin-bottom:20px}.view-header h1{margin:0;font-size:28px;letter-spacing:-.02em}.view-subtitle{margin:4px 0 0;color:var(--text-muted);font-size:14px}.add-task-trigger{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;margin-bottom:20px;box-shadow:0 4px 14px #6366f14d;transition:filter 80ms ease,transform 80ms ease}.add-task-trigger:hover{filter:brightness(1.08)}.add-task-trigger:active{transform:translateY(1px)}.add-task-trigger-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;background:#ffffff2e;font-size:14px;font-weight:700;line-height:1}.task-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.task-list-empty{background:var(--surface);border:1px dashed var(--border-strong);border-radius:10px;padding:32px 16px;text-align:center;color:var(--text-muted);font-size:14px}.task-row{display:flex;flex-direction:column}.task-item{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 12px;transition:border-color 80ms ease}.task-expand,.task-expand-spacer{width:18px;height:18px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.task-expand{background:transparent;border:none;color:var(--text-muted);font-size:11px;border-radius:4px;cursor:pointer;padding:0}.task-expand:hover{background:var(--surface-2);color:var(--text)}.task-children{margin:6px 0 0 18px;padding-left:14px;border-left:1px solid var(--border-strong);display:flex;flex-direction:column;gap:6px}.task-add-sub{background:transparent;border:none;color:var(--text-muted);font-size:16px;width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0;transition:opacity 80ms ease,color 80ms ease,background 80ms ease;cursor:pointer}.task-item:hover .task-add-sub{opacity:1}.task-add-sub:hover{color:var(--accent);background:var(--accent-soft)}.task-checkbox:disabled{opacity:.4;cursor:not-allowed}.task-item{cursor:grab}.task-item:active{cursor:grabbing}.task-item button,.task-item input{cursor:pointer}.task-item input:disabled{cursor:not-allowed}.task-item.dragging{opacity:.4}.task-item.drop-target{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 2px var(--accent-soft)}.task-item.drop-share{border-color:var(--template);background:#a855f71f;box-shadow:0 0 0 2px #a855f740}.task-item.reorder-before{box-shadow:0 -2px 0 var(--accent)}.task-item.reorder-after{box-shadow:0 2px 0 var(--accent)}.task-item{flex-wrap:wrap;align-items:flex-start;row-gap:8px}.task-item>.task-body{flex:1 1 calc(100% - 80px);min-width:0}.task-item>.task-pin,.task-item:not(:has(.task-pin))>.task-promote,.task-item:not(:has(.task-pin)):not(:has(.task-promote))>.task-add-sub{margin-left:auto}.task-item.priority-very-important{background:#dc26261f;border-color:#dc262666;box-shadow:inset 3px 0 #dc2626}.task-item.priority-very-important:hover{border-color:#dc262699}.task-item.priority-important{background:#f59e0b1a;border-color:#f59e0b59;box-shadow:inset 3px 0 #f59e0b}.task-item.priority-important:hover{border-color:#f59e0b8c}.priority-picker{display:flex;gap:6px}.priority-option{flex:1;padding:6px 10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);border-radius:6px;font-size:12px;cursor:pointer;transition:background 80ms ease,color 80ms ease,border-color 80ms ease}.priority-option:hover{border-color:var(--border-strong);color:var(--text)}.priority-option.none.active{background:var(--surface);border-color:var(--accent);color:var(--accent)}.priority-option.important.active{background:#f59e0b2e;border-color:#f59e0b;color:#f59e0b}.priority-option.very-important.active{background:#dc26262e;border-color:#dc2626;color:#ef4444}.organize-toggle{background:transparent;border:1px solid var(--border-strong);color:var(--text-muted);padding:6px 12px;border-radius:6px;font-size:13px;cursor:pointer;margin-bottom:6px;width:100%;transition:background 80ms ease,color 80ms ease,border-color 80ms ease}.organize-toggle:hover{color:var(--text);background:var(--surface-2);border-color:var(--accent)}.organize-toggle.active{background:var(--accent);border-color:var(--accent);color:#fff}.organize-toggle.active:hover{filter:brightness(1.05)}.task-item.selected{border-color:var(--accent);background:var(--accent-soft);box-shadow:inset 3px 0 0 var(--accent)}.task-item.selected:hover{border-color:var(--accent)}.bulk-action-bar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface);border:1px solid var(--border-strong);border-radius:12px;box-shadow:0 12px 40px #00000080;z-index:40}.bulk-count{font-size:13px;font-weight:600;color:var(--text);padding-right:4px}.bulk-action-add{background:var(--accent);color:#fff;border:none;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer}.bulk-action-add:hover{filter:brightness(1.05)}.bulk-action-clear{background:transparent;color:var(--text-muted);border:1px solid var(--border);padding:7px 12px;border-radius:8px;font-size:13px;cursor:pointer}.bulk-action-clear:hover{color:var(--text);background:var(--surface-2);border-color:var(--border-strong)}.task-item:hover{border-color:var(--border-strong)}.task-item.completed .task-title{text-decoration:line-through;color:var(--text-muted)}.task-children .task-item.completed{opacity:.55;filter:grayscale(.6)}.task-children .task-item.completed:hover{opacity:.85;filter:grayscale(.2)}.task-checkbox{width:18px;height:18px;flex-shrink:0;cursor:pointer}.task-body{flex:1;min-width:0;background:transparent;border:none;text-align:left;display:flex;align-items:center;gap:10px;padding:0}.task-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-meta{display:flex;gap:6px;flex-shrink:0}.task-tag{font-size:11px;padding:2px 8px;border-radius:999px;background:var(--surface-2);color:var(--text-muted);white-space:nowrap}.task-tag.section-inbox{background:#818cf82e;color:var(--inbox)}.task-tag.section-work{background:#f59e0b2e;color:var(--work)}.task-tag.section-reading{background:#06b6d433;color:var(--reading)}.task-tag.section-youtube{background:#f43f5e33;color:var(--youtube)}.task-tag.section-template{background:#a855f733;color:var(--template)}.task-tag.recurrence{background:#22c55e2e;color:var(--today)}.task-tag.front-page{background:#f59e0b2e;color:var(--work)}.task-tag.rollover{background:#22c55e26;color:#86efac;border:1px solid rgba(34,197,94,.35)}.notif-control{padding:12px 14px;border:1px solid var(--border);border-radius:8px;font-size:13px;line-height:1.4;background:var(--surface-2)}.notif-control.notif-enabled{border-color:#22c55e66;background:#22c55e14;color:#86efac}.notif-control.notif-disabled{color:var(--text-muted)}.notif-hint{display:block;font-size:11px;color:var(--text-muted);margin-top:2px}.plan-toggle{background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:12px 14px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:background 80ms ease,border-color 80ms ease,color 80ms ease}.plan-toggle:hover{background:var(--surface);border-color:var(--accent);color:var(--accent)}.plan-toggle.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.plan-mode-box{margin-top:10px;padding:12px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;display:flex;flex-direction:column;gap:10px}.plan-mode-hint{margin:0;font-size:12px;color:var(--text-muted);line-height:1.5}.plan-mode-hint code{background:var(--surface);border:1px solid var(--border);padding:1px 5px;border-radius:4px;font-size:11px;color:var(--accent)}.plan-mode-textarea{width:100%;min-height:140px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;line-height:1.5;resize:vertical;outline:none}.plan-mode-textarea:focus{border-color:var(--accent)}.plan-mode-preview{border-top:1px solid var(--border);padding-top:10px}.plan-mode-preview-heading{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.plan-mode-preview-list{list-style:none;margin:0;padding:0;font-size:13px;display:flex;flex-direction:column;gap:3px}.plan-mode-preview-list li{display:flex;align-items:baseline;gap:6px}.plan-mode-preview-bullet{color:var(--text-muted);font-size:11px;flex-shrink:0}.task-tag.shared{background:#a855f733;color:var(--template)}.bulk-action-share{background:var(--surface-2);color:var(--text);border:1px solid var(--border-strong);padding:7px 12px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer}.bulk-action-share:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.parent-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.parent-chip{display:inline-flex;align-items:center;gap:4px;background:#a855f729;border:1px solid rgba(168,85,247,.4);color:var(--template);padding:3px 4px 3px 10px;border-radius:999px;font-size:12px}.parent-chip button{background:transparent;border:none;color:var(--template);font-size:14px;width:18px;height:18px;border-radius:999px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.parent-chip button:hover{background:#a855f740}.parent-add{width:100%;margin-top:4px}.field-toggle{display:flex;align-items:flex-start;gap:10px;padding:12px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;margin-bottom:14px;cursor:pointer}.field-toggle:hover{border-color:var(--border-strong)}.field-toggle input[type=checkbox]{margin-top:2px;flex-shrink:0;cursor:pointer}.field-toggle-text{display:flex;flex-direction:column;gap:2px}.field-toggle-text strong{font-size:13px;font-weight:600;color:var(--text)}.field-toggle-hint{font-size:12px;color:var(--text-muted);line-height:1.4}.task-tag.category{background:#22c55e2e;color:var(--today)}.task-tag.date{background:var(--surface-2)}.task-tag.start-date{background:#3b82f626;color:#93c5fd;border:1px solid rgba(59,130,246,.3)}.task-tag.streak{background:#f9731626;color:#fdba74;border:1px solid rgba(249,115,22,.3);font-weight:600}.task-tag.subtasks{background:var(--surface-2)}.task-delete{background:transparent;border:none;color:var(--text-muted);font-size:18px;width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity 80ms ease}.task-item:hover .task-delete{opacity:1}.task-delete:hover{color:var(--danger);background:var(--danger-soft)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}.modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.modal-header h2{margin:0;font-size:18px}.modal-close{background:transparent;border:none;font-size:22px;width:28px;height:28px;border-radius:6px;color:var(--text-muted)}.modal-close:hover{background:var(--surface-2);color:var(--text)}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}.field>span{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.field input,.field select,.field textarea{border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:14px;outline:none;background:var(--surface)}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent)}.field-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.subtasks-block{margin-top:8px}.subtasks-block h3{font-size:14px;margin:0 0 8px}.subtle{color:var(--text-muted);font-size:13px;margin:0 0 8px}.subtask-list{list-style:none;margin:0 0 10px;padding:0;display:flex;flex-direction:column;gap:4px}.subtask-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:14px}.subtask-row .done{text-decoration:line-through;color:var(--text-muted)}.subtask-row span{flex:1}.subtask-delete{background:transparent;border:none;color:var(--text-muted);font-size:16px;width:22px;height:22px;border-radius:4px}.subtask-delete:hover{color:var(--danger)}.subtask-add{display:flex;gap:8px}.subtask-add input{flex:1;border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:14px;outline:none}.subtask-add input:focus{border-color:var(--accent)}.subtask-add button{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:6px 14px;font-size:13px}.subtask-add button:hover{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.btn-primary,.btn-secondary{padding:8px 18px;border-radius:6px;font-size:14px;border:1px solid transparent}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{filter:brightness(1.05)}.btn-secondary{background:var(--surface);border-color:var(--border);color:var(--text)}.btn-secondary:hover{background:var(--surface-2)}.category-filter{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:14px}.category-filter-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-right:4px}.category-chip{background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:4px 12px;font-size:12px;color:var(--text)}.category-chip:hover{border-color:var(--accent)}.category-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.category-chip-wrap{display:inline-flex;align-items:center;background:var(--surface);border-radius:999px}.category-chip-wrap .category-chip{border-right:none;border-radius:999px 0 0 999px}.category-delete{border:1px solid var(--border);border-left:none;border-radius:0 999px 999px 0;background:var(--surface);color:var(--text-muted);padding:4px 8px;font-size:14px;line-height:1}.category-delete:hover{color:var(--danger)}.calendar-view{max-width:880px;margin:0 auto}.calendar-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}.calendar-header h2{margin:0;font-size:22px;letter-spacing:-.02em}.calendar-header button{background:var(--surface);border:1px solid var(--border);width:32px;height:32px;border-radius:6px;font-size:18px;color:var(--text)}.calendar-header button:hover{background:var(--surface-2)}.calendar-today{margin-left:auto;width:auto!important;padding:0 14px!important;font-size:13px!important}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}.calendar-weekday{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:6px 4px;text-align:center}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:24px}.calendar-cell{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px;min-height:70px;display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;text-align:left;transition:border-color 80ms ease}.calendar-cell:hover{border-color:var(--accent)}.calendar-cell.out{background:var(--surface-2);color:var(--text-muted)}.calendar-cell.today{border-color:var(--today);background:var(--today-soft)}.calendar-cell.selected{border-color:var(--accent);background:var(--accent-soft)}.calendar-day-number{font-weight:600;font-size:14px}.calendar-cell.today .calendar-day-number{color:var(--today)}.calendar-dots{display:flex;align-items:center;gap:4px}.dot{width:6px;height:6px;border-radius:999px}.dot-inbox{background:var(--inbox)}.dot-work{background:var(--work)}.dot-reading{background:var(--reading)}.dot-youtube{background:var(--youtube)}.dot-template{background:var(--template)}.calendar-count{font-size:11px;color:var(--text-muted);margin-left:2px}.calendar-day-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;box-shadow:var(--shadow)}.calendar-day-panel-header{margin-bottom:12px}.calendar-day-panel-header h3{margin:0;font-size:16px}.view-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.view-toolbar{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.toolbar-btn,.print-btn{background:var(--surface);border:1px solid var(--border-strong);color:var(--text);padding:7px 12px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;flex-shrink:0;transition:background 80ms ease,border-color 80ms ease,color 80ms ease}.toolbar-btn:hover:not(:disabled),.print-btn:hover:not(:disabled){background:var(--surface-2);border-color:var(--accent);color:var(--accent)}.toolbar-btn:disabled,.print-btn:disabled{opacity:.4;cursor:not-allowed}.modal.modal-small{max-width:380px}.print-view{display:none}@media print{body{background:#fff!important;color:#000!important}.app *{visibility:hidden}.print-view,.print-view *{visibility:visible!important}.print-view{display:block!important;position:absolute;left:0;top:0;width:100%;background:#fff!important;color:#000!important;padding:.5in;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;column-count:3;column-gap:18pt}.print-header{column-span:all;border-bottom:1pt solid #000;padding-bottom:8pt;margin-bottom:12pt}.print-header h1{font-size:18pt;margin:0 0 4pt;color:#000}.print-meta{font-size:9pt;color:#555}.print-tree{list-style:none;margin:0;padding:0}.print-node{break-inside:avoid}.print-task{display:flex;align-items:baseline;gap:6pt;padding:1pt 0;font-size:10pt;break-inside:avoid}.print-task.completed .print-title{text-decoration:line-through;color:#888}.print-task.print-top-parent .print-title{text-decoration:underline}.print-task.print-top-parent.completed .print-title{text-decoration:underline line-through}.print-task.priority-important .print-title{font-size:11.5pt}.print-task.priority-very-important .print-title{font-size:12.5pt;font-weight:700}.print-check{font-size:11pt;color:#000}.print-title{color:#000;flex:1}.print-parent{color:#555;font-size:9pt}.print-tags{display:inline-flex;gap:6pt;flex-wrap:wrap}.print-tag{font-size:9pt;color:#555;border:.5pt solid #aaa;padding:0 6pt;border-radius:999pt}.print-notes{font-size:10pt;color:#555;font-style:italic;padding:2pt 0 6pt}.print-empty{color:#555;font-style:italic}}.library-group{margin-bottom:28px}.library-day{font-size:14px;color:var(--text-muted);margin:0 0 10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.category-group{margin-bottom:24px}.category-group-heading{display:flex;align-items:center;gap:8px;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:16px 0 10px;font-weight:600}.category-group-toggle{background:transparent;border:none;color:var(--text-muted);width:18px;height:18px;border-radius:4px;cursor:pointer;font-size:11px;padding:0;display:inline-flex;align-items:center;justify-content:center}.category-group-toggle:hover{background:var(--surface-2);color:var(--text)}.category-group.collapsed .category-group-heading{margin-bottom:0}.category-group-heading>span:first-child{color:var(--text);font-size:13px}.category-count{font-size:11px;color:var(--text-muted);background:var(--surface-2);padding:1px 8px;border-radius:999px}.add-task-icon{background:transparent;border:1px solid var(--border-strong);color:var(--text-muted);width:22px;height:22px;border-radius:999px;cursor:pointer;font-size:14px;font-weight:600;line-height:1;margin-left:2px;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:background 80ms ease,color 80ms ease,border-color 80ms ease}.add-task-icon:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.recurrence-picker{display:flex;flex-direction:column;gap:8px;padding:10px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.recurrence-presets{display:flex;gap:6px}.recurrence-preset{flex:1;padding:6px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;color:var(--text-muted);font-size:12px;cursor:pointer;transition:background 80ms ease,color 80ms ease,border-color 80ms ease}.recurrence-preset:hover{color:var(--text);border-color:var(--border-strong)}.recurrence-preset.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.recurrence-days{display:flex;gap:4px}.recurrence-day{flex:1;padding:6px 0;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:background 80ms ease,color 80ms ease,border-color 80ms ease}.recurrence-day:hover{color:var(--text);border-color:var(--border-strong)}.recurrence-day.active{background:var(--accent);color:#fff;border-color:var(--accent)}.undo-btn{background:transparent;border:1px solid var(--border);color:var(--text-muted);width:28px;height:28px;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:16px;margin-left:4px;transition:background 80ms ease,color 80ms ease,border-color 80ms ease}.undo-btn:hover:not(:disabled){background:var(--surface-2);color:var(--text);border-color:var(--border-strong)}.undo-btn:disabled{opacity:.35;cursor:not-allowed}.sidebar-search{position:relative;flex:0 1 220px;padding-bottom:12px;display:flex;align-items:center}.sidebar-search input{width:100%;padding:7px 28px 7px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px;outline:none;transition:border-color 80ms ease,background 80ms ease}.sidebar-search input::placeholder{color:var(--text-muted)}.sidebar-search input:focus{border-color:var(--accent);background:var(--surface)}.sidebar-search-clear{position:absolute;right:4px;top:50%;transform:translateY(calc(-50% - 6px));background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;line-height:1;padding:2px 6px;border-radius:4px}.sidebar-search-clear:hover{color:var(--text);background:var(--surface)}.task-breadcrumb{color:var(--text-muted);font-style:italic;font-weight:400;font-size:.92em}.task-parent-paren{color:var(--text-muted);font-weight:400;font-size:.92em;margin-left:4px}.task-promote{background:transparent;border:none;color:var(--text-muted);font-size:16px;width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0;transition:opacity 80ms ease,color 80ms ease,background 80ms ease;cursor:pointer}.task-item:hover .task-promote{opacity:1}.task-promote:hover{color:var(--accent);background:var(--accent-soft)}.task-pin{background:transparent;border:none;color:var(--text-muted);font-size:16px;width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0;cursor:pointer;transition:opacity 80ms ease,color 80ms ease,background 80ms ease}.task-item:hover .task-pin,.task-pin.active{opacity:1}.task-pin.active{color:#f59e0b}.task-pin:hover{background:#f59e0b2e;color:#fbbf24}.category-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.category-row{display:flex;align-items:stretch}.category-row-name{flex:1;text-align:left;background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:6px;cursor:text;font:inherit;font-size:14px;transition:border-color 80ms ease,background 80ms ease}.category-row-name:hover{border-color:var(--accent);background:var(--surface)}.category-row-input{flex:1;padding:8px 12px;background:var(--surface);border:1px solid var(--accent);border-radius:6px;color:var(--text);font:inherit;font-size:14px;outline:none}.field-error{color:#f87171;font-size:12px;margin:6px 0 0}.task-item.failed{background:#dc262614;border-color:#dc262659;box-shadow:inset 3px 0 #ef4444}.task-item.failed .task-title{text-decoration:line-through;color:#f87171;text-decoration-color:#f87171b3}.task-tag.failed{background:#dc26262e;color:#fca5a5;border:1px solid rgba(220,38,38,.4)}.btn-fail{background:transparent;color:#f87171;border:1px solid rgba(220,38,38,.5);padding:8px 14px;border-radius:6px;font-size:13px;cursor:pointer;margin-right:auto;transition:background 80ms ease,color 80ms ease}.btn-fail:hover{background:#dc262626;color:#fca5a5}.history-section{margin-bottom:32px}.history-section-heading{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;color:var(--text);margin:0 0 16px;padding-bottom:8px;border-bottom:1px solid var(--border)}.history-section-count{font-size:12px;font-weight:500;color:var(--text-muted);background:var(--surface-2);padding:2px 10px;border-radius:999px}.history-section:first-of-type .history-section-heading{color:#f87171;border-bottom-color:#dc26264d}.history-section:first-of-type .history-section-count{background:#dc26262e;color:#fca5a5}.week-recap{border:1px solid var(--border);background:var(--surface);border-radius:12px;padding:18px 22px;margin-bottom:28px;display:flex;flex-direction:column;gap:14px}.week-recap-heading{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.week-recap-heading h2{margin:0;font-size:18px;font-weight:700}.week-recap-window{font-size:12px;color:var(--text-muted)}.week-recap-stats{display:flex;gap:24px}.week-stat{display:flex;flex-direction:column;align-items:flex-start;padding:6px 14px 6px 0}.week-stat-num{font-size:28px;font-weight:700;color:#4ade80;line-height:1}.week-stat.failed .week-stat-num{color:#f87171}.week-stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-top:4px}.week-bars{display:flex;gap:8px;height:110px;padding-top:4px}.week-bar{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:stretch;gap:4px;height:100%}.week-bar-fill{width:100%;background:#f8717159;border-radius:4px 4px 0 0;position:relative;min-height:2px;display:flex;flex-direction:column-reverse;transition:background 80ms ease}.week-bar-completed{width:100%;background:#4ade80;border-radius:4px 4px 0 0}.week-bar-label{text-align:center}.week-bar-label{font-size:10px;color:var(--text-muted)}.week-cats{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.week-cats-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.week-cat-pill{font-size:12px;padding:3px 10px;background:var(--surface-2);border-radius:999px;color:var(--text)}.goal-progress{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:12px 16px;margin:8px 0 12px;display:flex;flex-direction:column;gap:8px}.goal-progress-header{display:flex;align-items:baseline;justify-content:space-between}.goal-progress-meta{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.goal-progress-pct{font-size:22px;font-weight:700;color:var(--accent)}.goal-progress-bar{height:8px;background:var(--surface);border-radius:999px;overflow:hidden;position:relative}.goal-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-strong, #818cf8));transition:width .2s ease-out;border-radius:999px}.goal-progress-counts{display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted)}.goal-progress-counts strong{color:var(--text);font-weight:600}.goal-progress-direct{opacity:.7}.vault-section{border-top:1px dashed var(--border);padding-top:24px}.vault-toggle{display:flex;align-items:center;gap:10px;background:transparent;border:1px solid var(--border);color:var(--text);padding:10px 14px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;width:100%;text-align:left;margin-bottom:16px;transition:background 80ms ease,border-color 80ms ease}.vault-toggle:hover{background:var(--surface-2);border-color:var(--border-strong)}.vault-caret{font-size:12px;color:var(--text-muted)}.vault-label{flex:0 0 auto}.vault-hint{margin-left:auto;font-size:12px;font-weight:400;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.calendar-mode-toggle{display:inline-flex;background:var(--surface-2);border-radius:6px;padding:2px;margin-left:12px}.calendar-mode-toggle button{background:transparent;border:none;color:var(--text-muted);padding:6px 14px;font-size:13px;border-radius:4px;cursor:pointer;transition:background 80ms ease,color 80ms ease}.calendar-mode-toggle button.active{background:var(--accent);color:#fff}.calendar-mode-toggle button:not(.active):hover{color:var(--text)}.calendar-week{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;margin-top:16px}.calendar-week-col{border:1px solid var(--border);border-radius:8px;background:var(--surface);padding:10px;display:flex;flex-direction:column;gap:8px;min-height:160px}.calendar-week-col.today{border-color:var(--accent);box-shadow:0 0 0 2px #6366f126}.calendar-week-header{display:flex;flex-direction:column;gap:2px;border-bottom:1px solid var(--border);padding-bottom:6px}.calendar-week-weekday{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.calendar-week-date{font-size:12px;color:var(--text);font-weight:600}.calendar-week-col .task-list-empty{padding:6px 4px;font-size:12px;text-align:center;border:none;background:transparent}@media (max-width: 720px){.calendar-week{grid-template-columns:1fr}.calendar-week-col{min-height:0}}.new-category-box{border:1px solid var(--border);border-radius:8px;background:var(--surface-2);padding:12px 14px 10px;margin:4px 0 10px;display:flex;flex-direction:column;gap:8px}.new-category-box>legend{padding:0 6px;font-size:12px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.04em}.new-category-box .field span{color:var(--text-muted);font-size:12px}.new-category-box-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:4px}.new-category-preview{font-size:12px;color:var(--text-muted)}.new-category-preview strong{color:var(--text);font-weight:600}.field-row-inline{display:flex;align-items:center;gap:8px}.field-row-inline select{flex:1}.category-group-name{background:transparent;border:none;color:var(--text);font:inherit;font-weight:600;padding:4px 6px;border-radius:6px;cursor:pointer;transition:background 80ms ease,color 80ms ease}.category-group-name:hover{background:var(--surface-2);color:var(--accent)}.category-edit-popover{border:1px solid var(--border);background:var(--surface-2);border-radius:8px;padding:12px 14px;margin:8px 0 14px;display:flex;flex-direction:column;gap:10px;max-width:480px}.category-edit-row{display:flex;align-items:center;gap:8px}.category-edit-row label{flex:0 0 130px;font-size:12px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.category-edit-row input{flex:1;padding:6px 10px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px;outline:none}.category-edit-row input:focus{border-color:var(--accent)}.category-edit-row button{padding:6px 14px;font-size:13px;border-radius:6px;cursor:pointer}.category-edit-footer{display:flex;justify-content:flex-end}@keyframes screen-flash{0%{opacity:.55}to{opacity:0}}body.screen-flashing:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at center,#22c55e59,#22c55e00);animation:screen-flash .35s ease-out forwards;z-index:9999}.sidebar-menu-toggle{display:none;background:transparent;border:1px solid var(--border);color:var(--text);width:36px;height:36px;border-radius:6px;cursor:pointer;align-items:center;justify-content:center;font-size:18px;margin-left:auto;transition:background 80ms ease,border-color 80ms ease}.sidebar-menu-toggle:hover{background:var(--surface-2);border-color:var(--border-strong)}@media (min-width: 768px){.sidebar-more{display:none}}@media (max-width: 767px){.app{display:flex;flex-direction:column;height:100dvh}.sidebar{display:contents}.sidebar-brand{order:-2;background:var(--surface);border-bottom:1px solid var(--border);padding:10px 14px;display:flex;align-items:center;gap:10px;width:100%;padding-top:max(10px,env(safe-area-inset-top))}.sidebar-brand-label{font-size:16px;font-weight:600;flex:1}.sidebar-brand .undo-btn{flex-shrink:0;width:40px;height:40px;font-size:20px}.sidebar-menu-toggle{display:none!important}.sidebar-search{order:-1;background:var(--surface);border-bottom:1px solid var(--border);padding:8px 12px 12px;width:100%;position:relative;flex:0 0 auto;display:block}.sidebar-search input{width:100%;height:42px;font-size:16px;padding:0 36px 0 16px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);color:var(--text)}.main{flex:1;min-height:0;overflow-y:auto;padding:16px 14px;padding-bottom:calc(76px + env(safe-area-inset-bottom))}.sidebar-nav{position:fixed;bottom:0;left:0;right:0;z-index:30;background:var(--surface);border-top:1px solid var(--border);border-bottom:none;display:flex;flex-direction:row;flex-wrap:nowrap;gap:0;padding:6px 4px;padding-bottom:max(6px,env(safe-area-inset-bottom));margin:0;box-shadow:0 -2px 12px #00000040}.sidebar-nav .sidebar-item:not([data-primary=true]){display:none}.sidebar-nav .sidebar-item{flex:1 1 0;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 2px;border-radius:8px;min-height:56px;text-align:center;color:var(--text-muted);background:transparent;font-size:11px;position:relative}.sidebar-nav .sidebar-item .sidebar-icon{width:auto;font-size:22px;line-height:1}.sidebar-nav .sidebar-item .sidebar-label{font-size:10.5px;line-height:1.1;letter-spacing:-.01em}.sidebar-nav .sidebar-item.active{color:var(--accent);background:var(--accent-soft)}.sidebar-nav .sidebar-item.active:after{display:none}.sidebar-nav .sidebar-count{position:absolute;top:2px;right:calc(50% - 22px);background:var(--accent);color:#fff;font-size:10px;font-weight:600;padding:0 5px;min-width:16px;height:16px;line-height:16px;border-radius:999px}.sidebar-nav .sidebar-item.active .sidebar-count{background:var(--accent);color:#fff}.sidebar-footer{display:none!important}.sidebar-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:35;border:none;padding:0;cursor:pointer;animation:mobile-fade-in .18s ease-out}.sidebar-sheet{position:fixed;bottom:calc(68px + env(safe-area-inset-bottom));left:0;right:0;z-index:36;background:var(--surface);border-top:1px solid var(--border-strong);border-radius:18px 18px 0 0;padding:6px 16px 20px;max-height:70vh;overflow-y:auto;box-shadow:0 -8px 32px #0009;animation:mobile-slide-up .24s cubic-bezier(.32,.72,0,1)}.sidebar-sheet-handle{width:36px;height:4px;background:var(--border-strong);border-radius:999px;margin:4px auto 12px}.sidebar-sheet-section{display:flex;flex-direction:column;gap:8px;padding:10px 0}.sidebar-sheet-section+.sidebar-sheet-section{border-top:1px solid var(--border)}.sidebar-sheet-heading{margin:0 0 4px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.sidebar-sheet-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.sidebar-sheet [data-variant=sheet]{flex:0 0 auto;flex-direction:row;justify-content:flex-start;gap:12px;padding:14px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;text-align:left;color:var(--text);font-size:14px;min-height:48px;width:100%}.sidebar-sheet [data-variant=sheet]:after{display:none}.sidebar-sheet [data-variant=sheet] .sidebar-icon{width:auto;font-size:20px}.sidebar-sheet [data-variant=sheet] .sidebar-label{font-size:14px;flex:1}.sidebar-sheet [data-variant=sheet].active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.sidebar-sheet [data-variant=sheet] .sidebar-count{position:static;background:var(--accent);color:#fff;font-size:11px;padding:1px 8px;min-width:20px;height:auto;line-height:1.4}.sidebar-sheet .organize-toggle{margin:0;padding:14px;font-size:14px;border-radius:10px}.sidebar-sheet .import-export{flex-direction:row;gap:8px}.sidebar-sheet .link-btn{flex:1;text-align:center;padding:14px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:14px}.task-item{padding:14px 12px;gap:12px;border-radius:10px}.task-checkbox{width:22px;height:22px}.task-body{flex-direction:column;align-items:flex-start;gap:6px}.task-title{white-space:normal;overflow:visible;text-overflow:clip;overflow-wrap:anywhere;word-break:normal;-webkit-hyphens:auto;hyphens:auto;width:100%;font-size:15px;line-height:1.35}.task-children{margin-left:10px;padding-left:10px}.task-children .task-children .task-children .task-add-sub,.task-children .task-children .task-children .task-promote,.task-children .task-children .task-children .task-delete,.task-children .task-children .task-children .task-pin{width:30px;height:30px;font-size:16px}.task-meta{flex-wrap:wrap;width:100%;gap:4px}.task-add-sub,.task-promote,.task-delete,.task-pin{opacity:1;width:36px;height:36px;font-size:18px}.view{max-width:100%}.view-header h1{font-size:24px}.view-header-row{flex-wrap:wrap;gap:10px}.view-toolbar{width:100%;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.view-toolbar::-webkit-scrollbar{display:none}.add-task-trigger{width:100%;padding:14px 18px;font-size:15px;margin-bottom:16px;justify-content:center;border-radius:10px}.bulk-action-bar{bottom:calc(82px + env(safe-area-inset-bottom));left:8px;right:8px;transform:none;width:auto;padding:10px 12px;border-radius:12px;flex-wrap:wrap;justify-content:center}.modal-backdrop{align-items:flex-end;padding:0}.modal{border-radius:18px 18px 0 0;max-height:92vh;width:100%;max-width:100%;padding:16px 16px calc(20px + env(safe-area-inset-bottom));animation:mobile-slide-up .24s cubic-bezier(.32,.72,0,1)}.modal:before{content:"";display:block;width:36px;height:4px;background:var(--border-strong);border-radius:999px;margin:0 auto 12px}.field input,.field select,.field textarea{font-size:16px;padding:12px;min-height:44px;border-radius:8px}.field-row{grid-template-columns:1fr}.modal-footer{flex-direction:column-reverse;gap:8px}.btn-primary,.btn-secondary{padding:14px;font-size:15px;width:100%;border-radius:10px}.calendar-cell{min-height:56px;padding:6px 4px}.calendar-day-number{font-size:13px}.calendar-header h2{font-size:18px}}@keyframes mobile-fade-in{0%{opacity:0}to{opacity:1}}@keyframes mobile-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}
