:root{--bg:#faf8f4;--bg-2:#f4f1ea;--bg-3:#ebe6db;--surface:#ffffff;--surface-sunk:#f7f4ee;--ink:#1c1a15;--ink-2:#3d3a32;--ink-3:#6b6558;--ink-4:#9a9489;--ink-5:#c7c2b6;--rule:rgba(28,26,21,0.08);--rule-strong:rgba(28,26,21,0.14);--personal:oklch(0.68 0.12 60);--personal-soft:oklch(0.94 0.04 65);--personal-ink:oklch(0.38 0.08 55);--work:oklch(0.48 0.12 265);--work-soft:oklch(0.94 0.03 265);--work-ink:oklch(0.32 0.09 265);--p1:oklch(0.58 0.19 25);--p2:oklch(0.68 0.16 50);--p3:oklch(0.62 0.13 230);--p4:var(--ink-5);--radius:8px;--radius-lg:12px;--radius-sm:5px;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,monospace;--shadow-sm:0 1px 2px rgba(28,26,21,0.04);--shadow:0 4px 16px -6px rgba(28,26,21,0.12),0 1px 3px rgba(28,26,21,0.06);--shadow-lg:0 24px 48px -16px rgba(28,26,21,0.18),0 4px 12px rgba(28,26,21,0.06)}.app,.app *{box-sizing:border-box}.app{font-family:var(--font-sans);color:var(--ink);background:var(--bg);width:100%;height:100%;font-size:13px;line-height:1.45;-webkit-font-smoothing:antialiased}.app,.sidebar{display:flex;overflow:hidden}.sidebar{width:248px;flex:0 0 248px;background:var(--bg-2);border-right:1px solid var(--rule);flex-direction:column}.sidebar-top{padding:14px 14px 10px;display:flex;flex-direction:column;gap:12px}.brand{display:flex;align-items:center;gap:8px;font-weight:600;font-size:12.5px;color:var(--ink-2);letter-spacing:-.005em}.brand-mark{width:20px;height:20px;border-radius:5px;background:linear-gradient(135deg,var(--personal) 0,var(--work) 100%);position:relative;flex:0 0 20px}.brand-mark:after{content:"";position:absolute;inset:3px;border-radius:3px;background:var(--bg-2)}.brand-mark:before{content:"";position:absolute;left:6px;top:7px;width:8px;height:5px;border-left:1.5px solid var(--ink);border-bottom:1.5px solid var(--ink);transform:rotate(-45deg);z-index:1}.ws-switch{display:flex;background:var(--surface);border:1px solid var(--rule);border-radius:8px;padding:2px;gap:2px;position:relative}.ws-tab{flex:1 1;display:flex;align-items:center;justify-content:center;gap:5px;padding:5px 6px;border-radius:6px;font-size:11.5px;font-weight:500;color:var(--ink-3);cursor:pointer;transition:background .12s,color .12s;border:none;background:transparent;font-family:inherit}.ws-tab:hover{color:var(--ink-2)}.ws-tab.active{color:var(--ink);background:var(--bg-2);box-shadow:var(--shadow-sm)}.ws-tab.active.personal{color:var(--personal-ink)}.ws-tab.active.work{color:var(--work-ink)}.ws-dot{width:7px;height:7px;border-radius:50%}.ws-dot.personal{background:var(--personal)}.ws-dot.work{background:var(--work)}.ws-dot.both{background:linear-gradient(90deg,var(--personal) 50%,var(--work) 50%)}.quick-add-btn{display:flex;align-items:center;gap:8px;padding:7px 10px;border:1px dashed var(--rule-strong);border-radius:7px;background:transparent;color:var(--ink-3);font-size:12px;cursor:pointer;font-family:inherit;text-align:left;justify-content:space-between}.quick-add-btn:hover{background:var(--surface);color:var(--ink-2);border-color:var(--ink-4)}.quick-add-btn .kbd{font-family:var(--font-mono);font-size:10px;color:var(--ink-4)}.nav{padding:4px 8px;overflow-y:auto;flex:1 1}.nav-section{padding:8px 6px 4px;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;display:flex;justify-content:space-between}.nav-section,.nav-section .add{color:var(--ink-4);align-items:center}.nav-section .add{width:16px;height:16px;display:inline-flex;justify-content:center;border-radius:4px;cursor:pointer}.nav-section .add:hover{background:var(--rule);color:var(--ink-2)}.nav-item{display:flex;align-items:center;gap:9px;padding:5px 8px;border-radius:6px;color:var(--ink-2);cursor:pointer;font-size:12.5px;font-weight:450;position:relative}.nav-item:hover{background:var(--rule)}.nav-item.active{background:var(--surface);box-shadow:var(--shadow-sm);font-weight:500}.nav-item .ico{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-3);flex:0 0 16px}.nav-item.active .ico{color:var(--ink)}.nav-item .count{margin-left:auto;font-size:11px;color:var(--ink-4);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.nav-item .dot{width:9px;height:9px;border-radius:3px;flex:0 0 9px}.nav-item .ws-pill{font-size:9px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:1px 5px;border-radius:3px;margin-left:auto;color:var(--ink-3);background:var(--rule)}.nav-item .ws-pill.personal{color:var(--personal-ink);background:var(--personal-soft)}.nav-item .ws-pill.work{color:var(--work-ink);background:var(--work-soft)}.sidebar-bottom{padding:8px 10px 12px;border-top:1px solid var(--rule);gap:8px}.avatar,.sidebar-bottom{display:flex;align-items:center}.avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--personal),var(--work));color:white;justify-content:center;font-size:11px;font-weight:600}.sidebar-bottom .name{font-size:12px;font-weight:500;color:var(--ink-2)}.sidebar-bottom .mode{font-size:10.5px;color:var(--ink-4);font-family:var(--font-mono)}.main{flex:1 1;display:flex;flex-direction:column;min-width:0;background:var(--bg)}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 22px 10px;gap:16px;min-height:48px}.topbar-l{display:flex;align-items:baseline;gap:14px;min-width:0}.page-title{font-size:22px;font-weight:600;letter-spacing:-.015em;color:var(--ink);margin:0}.page-sub{font-size:12px;color:var(--ink-3);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.topbar-r{gap:6px}.icon-btn,.topbar-r{display:flex;align-items:center}.icon-btn{width:28px;height:28px;justify-content:center;border-radius:6px;border:none;background:transparent;color:var(--ink-3);cursor:pointer}.icon-btn:hover{background:var(--rule);color:var(--ink)}.icon-btn.primary{background:var(--ink);color:white}.icon-btn.primary:hover{background:#000}.content{flex:1 1;overflow-y:auto;padding:4px 22px 22px;min-height:0}.section-h{display:flex;align-items:baseline;gap:10px;padding:16px 6px 8px;border-bottom:1px solid var(--rule);margin-bottom:2px}.section-h:first-child{padding-top:6px}.section-h .h-title{font-size:13px;font-weight:600;color:var(--ink)}.section-h .h-date{font-size:12px;color:var(--ink-3);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.section-h .h-count{font-size:11px;color:var(--ink-4);margin-left:auto}.task{display:flex;align-items:flex-start;gap:10px;padding:9px 6px;border-bottom:1px solid var(--rule);position:relative;cursor:pointer;transition:background .08s}.task:hover{background:rgba(28,26,21,.025)}.task.selected{background:rgba(28,26,21,.04)}.task.dim{opacity:.5}.task.completed .task-title{text-decoration:line-through;color:var(--ink-4)}.task-rail{width:2px;align-self:stretch;border-radius:2px;margin-right:2px;margin-left:-2px;flex:0 0 2px}.task-rail.personal{background:var(--personal)}.task-rail.work{background:var(--work)}.checkbox{width:16px;height:16px;flex:0 0 16px;border-radius:50%;border:1.5px solid var(--ink-5);margin-top:2px;cursor:pointer;display:flex;align-items:center;justify-content:center;background:transparent;transition:all .12s;position:relative}.checkbox:hover{border-color:var(--ink-3)}.checkbox.p1{border-color:var(--p1);background:color-mix(in srgb,var(--p1) 8%,transparent)}.checkbox.p2{border-color:var(--p2);background:color-mix(in srgb,var(--p2) 8%,transparent)}.checkbox.p3{border-color:var(--p3);background:color-mix(in srgb,var(--p3) 8%,transparent)}.checkbox.p4{border-color:var(--ink-5)}.checkbox.p1:hover{background:color-mix(in srgb,var(--p1) 20%,transparent)}.checkbox.p2:hover{background:color-mix(in srgb,var(--p2) 20%,transparent)}.checkbox.p3:hover{background:color-mix(in srgb,var(--p3) 20%,transparent)}.checkbox.done{background:var(--ink-3);border-color:var(--ink-3)}.checkbox.done:after{content:"";width:5px;height:8px;border-right:1.5px solid white;border-bottom:1.5px solid white;transform:rotate(45deg) translate(-1px,-1px)}.task-body{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:2px}.task-title{font-size:13px;font-weight:450;color:var(--ink);line-height:1.4}.task-meta{display:flex;gap:10px;align-items:center;font-size:11.5px;color:var(--ink-3);flex-wrap:wrap}.task-meta .meta{display:inline-flex;align-items:center;gap:4px}.meta svg{width:11px;height:11px}.meta.overdue{color:var(--p1)}.meta.today{color:var(--p2);font-weight:500}.chip-proj{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:0 5px 0 0;color:var(--ink-3)}.chip-proj .dot{width:7px;height:7px;border-radius:2px}.chip-label{font-size:10.5px;padding:0 5px;border-radius:3px;background:var(--rule);color:var(--ink-3)}.subtasks{margin-top:4px;padding-left:2px;display:flex;align-items:center;gap:4px;font-size:11px;color:var(--ink-4)}.subtask-bar{width:40px;height:3px;background:var(--rule);border-radius:2px;overflow:hidden}.subtask-fill{height:100%;background:var(--ink-4);border-radius:2px}.task-add-inline{display:flex;align-items:center;gap:10px;padding:9px 6px;color:var(--ink-4);font-size:12.5px;cursor:text;border-bottom:1px dashed transparent}.task-add-inline:hover{color:var(--ink-3)}.task-add-inline .plus{width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink-4)}.detail{width:360px;flex:0 0 360px;background:var(--surface);border-left:1px solid var(--rule);display:flex;flex-direction:column;overflow:hidden}.detail-top{padding:14px 18px 10px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--rule)}.detail-breadcrumbs{font-size:11px;color:var(--ink-4);flex:1 1}.detail-body{padding:16px 18px;overflow-y:auto;flex:1 1;display:flex;flex-direction:column;gap:16px}.detail-title{font-size:16px;font-weight:600;color:var(--ink);letter-spacing:-.01em;line-height:1.3;display:flex;align-items:flex-start;gap:10px}.detail-title .checkbox{margin-top:3px;width:18px;height:18px;flex:0 0 18px}.detail-desc{font-size:12.5px;color:var(--ink-2);line-height:1.55;padding-left:28px}.detail-fields{display:grid;grid-template-columns:72px 1fr;grid-gap:2px 10px;gap:2px 10px;font-size:12px;padding-left:28px}.detail-fields dt{color:var(--ink-4);padding:5px 0}.detail-fields dd{color:var(--ink-2);display:flex;align-items:center;gap:6px;border-radius:4px;padding:5px 6px;margin:0 0 0 -6px;cursor:pointer;transition:background .08s}.detail-fields dd:hover{background:var(--surface-sunk)}.detail-fields dd.empty{color:var(--ink-4)}.detail-fields dd svg{width:13px;height:13px;flex-shrink:0;color:var(--ink-3)}.detail-fields dd .swatch{flex-shrink:0}.detail-title.done span{text-decoration:line-through;color:var(--ink-4)}.detail-breadcrumbs .ws-pill{font-size:9.5px;padding:1px 5px;border-radius:3px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin-right:4px}.detail-breadcrumbs .ws-pill.work{background:var(--work-soft);color:var(--work-ink)}.detail-breadcrumbs .ws-pill.personal{background:var(--personal-soft);color:var(--personal-ink)}.detail-activity-input{width:100%;background:var(--surface-sunk);border:1px solid var(--rule);border-radius:6px;padding:8px 10px;font-family:inherit;font-size:12px;color:var(--ink);resize:vertical;min-height:32px}.detail-activity-input::placeholder{color:var(--ink-4)}.detail-activity-input:focus{outline:none;border-color:var(--ink-3);background:var(--surface)}.detail-actions{display:flex;gap:6px;padding-left:28px;margin-top:4px}.detail-actions button{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;font-size:11.5px;font-family:inherit;color:var(--ink-2);background:var(--surface-sunk);border:1px solid var(--rule);border-radius:5px;cursor:pointer;transition:background .08s,border-color .08s}.detail-actions button:hover{background:var(--rule);border-color:var(--rule-strong);color:var(--ink)}.detail-actions button svg{width:12px;height:12px}.detail-subtasks{padding-left:28px;display:flex;flex-direction:column;gap:2px}.detail-subtasks .st{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:12.5px;border-top:1px solid var(--rule)}.detail-subtasks .st:first-of-type{border-top:none}.detail-subtasks .st.done{color:var(--ink-4);text-decoration:line-through}.detail-subtasks .checkbox{width:14px;height:14px;flex:0 0 14px;margin:0}.detail-section-label{font-size:10.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-4);padding-left:28px;margin-bottom:-10px}.detail-comments{padding-left:28px;display:flex;flex-direction:column;gap:8px}.detail-modal-subtasks .st-add,.detail-subtasks .st-add{padding:4px 0 0 22px;font-size:11.5px;color:var(--ink-4);cursor:pointer}.detail-modal-subtasks .st-add:hover,.detail-subtasks .st-add:hover{color:var(--ink-2)}.detail-expand-hint{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;color:var(--ink-4);background:none;border:none;padding:2px 0 2px 28px;cursor:pointer;margin-top:-8px}.detail-expand-hint:hover{color:var(--ink-2)}.detail-expand-hint svg{width:12px;height:12px}.detail-modal-backdrop{position:fixed;inset:0;background:rgba(28,26,21,.45);z-index:500;display:flex;align-items:center;justify-content:center;padding:24px;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.detail-modal-card{background:var(--surface);border-radius:12px;width:100%;max-width:660px;max-height:86vh;display:flex;flex-direction:column;box-shadow:0 24px 64px rgba(28,26,21,.22),0 0 0 1px var(--rule-strong);overflow:hidden}.detail-modal-header{padding:14px 18px 12px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--rule);flex-shrink:0}.detail-modal-body{padding:22px 24px 24px;overflow-y:auto;flex:1 1;display:flex;flex-direction:column;gap:20px}.detail-modal-title{font-size:19px;font-weight:600;display:flex;align-items:flex-start;gap:12px;line-height:1.3;color:var(--ink)}.detail-modal-title .checkbox{margin-top:3px;width:20px;height:20px;flex:0 0 20px}.detail-modal-title.done span{text-decoration:line-through;color:var(--ink-4)}.detail-modal-desc{font-size:13px;color:var(--ink-2);line-height:1.65;padding-left:32px}.detail-modal-sections{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:0 24px;gap:0 24px;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:16px 0}@media (max-width:580px){.detail-modal-sections{grid-template-columns:1fr}}.detail-modal-section{display:flex;flex-direction:column;gap:4px}.detail-modal-section-title{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4);margin-bottom:6px}.detail-modal-fields{display:grid;grid-template-columns:auto 1fr;align-items:start;margin:0;grid-column-gap:8px;column-gap:8px}.detail-modal-fields dt{color:var(--ink-4);font-size:11.5px;padding:5px 0;white-space:nowrap}.detail-modal-fields dd{color:var(--ink-2);margin:0;display:flex;align-items:center;gap:5px;padding:4px 6px;border-radius:5px;font-size:12.5px;flex-wrap:wrap;transition:background .08s}.detail-modal-fields dd:hover{background:var(--surface-sunk)}.detail-modal-fields dd.empty{color:var(--ink-5)}.detail-modal-fields dd svg{width:13px;height:13px;flex-shrink:0;color:var(--ink-3)}.detail-modal-fields dd .swatch{flex-shrink:0}.detail-modal-fields .empty-val{color:var(--ink-5)}.detail-modal-subtasks{display:flex;flex-direction:column;gap:2px}.detail-modal-subtasks .st{display:flex;align-items:center;gap:10px;padding:5px 8px;border-radius:6px;font-size:13px;transition:background .08s}.detail-modal-subtasks .st:hover{background:var(--surface-sunk)}.detail-modal-subtasks .st.done{color:var(--ink-4);text-decoration:line-through}.detail-modal-subtasks .checkbox{width:16px;height:16px;flex:0 0 16px;margin:0}.detail-modal-activity{min-height:72px!important}.em-title-wrap{display:flex;align-items:flex-start;gap:12px}.em-title-wrap .checkbox{margin-top:5px;width:20px;height:20px;flex:0 0 20px;cursor:pointer}.em-title{flex:1 1;font-size:19px;font-weight:600;line-height:1.3;color:var(--ink);background:none;border:none;resize:none;padding:0;font-family:var(--font-sans);overflow:hidden}.em-title,.em-title:focus{outline:none}.em-title.done{text-decoration:line-through;color:var(--ink-4)}.em-desc{width:100%;font-size:13px;color:var(--ink-2);line-height:1.6;background:var(--surface-sunk);border:1px solid var(--rule);border-radius:7px;padding:8px 10px;resize:vertical;font-family:var(--font-sans);box-sizing:border-box}.em-desc::placeholder{color:var(--ink-4)}.em-desc:focus{outline:none;border-color:var(--ink-3)}.em-section{display:flex;flex-direction:column;gap:2px;border-top:1px solid var(--rule);padding-top:14px}.em-section-title{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4);margin-bottom:6px}.em-row{display:flex;align-items:center;gap:10px;min-height:34px}.em-row-labels{align-items:flex-start;padding-top:4px}.em-lbl{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--ink-4);width:108px;flex:0 0 108px;white-space:nowrap}.em-lbl svg{width:13px;height:13px;flex-shrink:0}.em-controls{display:flex;gap:6px;align-items:center}.em-date,.em-input,.em-select,.em-time{font-size:12.5px;color:var(--ink);background:var(--surface-sunk);border:1px solid var(--rule);border-radius:6px;padding:5px 8px;font-family:var(--font-sans);transition:border-color .1s}.em-input{flex:1 1}.em-date{width:140px}.em-time{width:100px}.em-select{flex:1 1;cursor:pointer}.em-date:focus,.em-input:focus,.em-select:focus,.em-time:focus{outline:none;border-color:var(--ink-3)}.em-input::placeholder{color:var(--ink-4)}.em-prio{display:flex;gap:5px;flex-wrap:wrap}.em-prio-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:6px;border:1px solid var(--rule-strong);background:var(--surface-sunk);font-size:12px;font-weight:500;cursor:pointer;color:var(--ink-2);transition:background .1s,border-color .1s,color .1s}.em-prio-chip:hover{border-color:var(--ink-4)}.em-prio-chip .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.em-labels-wrap{display:flex;flex-wrap:wrap;gap:4px;align-items:center;flex:1 1;padding:3px 0}.em-chip{display:inline-flex;align-items:center;gap:3px;background:var(--surface-sunk);border:1px solid var(--rule-strong);border-radius:5px;padding:2px 6px 2px 7px;font-size:11.5px;color:var(--ink-2);white-space:nowrap}.em-chip-x{background:none;border:none;color:var(--ink-4);cursor:pointer;font-size:13px;padding:0 1px;line-height:1}.em-chip-x:hover,.em-label-input{color:var(--ink)}.em-label-input{font-size:12.5px;background:none;border:none;outline:none;min-width:80px;font-family:var(--font-sans)}.em-label-input::placeholder{color:var(--ink-4)}.em-subtasks{display:flex;flex-direction:column;gap:1px}.em-sub{display:flex;align-items:center;gap:9px;padding:5px 6px;border-radius:6px;font-size:13px;color:var(--ink-2);transition:background .08s}.em-sub:hover{background:var(--surface-sunk)}.em-sub.done .em-sub-title{text-decoration:line-through;color:var(--ink-4)}.em-sub .checkbox{width:16px;height:16px;flex:0 0 16px;margin:0;cursor:pointer}.em-sub-title{flex:1 1}.em-sub-x{background:none;border:none;color:var(--ink-5);font-size:15px;cursor:pointer;padding:0 2px;line-height:1;opacity:0;transition:opacity .1s}.em-sub:hover .em-sub-x{opacity:1}.em-sub-x:hover{color:var(--p1)}.em-sub-add{display:flex;align-items:center;gap:9px;padding:5px 6px}.em-sub-ghost-check{opacity:.25;flex:0 0 16px;width:16px;height:16px;margin:0}.em-sub-input{flex:1 1;font-size:12.5px;color:var(--ink-3);background:none;border:none;outline:none;font-family:var(--font-sans)}.em-sub-input::placeholder{color:var(--ink-4)}.em-footer{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--rule);padding-top:14px;gap:12px;flex-wrap:wrap}.em-delete-btn{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--ink-4);background:none;border:1px solid transparent;border-radius:6px;padding:5px 10px;cursor:pointer;font-family:var(--font-sans);transition:color .1s,border-color .1s,background .1s}.em-delete-btn svg{width:13px;height:13px}.em-delete-btn:hover{color:var(--p1);border-color:var(--p1);background:oklch(.97 .02 25)}.em-delete-btn.confirming{color:#fff;background:var(--p1);border-color:var(--p1)}.comment{background:var(--surface-sunk);border-radius:8px;padding:8px 10px;font-size:12px;color:var(--ink-2)}.comment .who{font-size:10.5px;color:var(--ink-4);margin-bottom:2px}.kanban{display:flex;gap:12px;overflow-x:auto;padding-bottom:12px;min-height:100%;align-items:flex-start}.col{width:268px;flex:0 0 268px;background:var(--bg-2);border-radius:10px;padding:10px;flex-direction:column;max-height:calc(100% - 4px)}.col,.col-h{display:flex;gap:8px}.col-h{align-items:center;padding:2px 4px 4px}.col-h .title{font-size:12px;font-weight:600;color:var(--ink);flex:1 1}.col-h .n{font-size:11px;color:var(--ink-4);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.col-h .add{width:18px;height:18px;color:var(--ink-4);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center}.col-h .add:hover{background:var(--rule);color:var(--ink)}.card{background:var(--surface);border-radius:7px;padding:9px 10px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:6px;cursor:-webkit-grab;cursor:grab;border-left:2px solid transparent;position:relative}.card.personal{border-left-color:var(--personal)}.card.work{border-left-color:var(--work)}.card .ctitle{font-size:12.5px;color:var(--ink);line-height:1.35;font-weight:450}.card .cmeta{display:flex;gap:8px;font-size:10.5px;color:var(--ink-3);align-items:center}.card .cmeta .meta{display:inline-flex;align-items:center;gap:3px}.card .prio-flag{width:7px;height:7px;border-radius:50%}.col-add{display:flex;align-items:center;gap:6px;padding:7px 8px;border-radius:6px;color:var(--ink-4);cursor:pointer;font-size:11.5px}.col-add:hover{background:var(--rule);color:var(--ink-2)}.matrix-wrap{display:flex;gap:12px;flex:1 1;min-height:0}.matrix-pool{display:flex;flex-direction:column;width:232px;flex:0 0 232px;background:var(--bg-2);border:1px solid var(--rule);border-radius:var(--radius-lg);padding:12px 14px;min-height:0;transition:background .12s,box-shadow .12s}.matrix-pool--over{background:var(--bg-3);box-shadow:inset 0 0 0 2px var(--ink-4)}.matrix{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;grid-gap:12px;gap:12px;flex:1 1;min-height:0}.quad{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--rule);border-top:2px solid var(--ink-5);border-radius:var(--radius-lg);padding:12px 14px;min-height:0;transition:background .12s,box-shadow .12s}.quad.q1{border-top-color:var(--p1);background:color-mix(in srgb,var(--p1) 4%,var(--surface))}.quad.q2{border-top-color:var(--p2);background:color-mix(in srgb,var(--p2) 4%,var(--surface))}.quad.q3{border-top-color:var(--p3);background:color-mix(in srgb,var(--p3) 4%,var(--surface))}.quad.q4{border-top-color:var(--ink-5)}.quad--over.q1{background:color-mix(in srgb,var(--p1) 12%,var(--surface));box-shadow:inset 0 0 0 2px var(--p1)}.quad--over.q2{background:color-mix(in srgb,var(--p2) 12%,var(--surface));box-shadow:inset 0 0 0 2px var(--p2)}.quad--over.q3{background:color-mix(in srgb,var(--p3) 12%,var(--surface));box-shadow:inset 0 0 0 2px var(--p3)}.quad--over.q4{background:color-mix(in srgb,var(--ink-5) 18%,var(--surface));box-shadow:inset 0 0 0 2px var(--ink-4)}.quad-h{display:flex;align-items:baseline;gap:8px;padding-bottom:10px;margin-bottom:8px;border-bottom:1px solid var(--rule)}.quad-h .title{font-size:13px;font-weight:600;color:var(--ink)}.quad-h .sub{flex:1 1}.quad-h .n,.quad-h .sub{font-size:11px;color:var(--ink-4)}.quad-h .n{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.quad-body{flex:1 1;display:flex;flex-direction:column;gap:8px;overflow-y:auto;min-height:0}.quad-empty{margin:auto;font-size:12px;color:var(--ink-5);padding:16px}.matrix .card{cursor:-webkit-grab;cursor:grab}.matrix .card:active{cursor:-webkit-grabbing;cursor:grabbing}.matrix-toolbar .m-search,.matrix-toolbar .m-sel{height:28px;font-size:12px;font-family:inherit;color:var(--ink-2);background:var(--surface);border:1px solid var(--rule-strong);border-radius:6px;padding:0 8px}.matrix-toolbar .m-search{width:130px}.matrix-toolbar .m-sel{cursor:pointer}.prio-pill{align-self:flex-start;margin-top:1px;font-size:10px;font-weight:600;padding:2px 7px;border-radius:999px;border:1px solid;background:transparent;font-family:inherit}.prio-pop{position:absolute;right:0;top:28px;z-index:20;background:var(--surface);border:1px solid var(--rule-strong);border-radius:10px;box-shadow:var(--shadow-lg);padding:4px;display:flex;flex-direction:column;gap:2px}.prio-pop button{text-align:left;font-size:12px;font-weight:500;padding:7px 12px;border:none;background:transparent;border-radius:6px;white-space:nowrap;font-family:inherit}.prio-pop button.on{background:var(--bg-2)}.filter-editor{background:var(--surface);border:1px solid var(--rule);border-radius:10px;padding:14px;margin-bottom:16px}.filter-name{font-size:18px;font-weight:600;color:var(--ink);border:none;outline:none;background:transparent;width:100%;letter-spacing:-.01em;margin-bottom:10px;font-family:inherit}.filter-row{display:flex;align-items:center;gap:6px;padding:6px 0;flex-wrap:wrap;font-size:12px}.filter-token{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:5px;font-size:11.5px;background:var(--bg-2);color:var(--ink-2);border:1px solid var(--rule);font-family:var(--font-mono)}.filter-token.op{background:transparent;border-color:transparent;color:var(--ink-4);text-transform:uppercase;font-size:10.5px;letter-spacing:.06em;padding:0 2px}.filter-token.field{color:var(--work-ink);background:var(--work-soft);border-color:transparent}.filter-token.val{color:var(--ink);background:white;box-shadow:var(--shadow-sm)}.filter-query{background:var(--surface-sunk);border:1px solid var(--rule);border-radius:7px;padding:10px 12px;font-family:var(--font-mono);font-size:12px;color:var(--ink-2);margin-top:10px;line-height:1.7}.filter-query .k{color:var(--work-ink);font-weight:500}.filter-query .v{color:var(--p1)}.filter-query .op{color:var(--ink-4)}.quick-overlay{position:fixed;inset:0;background:rgba(28,26,21,.3);display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:5}.quick-box{width:560px;max-width:92%;background:var(--surface);border-radius:12px;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--rule);display:flex;flex-direction:column;max-height:80vh}.quick-input{padding:14px 16px;border-bottom:1px solid var(--rule);display:flex;align-items:center;gap:10px}.quick-input input{flex:1 1;border:none;outline:none;padding:0;font-size:15px;color:var(--ink);background:transparent;font-family:inherit;letter-spacing:-.005em}.quick-box.expanded{width:620px}.quick-expand{display:inline-flex;align-items:center;gap:4px;background:var(--surface-sunk);border:1px solid var(--rule);color:var(--ink-3);font-family:inherit;font-size:11px;padding:3px 8px;border-radius:5px;cursor:pointer}.quick-expand:hover{color:var(--ink);border-color:var(--ink-4)}.quick-expand .chev{display:inline-flex;transform:rotate(90deg);transition:transform .12s ease}.quick-expand .chev.open{transform:rotate(-90deg)}.quick-detailed{padding:0 20px 8px;background:var(--surface);border-bottom:1px solid var(--rule);display:flex;flex-direction:column;font-size:12px;overflow-y:auto;flex:1 1}.quick-detailed .qd-desc{width:100%;font-size:13px;color:var(--ink-2);border:1px solid transparent;border-radius:var(--radius-sm);padding:4px 0;background:transparent;resize:vertical;min-height:42px;font-family:var(--font-sans);box-sizing:border-box;outline:none;margin-top:12px}.quick-detailed .qd-desc::placeholder{color:var(--ink-4)}.quick-detailed .qd-desc:focus{border-color:var(--ink-3)}.quick-detailed .qd-row{display:flex;flex-direction:row;align-items:center;gap:10px;min-height:34px}.quick-detailed .qd-row-top{align-items:flex-start;padding-top:4px}.quick-detailed .qd-lbl{display:flex;align-items:center;gap:5px;color:var(--ink-3);font-size:11.5px;font-family:var(--font-sans);letter-spacing:normal;flex:0 0 108px;white-space:nowrap}.quick-detailed .qd-lbl svg{width:13px;height:13px;flex-shrink:0}.quick-detailed input[type=date],.quick-detailed input[type=text],.quick-detailed input[type=time],.quick-detailed select,.quick-detailed textarea{flex:1 1;min-width:0;background:var(--surface-sunk);border:1px solid var(--rule);border-radius:var(--radius-sm);padding:5px 8px;font-family:var(--font-sans);font-size:12.5px;color:var(--ink);outline:none;transition:border-color .1s}.quick-detailed input:focus,.quick-detailed select:focus,.quick-detailed textarea:focus{border-color:var(--ink-3)}.quick-detailed textarea{resize:vertical;min-height:38px}.quick-detailed .em-date{flex:0 0 140px;width:140px}.quick-detailed .em-time{flex:0 0 110px;width:110px}.quick-detailed .qd-grid{display:contents}.quick-detailed .qd-prio{display:flex;gap:5px;flex-wrap:wrap}.quick-detailed .qd-prio-chip{display:inline-flex;align-items:center;gap:5px;background:var(--surface-sunk);border:1px solid var(--rule);border-radius:20px;padding:4px 10px;font-family:inherit;font-size:12px;font-weight:500;color:var(--ink-2);cursor:pointer;transition:background .1s,border-color .1s,color .1s}.quick-detailed .qd-prio-chip:hover{border-color:var(--ink-4)}.quick-detailed .qd-prio-chip.active{border-color:var(--ink);background:var(--ink);color:#fff}.quick-detailed .qd-prio-chip .dot{width:8px;height:8px;border-radius:50%}.qd-proj-wrap{position:relative;flex:1 1}.qd-proj-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:4px;background:var(--surface-sunk);border:1px solid var(--rule);border-radius:var(--radius-sm);padding:5px 8px;font-family:inherit;font-size:12.5px;color:var(--ink);cursor:pointer;text-align:left;transition:border-color .1s}.qd-proj-trigger:hover{border-color:var(--rule-strong)}.qd-proj-trigger.open,.qd-proj-trigger:focus{border-color:var(--ink-4);outline:none}.qd-proj-chevron{font-size:9px;color:var(--ink-4);flex-shrink:0;transition:transform .12s ease}.qd-proj-trigger.open .qd-proj-chevron{transform:rotate(180deg)}.qd-proj-drop{position:fixed;background:var(--surface);border:1px solid var(--rule-strong);border-radius:var(--radius);box-shadow:var(--shadow);z-index:9999;overflow:hidden;font-family:var(--font-sans);font-size:13px;color:var(--ink)}.qd-proj-search{display:block;width:100%;border:none;border-bottom:1px solid var(--rule);padding:7px 10px;font-family:inherit;font-size:12.5px;color:var(--ink);background:var(--surface-sunk);outline:none}.qd-proj-search::placeholder{color:var(--ink-4)}.qd-proj-list{max-height:196px;overflow-y:auto;padding:3px 0}.qd-proj-opt{display:flex;align-items:center;gap:6px;padding:6px 10px;font-size:12.5px;color:var(--ink-2);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.qd-proj-opt:hover{background:var(--bg-2);color:var(--ink)}.qd-proj-opt.selected{color:var(--ink);font-weight:500}.qd-proj-opt.selected:after{content:"";display:block;width:5px;height:5px;border-radius:50%;background:var(--ink-3);margin-left:auto}.qd-proj-empty{padding:8px 10px;font-size:12px;color:var(--ink-4);font-style:italic}.quick-detailed .qd-subs{display:flex;flex-direction:column;gap:4px;margin-bottom:4px}.quick-detailed .qd-sub,.quick-detailed .qd-sub-add{display:flex;align-items:center;gap:8px}.quick-detailed .qd-sub input[type=text],.quick-detailed .qd-sub-add input[type=text]{flex:1 1;width:auto}.qd-sub-bullet{width:11px;height:11px;border-radius:50%;border:1.25px solid var(--ink-5);background:var(--surface);flex-shrink:0}.qd-sub-x{background:transparent;border:none;color:var(--ink-4);font-size:16px;line-height:1;width:20px;height:20px;border-radius:4px;cursor:pointer;padding:0;font-family:inherit}.qd-sub-x:hover{background:var(--bg-2);color:var(--ink-2)}.qd-sub-addbtn{background:var(--surface);border:1px solid var(--rule);border-radius:5px;padding:4px 9px;font-family:inherit;font-size:11.5px;color:var(--ink-2);cursor:pointer}.qd-sub-addbtn:hover{border-color:var(--ink-4);color:var(--ink)}.qd-require-toggle{display:inline-flex;align-items:center;gap:7px;margin-top:8px;padding-left:2px;font-size:11.5px;color:var(--ink-3);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.qd-require-toggle input[type=checkbox]{width:13px;height:13px;accent-color:var(--ink);cursor:pointer;flex-shrink:0}.qd-require-toggle span{display:inline-flex;align-items:center;gap:5px}.qd-require-toggle svg{width:12px;height:12px;opacity:.65}.qd-require-toggle:hover{color:var(--ink-2)}.quick-detailed select:disabled{opacity:.5;cursor:not-allowed;background:var(--surface-sunk)}.reminder-toast{position:fixed;bottom:20px;right:20px;z-index:10000;display:flex;align-items:center;gap:10px;min-width:280px;max-width:380px;padding:10px 12px;background:var(--surface);border:1px solid var(--rule-strong);border-radius:var(--radius);box-shadow:var(--shadow-lg);font-family:var(--font-sans);font-size:13px;color:var(--ink);animation:reminder-toast-in .22s cubic-bezier(.2,.7,.2,1)}@keyframes reminder-toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.reminder-toast-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.reminder-toast-dot.personal{background:var(--personal)}.reminder-toast-dot.work{background:var(--work)}.reminder-toast-ico{color:var(--ink-3);display:inline-flex;flex-shrink:0}.reminder-toast-ico,.reminder-toast-ico svg{width:16px;height:16px}.reminder-toast-body{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:1px}.reminder-toast-title{font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reminder-toast-sub{font-size:11.5px;color:var(--ink-4);font-family:var(--font-mono)}.reminder-toast-action{background:var(--surface-sunk);border:1px solid var(--rule);border-radius:var(--radius-sm);padding:4px 10px;font-size:11.5px;font-weight:500;color:var(--ink-2);cursor:pointer;font-family:inherit;flex-shrink:0}.reminder-toast-action:hover{border-color:var(--ink-4);color:var(--ink)}.reminder-toast-x{background:transparent;border:none;width:22px;height:22px;border-radius:4px;color:var(--ink-4);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;padding:0}.reminder-toast-x:hover{background:var(--bg-2);color:var(--ink-2)}.reminder-toast-x svg{width:12px;height:12px}.quick-detailed .qd-rep-modes{display:flex;gap:0;background:var(--surface);border:1px solid var(--rule);border-radius:5px;overflow:hidden;width:-moz-fit-content;width:fit-content}.quick-detailed .qd-rep-mode{background:transparent;border:none;border-right:1px solid var(--rule);padding:5px 9px;font-family:inherit;font-size:11.5px;color:var(--ink-3);cursor:pointer}.quick-detailed .qd-rep-mode:last-child{border-right:none}.quick-detailed .qd-rep-mode:hover{color:var(--ink);background:var(--bg-2)}.quick-detailed .qd-rep-mode.active{background:var(--ink);color:var(--surface)}.quick-detailed .qd-rep-config{display:flex;flex-direction:column;gap:8px;padding:10px 12px;background:var(--surface);border:1px solid var(--rule);border-radius:6px}.quick-detailed .qd-rep-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.quick-detailed .qd-rep-prefix{color:var(--ink-3);font-size:11.5px}.quick-detailed .qd-rep-num{width:64px;flex:0 0 64px}.quick-detailed .qd-rep-unit{color:var(--ink-2);font-size:12px}.quick-detailed .qd-rep-dow{display:flex;gap:4px}.quick-detailed .qd-dow{width:26px;height:26px;border-radius:50%;border:1px solid var(--rule);background:var(--surface);color:var(--ink-3);font-family:inherit;font-size:11px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.quick-detailed .qd-dow:hover{border-color:var(--ink-4);color:var(--ink)}.quick-detailed .qd-dow.active{background:var(--ink);color:var(--surface);border-color:var(--ink)}.quick-detailed .qd-rep-preview{font-family:var(--font-mono);font-size:11px;color:var(--ink-4);padding-top:4px;border-top:1px dashed var(--rule)}.quick-detailed .qd-deadline-wrap{display:flex;flex-direction:column;gap:4px}.quick-detailed .qd-deadline-hint{margin:0;font-size:10.5px;color:var(--ink-4);font-family:var(--font-mono)}.meta.deadline-chip{display:inline-flex;align-items:center;gap:3px}.meta.deadline-chip svg{width:11px;height:11px}.meta.deadline-chip.overdue{color:var(--p1);font-weight:600}.meta.deadline-chip.urgent{color:var(--p2);font-weight:500}.quick-parsed{padding:10px 16px;display:flex;gap:6px;align-items:center;flex-wrap:wrap;background:var(--surface-sunk);font-size:11.5px}.parsed-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 7px;border-radius:5px;background:var(--surface);border:1px solid var(--rule);font-family:var(--font-mono);font-size:11px;color:var(--ink-2)}.parsed-chip .chip-k{color:var(--ink-4)}.parsed-chip.date .chip-v{color:var(--p3)}.parsed-chip.prio .chip-v{color:var(--p1);font-weight:600}.parsed-chip.project .chip-v{color:var(--ink)}.parsed-chip.label .chip-v{color:var(--work-ink)}.parsed-chip.recurring .chip-v{color:var(--personal-ink)}.parsed-hint{font-family:var(--font-mono)}.parsed-hint,.quick-footer{color:var(--ink-4);font-size:11px}.quick-footer{padding:10px 16px;display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--rule);background:var(--surface)}.quick-footer .kbd{font-family:var(--font-mono);padding:1px 5px;background:var(--bg-2);border-radius:3px;color:var(--ink-3);font-size:10.5px;border:1px solid var(--rule);margin:0 2px}.quick-footer .btn{background:var(--ink);color:white;border:none;border-radius:6px;padding:5px 12px;font-size:11.5px;font-weight:500;cursor:pointer;font-family:inherit}.hl-wrap{position:relative;flex:1 1}.hl-mirror{position:absolute;inset:0;pointer-events:none;font:inherit;font-size:15px;letter-spacing:-.005em;color:transparent;white-space:pre;overflow:hidden;display:flex;align-items:center}.hl-mirror .tok{color:transparent;border-radius:3px;padding:1px 0;pointer-events:auto;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.hl-mirror .tok.date{background:color-mix(in srgb,var(--p3) 14%,transparent)}.hl-mirror .tok.prio{background:color-mix(in srgb,var(--p1) 14%,transparent)}.hl-mirror .tok.proj{background:color-mix(in srgb,var(--personal) 14%,transparent)}.hl-mirror .tok.label{background:color-mix(in srgb,var(--work) 14%,transparent)}.hl-mirror .tok.recur{background:color-mix(in srgb,var(--personal-ink) 18%,transparent)}.settings{max-width:640px;margin:0 auto;padding:10px 6px 40px}.settings h2{font-size:20px;font-weight:600;color:var(--ink);margin:0 0 4px;letter-spacing:-.01em}.settings .lead{font-size:13px;color:var(--ink-3);margin:0 0 24px}.settings-card{background:var(--surface);border:1px solid var(--rule);border-radius:12px;overflow:hidden;margin-bottom:18px}.settings-card h3{font-size:13px;font-weight:600;color:var(--ink);margin:0;background:var(--bg-2)}.row,.settings-card h3{padding:12px 16px;border-bottom:1px solid var(--rule)}.row{display:flex;align-items:center;gap:14px}.row:last-child{border-bottom:none}.row .rl{flex:1 1;min-width:0}.row .rl .t{font-size:12.5px;font-weight:500;color:var(--ink)}.row .rl .s{font-size:11.5px;color:var(--ink-3);margin-top:1px;line-height:1.4}.toggle{width:32px;height:19px;background:var(--ink-5);border-radius:10px;position:relative;cursor:pointer;transition:background .15s;flex:0 0 32px}.toggle:after{content:"";position:absolute;left:2px;top:2px;width:15px;height:15px;background:white;border-radius:50%;transition:transform .15s;box-shadow:0 1px 2px rgba(0,0,0,.2)}.toggle.on{background:var(--ink)}.toggle.on:after{transform:translateX(13px)}.seg{display:inline-flex;padding:2px;background:var(--bg-2);border-radius:7px;border:1px solid var(--rule)}.seg button{padding:4px 10px;border:none;background:transparent;font-size:11.5px;border-radius:5px;cursor:pointer;color:var(--ink-3);font-family:inherit;font-weight:500}.seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.swatch-row{display:flex;gap:6px;flex:0 0 auto}.swatch{width:20px;height:20px;border-radius:50%;cursor:pointer;border:2px solid transparent;position:relative}.swatch.on{border-color:var(--ink)}.swatch:after{content:"";position:absolute;inset:2px;border-radius:50%;background:currentColor}.hours-row{display:flex;gap:8px;align-items:center}.hours-input{width:68px;padding:5px 8px;border:1px solid var(--rule-strong);border-radius:6px;font-family:var(--font-mono);font-size:12px;text-align:center;background:var(--surface)}.days-row{display:flex;gap:4px}.day-chip{width:24px;height:24px;border-radius:5px;background:var(--bg-2);color:var(--ink-3);font-size:10.5px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:pointer;border:1px solid var(--rule)}.day-chip.on{background:var(--work);color:white;border-color:var(--work)}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px 20px;color:var(--ink-3);gap:10px}.empty .art{width:88px;height:88px;position:relative;margin-bottom:6px}.empty h3{font-size:15px;font-weight:600;color:var(--ink);margin:0}.empty p{font-size:12.5px;margin:0;max-width:280px;line-height:1.5}.empty .cta{margin-top:8px;display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;background:var(--ink);color:white;font-size:12px;font-weight:500;cursor:pointer;border:none;font-family:inherit}.project-head{gap:10px;margin-bottom:10px}.project-head,.project-icon{display:flex;align-items:center}.project-icon{width:22px;height:22px;border-radius:6px;justify-content:center;color:white;font-size:12px}.view-tabs{display:inline-flex;gap:2px;padding:2px;background:var(--bg-2);border-radius:7px;margin-left:auto}.view-tabs button{padding:4px 10px;border:none;background:transparent;font-size:11.5px;border-radius:5px;cursor:pointer;color:var(--ink-3);font-family:inherit;font-weight:500;display:inline-flex;align-items:center;gap:4px}.view-tabs button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.mobile-chrome{background:var(--bg);height:100%;font-family:var(--font-sans);color:var(--ink)}.mobile-chrome,.mobile-head{display:flex;flex-direction:column}.mobile-head{padding:8px 18px 12px;gap:4px}.mobile-head .date{font-size:12px;color:var(--ink-3);font-weight:500}.mobile-head .title{font-size:28px;font-weight:700;letter-spacing:-.02em}.mobile-switch{display:flex;background:var(--bg-2);border-radius:10px;padding:3px;gap:3px;margin:4px 18px 12px}.mobile-switch button{flex:1 1;padding:7px;border:none;background:transparent;font-size:12px;border-radius:8px;font-weight:500;color:var(--ink-3);font-family:inherit}.mobile-switch button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.mobile-list{flex:1 1;overflow-y:auto;padding:0 18px 12px}.mobile-section{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-4);padding:12px 0 6px}.mobile-task{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--rule);align-items:flex-start}.mobile-task .checkbox{width:18px;height:18px;flex:0 0 18px;margin-top:1px}.mobile-task .tb{flex:1 1}.mobile-task .tt{font-size:14px;font-weight:450;line-height:1.3}.mobile-task .tm{font-size:11px;color:var(--ink-3);margin-top:2px;display:flex;gap:8px}.mobile-task .ws-stripe{width:3px;align-self:stretch;border-radius:2px;margin-right:-3px}.mobile-fab{position:absolute;bottom:92px;right:18px;width:52px;height:52px;border-radius:16px;background:var(--ink);color:white;box-shadow:0 10px 24px -6px rgba(0,0,0,.35);display:flex;align-items:center;justify-content:center;cursor:pointer}.mobile-tabbar{padding:6px 18px 12px;display:flex;justify-content:space-around;border-top:1px solid var(--rule);background:rgba(250,248,244,.95);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.mobile-tabbar .tb{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 14px;color:var(--ink-4);font-size:10.5px}.mobile-tabbar .tb.on{color:var(--ink)}.mobile-quick{position:absolute;inset:0;background:rgba(28,26,21,.35);justify-content:flex-end;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.mobile-quick,.mobile-quick-box{display:flex;flex-direction:column}.mobile-quick-box{background:var(--surface);border-radius:20px 20px 0 0;padding:16px 18px 24px;gap:12px}.mobile-quick-box .minput{font-size:16px;border:none;outline:none;padding:4px 0;font-family:inherit;color:var(--ink);background:transparent}.mobile-quick-box .mchips{display:flex;gap:6px;flex-wrap:wrap}.i{width:14px;height:14px;display:inline-block;flex-shrink:0}.i svg{width:100%;height:100%;display:block}.chip-parent{display:inline-flex;align-items:center;gap:3px;font-size:10.5px;color:var(--ink-3);background:var(--surface-sunk);border:1px solid var(--rule);padding:1px 6px;border-radius:3px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task.indent{padding-left:28px;position:relative}.task.indent:before{content:"";position:absolute;left:14px;top:0;bottom:0;width:1px;background:var(--rule)}.detail-parent-crumb{cursor:pointer;color:var(--ink-3);border-bottom:1px dotted var(--rule-strong);padding-bottom:1px}.detail-parent-crumb:hover{color:var(--ink)}.detail-modal-subtasks .st-title,.detail-subtasks .st-title{-webkit-user-select:none;-moz-user-select:none;user-select:none}.detail-modal-subtasks .st-remove,.detail-subtasks .st-remove{background:none;border:none;color:var(--ink-4);cursor:pointer;font-size:14px;line-height:1;padding:2px 4px;border-radius:3px;opacity:0;transition:opacity .08s,background .08s,color .08s}.detail-modal-subtasks .st:hover .st-remove,.detail-subtasks .st:hover .st-remove{opacity:1}.detail-modal-subtasks .st-remove:hover,.detail-subtasks .st-remove:hover{background:var(--surface-sunk);color:var(--p1)}.st-add-row{padding:4px 0 0;display:flex;align-items:center;gap:6px}.st-add-input{flex:1 1;border:none;outline:none;background:transparent;font-family:inherit;font-size:12px;color:var(--ink-3);padding:2px 0}.st-add-input::placeholder{color:var(--ink-4)}.st-add-input:focus{color:var(--ink)}.st-add-btn{font-size:11px;padding:2px 8px;border-radius:4px;border:1px solid var(--rule-strong);background:var(--surface);color:var(--ink-2);cursor:pointer;font-family:inherit;white-space:nowrap}.st-add-btn:hover{background:var(--surface-sunk);color:var(--ink)}.m-toggle{display:inline-flex;align-items:center;gap:5px;height:28px;padding:0 10px;border-radius:5px;border:1px solid var(--rule-strong);background:var(--surface);color:var(--ink-3);font-size:12px;font-family:inherit;cursor:pointer;white-space:nowrap;transition:background .1s,color .1s,border-color .1s}.m-toggle svg{width:13px;height:13px;opacity:.6}.m-toggle:hover{background:var(--surface-sunk);color:var(--ink-2)}.m-toggle.on{background:var(--ink);color:var(--surface);border-color:var(--ink)}.m-toggle.on svg{opacity:1}.checkbox.locked{cursor:not-allowed!important;opacity:.35;position:relative}.checkbox.locked:after{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='none' stroke='%23888' stroke-width='1.5' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='4' y='7.5' width='8' height='6' rx='1'/%3E%3Cpath d='M5.5 7.5V5.5a2.5 2.5 0 015 0v2'/%3E%3C/svg%3E") 50%/70% no-repeat}.em-row-require{align-items:center}.em-require-toggle{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--ink-2);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.em-require-toggle input[type=checkbox]{width:14px;height:14px;accent-color:var(--ink);cursor:pointer;flex-shrink:0}.em-require-toggle span{line-height:1.3}.confirm-card{background:var(--surface);border:1px solid var(--rule-strong);border-radius:10px;box-shadow:0 12px 40px rgba(0,0,0,.18);padding:20px 22px;max-width:380px;width:calc(100% - 32px)}.confirm-title{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:6px}.confirm-body{font-size:12.5px;color:var(--ink-2);margin-bottom:16px;line-height:1.4}.confirm-actions{display:flex;gap:8px;justify-content:flex-end}.confirm-btn{font-size:12px;padding:6px 12px;border-radius:5px;border:1px solid var(--rule-strong);background:var(--surface);color:var(--ink-2);cursor:pointer;font-family:inherit}.confirm-btn:hover{background:var(--surface-sunk);color:var(--ink)}.confirm-btn.primary{background:var(--ink);color:var(--surface);border-color:var(--ink)}.confirm-btn.primary:hover{background:var(--ink-2);border-color:var(--ink-2)}body,html{margin:0;padding:0;background:var(--bg,#faf8f4);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#1c1a15;-webkit-font-smoothing:antialiased;overscroll-behavior:none}#__next,body,main.shell{min-height:100dvh}main.shell>.app,main.shell>.mobile-wrap{height:100dvh;width:100vw}main.shell>.mobile-wrap{display:flex;flex-direction:column;background:var(--bg)}main.shell>.mobile-wrap>.mobile-chrome{flex:1 1;min-height:0}.signin{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:32px;background:var(--bg);text-align:center}.signin .mark{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,var(--personal) 0,var(--work) 100%);position:relative}.signin .mark:after{content:"";position:absolute;inset:10px;border-radius:6px;background:var(--bg)}.signin .mark:before{content:"";position:absolute;left:18px;top:22px;width:20px;height:13px;border-left:2.5px solid var(--ink);border-bottom:2.5px solid var(--ink);transform:rotate(-45deg);z-index:1}.signin h1{margin:0;font-size:28px;font-weight:700;letter-spacing:-.02em}.signin p{margin:0;max-width:360px;color:var(--ink-3);font-size:14px;line-height:1.5}.signin button{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;border-radius:8px;border:1px solid var(--rule-strong);background:var(--surface);font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;color:var(--ink);box-shadow:var(--shadow-sm)}.signin button:hover{background:white}.signin .err{color:var(--p1);font-size:12px;max-width:360px}.loading-splash{min-height:100dvh;display:flex;align-items:center;justify-content:center;color:var(--ink-4);font-size:13px;background:var(--bg)}.app .main{min-width:0}.nav-item.proj-row{padding-left:4px}.sub-chev{width:14px;height:14px;flex:0 0 14px;display:inline-flex;align-items:center;justify-content:center;color:transparent;border-radius:3px;cursor:default;transition:transform .15s,color .1s}.sub-chev.visible{color:var(--ink-4);cursor:pointer}.sub-chev.visible:hover{color:var(--ink-2);background:var(--rule)}.sub-chev.open{transform:rotate(90deg)}.nav-item.proj-row:hover .sub-chev:not(.visible){color:transparent}.nav-item .proj-name{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.proj-add-sub{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;border-radius:3px;cursor:pointer;flex:0 0 16px;color:transparent}.nav-item.proj-row:hover .proj-add-sub{color:var(--ink-4)}.proj-add-sub:hover{background:var(--rule)!important;color:var(--ink-2)!important}.nav-item.sub-row{padding-left:30px}.sub-add-row{padding:3px 6px 4px 30px}.sub-add-input{width:100%;padding:4px 8px;border:1px solid var(--rule-strong);border-radius:5px;background:var(--surface);font-size:12px;font-family:inherit;color:var(--ink);outline:none}.sub-add-input:focus{border-color:var(--ink-4)}.proj-toolbar{display:flex;align-items:center;gap:6px;padding:5px 22px 8px;border-bottom:1px solid var(--rule);flex-wrap:wrap;background:var(--bg)}.toolbar-sep{width:1px;height:18px;background:var(--rule-strong);flex-shrink:0;margin:0 2px}.subproj-section-h{display:flex;align-items:center;gap:7px;padding:8px 2px 5px;margin-top:6px;border-top:1px solid var(--rule);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.subproj-section-h:first-child{border-top:none}.sub-sec-chev{width:14px;height:14px;flex:0 0 14px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-4);transition:transform .15s}.sub-sec-chev.open{transform:rotate(90deg)}.sub-sec-name{font-size:12.5px;font-weight:500;color:var(--ink-2);flex:1 1;cursor:pointer}.sub-sec-name:hover{color:var(--ink);text-decoration:underline}.sub-sec-count{font-size:11px;color:var(--ink-4);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;background:var(--surface-sunk);padding:0 6px;border-radius:10px}.sub-sec-hint{font-size:10.5px;color:var(--ink-5)}.subproj-section-h:hover .sub-sec-hint{color:var(--ink-3)}.subproj-filter-bar{display:flex;align-items:center;gap:6px;padding:0 0 10px;flex-wrap:wrap}.subproj-filter-label{font-size:11px;font-weight:500;color:var(--ink-4)}.subproj-filter-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;border:1px solid var(--rule-strong);background:transparent;font-size:11.5px;font-family:inherit;color:var(--ink-3);cursor:pointer;transition:background .1s,color .1s,border-color .1s}.subproj-filter-chip:hover{background:var(--surface);color:var(--ink-2)}.subproj-filter-chip.on{background:var(--surface);color:var(--ink);border-color:var(--ink-4);font-weight:500}.card-subproj-badge{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--ink-4);margin:3px 0 1px}.proj-breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink-3)}.proj-breadcrumb-parent{cursor:pointer;color:var(--ink-3)}.proj-breadcrumb-parent:hover{color:var(--ink);text-decoration:underline}.proj-breadcrumb-sep{color:var(--ink-5)}.section-editor{margin:0 0 12px;background:var(--surface);border:1px solid var(--rule);border-radius:10px;overflow:hidden}.section-editor-head{display:flex;align-items:baseline;gap:8px;padding:10px 14px 8px;border-bottom:1px solid var(--rule)}.section-editor-head .se-title{font-size:12px;font-weight:600;color:var(--ink-2)}.section-editor-head .se-sub{font-size:11px;color:var(--ink-4)}.section-editor-head .se-sub b{font-weight:600;color:var(--ink-3)}.se-row{display:flex;align-items:center;gap:10px;padding:7px 14px;border-bottom:1px solid var(--rule);transition:background .1s}.se-row:last-of-type{border-bottom:none}.se-row:hover{background:var(--surface-sunk)}.se-name-input{flex:1 1;border:none;outline:none;background:transparent;font-size:13px;font-family:inherit;color:var(--ink);padding:1px 0;min-width:0}.se-name-input:focus{color:var(--ink);text-decoration:underline;-webkit-text-decoration-color:var(--rule-strong);text-decoration-color:var(--rule-strong);text-underline-offset:3px}.se-pill{flex-shrink:0;display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;border:1.5px solid var(--rule-strong);background:transparent;font-size:10.5px;font-family:inherit;font-weight:500;color:var(--ink-4);cursor:pointer;white-space:nowrap;transition:border-color .15s,background .15s,color .15s;opacity:0}.se-pill.active,.se-row:hover .se-pill{opacity:1}.se-pill:hover{border-color:var(--ink-3);color:var(--ink-2);background:var(--surface-sunk)}.se-pill.se-pill-default.active{background:var(--ink);border-color:var(--ink);color:white}.se-pill.se-pill-done.active{background:oklch(.5 .14 145);border-color:oklch(.5 .14 145);color:white}.se-delete{width:22px;height:22px;flex:0 0 22px;display:flex;align-items:center;justify-content:center;border-radius:5px;border:none;background:transparent;color:transparent;cursor:pointer;font-size:14px;transition:background .1s,color .1s}.se-row:hover .se-delete{color:var(--ink-4)}.se-delete:hover{background:var(--rule)!important;color:var(--ink-2)!important}.se-delete:disabled{pointer-events:none;opacity:0}.se-add-row{gap:8px;padding:7px 14px;border-top:1px solid var(--rule)}.se-add-icon,.se-add-row{display:flex;align-items:center}.se-add-icon{width:14px;height:14px;flex:0 0 14px;color:var(--ink-4);justify-content:center}.se-add-input{flex:1 1;border:none;outline:none;background:transparent;font-size:13px;font-family:inherit;color:var(--ink);padding:1px 0}.se-add-input::placeholder{color:var(--ink-5)}.se-add-input:focus::placeholder{color:var(--ink-4)}.list-section-h{display:flex;align-items:center;gap:6px;padding:16px 0 4px;cursor:default}.list-sec-chev-btn{display:flex;align-items:center;justify-content:center;width:18px;height:18px;flex:0 0 18px;border:none;background:transparent;cursor:pointer;padding:0;color:var(--ink-4)}.list-sec-name{font-size:12px;font-weight:600;color:var(--ink-3);white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none;cursor:default}.list-section-h:hover .list-sec-name{color:var(--ink-2)}.list-sec-name-input{font-size:12px;font-weight:600;color:var(--ink);border:none;outline:none;background:transparent;font-family:inherit;border-bottom:1.5px solid var(--ink-3);padding:0 0 1px;min-width:80px}.list-sec-count{font-size:11px;color:var(--ink-5);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;flex-shrink:0}.list-sec-line{flex:1 1;height:1px;background:var(--rule);min-width:16px}.list-sec-actions{display:flex;align-items:center;gap:1px;opacity:0;transition:opacity .15s;flex-shrink:0}.list-section-h:hover .list-sec-actions{opacity:1}.list-sec-add-btn,.list-sec-del-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;background:transparent;cursor:pointer;border-radius:4px;color:var(--ink-4);font-size:14px;transition:background .1s,color .1s}.list-sec-add-btn:hover{background:var(--surface);color:var(--ink-2)}.list-sec-del-btn:hover{background:var(--surface);color:oklch(.6 .2 25)}.list-sec-del-btn:disabled{opacity:.25;cursor:not-allowed}.list-add-section-btn{display:flex;align-items:center;gap:8px;padding:10px 2px 6px;color:var(--ink-5);cursor:pointer;font-size:13px;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color .12s}.list-add-section-btn:hover{color:var(--ink-3)}.list-add-section-btn .plus{display:flex;align-items:center;justify-content:center;width:16px;height:16px}.list-add-section-input-row{padding:10px 2px 4px}.list-new-section-input{font-size:12px;font-weight:600;color:var(--ink);border:none;outline:none;background:transparent;border-bottom:1.5px solid var(--ink-3);font-family:inherit;padding:2px 0;width:200px}.list-new-section-input::placeholder{color:var(--ink-5)}@supports (padding:max(0px)){.mobile-chrome{padding-top:max(env(safe-area-inset-top),0px)}.mobile-tabbar{padding-bottom:max(env(safe-area-inset-bottom),12px)!important}.mobile-fab{bottom:calc(92px + env(safe-area-inset-bottom))!important}}