:root{color-scheme:light dark;--bg: oklch(.98 .006 255);--bg-elevated: oklch(1 0 0);--bg-sunken: oklch(.95 .012 255);--ink: oklch(.2 .02 260);--ink-2: oklch(.42 .02 260);--ink-3: oklch(.62 .015 260);--line: oklch(.9 .014 255);--line-1: oklch(.78 .022 255);--line-2: oklch(.94 .01 255);--accent: oklch(.58 .22 264);--accent-ink: oklch(.42 .2 264);--accent-wash: oklch(.96 .04 264);--accent-soft: oklch(.82 .1 264);--calm: oklch(.55 .08 200);--calm-wash: oklch(.95 .02 200);--warn: oklch(.68 .16 75);--warn-wash: oklch(.95 .06 75);--danger: oklch(.58 .18 25);--danger-wash: oklch(.94 .06 18);--danger-border: oklch(.8 .12 18);--ok: oklch(.6 .12 155);--ok-wash: oklch(.94 .06 155);--bulk-bar-bg: #1A1C24;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-xl: 22px;--shadow-sm: 0 1px 2px oklch(.2 .01 260 / .04), 0 1px 1px oklch(.2 .01 260 / .03);--shadow: 0 2px 8px oklch(.2 .01 260 / .05), 0 1px 2px oklch(.2 .01 260 / .04);--shadow-lg: 0 12px 32px oklch(.2 .01 260 / .08), 0 2px 6px oklch(.2 .01 260 / .04);--ui: "Inter", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--display: "Instrument Serif", "Cormorant Garamond", Georgia, serif;--mono: "JetBrains Mono", ui-monospace, monospace}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--bg: oklch(.18 .02 260);--bg-elevated: oklch(.24 .018 260);--bg-sunken: oklch(.14 .02 260);--ink: oklch(.96 .008 250);--ink-2: oklch(.78 .012 250);--ink-3: oklch(.58 .014 250);--line: oklch(.32 .02 260);--line-1: oklch(.45 .025 260);--line-2: oklch(.26 .016 260);--accent: oklch(.72 .18 264);--accent-ink: oklch(.86 .12 264);--accent-wash: oklch(.3 .1 264);--accent-soft: oklch(.55 .16 264);--warn: oklch(.74 .16 75);--warn-wash: oklch(.3 .1 75);--danger: oklch(.66 .18 25);--danger-wash: oklch(.3 .14 18);--danger-border: oklch(.42 .16 18);--ok: oklch(.7 .13 155);--ok-wash: oklch(.28 .08 155);--bulk-bar-bg: #0A0E1A;--shadow-sm: 0 1px 2px rgb(0 0 0 / .4), 0 1px 1px rgb(0 0 0 / .3);--shadow: 0 2px 8px rgb(0 0 0 / .45), 0 1px 2px rgb(0 0 0 / .35);--shadow-lg: 0 12px 32px rgb(0 0 0 / .55), 0 2px 6px rgb(0 0 0 / .4)}}:root[data-theme=dark]{--bg: oklch(.18 .02 260);--bg-elevated: oklch(.24 .018 260);--bg-sunken: oklch(.14 .02 260);--ink: oklch(.96 .008 250);--ink-2: oklch(.78 .012 250);--ink-3: oklch(.58 .014 250);--line: oklch(.32 .02 260);--line-1: oklch(.45 .025 260);--line-2: oklch(.26 .016 260);--accent: oklch(.72 .18 264);--accent-ink: oklch(.86 .12 264);--accent-wash: oklch(.3 .1 264);--accent-soft: oklch(.55 .16 264);--warn: oklch(.74 .16 75);--danger: oklch(.66 .18 25);--ok: oklch(.7 .13 155);--shadow-sm: 0 1px 2px rgb(0 0 0 / .4), 0 1px 1px rgb(0 0 0 / .3);--shadow: 0 2px 8px rgb(0 0 0 / .45), 0 1px 2px rgb(0 0 0 / .35);--shadow-lg: 0 12px 32px rgb(0 0 0 / .55), 0 2px 6px rgb(0 0 0 / .4)}:root[data-theme=dark] .btn-accent:hover{background:#5588fb}:root[data-theme=dark] .btn-subtle:hover{background:#282e38}:root[data-theme=dark] .shimmer{background-image:linear-gradient(90deg,var(--bg-sunken) 0%,oklch(.22 .02 260) 50%,var(--bg-sunken) 100%)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .btn-accent:hover{background:#5588fb}:root:not([data-theme=light]) .btn-subtle:hover{background:#282e38}:root:not([data-theme=light]) .shimmer{background-image:linear-gradient(90deg,var(--bg-sunken) 0%,oklch(.22 .02 260) 50%,var(--bg-sunken) 100%)}}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--ui);font-size:15px;line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{min-height:100vh}button,input,textarea,select{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none}::selection{background:var(--accent-wash);color:var(--accent-ink)}.app{min-height:100vh;display:grid;grid-template-columns:260px 1fr}.sidebar{border-inline-end:1px solid var(--line);background:var(--bg);padding:20px 16px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:4px}.main{min-width:0;min-height:100vh;display:flex;flex-direction:column}.content{flex:1;padding:32px 48px 80px;max-width:1100px;width:100%;margin:0 auto}.web-footer{border-top:1px solid var(--line-2);background:var(--bg);padding:20px 48px calc(20px + env(safe-area-inset-bottom))}.web-footer-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:14px 18px}.web-footer-text{font-size:13px;color:var(--ink-3);font-weight:500}.web-footer-badges{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.web-footer-legal{max-width:1100px;margin:14px auto 0;text-align:center;font-size:12px;color:var(--ink-3);font-weight:400;letter-spacing:.01em}.web-footer-tm{font-size:.7em;vertical-align:super;margin-inline-start:.1em;font-weight:500}.store-badge{display:inline-flex;border-radius:7px;transition:transform .12s ease,opacity .12s ease;text-decoration:none}.store-badge:hover{opacity:.85;transform:translateY(-1px)}.store-badge:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.store-badge-svg{display:block}.auth-store-badges{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.brand{display:flex;align-items:center;gap:10px;padding:4px 8px 16px;border-bottom:1px solid var(--line-2);margin-bottom:12px}.brand-mark{width:32px;height:32px;border-radius:9px;background:var(--ink);color:var(--bg);display:grid;place-items:center;font-family:var(--display);font-size:20px;line-height:1;padding-bottom:2px;position:relative}.brand-mark:after{content:"";position:absolute;right:-2px;top:-2px;width:8px;height:8px;border-radius:50%;background:var(--accent)}.brand-name{font-family:var(--display);font-size:22px;letter-spacing:-.01em;line-height:1}.brand-name em{font-style:italic;color:var(--accent-ink)}.nav-section{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);padding:14px 10px 6px;font-weight:500}.nav-item{display:flex;align-items:center;gap:12px;padding:9px 10px;border-radius:10px;color:var(--ink-2);font-size:14px;font-weight:500;cursor:pointer;transition:background .12s,color .12s;width:100%;text-align:start;position:relative}.nav-item:hover{background:var(--bg-sunken);color:var(--ink)}.nav-item.active{background:var(--ink);color:var(--bg)}.nav-item .nav-icon{width:18px;height:18px;flex-shrink:0}.nav-item .nav-count{margin-inline-start:auto;font-size:11px;font-variant-numeric:tabular-nums;background:var(--bg-sunken);color:var(--ink-2);padding:2px 7px;border-radius:20px;font-weight:600}.nav-item.active .nav-count{background:#ffffff26;color:var(--bg)}.nav-item .nav-count.accent{background:var(--accent);color:#fff}.topbar{padding:14px 48px;display:flex;align-items:center;gap:16px;border-bottom:1px solid var(--line-2);background:var(--bg);position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.topbar-crumb{font-size:13px;color:var(--ink-3)}.topbar-crumb b{color:var(--ink);font-weight:600}.login-as{margin-inline-start:auto;position:relative}.login-as-trigger{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600;color:#fff;background:var(--accent, #1E5BFF);border:1px solid transparent;cursor:pointer;box-shadow:var(--shadow-sm)}.login-as-trigger:hover{filter:brightness(.96)}.login-as-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:flex-start;justify-content:center;padding-top:10vh;z-index:9100}.login-as-panel{width:min(520px,calc(100vw - 32px));background:var(--bg-elevated);border:1px solid var(--line-2);border-radius:14px;box-shadow:0 10px 40px #00000040;display:flex;flex-direction:column;max-height:70vh;overflow:hidden}.login-as-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line-2);font-size:14px}.login-as-panel .input{margin:12px 16px 8px}.login-as-err{padding:6px 16px;color:var(--danger, #c0392b);font-size:12px}.login-as-list{flex:1;overflow-y:auto;padding:4px 8px 8px}.login-as-empty{padding:20px 16px;color:var(--ink-3);font-size:13px;text-align:center}.login-as-row{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:8px;text-align:start;background:transparent;border:1px solid transparent;cursor:pointer}.login-as-row:hover:not(:disabled){background:var(--bg-sunken);border-color:var(--line-2)}.login-as-row:disabled{opacity:.45;cursor:not-allowed}.login-as-row-main{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.login-as-name{font-weight:600;color:var(--ink);font-size:13px}.login-as-email{color:var(--ink-3);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.login-as-role{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3)}.login-as-role.is-super{color:var(--accent, #1E5BFF)}.login-as-foot{padding:10px 16px;border-top:1px solid var(--line-2);background:var(--bg-sunken);color:var(--ink-3);font-size:11px}.display{font-family:var(--display);font-weight:400;letter-spacing:-.015em;line-height:1.05}.display em{font-style:italic;color:var(--accent-ink)}h1.display{font-size:44px;margin:0 0 12px}h2.display{font-size:32px;margin:0 0 10px}h3.display{font-size:24px;margin:0 0 6px}.eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);font-weight:600}.dim{color:var(--ink-3)}.meta{font-size:13px;color:var(--ink-2)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;font-size:14px;font-weight:500;transition:all .12s;white-space:nowrap}.btn-primary{background:var(--ink);color:var(--bg)}.btn-primary:hover{background:#292e36}.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:#1d52de}.btn-ghost{background:transparent;color:var(--ink-2);border:1px solid var(--line)}.btn-ghost:hover,.btn-subtle{background:var(--bg-sunken);color:var(--ink)}.btn-subtle:hover{background:#dee5ee}.btn-danger{background:transparent;color:var(--danger);border:1px solid oklch(.88 .05 25)}.btn-danger:hover{background:#fff1f0;background:oklch(.97 .02 25)}.btn-sm{padding:6px 10px;font-size:13px;border-radius:8px}.btn-lg{padding:14px 22px;font-size:15px;border-radius:12px}.btn-icon{padding:8px;border-radius:8px}.btn:disabled{opacity:.4;cursor:not-allowed}.card{background:var(--bg-elevated);border:1px solid var(--line-2);border-radius:var(--radius-lg);padding:20px;position:relative}.card-hover{cursor:pointer;transition:all .15s}.card-hover:hover{border-color:var(--line);box-shadow:var(--shadow);transform:translateY(-1px)}.list-card-actions{opacity:0;transform:translateY(-2px);transition:opacity .12s ease,transform .12s ease;pointer-events:none}.list-card:hover .list-card-actions,.list-card:focus-within .list-card-actions,.list-card-actions.is-open{opacity:1;transform:translateY(0);pointer-events:auto}@media(hover:none){.list-card-actions{opacity:1;transform:none;pointer-events:auto}}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.input,.textarea,.select{width:100%;background:var(--bg-elevated);border:1px solid var(--line);border-radius:var(--radius);padding:11px 14px;font-size:14px;color:var(--ink);transition:border .12s,box-shadow .12s;font-family:inherit}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-wash)}.textarea{resize:vertical;min-height:80px;line-height:1.5}.input-lg{padding:14px 18px;font-size:16px;border-radius:14px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;font-weight:500;color:var(--ink-2)}.field .hint{font-size:12px;color:var(--ink-3)}.avatar{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:600;background:var(--bg-sunken);color:var(--ink-2);flex-shrink:0;border:1px solid var(--line-2)}.avatar-lg{width:48px;height:48px;font-size:16px}.avatar-sm{width:24px;height:24px;font-size:10px}.avatar.c-1{background:#fedcd3;color:#7b2813}.avatar.c-2{background:#c7edef;color:#004447;color:oklch(.35 .1 200)}.avatar.c-3{background:#d3edd7;color:#00481d;color:oklch(.35 .1 150)}.avatar.c-4{background:#dfe2ff;background:oklch(.92 .04 280);color:#32326d}.avatar.c-5{background:#f9dfcb;color:#6b3900;color:oklch(.4 .12 60)}.avatar.c-6{background:#f8dbed;color:#60194e}.avatar-stack{display:inline-flex}.avatar-stack .avatar{margin-inline-start:-8px;border:2px solid var(--bg-elevated)}.avatar-stack .avatar:first-child{margin-inline-start:0}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.01em;background:var(--bg-sunken);color:var(--ink-2);white-space:nowrap}.badge-accent{background:var(--accent-wash);color:var(--accent-ink)}.badge-calm{background:var(--calm-wash);color:#004447;color:oklch(.35 .1 200)}.badge-ok{background:#e0f5e6;color:#004725;color:oklch(.35 .1 155)}.badge-warn{background:#ffeada;background:oklch(.95 .04 60);color:#6b3900;color:oklch(.4 .12 60)}.badge-danger{background:#ffe8e6;background:oklch(.95 .03 25);color:#7c2524}.badge-outline{background:transparent;border:1px solid var(--line)}.badge .dot{width:5px;height:5px;border-radius:50%;background:currentColor}.empty{text-align:center;padding:60px 20px;border:1.5px dashed var(--line);border-radius:var(--radius-lg);background:var(--bg-sunken)}.empty h3{font-family:var(--display);font-size:22px;margin:0 0 6px}.empty p{color:var(--ink-2);max-width:360px;margin:0 auto 16px}.row{display:flex;align-items:center;gap:12px}.col{display:flex;flex-direction:column}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}.gap-32{gap:32px}.flex-1{flex:1;min-width:0}.hidden{display:none!important}.spacer{flex:1}.divider{height:1px;background:var(--line-2);margin:16px 0}.grow{flex:1;min-width:0}.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.list{background:var(--bg-elevated);border:1px solid var(--line-2);border-radius:var(--radius-lg);overflow:hidden}.list-row{display:flex;flex-wrap:wrap;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid var(--line-2);transition:background .1s}.list-row:last-child{border-bottom:none}.list-row:hover{background:var(--bg-sunken)}.list-row.strike .item-name{text-decoration:line-through;color:var(--ink-3)}.list-row .item-name{overflow-wrap:anywhere}.item-check:hover>span{border-color:var(--ink-2)}.item-check:focus-visible{outline:2px solid var(--accent, oklch(.55 .18 264));outline-offset:2px}.check{width:22px;height:22px;border-radius:7px;border:1.5px solid var(--line);background:var(--bg-elevated);display:grid;place-items:center;flex-shrink:0;cursor:pointer;transition:all .12s}.check:hover{border-color:var(--ink-2)}.check.checked{background:var(--ink);border-color:var(--ink);color:#fff}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.fade-in{opacity:1}@keyframes slideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.slide-in{animation:slideIn .3s cubic-bezier(.2,.8,.2,1)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.pulsing{animation:pulse 1.2s ease-in-out infinite}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#13161b59;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:100;padding:20px;animation:fadeIn .15s}.modal{background:var(--bg-elevated);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:90vh;overflow:auto;animation:slideIn .2s cubic-bezier(.2,.8,.2,1)}.modal-header{padding:22px 24px 4px}.modal-body{padding:8px 24px 20px}.modal-footer{padding:16px 24px;border-top:1px solid var(--line-2);display:flex;gap:8px;justify-content:flex-end;background:var(--bg-sunken)}.segmented{display:inline-flex;background:var(--bg-sunken);padding:3px;border-radius:10px;gap:2px;border:1px solid var(--line-2)}.segmented button{padding:6px 12px;border-radius:7px;font-size:13px;font-weight:500;color:var(--ink-2)}.segmented button.active{background:var(--bg-elevated);color:var(--ink);box-shadow:var(--shadow-sm)}.progress{height:6px;background:var(--bg-sunken);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--ink);border-radius:3px;transition:width .4s cubic-bezier(.2,.8,.2,1)}.progress-fill.accent{background:var(--accent)}.toast-stack{position:fixed;bottom:24px;inset-inline-end:24px;display:flex;flex-direction:column;gap:8px;z-index:200;pointer-events:none}.toast{background:var(--ink);color:var(--bg);padding:12px 16px;border-radius:var(--radius);box-shadow:var(--shadow-lg);font-size:13px;max-width:340px;display:flex;align-items:center;gap:10px;animation:slideIn .25s cubic-bezier(.2,.8,.2,1);pointer-events:auto}@media(max-width:780px){.app{grid-template-columns:1fr}.sidebar{position:fixed;bottom:0;left:0;right:0;top:auto;height:auto;flex-direction:row;border-inline-end:none;border-top:1px solid var(--line);padding:8px 12px calc(8px + env(safe-area-inset-bottom));z-index:50;background:var(--bg-elevated);overflow-x:auto}.sidebar .brand,.sidebar .nav-section,.sidebar .spacer{display:none}.sidebar .nav-item:not(.nav-tab){display:none}.sidebar .sidebar-bottom{display:contents}.sidebar .sidebar-bottom>:not(.nav-tab){display:none}.nav-item{flex:1;flex-direction:column;gap:3px;padding:8px 10px;font-size:10px;min-width:64px;border-radius:10px}.nav-item .nav-count{position:absolute;top:2px;inset-inline-end:8px;padding:1px 5px;font-size:10px;min-width:16px;height:16px}.main{padding-bottom:78px}.content{padding:20px 16px}.topbar{padding:12px 16px}.toast-stack{bottom:calc(86px + env(safe-area-inset-bottom));left:16px;right:16px}.toast{max-width:none}.web-footer{padding:16px;text-align:center}.web-footer-inner{flex-direction:column;gap:10px}.web-footer-badges{justify-content:center}h1.display{font-size:32px}h2.display{font-size:26px}.login-as-trigger span{display:none}.login-as-trigger{padding:8px}}.shimmer{background:linear-gradient(90deg,var(--bg-sunken) 0%,oklch(.94 .012 255) 50%,var(--bg-sunken) 100%);background-size:200% 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:8px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ic{width:16px;height:16px;stroke-width:1.8;flex-shrink:0}.ic-lg{width:20px;height:20px}.ic-sm{width:14px;height:14px}.btn-icon-mini{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;color:var(--ink-3);flex-shrink:0}.btn-icon-mini:hover{background:var(--bg-sunken);color:var(--ink)}.todo-quickadd{margin-bottom:16px;padding:14px 16px}.todo-quickadd-row{display:flex;align-items:center;gap:10px}.todo-quickadd-row>.ic{color:var(--ink-3)}.todo-quickadd-input{border:none;padding:6px 0;font-size:16px;background:transparent;flex:1}.todo-quickadd-input:focus{box-shadow:none}.todo-quickadd-meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:10px;padding-top:10px;border-top:1px dashed var(--line-2);font-size:13px}.todo-meta-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid var(--line);border-radius:999px;background:var(--bg);cursor:pointer}.todo-meta-chip input,.todo-meta-chip select{border:none;background:transparent;font:inherit;color:inherit;padding:0;cursor:pointer}.todo-meta-chip input[type=date]{min-width:130px}.todo-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:12px;margin:18px 0 12px}.todo-tabs{display:inline-flex;background:var(--bg-sunken);padding:3px;border-radius:12px;border:1px solid var(--line-2);flex-wrap:wrap}.todo-tab{padding:7px 13px;border-radius:9px;font-size:13px;font-weight:500;color:var(--ink-2);display:inline-flex;align-items:center;gap:6px}.todo-tab.active{background:var(--bg-elevated);color:var(--ink);box-shadow:var(--shadow-sm)}.todo-tab-count{background:var(--bg-sunken);color:var(--ink-2);padding:1px 7px;border-radius:999px;font-size:11px;font-variant-numeric:tabular-nums;font-weight:600}.todo-tab.active .todo-tab-count{background:var(--ink);color:var(--bg)}.todo-search{position:relative;display:inline-flex;align-items:center;gap:8px;min-width:220px;flex:1;max-width:320px}.todo-search>.ic{position:absolute;inset-inline-start:12px;pointer-events:none;color:var(--ink-3)}.todo-search .input{padding-inline-start:34px;padding-inline-end:34px}.todo-search .btn-icon-mini{position:absolute;inset-inline-end:8px}.todo-sort{width:auto;min-width:170px}.todo-stats{display:flex;align-items:center;gap:28px;padding:14px 18px;background:var(--bg-sunken);border:1px solid var(--line-2);border-radius:var(--radius-lg);margin-bottom:14px}.todo-stats>div{display:flex;flex-direction:column}.todo-stat-num{font-family:var(--display);font-size:22px;line-height:1;color:var(--ink)}.todo-stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);margin-top:4px}.todo-list{display:flex;flex-direction:column;gap:8px}.todo-row{display:flex;align-items:flex-start;gap:14px;padding:12px 16px;background:var(--bg-elevated);border:1px solid var(--line-2);border-radius:var(--radius);transition:border-color .12s,box-shadow .12s,transform .12s;position:relative}.todo-row:hover{border-color:var(--line);box-shadow:var(--shadow-sm)}.todo-row:before{content:"";position:absolute;inset-inline-start:0;top:12px;bottom:12px;width:3px;border-start-end-radius:3px;border-end-end-radius:3px;background:transparent}.todo-row.pri-low:before{background:#298084}.todo-row.pri-medium:before{background:#bb6802}.todo-row.pri-high:before{background:#c53637}.todo-row.is-done{opacity:.62}.todo-row.is-done .todo-row-title{text-decoration:line-through;color:var(--ink-3)}.todo-row .check{margin-top:1px}.todo-row-body{flex:1;min-width:0;text-align:start;display:flex;flex-direction:column;gap:4px;padding:0;background:transparent}.todo-row-title-line{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.todo-row-title{font-size:15px;font-weight:500;color:var(--ink);word-break:break-word}.todo-priority-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.todo-row-icon{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--ink-3)}.todo-row-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13px;color:var(--ink-2)}.todo-row-notes{color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:380px}.todo-row-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.todo-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:12px;background:var(--bg-sunken);color:var(--ink-2)}.todo-tag-removable{padding-inline-end:4px}.todo-due{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--bg-sunken);color:var(--ink-2);white-space:nowrap}.todo-due-today{background:var(--accent-wash);color:var(--accent-ink)}.todo-due-overdue{background:#ffe8e6;background:oklch(.95 .03 25);color:#7c2524}.todo-due-soon{background:var(--calm-wash);color:#004447;color:oklch(.35 .1 200)}.todo-due-far{background:var(--bg-sunken);color:var(--ink-2)}.todo-ai-btn{display:inline-flex;align-items:center;gap:6px}.todo-ai-modal{display:flex;flex-direction:column;gap:14px;padding-top:4px}.todo-ai-loading{display:flex;align-items:center;gap:10px;padding:14px;border:1px dashed var(--line-2);border-radius:12px;background:var(--bg-sunken);color:var(--ink-2);font-size:14px}.todo-ai-loading>.ic{color:var(--accent);animation:pulse 1.4s ease-in-out infinite}.todo-ai-error{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid oklch(.85 .05 25);background:#fff1f0;background:oklch(.97 .02 25);color:#7c2524;border-radius:10px;font-size:13px}.todo-ai-drafts{display:flex;flex-direction:column;gap:8px}.todo-ai-drafts-head{display:flex;align-items:center;justify-content:space-between;font-size:12px;margin-bottom:2px}.todo-ai-draft{display:flex;gap:12px;padding:10px 12px;border:1px solid var(--line-2);border-radius:12px;background:var(--bg);opacity:.55;transition:opacity .15s,border-color .15s}.todo-ai-draft.is-picked{opacity:1;border-color:var(--line)}.todo-ai-draft .check{margin-top:4px;flex-shrink:0}.todo-ai-draft-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.todo-ai-draft-title{font-size:15px;font-weight:500;padding:6px 10px}.todo-ai-draft-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:12px}.todo-ai-draft-notes{font-size:13px;line-height:1.4}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}.todo-editor{display:flex;flex-direction:column;gap:16px;padding-top:4px}.todo-editor-head{display:flex;align-items:center;gap:12px}.todo-editor-title{flex:1;font-family:var(--display);font-size:22px;padding:8px 12px}.todo-editor-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:600px){.todo-editor-grid{grid-template-columns:1fr}}.todo-priority-row{display:flex;flex-wrap:wrap;gap:6px}.todo-priority-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--line);border-radius:999px;font-size:12px;font-weight:500;color:var(--ink-2);background:var(--bg-elevated)}.todo-priority-btn.active{background:var(--bg-sunken)}.todo-tag-row{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:6px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-elevated)}.todo-tag-input{border:none;flex:1;min-width:80px;padding:4px 6px;font-size:13px}.todo-tag-input:focus{box-shadow:none}.todo-due-shortcuts{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.todo-subtasks{display:flex;flex-direction:column;gap:4px;border:1px solid var(--line-2);border-radius:var(--radius);padding:8px;background:var(--bg-sunken)}.todo-subtask{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:8px}.todo-subtask:hover{background:var(--bg-elevated)}.todo-subtask-text{flex:1;font-size:14px;color:var(--ink)}.todo-subtask-text.is-done{text-decoration:line-through;color:var(--ink-3)}.todo-subtask-add{display:flex;align-items:center;gap:8px;padding:8px 8px 4px;border-top:1px dashed var(--line);margin-top:4px}.todo-subtask-add>.ic{color:var(--ink-3)}.todo-subtask-add .input{flex:1;border:none;background:transparent;padding:4px 0;font-size:14px}.todo-subtask-add .input:focus{box-shadow:none}.todo-editor-foot{font-size:12px;text-align:center;border-top:1px solid var(--line-2);padding-top:12px}.toggle{position:relative;width:40px;height:24px;border-radius:999px;background:var(--line);flex-shrink:0;transition:background .15s;padding:0;border:none;cursor:pointer}.toggle:after{content:"";position:absolute;top:3px;inset-inline-start:3px;width:18px;height:18px;border-radius:50%;background:var(--bg-elevated);box-shadow:0 1px 2px #0003;transition:inset-inline-start .15s,background .15s}.toggle.is-on{background:var(--ink)}.toggle.is-on:after{inset-inline-start:19px}.toggle.is-accent.is-on{background:var(--accent)}.toggle:disabled{cursor:not-allowed;opacity:.5}.toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.settings-tabs{display:flex;flex-wrap:wrap;gap:4px;padding:4px;margin:0 0 24px;background:var(--bg-sunken);border:1px solid var(--line-2);border-radius:12px}.settings-tabs::-webkit-scrollbar{display:none}.settings-tab{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:9px;font-size:13px;font-weight:500;color:var(--ink-2);white-space:nowrap;flex-shrink:0;transition:background .12s,color .12s}.settings-tab:hover{color:var(--ink)}.settings-tab.is-active{background:var(--bg-elevated);color:var(--ink);box-shadow:var(--shadow-sm)}.settings-tab .ic{width:15px;height:15px}.settings-section{display:flex;flex-direction:column;gap:24px}.settings-group{display:flex;flex-direction:column;gap:8px}.settings-group-head{display:flex;flex-direction:column;gap:2px}.settings-group-title{font-family:var(--display);font-size:22px;letter-spacing:-.01em;line-height:1.2;margin:0;color:var(--ink)}.settings-group-hint{font-size:13px;color:var(--ink-3);margin:0;line-height:1.5}.settings-row{display:flex;align-items:center;gap:16px;padding:14px 0;border-bottom:1px solid var(--line-2)}.settings-row:last-child{border-bottom:none}.settings-row:first-child{padding-top:0}.settings-row-main{flex:1;min-width:0}.settings-row-title{font-size:14px;font-weight:500;color:var(--ink)}.settings-row-sub{font-size:12px;color:var(--ink-3);margin-top:2px;line-height:1.5}.settings-row-sub a{color:var(--ink-2);text-decoration:underline}.notif-matrix{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.notif-matrix th,.notif-matrix td{padding:10px 6px;text-align:center;vertical-align:middle}.notif-matrix thead th{font-size:11px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line-2);position:sticky;top:0;background:var(--bg-elevated);z-index:1}.notif-matrix th.notif-cat-head,.notif-matrix td.notif-cat-cell{text-align:start;width:100%;padding-inline-start:0;padding-inline-end:12px}.notif-matrix td.notif-cat-cell{font-size:13px;color:var(--ink);font-weight:450}.notif-matrix .notif-tier-row td{padding:16px 0 6px;border-bottom:1px solid var(--line-2)}.notif-matrix .notif-tier-row:first-child td{padding-top:4px}.notif-matrix .notif-tier-label{font-size:11px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em}.notif-matrix .notif-cell-na{color:var(--ink-3);font-size:14px}.notif-matrix tbody tr:not(.notif-tier-row) td{border-bottom:1px solid var(--line-2)}.notif-matrix tbody tr:not(.notif-tier-row):last-child td{border-bottom:none}.notif-matrix tbody tr:not(.notif-tier-row):hover td{background:var(--bg-sunken)}.notif-channel-head{display:inline-flex;flex-direction:column;align-items:center;gap:4px}.notif-channel-head .ic{color:var(--ink-2);width:16px;height:16px}.notif-check{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--line);background:var(--bg-elevated);display:inline-grid;place-items:center;cursor:pointer;transition:border-color .12s,background .12s}.notif-check:hover{border-color:var(--ink-3)}.notif-check.is-on{background:var(--ink);border-color:var(--ink);color:var(--bg-elevated)}.notif-check:disabled,.notif-check[aria-disabled=true]{opacity:.4;cursor:not-allowed}.notif-check .ic{width:12px;height:12px}.notif-matrix-scroll{margin:0 -20px;padding:0 20px;overflow-x:auto}.notif-verify{margin-top:8px;padding:12px;background:var(--bg-sunken);border:1px solid var(--line-2);border-radius:10px;display:flex;flex-direction:column;gap:8px}.notif-verify-row{display:flex;gap:8px;flex-wrap:wrap}.notif-verify-row .input{flex:1;min-width:180px}.notif-verify-msg{font-size:12px;color:var(--ink-3);margin:0}.notif-verify-err{font-size:12px;color:var(--danger);margin:0}@media(max-width:600px){.notif-matrix th,.notif-matrix td{padding:8px 4px}.notif-matrix th.notif-cat-head,.notif-matrix td.notif-cat-cell{padding-inline-end:8px;font-size:12px}.settings-group-title{font-size:19px}}.cal-page{padding:22px 28px 40px;min-width:0;max-width:1200px}.cal-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}.cal-title-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;font-family:var(--display);font-size:30px;line-height:1.1;color:var(--ink);cursor:pointer;padding:2px 10px;border-radius:var(--radius-sm)}.cal-title-btn:hover{background:var(--bg-sunken)}.cal-today-btn{font-weight:600}.cal-today-btn:disabled{opacity:.5;cursor:default}.cal-filter{display:inline-flex;padding:3px;background:var(--bg-sunken);border-radius:999px;border:1px solid var(--line-2)}.cal-filter button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;padding:5px 13px;border-radius:999px;font:inherit;font-size:12.5px;color:var(--ink-2);cursor:pointer}.cal-filter button.is-active{background:var(--bg-elevated);color:var(--ink);font-weight:600;box-shadow:var(--shadow-sm)}.cal-conn-strip{display:flex;align-items:center;gap:12px;padding:10px 14px;margin-bottom:14px;background:var(--bg-sunken);border:1px solid var(--line-2);border-radius:var(--radius)}.cal-conn-strip.is-connected{background:var(--ok-wash);border-color:transparent}.cal-conn-text{display:flex;flex-direction:column;line-height:1.25;flex:1;min-width:0}.cal-conn-text b{font-size:13.5px}.cal-conn-text span{font-size:12px;color:var(--ink-3)}.cal-conn-toggle{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink-2);cursor:pointer;-webkit-user-select:none;user-select:none}.cal-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;margin-bottom:6px}.cal-weekday{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--ink-3);padding:4px 8px}.cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-auto-rows:minmax(112px,1fr);gap:6px}.cal-cell{background:var(--bg-elevated);border:1px solid var(--line-2);border-radius:var(--radius-sm);padding:7px 8px 6px;display:flex;flex-direction:column;gap:4px;min-width:0;min-height:0;cursor:pointer;transition:border-color .12s ease,background .12s ease}.cal-cell:hover{border-color:var(--line-1)}.cal-cell.is-other-month{opacity:.4}.cal-cell.is-past{opacity:.78}.cal-cell.is-past.has-events{opacity:.92}.cal-cell.is-today{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-wash)}.cal-cell.has-events{background:var(--accent-wash)}.cal-cell.is-today .cal-daynum{background:var(--accent);color:#fff;border-radius:999px;padding:1px 8px;margin-inline-start:-4px}.cal-daynum{font-size:12.5px;font-weight:600;color:var(--ink-2);align-self:flex-start}.cal-chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:flex;align-items:center;gap:5px;background:var(--bg-elevated);border:1px solid var(--line-2);border-inline-start-width:3px;border-radius:6px;padding:3px 6px;font-size:11.5px;color:var(--ink);line-height:1.2;overflow:hidden;cursor:pointer;text-align:start;width:100%}.cal-chip:hover{border-color:var(--accent-soft)}.cal-chip-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-chip-time{color:var(--ink-3);font-size:10.5px;flex-shrink:0}.cal-chip-source{display:inline-grid;place-items:center;width:14px;height:14px;font-size:9px;font-weight:800;border-radius:4px;background:var(--bg-sunken);color:var(--ink-2);flex-shrink:0}.cal-chip.is-gcal{background:var(--bg-sunken)}.cal-more{font-size:11px;color:var(--accent-ink);font-weight:600;padding:1px 4px;cursor:pointer;background:none;border:0;font-family:inherit;display:inline;text-align:start}.cal-grid.is-narrow{grid-auto-rows:minmax(54px,1fr)}.cal-grid.is-narrow .cal-cell{padding:4px 4px 6px;align-items:center;justify-content:flex-start}.cal-grid.is-narrow .cal-daynum{align-self:center}.cal-dots{display:flex;gap:3px;margin-top:3px;align-items:center;flex-wrap:wrap;justify-content:center}.cal-dot{width:5px;height:5px;border-radius:999px;background:var(--accent)}.cal-dot-more{background:transparent;color:var(--ink-3);font-size:9px;font-weight:700;width:auto;height:auto}.cal-pop-list{display:flex;flex-direction:column}.cal-pop-row{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;display:flex;align-items:center;gap:12px;padding:12px 4px;border-top:1px solid var(--line-2);cursor:pointer;text-align:start;width:100%;color:var(--ink)}.cal-pop-row:first-child{border-top:0}.cal-pop-row:hover{background:var(--bg-sunken);margin:0 -8px;padding:12px;border-radius:8px}.cal-pop-icon{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;color:var(--accent-ink);flex-shrink:0}.cal-pop-title{font-weight:600;font-size:14px}.cal-pop-meta{display:flex;gap:6px;flex-wrap:wrap;color:var(--ink-3);font-size:12px;margin-top:2px}.cal-pop-empty{color:var(--ink-3);padding:16px 4px;text-align:center}.cal-mp-yearrow{display:flex;align-items:center;justify-content:center;gap:12px;padding-bottom:8px}.cal-mp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.cal-mp-cell{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--line);background:var(--bg-elevated);color:var(--ink);padding:14px 8px;border-radius:var(--radius-sm);font:inherit;font-size:14px;cursor:pointer}.cal-mp-cell:hover{background:var(--bg-sunken)}.cal-mp-cell.is-current{background:var(--accent-wash);color:var(--accent-ink);border-color:var(--accent-soft);font-weight:600}.cal-picker-list{display:flex;flex-direction:column;gap:2px}.cal-picker-row{display:flex;align-items:center;gap:10px;padding:8px 4px;cursor:pointer;border-radius:6px}.cal-picker-row:hover{background:var(--bg-sunken)}.cal-picker-swatch{width:14px;height:14px;border-radius:4px;flex-shrink:0}.cal-picker-name{font-size:14px;color:var(--ink)}@media(max-width:780px){.cal-page{padding:16px 14px 32px}.cal-head{gap:6px}.cal-title-btn{font-size:22px}.cal-conn-strip{flex-wrap:wrap}.cal-conn-toggle{order:3;flex-basis:100%;margin-top:4px}}.cal-picker-error{display:flex;gap:10px;align-items:flex-start;padding:12px;margin:4px 0 10px;background:var(--danger-wash);border:1px solid var(--danger-border);border-radius:var(--radius);color:var(--ink)}.cal-picker-error-body{display:flex;flex-direction:column;gap:4px;font-size:13px;min-width:0}.cal-picker-error-body b{font-size:13.5px}.cal-picker-error-body span{font-size:12px;color:var(--ink-2);word-break:break-word}.cal-picker-error-link{font-size:12.5px;font-weight:600;color:var(--accent-ink);text-decoration:underline;margin-top:2px}.gcal-chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--line-1);background:var(--bg-elevated);color:var(--ink-2);display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:999px;font-size:12px;cursor:pointer}.gcal-chip:hover{background:var(--bg-sunken)}.gcal-chip.is-synced{background:var(--ok-wash);color:var(--ink);border-color:transparent;font-weight:600;gap:4px}.gcal-chip.is-synced .gcal-chip-action{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:inherit;font:inherit;font-weight:inherit;cursor:pointer;padding:0}.gcal-chip.is-synced .gcal-chip-link{display:inline-flex;align-items:center;padding:1px 4px;border-radius:6px;color:var(--ink-2);margin-inline-start:2px}.gcal-chip.is-synced .gcal-chip-link:hover{color:var(--accent-ink)}.gcal-chip.is-pending{color:var(--ink-3);cursor:default}.gcal-chip.is-pending svg{animation:gcal-spin 1.4s linear infinite}@keyframes gcal-spin{to{transform:rotate(360deg)}}.gcal-chip.is-error{background:var(--danger-wash);color:var(--ink);border-color:var(--danger-border)}.gcal-delete-opt{margin-top:12px;padding:8px 10px;display:flex;align-items:center;gap:8px;background:var(--bg-sunken);border-radius:8px;font-size:13px;cursor:pointer}.gcal-settings-row{display:flex;align-items:flex-start;gap:16px;padding:14px 0;border-top:1px solid var(--line-2);justify-content:space-between}.gcal-settings-row:first-of-type{border-top:0}.gcal-settings-row>div:first-child{flex:1;min-width:0}.gcal-settings-row b{display:block;font-size:14px}.gcal-settings-sub{display:block;font-size:12.5px;color:var(--ink-3);margin-top:2px}.gcal-settings-toggle{display:flex;align-items:flex-start;gap:10px;cursor:pointer}.gcal-settings-toggle>input{margin-top:4px;flex-shrink:0}.gcal-settings-warn{background:var(--warn-wash);border-radius:10px;padding:10px 12px;border-top:0!important}.gcal-settings-warn b{font-size:13px}.gcal-settings-caveat{margin-top:16px;padding:10px 12px;border-top:1px dashed var(--line-2);display:flex;gap:8px;color:var(--ink-3);font-size:12.5px}[dir=rtl] .ic-dir{transform:scaleX(-1)}[dir=rtl] .brand-mark:after{right:auto;left:-2px}.bidi,.nav-item .nav-count,.todo-tab-count{unicode-bidi:isolate}.gcal-settings-caveat svg{flex-shrink:0;margin-top:2px}
