.layout{min-height:100vh;display:flex;flex-direction:column}.header{position:sticky;top:0;z-index:50;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;max-width:57.6rem;width:100%;margin:0 auto}.header-title{display:flex;align-items:center;gap:.5rem;margin:0;cursor:pointer;-webkit-user-select:none;user-select:none}.header-logo{color:var(--color-primary);flex-shrink:0}.header-title-text{font-size:1.4rem;font-weight:700;letter-spacing:.02em;line-height:1}.header-title-s{color:var(--color-primary);font-weight:800}.header-actions{display:flex;align-items:center;gap:.5rem}.header-icon{background:transparent;color:var(--color-muted);border:none;padding:.25rem;display:flex;align-items:center;justify-content:center;cursor:pointer}.header-icon:hover{color:var(--color-primary);background:transparent}.main{flex:1;padding:.75rem 1rem 5rem;max-width:57.6rem;width:100%;margin:0 auto}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh}.login-form{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:20rem;padding:2rem;background:var(--color-surface);border-radius:8px;border:1px solid var(--color-border)}.login-form h2{text-align:center;margin:0;font-size:1.6rem;letter-spacing:.02em}.login-brand{display:flex;align-items:center;justify-content:center;gap:.6rem;margin-bottom:.5rem;color:var(--color-primary)}.login-brand svg{flex-shrink:0}.login-brand h2{color:var(--color-text)}.brand-s{color:var(--color-primary);font-weight:800}.login-error{color:var(--color-danger);font-size:.85rem;margin:0;text-align:center}.cat-picker-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:149;background:transparent}.cat-picker-panel{position:fixed;z-index:150;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;box-shadow:0 6px 24px #00000059;padding:.6rem;display:flex;flex-direction:column;gap:.5rem;max-width:min(22rem,calc(100vw - 2rem));animation:catPickerIn .12s ease-out}.cat-picker-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-muted)}.cat-picker-chips{display:flex;flex-wrap:wrap;gap:.3rem}.cat-picker-chip{padding:.35rem .75rem;border-radius:14px;font-size:.8rem;cursor:pointer;border:1.5px solid var(--color-border);background:transparent;color:var(--color-text);transition:all .12s}.cat-picker-chip:hover{border-color:var(--color-primary)}.cat-picker-active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.cat-picker-none{color:var(--color-muted);border-style:dashed}.cat-picker-sub{padding:.3rem .65rem;border-radius:4px;font-size:.78rem;cursor:pointer;border:1.5px solid var(--color-border);background:transparent;color:var(--color-muted);transition:all .12s}.cat-picker-sub:hover{border-color:var(--color-primary)}.cat-picker-sub-active{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 15%,transparent);color:var(--color-primary)}@keyframes catPickerIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.task-item-wrapper{position:relative;overflow:visible;border-radius:6px;width:100%;min-width:0}.task-item-wrapper.swiped,.task-item-wrapper.swiped-right{overflow:hidden}.task-item.task-highlight-active{animation:taskHighlight 1.8s ease-out}@keyframes taskHighlight{0%,20%{background:#6495ed4d;box-shadow:0 0 0 2px var(--color-primary),0 0 12px #6495ed66}to{background:var(--color-surface);box-shadow:none}}.task-item-wrapper .task-item{transition:transform .25s ease,border-color .15s}.task-item-wrapper.swiped .task-item{transform:translate(-60px)}.task-item-wrapper.swiped-right .task-item{transform:translate(60px)}.task-delete-btn{position:absolute;right:0;top:0;bottom:0;width:60px;display:flex;align-items:center;justify-content:center;background:var(--color-danger);color:#fff;border:none;cursor:pointer;animation:fadeIn .2s ease}.task-complete-btn{position:absolute;left:0;top:0;bottom:0;width:60px;display:flex;align-items:center;justify-content:center;background:var(--color-success);color:#fff;border:none;cursor:pointer;animation:fadeIn .2s ease;border-radius:6px 0 0 6px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.task-item{position:relative;display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;cursor:pointer;transition:border-color .15s}.task-item:hover{border-color:var(--color-primary)}.task-item.task-completed{opacity:.45}.task-item.task-drag-over{border-color:var(--color-primary);background:#6495ed1a}.task-item.task-drop-ok{border-color:var(--color-success);background:#4ecca31a}.task-item.task-drop-fail{border-color:var(--color-danger);background:#e945601a}.task-drop-message{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);font-size:.7rem;font-weight:600;padding:.15rem .4rem;border-radius:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%;animation:dropMsgIn .2s ease-out}.task-drop-message.drop-msg-ok{color:#fff;background:var(--color-success)}.task-drop-message.drop-msg-fail{color:#fff;background:var(--color-danger)}@keyframes dropMsgIn{0%{opacity:0;transform:translateY(-50%) translate(.5rem)}to{opacity:1;transform:translateY(-50%) translate(0)}}.task-check-wrapper{flex-shrink:0;width:1.75rem;height:1.75rem;position:relative;cursor:pointer;display:flex;align-items:center;justify-content:center}.task-check-box{width:1.1rem;height:1.1rem;border:1.5px solid var(--color-border);border-radius:2px;background:transparent}.task-check-wrapper:hover .task-check-box{border-color:var(--color-success)}.task-check-mark{position:absolute;width:1.75rem;height:1.75rem;color:var(--color-success);top:-2px;left:2px;transform:rotate(-5deg)}.task-content{flex:1;min-width:0;display:flex;align-items:center;gap:.5rem}.task-title-row{display:flex;align-items:center;gap:.3rem;min-width:0;flex:1}.task-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.9rem;min-width:0;flex:1}.task-title-editable{cursor:text}.task-title-editable:hover{text-decoration:underline;text-decoration-color:var(--color-muted);text-underline-offset:2px}input.task-title-edit{font-size:.9rem;font-family:inherit;font-weight:inherit;color:var(--color-text);background:transparent;border:none;border-bottom:1.5px solid var(--color-primary);outline:none;padding:0;min-width:0;flex:1;text-align:left}.task-due-editable{cursor:pointer}.task-due-editable:hover{color:var(--color-primary)}input.task-due-edit{font-size:.7rem;font-family:inherit;color:var(--color-text);background:transparent;border:none;border-bottom:1.5px solid var(--color-primary);outline:none;padding:0;width:4rem;flex-shrink:0;color-scheme:dark}.task-attachment-icons{position:absolute;right:.15rem;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:.1rem}.task-link-indicators{display:flex;align-items:center;justify-content:center;width:1.1rem;cursor:pointer}.task-link-icon{font-size:.75rem;text-decoration:none;opacity:.15}.task-image-icon{display:flex;align-items:center;justify-content:center;width:1.1rem;opacity:.15;color:var(--color-muted)}.task-icon-active .task-link-icon,.task-icon-active.task-image-icon{opacity:.5;cursor:pointer}.task-icon-active .task-link-icon:hover,.task-icon-active.task-image-icon:hover{opacity:1}.task-completed .task-title{text-decoration:line-through}.task-meta{display:flex;align-items:center;gap:.3rem;flex-shrink:0;margin-left:auto;margin-right:.65rem}.task-meta-has-image{margin-right:1.85rem}.task-category{font-size:.65rem;padding:.1rem .3rem;border-radius:3px;background:var(--color-border);color:var(--color-primary);white-space:nowrap;cursor:pointer;transition:background .15s,color .15s}.task-category-clickable{cursor:pointer}.task-category-clickable:hover{background:var(--color-primary);color:#fff}.task-item.priority-1{background:linear-gradient(to right,var(--color-surface) 60%,rgba(255,59,48,.25))}.task-item.priority-2{background:linear-gradient(to right,var(--color-surface) 60%,rgba(230,168,23,.25))}.task-item.priority-3{background:linear-gradient(to right,var(--color-surface) 60%,rgba(128,128,128,.15))}.task-critical-stamp{flex-shrink:0;font-size:1.1rem;font-weight:900;color:var(--color-danger);font-family:Georgia,serif;line-height:1;margin-left:-.25rem;margin-right:-.1rem}.task-due{font-size:.7rem;color:var(--color-muted);white-space:nowrap;flex-shrink:0;width:4rem;text-align:right}.due-overdue{color:#ff6b35;font-weight:600}.task-preview-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.task-preview-dialog{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:1rem;max-width:90vw;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #0000004d}.task-preview-title{font-size:.85rem;font-weight:600;margin-bottom:.75rem;color:var(--color-muted)}.task-preview-list{display:flex;flex-direction:column;gap:.4rem}.task-preview-item{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;border-radius:6px;background:var(--color-bg);text-decoration:none;color:var(--color-text);transition:background .15s;font-size:1rem}.task-preview-item:hover{background:var(--color-border)}.task-preview-item-icon{font-size:1.2rem;flex-shrink:0}.task-preview-item-name{font-size:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-preview-images{display:flex;flex-direction:column;gap:.5rem}.task-preview-thumb{border-radius:6px;overflow:hidden;cursor:pointer;border:1px solid var(--color-border)}.task-preview-thumb img{width:100%;max-height:65vh;object-fit:contain;display:block}.task-preview-thumb:hover{border-color:var(--color-primary)}.task-preview-fullimg{display:flex;align-items:center;justify-content:center;cursor:pointer}.task-preview-fullimg img{max-width:100%;max-height:70vh;border-radius:6px}.task-preview-empty{color:var(--color-muted);font-size:.85rem}.task-preview-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.task-preview-header .task-preview-title{margin-bottom:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-preview-back{background:none;border:none;color:var(--color-text);cursor:pointer;padding:.25rem;display:flex;align-items:center;border-radius:4px}.task-preview-back:hover{background:var(--color-border)}.task-preview-open{color:var(--color-muted);display:flex;align-items:center;padding:.25rem;border-radius:4px;flex-shrink:0}.task-preview-open:hover{color:var(--color-text);background:var(--color-border)}.task-preview-iframe{width:100%;height:65vh;border:1px solid var(--color-border);border-radius:6px;background:#fff}.task-preview-filepath{padding:1.5rem;text-align:center;color:var(--color-muted);font-size:.85rem}.task-preview-filepath span{display:block;font-family:monospace;color:var(--color-text);margin-bottom:.5rem;word-break:break-all}.task-preview-item{cursor:pointer}.task-notes-toggle{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:1.2rem;height:1.2rem;cursor:pointer;transition:opacity .15s,color .15s,transform .15s;margin-left:-.15rem;margin-right:.1rem}.task-notes-toggle-empty{color:var(--color-muted);opacity:.35}.task-notes-toggle-empty:hover{opacity:.85;color:var(--color-primary)}.task-notes-toggle-has{color:var(--color-primary);opacity:.75}.task-notes-toggle-has:hover{opacity:1;transform:scale(1.08)}.task-notes-toggle-expanded{opacity:1!important;color:var(--color-primary)!important}.task-context-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:199}.task-context-menu{position:fixed;z-index:200;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 4px 16px #0000004d;padding:.25rem;min-width:10rem;animation:contextIn .1s ease-out}@keyframes contextIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.task-context-menu button{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;background:none;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;color:var(--color-text)}.task-context-menu button:hover{background:var(--color-bg)}.task-context-prio-row{display:flex;gap:.3rem;padding:.25rem .75rem .4rem}.task-context-prio-btn{width:2rem;height:1.6rem;padding:0;border-radius:4px;font-size:.7rem;font-weight:700;cursor:pointer;border:1.5px solid;transition:all .12s}.task-item-wrapper:has(.task-inline-notes) .task-item{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom:1px dashed var(--color-border)}.task-inline-notes{position:relative;padding:.5rem .75rem .5rem 1.5rem;display:flex;flex-direction:column;gap:.4rem;border:1px solid var(--color-border);border-top:none;background:var(--color-bg);border-radius:0 0 6px 6px;animation:notesSlideIn .18s ease-out}.task-inline-notes:before{content:"";position:absolute;left:.55rem;top:.25rem;bottom:.25rem;width:2px;background:var(--color-primary);border-radius:1px;opacity:.4}@keyframes notesSlideIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.task-inline-notes-list{display:flex;flex-direction:column;gap:.35rem;max-height:280px;overflow-y:auto}.task-inline-note{display:flex;align-items:baseline;gap:.6rem;padding:.2rem 0;font-size:.8rem;color:var(--color-text);border-bottom:1px solid var(--color-border)}.task-inline-note:last-child{border-bottom:none}.task-inline-note-date{flex-shrink:0;font-size:.62rem;color:var(--color-muted);white-space:nowrap;font-variant-numeric:tabular-nums;min-width:5.5rem}.task-inline-note-text{flex:1;min-width:0;white-space:pre-wrap;word-break:break-word;line-height:1.4}.task-inline-note-delete{flex-shrink:0;background:transparent;border:none;color:var(--color-muted);cursor:pointer;padding:.15rem;display:flex;align-items:center;justify-content:center;border-radius:3px;opacity:0;transition:opacity .15s,color .15s,background .15s}.task-inline-note:hover .task-inline-note-delete{opacity:.6}.task-inline-note-delete:hover{opacity:1!important;color:var(--color-danger);background:#e945601a}.task-inline-notes-add-fab{position:absolute;top:.25rem;left:-.15rem;width:1.35rem;height:1.35rem;display:flex;align-items:center;justify-content:center;background:var(--color-primary);color:#fff;border:2px solid var(--color-bg);border-radius:50%;cursor:pointer;padding:0;opacity:0;transform:scale(.85);transition:opacity .18s ease,transform .18s ease,box-shadow .18s ease;box-shadow:0 1px 3px #0003;z-index:2}.task-inline-notes:hover .task-inline-notes-add-fab{opacity:1;transform:scale(1)}.task-inline-notes-add-fab:hover{box-shadow:0 2px 8px #e9456066;transform:scale(1.12)!important}.task-inline-note-new{border-bottom:1px solid var(--color-border);padding-bottom:.3rem!important;margin-bottom:.05rem}.task-inline-note-new .task-inline-note-date{opacity:.5}.task-inline-note-input{flex:1;min-width:0;font-size:.8rem;padding:.2rem .4rem;border:1px solid var(--color-primary);border-radius:4px;background:var(--color-surface);color:var(--color-text);resize:none;outline:none;font-family:inherit;line-height:1.4}.task-inline-note-input::placeholder{color:var(--color-muted);opacity:.55;font-size:.76rem}.task-context-delete{color:var(--color-danger)!important}.task-context-delete:hover{background:#ff3b301a!important}.task-form{display:flex;flex-direction:column;gap:.75rem}.form-error{color:var(--color-danger);font-size:.85rem;margin:0}.autosave-indicator{font-size:.75rem;color:var(--color-success, #4caf50);text-align:right;opacity:.8}.form-row{display:flex;gap:.5rem}.form-row input,.form-row select{flex:1}.form-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.85rem;cursor:pointer}.form-checkbox input[type=checkbox]{width:auto;accent-color:var(--color-danger)}.form-actions{display:flex;gap:.5rem;justify-content:flex-end}.btn-secondary{background:var(--color-border);color:var(--color-text)}.btn-secondary:hover{background:var(--color-muted)}.form-divider{border:none;border-top:1px solid var(--color-border);margin:.25rem 0}textarea{resize:vertical;min-height:3rem}.quick-add{position:fixed;bottom:0;left:0;right:0;display:flex;gap:.5rem;padding:.5rem 1rem;background:var(--color-surface);border-top:1px solid var(--color-border);z-index:100;max-width:48rem;margin:0 auto}.quick-add input{flex:1;padding:.5rem .75rem}.qa-wizard-panel{position:absolute;bottom:100%;left:0;right:0;background:var(--color-surface);border-top:1px solid var(--color-border);padding:.5rem 1rem .6rem;display:flex;flex-direction:column;gap:.4rem;animation:qaSlideUp .15s ease-out}@keyframes qaSlideUp{0%{opacity:0;transform:translateY(.5rem)}to{opacity:1;transform:translateY(0)}}.qa-wizard-label{font-size:.7rem;color:var(--color-muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em}.qa-options{display:flex;flex-wrap:wrap;gap:.35rem}.qa-option{padding:.35rem .85rem;border-radius:16px;font-size:.85rem;cursor:pointer;background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);transition:all .1s;white-space:nowrap}.qa-option:hover{border-color:var(--color-primary)}.qa-option-none{color:var(--color-muted)}.qa-option-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.qa-option-sub{font-size:.82rem}.qa-option-priority{font-weight:600;min-width:3rem;text-align:center}.qa-option-p1{border-color:#ff3b3066}.qa-option-p2{border-color:#e6a81766}.qa-option-p3{border-color:var(--color-border)}.qa-option-p1.qa-option-active{background:#ff3b30;border-color:#ff3b30}.qa-option-p2.qa-option-active{background:#e6a817;border-color:#e6a817}.qa-option-confirmed{transform:scale(1.15);box-shadow:0 0 8px #ffffff4d;transition:transform .15s ease-out,box-shadow .15s ease-out}.qa-input-wizard{opacity:.6}.filter-bar{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;flex-wrap:wrap}.header-filter-bar{display:flex;align-items:center;gap:.5rem;flex-wrap:nowrap;white-space:nowrap}.header-tool-btn{background:transparent;border:none;color:var(--color-muted);padding:.25rem;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:4px}.header-tool-btn:hover{color:var(--color-primary);background:transparent}.header-tool-btn.header-tool-active{color:var(--color-primary);background:#6495ed26}.task-filter{position:relative}.filter-toggle{background:var(--color-surface);color:var(--color-muted);border:1px solid var(--color-border);padding:.35rem .75rem;font-size:.8rem;font-weight:600}.filter-toggle:hover{background:var(--color-border)}.filter-toggle.filter-active{color:var(--color-primary);border-color:var(--color-primary)}.filter-toggle.filter-custom-active{background:var(--color-success);color:#fff;border-color:var(--color-success)}.filter-toggle.filter-custom-active:hover{background:var(--color-success-hover);border-color:var(--color-success-hover)}.filter-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;padding:.75rem;display:flex;flex-direction:column;gap:.5rem;z-index:100;min-width:14rem;box-shadow:0 4px 16px #0000004d}.filter-row{display:flex;align-items:center;gap:.5rem}.filter-row label{font-size:.8rem;color:var(--color-muted);min-width:4.5rem}.filter-row select{flex:1;font-size:.8rem;padding:.3rem .5rem}.filter-actions{display:flex;flex-direction:column;gap:.35rem;border-top:1px solid var(--color-border);padding-top:.5rem;margin-top:.25rem}.filter-reset{background:transparent;color:var(--color-muted);font-size:.75rem;padding:.25rem}.filter-reset:hover{color:var(--color-text);background:transparent}.filter-save-toggle{background:transparent;color:var(--color-primary);font-size:.75rem;padding:.25rem}.filter-save-toggle:hover{color:var(--color-text);background:transparent}.filter-save-row{display:flex;gap:.35rem;align-items:center}.filter-save-row input{flex:1;font-size:.75rem;padding:.25rem .4rem}.filter-save-btn{font-size:.75rem;padding:.25rem .5rem}.filter-save-btn:disabled{opacity:.4;cursor:not-allowed}.filter-favorites{display:flex;gap:.35rem;flex-wrap:wrap;flex:1;min-width:0}.filter-fav-chip{display:flex;align-items:center;gap:.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:1rem;padding:.2rem .5rem;font-size:.75rem;cursor:pointer;transition:border-color .15s}.filter-fav-chip:hover{border-color:var(--color-primary)}.filter-fav-chip.fav-active{background:var(--color-success);border-color:var(--color-success);color:#fff}.filter-fav-chip.fav-active:hover{background:var(--color-success-hover);border-color:var(--color-success-hover)}.filter-fav-chip.fav-active .filter-fav-delete{color:#ffffffb3}.filter-fav-chip.fav-active .filter-fav-delete:hover{color:#fff}.filter-fav-delete{background:transparent;border:none;color:var(--color-muted);font-size:.85rem;padding:0;cursor:pointer;line-height:1}.filter-fav-delete:hover{color:var(--color-danger);background:transparent}.notes{margin-top:.5rem}.notes-title{font-size:.9rem;font-weight:600;margin:0 0 .5rem}.note-add{margin-bottom:.75rem}.note-add textarea{width:100%;font-size:.85rem;padding:.35rem .5rem;box-sizing:border-box}.notes-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.35rem}.note-item{display:flex;align-items:baseline;gap:.6rem;padding:.3rem .5rem;background:var(--color-bg);border-radius:4px;border-bottom:1px solid var(--color-border)}.note-item:last-child{border-bottom:none}.note-date{flex-shrink:0;font-size:.62rem;color:var(--color-muted);white-space:nowrap;font-variant-numeric:tabular-nums;min-width:5.5rem}.note-content{flex:1;min-width:0;font-size:.8rem;white-space:pre-wrap;word-break:break-word;line-height:1.4}.note-delete{flex-shrink:0;background:transparent;border:none;color:var(--color-muted);font-size:1rem;padding:.15rem;cursor:pointer;border-radius:3px;opacity:0;transition:opacity .15s,color .15s,background .15s}.note-item:hover .note-delete{opacity:.6}.note-delete:hover{opacity:1!important;color:var(--color-danger);background:#e945601a}.debug-fab{position:fixed;top:50%;right:0;transform:translateY(-50%);width:1.5rem;height:3rem;border-radius:6px 0 0 6px;background:var(--color-border);color:var(--color-muted);font-size:.6rem;font-weight:700;z-index:1000;display:flex;align-items:center;justify-content:center;box-shadow:-2px 0 8px #0003;padding:0}.debug-fab:hover{background:var(--color-primary);color:#fff}.debug-panel{position:fixed;top:50%;right:1.75rem;transform:translateY(-50%);width:min(24rem,calc(100vw - 3rem));max-height:20rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;z-index:1000;display:flex;flex-direction:column;box-shadow:0 4px 16px #0006}.debug-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-bottom:1px solid var(--color-border);font-size:.8rem;font-weight:600}.debug-clear{background:transparent;color:var(--color-muted);font-size:.7rem;padding:.2rem .5rem}.debug-clear:hover{color:var(--color-danger);background:transparent}.debug-entries{flex:1;overflow-y:auto;padding:.5rem}.debug-empty{color:var(--color-muted);font-size:.8rem;text-align:center;margin:0}.debug-entry{display:flex;gap:.5rem;font-size:.75rem;padding:.2rem 0;border-bottom:1px solid var(--color-border)}.debug-entry:last-child{border-bottom:none}.debug-time{color:var(--color-muted);flex-shrink:0;font-family:monospace}.debug-msg{word-break:break-all}.debug-embedded{background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.debug-embedded-header{display:flex;align-items:center;justify-content:space-between;padding:.4rem .75rem;border-bottom:1px solid var(--color-border);font-size:.8rem;color:var(--color-muted)}.debug-embedded-entries{max-height:15rem;overflow-y:auto;padding:.5rem}.task-links{margin-top:.5rem}.links-title{font-size:.9rem;font-weight:600;margin:0 0 .5rem}.drop-zone{border:2px dashed var(--color-border);border-radius:6px;padding:1rem;text-align:center;font-size:.8rem;color:var(--color-muted);margin-bottom:.5rem;transition:border-color .15s,background .15s;cursor:pointer;outline:none}.drop-zone:focus{border-color:var(--color-primary);color:var(--color-primary)}.drop-zone.drop-active{border-color:#6495ed;background:#6495ed14;color:#6495ed}.drop-zone.drop-ok{border-color:var(--color-success);background:#4ecca314;color:var(--color-success)}.drop-zone.drop-fail{border-color:var(--color-danger);background:#e9456014;color:var(--color-danger)}.drop-msg{font-size:.8rem;margin:.25rem 0}.drop-msg-ok{color:var(--color-success)}.drop-msg-fail{color:var(--color-danger)}.link-add{display:flex;gap:.35rem;margin-bottom:.5rem}.link-add input{flex:1;padding:.35rem .5rem;font-size:.85rem}.link-add button{flex-shrink:0;width:2rem;padding:.35rem;font-size:.9rem}.link-add button:disabled{opacity:.4;cursor:not-allowed}.links-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25rem}.link-item{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;background:var(--color-bg);border-radius:4px}.link-name{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-decoration:none;color:inherit}a.link-name{color:var(--color-primary)}a.link-name:hover{text-decoration:underline}.link-path{flex:1;font-size:.7rem;color:var(--color-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.link-delete{flex-shrink:0;background:transparent;border:none;color:var(--color-muted);font-size:1rem;padding:0 .25rem;cursor:pointer}.link-delete:hover{color:var(--color-danger);background:transparent}.task-images{display:flex;flex-direction:column;gap:.5rem}.task-images-header{display:flex;align-items:center;justify-content:space-between}.task-images-header h3{margin:0;font-size:.95rem}.task-images-add{font-size:.8rem;color:var(--color-primary);cursor:pointer;font-weight:600}.task-images-add:hover{color:var(--color-primary-hover)}.task-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(5rem,1fr));gap:.5rem}.task-image-thumb{position:relative;aspect-ratio:1;border-radius:6px;overflow:hidden;border:1px solid var(--color-border);cursor:pointer}.task-image-thumb img{width:100%;height:100%;object-fit:cover}.task-image-delete{position:absolute;top:2px;right:2px;background:#0009;color:#fff;border:none;border-radius:50%;width:1.4rem;height:1.4rem;font-size:.9rem;line-height:1;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center}.task-image-delete:hover{background:var(--color-danger)}.task-image-preview{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:200;cursor:pointer}.task-image-preview img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:6px}.detail-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#00000073;animation:detailFadeIn .2s ease-out}.detail-sheet{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:calc(100% - 2rem);max-height:85vh;background:var(--color-bg);border-radius:14px;box-shadow:0 8px 40px #0006;z-index:201;display:flex;flex-direction:column;animation:detailFadeScale .25s cubic-bezier(.32,.72,0,1) forwards;max-width:36rem}.detail-handle{width:2.5rem;height:.25rem;background:var(--color-border);border-radius:2px;margin:.5rem auto .25rem;flex-shrink:0}.detail-status{height:1.2rem;text-align:center;font-size:.7rem}.detail-saving{color:var(--color-muted)}.detail-saved{color:var(--color-success, #4caf50)}.detail-body{flex:1;overflow-y:auto;padding:0 1.25rem 2.5rem;display:flex;flex-direction:column;gap:.85rem;-webkit-overflow-scrolling:touch}.detail-title{font-size:1.25rem;font-weight:600;border:none;border-bottom:2px solid transparent;background:transparent;color:var(--color-text);padding:.4rem 0;width:100%;outline:none;transition:border-color .15s}.detail-title:focus{border-bottom-color:var(--color-primary)}.detail-title-display{cursor:text;border-bottom:2px solid var(--color-border);min-height:1.25em}.detail-cat-row{display:flex;align-items:center;gap:.35rem}.detail-cat-right{display:flex;align-items:center;gap:.3rem;margin-left:auto}.detail-critical-chip{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border-radius:50%;cursor:pointer;border:2px solid var(--color-border);background:transparent;color:var(--color-muted);font-size:1rem;font-weight:900;font-family:Georgia,serif;line-height:1;transition:all .15s}.detail-critical-on{border-color:var(--color-danger);background:var(--color-danger);color:#fff}.detail-critical-chip:active{transform:scale(.92)}.detail-prio-toggle{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border-radius:50%;font-size:.72rem;font-weight:700;cursor:pointer;border:2px solid;color:#fff;transition:all .15s}.detail-prio-toggle:active{transform:scale(.92)}.detail-cat-chip{padding:.35rem .85rem;border-radius:16px;font-size:.82rem;cursor:pointer;border:1.5px dashed var(--color-border);background:transparent;color:var(--color-muted);transition:all .15s}.detail-cat-set{border-style:solid;border-color:var(--color-primary);color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 8%,transparent)}.detail-cat-sub{font-weight:400;opacity:.8}.detail-cat-clear{background:transparent;border:none;color:var(--color-muted);font-size:1rem;cursor:pointer;padding:.2rem .4rem;line-height:1}.detail-cat-picker{display:flex;flex-direction:column;gap:.5rem;padding:.6rem;background:var(--color-surface);border-radius:10px;border:1px solid var(--color-border);animation:detailFadeIn .15s ease-out}.detail-cat-picker-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-muted)}.detail-cat-picker-row{display:flex;flex-wrap:wrap;gap:.3rem;align-items:center}.detail-cat-option{padding:.35rem .75rem;border-radius:14px;font-size:.8rem;cursor:pointer;border:1.5px solid var(--color-border);background:transparent;color:var(--color-text);transition:all .12s}.detail-cat-option:hover{border-color:var(--color-primary)}.detail-cat-option-active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.detail-cat-sub-option{padding:.3rem .65rem;border-radius:4px;font-size:.78rem;cursor:pointer;border:1.5px solid var(--color-border);background:transparent;color:var(--color-muted);transition:all .12s}.detail-cat-sub-option:hover{border-color:var(--color-primary)}.detail-cat-sub-active{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 15%,transparent);color:var(--color-primary)}.detail-date-row{display:flex;align-items:center;gap:.4rem;color:var(--color-muted)}.detail-date{border:none;background:transparent;color:var(--color-text);font-size:.85rem;padding:.25rem 0;outline:none;color-scheme:dark}.detail-date-clear{background:transparent;border:none;color:var(--color-muted);font-size:1rem;cursor:pointer;padding:0 .3rem;line-height:1}.detail-desc{border:none;border-left:3px solid var(--color-border);background:transparent;color:var(--color-text);font-size:.88rem;padding:.5rem .75rem;resize:vertical;min-height:2.5rem;outline:none;transition:border-color .15s}.detail-desc:focus{border-left-color:var(--color-primary)}.detail-sections{display:flex;flex-direction:column;gap:.75rem;border-top:1px solid var(--color-border);padding-top:.75rem}.detail-delete{background:transparent;border:1px solid var(--color-border);color:var(--color-muted);padding:.5rem;border-radius:8px;font-size:.8rem;cursor:pointer;transition:all .15s;margin-top:.5rem}.detail-delete:hover{border-color:var(--color-danger);color:var(--color-danger)}.detail-delete-confirm{border-color:var(--color-danger);background:var(--color-danger);color:#fff}@keyframes detailFadeScale{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes detailFadeIn{0%{opacity:0}to{opacity:1}}.camera-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:300;display:flex;flex-direction:column}.camera-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.camera-video{width:100%;max-height:calc(100vh - 5rem);object-fit:contain;background:#000}.camera-error{color:#fff;text-align:center;padding:2rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.camera-error p{margin:0;font-size:1rem}.camera-pick-file{background:var(--color-primary);color:#fff;border:none;border-radius:6px;padding:.6rem 1.2rem;font-size:.9rem;cursor:pointer}.camera-controls{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;width:100%;background:#0009}.camera-cancel{background:transparent;color:#fff;border:none;font-size:.95rem;padding:.5rem 1rem;min-width:5rem}.camera-cancel:hover{background:#ffffff1a}.camera-snap{width:4rem;height:4rem;border-radius:50%;background:transparent;border:3px solid #fff;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center}.camera-snap:hover{border-color:var(--color-primary)}.camera-snap-inner{display:block;width:100%;height:100%;border-radius:50%;background:#fff}.camera-snap:hover .camera-snap-inner{background:var(--color-primary)}.camera-spacer{min-width:5rem}.tasks-page{display:flex;flex-direction:column;gap:.75rem}.tasks-list,.task-group{display:flex;flex-direction:column;gap:.35rem}.task-group-header{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-muted);padding:.4rem 0 .15rem;border-bottom:1px solid var(--color-border);margin-bottom:.1rem}.tasks-empty{text-align:center;color:var(--color-muted);padding:2rem}.page-form{display:flex;flex-direction:column;gap:1rem}.page-form h2{margin:0;font-size:1.1rem}.btn-danger{background:transparent;color:var(--color-danger);border:1px solid var(--color-danger);margin-top:.5rem}.btn-danger:hover{background:var(--color-danger);color:#fff}.btn-toggle{background:transparent;color:var(--color-muted);font-size:.8rem;padding:.25rem 0;text-align:left}.btn-toggle:hover{color:var(--color-text);background:transparent}.fab-camera{position:fixed;bottom:8.5rem;right:1.25rem;width:3.5rem;height:3.5rem;border-radius:50%;background:var(--color-surface);color:var(--color-primary);border:2px solid var(--color-primary);box-shadow:0 3px 12px #00000059;display:flex;align-items:center;justify-content:center;z-index:100;cursor:pointer;padding:0}.fab-camera:hover{background:var(--color-primary);color:#fff;transform:scale(1.05)}.fab-new{position:fixed;bottom:4rem;right:1.25rem;width:3.5rem;height:3.5rem;border-radius:50%;background:var(--color-primary);color:#fff;font-size:1.8rem;font-weight:300;border:none;box-shadow:0 3px 12px #00000059;display:flex;align-items:center;justify-content:center;z-index:100;cursor:pointer;line-height:1;padding:0}.fab-new:hover{background:var(--color-primary-hover);transform:scale(1.05)}.cat-picker-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:150;background:#0006}.cat-picker{position:fixed;right:1.25rem;bottom:8rem;display:flex;flex-direction:column-reverse;gap:.5rem;align-items:flex-end}.cat-picker-row{display:flex;gap:.4rem;align-items:flex-end;justify-content:flex-end;animation:chipFlyIn .25s ease-out both}.cat-picker-subs{display:flex;flex-direction:column-reverse;gap:.4rem;align-items:flex-end}.cat-chip{padding:.6rem 1.3rem;border-radius:24px;border:none;font-size:.95rem;font-weight:500;cursor:pointer;background:var(--color-primary);color:#fff;box-shadow:0 2px 10px #0000004d;white-space:nowrap;animation:chipFlyIn .25s ease-out both}.cat-chip:active{transform:scale(.95)}.cat-chip-none{background:var(--color-surface);color:var(--color-muted);border:1px solid var(--color-border);animation-delay:0ms}.cat-chip-active{box-shadow:0 0 0 2px #fff,0 0 0 4px var(--color-primary)}.cat-chip-sub{background:var(--color-surface);color:var(--color-primary);border:1px solid var(--color-primary);font-size:.88rem;padding:.55rem 1.1rem}@keyframes chipFlyIn{0%{opacity:0;transform:translate(1rem) scale(.8)}to{opacity:1;transform:translate(0) scale(1)}}.grouped-tasks{display:flex;flex-direction:column;gap:.75rem}.task-group-heading{font-size:.8rem;font-weight:600;color:var(--color-muted);margin:0;padding:.25rem 0;border-bottom:1px solid var(--color-border)}.pending-image-preview{border-radius:6px;overflow:hidden;border:1px solid var(--color-border)}.pending-image-preview img{width:100%;max-height:12rem;object-fit:cover;display:block}.archive-page{display:flex;flex-direction:column;gap:.75rem}.archive-page h2{margin:0;font-size:1.1rem}.archive-search{display:flex;gap:.35rem}.archive-search input{flex:1}.archive-list{display:flex;flex-direction:column;gap:.35rem}.archive-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px}.archive-content{min-width:0}.archive-title{font-size:.9rem;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.archive-meta{display:flex;gap:.5rem;font-size:.7rem;color:var(--color-muted);margin-top:.15rem}.archive-cat{background:#2a3a5e;color:#8ab4f8;padding:0 .3rem;border-radius:3px}.archive-empty{text-align:center;color:var(--color-muted);padding:2rem}.archive-paging{display:flex;align-items:center;justify-content:center;gap:.75rem;font-size:.85rem}.archive-paging button{font-size:.8rem;padding:.3rem .75rem}.settings-page{display:flex;flex-direction:column;gap:1.5rem}.settings-page h2{margin:0;font-size:1.1rem}.settings-page h3{margin:0 0 .5rem;font-size:.95rem;color:var(--color-muted)}.setting-row{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.setting-row input[type=number]{width:4rem;text-align:center}.add-row{display:flex;gap:.35rem}.add-row input{flex:1;font-size:.85rem}.add-row button{font-size:.8rem;padding:.35rem .75rem}.categories-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.category-block{background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;padding:.5rem .75rem}.category-header{display:flex;align-items:center;justify-content:space-between;font-weight:600;font-size:.9rem}.sub-list{margin:.35rem 0 .35rem 1rem;display:flex;flex-direction:column;gap:.2rem}.sub-item{display:flex;align-items:center;justify-content:space-between;font-size:.8rem;color:var(--color-muted)}.sub-add{margin-top:.35rem}.sub-add input{font-size:.8rem}.sub-add button{font-size:.75rem;padding:.25rem .5rem}.btn-small{background:transparent;border:none;padding:.15rem .4rem;font-size:.75rem;cursor:pointer}.btn-danger-small{color:var(--color-danger)}.btn-danger-small:hover{background:var(--color-danger);color:#fff;border-radius:3px}.editable-name{cursor:pointer;border-bottom:1px dashed transparent}.editable-name:hover{border-bottom-color:var(--color-primary)}.inline-edit{font-size:inherit;font-weight:inherit;padding:.1rem .25rem;border:1px solid var(--color-primary);border-radius:3px;background:var(--color-bg);color:var(--color-text);width:100%;max-width:12rem}.btn-archive{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);padding:.5rem 1rem;font-size:.85rem;width:100%}.btn-archive:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-surface)}.theme-toggle{display:flex;gap:.35rem}.theme-btn{flex:1;padding:.5rem;font-size:.85rem;background:var(--color-bg);color:var(--color-muted);border:1px solid var(--color-border)}.theme-btn:hover{border-color:var(--color-primary);background:var(--color-bg)}.theme-btn.theme-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.password-form{display:flex;gap:.35rem;flex-wrap:wrap}.password-form input{flex:1;min-width:8rem;font-size:.85rem}.password-form button{font-size:.8rem;padding:.35rem .75rem}.form-success{color:var(--color-success);font-size:.85rem;margin:.25rem 0 0}.form-error{color:var(--color-danger);font-size:.85rem;margin:.25rem 0 0}.user-create-form{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:.75rem}.user-create-form input{flex:1;min-width:6rem;font-size:.85rem}.user-create-form select{font-size:.85rem}.user-create-form button{font-size:.8rem;padding:.35rem .75rem}.users-list{display:flex;flex-direction:column;gap:.4rem}.user-row{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;flex-wrap:wrap}.user-name{font-weight:600;font-size:.9rem;min-width:6rem}.user-row select{font-size:.8rem;padding:.25rem .35rem}.user-reset{display:flex;gap:.25rem;margin-left:auto}.user-reset input{width:6rem;font-size:.8rem;padding:.25rem .35rem}.user-reset .btn-small{color:var(--color-primary)}.user-reset .btn-small:disabled{opacity:.3}:root,[data-theme=dark]{--color-bg: #0f0f1a;--color-surface: #1a1a2e;--color-border: #2a2a3e;--color-text: #e0e0e0;--color-muted: #888;--color-primary: #6495ed;--color-primary-hover: #5282d6;--color-danger: #e94560;--color-success: #4ecca3;--color-success-hover: #3dba91}[data-theme=light]{--color-bg: #f5f5f7;--color-surface: #ffffff;--color-border: #d8d8dc;--color-text: #1d1d1f;--color-muted: #6e6e73;--color-primary: #4a7edc;--color-primary-hover: #3d6bc4;--color-danger: #d6304a;--color-success: #34a77f;--color-success-hover: #2a8f6b}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;overflow-x:hidden}input,select,textarea,button{font:inherit;color:inherit}input,select,textarea{background:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;padding:.5rem .75rem}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary)}button{background:var(--color-primary);color:#fff;border:none;border-radius:6px;padding:.5rem 1rem;cursor:pointer;font-weight:600}button:hover{background:var(--color-primary-hover)}
