:root{--font-display: 'Bricolage Grotesque', 'Schibsted Grotesk', sans-serif;--font-body: 'Schibsted Grotesk', 'Segoe UI', sans-serif;--font-mono: 'JetBrains Mono', 'SFMono-Regular', monospace;--bg: #f3edde;--surface: #fbf7ec;--surface-raised: #fffdf6;--sidebar-bg: #eae2cd;--ink: #231e15;--ink-soft: #776c58;--ink-faint: #a3987f;--line: rgba(35, 30, 21, 0.16);--line-soft: rgba(35, 30, 21, 0.08);--accent: #c2491d;--accent-hover: #a93c14;--accent-ink: #fff6ec;--accent-soft: rgba(194, 73, 29, 0.1);--star: #cf8a08;--star-soft: rgba(207, 138, 8, 0.15);--danger: #ac2318;--done: #63755a;--shadow-panel: -24px 0 48px rgba(60, 45, 20, 0.12);--shadow-pop: 0 18px 48px rgba(60, 45, 20, 0.22);--shadow-soft: 0 2px 10px rgba(60, 45, 20, 0.08);--backdrop: rgba(35, 30, 21, 0.35);--grain-opacity: 0.05}@media(prefers-color-scheme: dark){:root{--bg: #161210;--surface: #1e1913;--surface-raised: #262019;--sidebar-bg: #110e0b;--ink: #ece3d0;--ink-soft: #a2947a;--ink-faint: #6f6450;--line: rgba(236, 227, 208, 0.16);--line-soft: rgba(236, 227, 208, 0.07);--accent: #e6672f;--accent-hover: #f07a42;--accent-ink: #1c1006;--accent-soft: rgba(230, 103, 47, 0.14);--star: #e2a52c;--star-soft: rgba(226, 165, 44, 0.16);--danger: #e2604f;--done: #8ba37f;--shadow-panel: -24px 0 48px rgba(0, 0, 0, 0.5);--shadow-pop: 0 18px 48px rgba(0, 0, 0, 0.55);--shadow-soft: 0 2px 10px rgba(0, 0, 0, 0.35);--backdrop: rgba(8, 6, 4, 0.55);--grain-opacity: 0.07}}*,*::before,*::after{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{font-family:var(--font-body);background:var(--bg);color:var(--ink);font-size:15px;line-height:1.45;-webkit-font-smoothing:antialiased;overflow:hidden}body::after{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:var(--grain-opacity);background-image:url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 width=%27140%27 height=%27140%27%3E%3Cfilter id=%27n%27%3E%3CfeTurbulence type=%27fractalNoise%27 baseFrequency=%270.9%27 numOctaves=%272%27/%3E%3C/filter%3E%3Crect width=%27140%27 height=%27140%27 filter=%27url%28%23n%29%27/%3E%3C/svg%3E")}#root{height:100%}h1,h2,h3{font-family:var(--font-display);margin:0}button{font-family:inherit;font-size:inherit;color:inherit;background:none;border:none;padding:0;cursor:pointer}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}a{color:inherit;text-decoration:none}::selection{background:var(--accent-soft)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}*{scrollbar-width:thin;scrollbar-color:var(--line) rgba(0,0,0,0)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 18px;border-radius:10px;font-weight:600;border:1px solid var(--line);background:var(--surface-raised);transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-soft)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:default;transform:none;box-shadow:none}.btn-primary{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-danger{color:var(--danger);border-color:currentColor;background:rgba(0,0,0,0)}.btn-ghost{border-color:rgba(0,0,0,0);background:rgba(0,0,0,0)}.btn-ghost:hover{background:var(--accent-soft);box-shadow:none;transform:none}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;color:var(--ink-soft);transition:background .15s ease,color .15s ease}.icon-btn:hover{background:var(--line-soft);color:var(--ink)}.icon-btn svg{width:18px;height:18px}.field-input{width:100%;padding:9px 12px;border-radius:10px;border:1px solid var(--line);background:var(--surface-raised);color:var(--ink);transition:border-color .15s ease}.field-input::placeholder{color:var(--ink-faint)}.field-input:focus{outline:none;border-color:var(--accent)}.kicker{font-family:var(--font-mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-soft)}.boot-screen{height:100dvh;display:flex;align-items:center;justify-content:center;gap:14px;color:var(--ink-soft);font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase}.boot-mark{width:26px;height:26px;border-radius:50%;background:conic-gradient(from 90deg, var(--accent) 0 50%, var(--ink) 50% 100%);animation:boot-spin 1.1s cubic-bezier(0.6, 0.1, 0.3, 0.9) infinite}@keyframes boot-spin{to{transform:rotate(360deg)}}@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes pop{0%{transform:scale(0.6)}60%{transform:scale(1.25)}100%{transform:scale(1)}}@keyframes fade-in{from{opacity:0}to{opacity:1}}
.shell{display:grid;grid-template-columns:276px minmax(0, 1fr);height:100dvh;background:var(--bg)}.shell.with-detail{grid-template-columns:276px minmax(0, 1fr) 420px}.shell-main{min-width:0;display:flex;flex-direction:column;overflow:hidden;animation:rise .45s cubic-bezier(0.2, 0.8, 0.3, 1) both;animation-delay:.08s}.mobile-topbar{display:none;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--line-soft);background:var(--surface)}.mobile-topbar .brand-mark{margin-left:auto}.nav-backdrop{display:none}.sidebar{display:flex;flex-direction:column;background:var(--sidebar-bg);border-right:1px solid var(--line-soft);overflow-y:auto;overflow-x:hidden;padding:20px 14px 14px;animation:rise .45s cubic-bezier(0.2, 0.8, 0.3, 1) both}.brand-row{display:flex;align-items:center;gap:8px;padding:0 10px}.brand-mark{width:18px;height:18px;border-radius:50%;flex-shrink:0;background:conic-gradient(from 90deg, var(--accent) 0 50%, var(--ink) 50% 100%)}.brand-name{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft)}.workspace-name{font-family:var(--font-display);font-size:26px;font-weight:750;letter-spacing:-0.02em;line-height:1.1;padding:10px 10px 18px}.sb-views{display:flex;flex-direction:column;gap:2px}.sb-view{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:10px;font-weight:600;color:var(--ink-soft);transition:background .15s ease,color .15s ease}.sb-view:hover{background:var(--line-soft);color:var(--ink)}.sb-view.active{background:var(--surface-raised);color:var(--ink);box-shadow:var(--shadow-soft)}.sb-view .sb-view-icon{width:18px;height:18px;flex-shrink:0;color:var(--ink-faint)}.sb-view.active .sb-view-icon{color:var(--accent)}.sb-view.sb-view-today.active .sb-view-icon{color:var(--star)}.sb-count{margin-left:auto;font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--ink-faint);background:var(--line-soft);border-radius:20px;padding:1px 8px;min-width:24px;text-align:center}.sb-view.active .sb-count{color:var(--accent);background:var(--accent-soft)}.sb-section-head{display:flex;align-items:center;justify-content:space-between;margin:22px 10px 6px}.sb-add-project{width:22px;height:22px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-soft);font-size:16px;line-height:1;transition:background .15s ease,color .15s ease,transform .15s ease}.sb-add-project:hover{background:var(--accent);color:var(--accent-ink);transform:rotate(90deg)}.sb-projects,.sb-tags{display:flex;flex-direction:column;gap:1px}.sb-project{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:9px;color:var(--ink-soft);transition:background .15s ease,color .15s ease}.sb-project:hover{background:var(--line-soft);color:var(--ink)}.sb-project.active{background:var(--surface-raised);color:var(--ink);box-shadow:var(--shadow-soft)}.sb-project-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.color-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.sb-lock{margin-left:auto;width:12px;height:12px;flex-shrink:0;color:var(--ink-faint)}.sb-tag{display:inline-flex;align-items:center;gap:7px;padding:5px 10px;border-radius:9px;font-size:13px;color:var(--ink-soft)}.sb-tag:hover{background:var(--line-soft);color:var(--ink)}.sb-tag.active{background:var(--surface-raised);color:var(--ink)}.sb-tag .color-dot{width:7px;height:7px}.sb-footer{margin-top:auto;padding-top:18px;display:flex;align-items:center;gap:10px;border-top:1px solid var(--line-soft);margin-top:24px;padding:14px 10px 2px}.avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--ink);color:var(--bg);font-family:var(--font-display);font-weight:700;font-size:13px;overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.sb-user{min-width:0;flex:1}.sb-user-name{font-weight:600;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-user-email{font-size:11px;color:var(--ink-faint);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width: 1180px){.shell.with-detail{grid-template-columns:276px minmax(0, 1fr)}}@media(max-width: 860px){.shell,.shell.with-detail{grid-template-columns:minmax(0, 1fr)}.mobile-topbar{display:flex}.sidebar{position:fixed;inset:0 auto 0 0;width:min(300px,84vw);z-index:60;transform:translateX(-105%);transition:transform .28s cubic-bezier(0.2, 0.8, 0.3, 1);box-shadow:none}.shell.nav-open .sidebar{transform:translateX(0);box-shadow:var(--shadow-pop)}.nav-backdrop{display:block;position:fixed;inset:0;z-index:55;background:var(--backdrop);opacity:0;pointer-events:none;transition:opacity .25s ease}.shell.nav-open .nav-backdrop{opacity:1;pointer-events:auto}}
.tl{flex:1;min-height:0;display:flex;flex-direction:column;background:var(--surface)}.tl-header{display:flex;align-items:baseline;gap:14px;padding:26px 32px 6px}.tl-title{font-family:var(--font-display);font-size:34px;font-weight:780;letter-spacing:-0.025em;line-height:1.05;display:flex;align-items:center;gap:12px}.tl-title .color-dot{width:13px;height:13px;margin-top:4px}.tl-count{font-family:var(--font-mono);font-size:12px;color:var(--ink-faint);white-space:nowrap}.quick-add{display:flex;align-items:center;gap:12px;margin:16px 32px 4px;padding:4px 4px 4px 16px;border:1px dashed var(--line);border-radius:12px;background:rgba(0,0,0,0);transition:border-color .15s ease,background .15s ease}.quick-add:focus-within{border-style:solid;border-color:var(--accent);background:var(--surface-raised)}.quick-add-plus{color:var(--accent);font-size:19px;font-weight:600;line-height:1}.quick-add input{flex:1;border:none;background:rgba(0,0,0,0);padding:10px 0;font-size:15px;color:var(--ink)}.quick-add input::placeholder{color:var(--ink-faint)}.quick-add input:focus{outline:none}.tl-scroll{flex:1;overflow-y:auto;padding:12px 32px 48px}.tl-section-head{display:flex;align-items:center;gap:12px;margin:26px 0 8px;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}.tl-section-head::after{content:"";flex:1;height:1px;background:var(--line-soft)}.task-row{display:flex;align-items:flex-start;gap:13px;padding:11px 12px;margin:0 -12px;border-radius:12px;border-bottom:1px solid var(--line-soft);cursor:pointer;transition:background .14s ease,opacity .3s ease,transform .3s ease;animation:rise .3s cubic-bezier(0.2, 0.8, 0.3, 1) both}.task-row:hover{background:var(--surface-raised)}.task-row.selected{background:var(--accent-soft)}.task-row.leaving{opacity:0;transform:translateX(24px)}.task-row.muted{cursor:pointer}.task-row.muted .task-title{color:var(--ink-faint);text-decoration:line-through;text-decoration-color:var(--line)}.task-row.sortable{touch-action:manipulation}.task-row.dragging{position:relative;z-index:4;animation:none;transition:none;cursor:grabbing;background:var(--surface-raised);border-bottom-color:rgba(0,0,0,0);box-shadow:var(--shadow-pop),var(--shadow-soft)}.tl-scroll.is-dragging .task-row{animation:none}.tl-scroll.is-dragging .task-row:not(.dragging):hover{background:rgba(0,0,0,0)}.task-check{width:22px;height:22px;flex-shrink:0;margin-top:1px;border-radius:50%;border:1.8px solid var(--ink-faint);display:inline-flex;align-items:center;justify-content:center;background:rgba(0,0,0,0);transition:border-color .15s ease,background .15s ease,transform .15s ease}.task-check svg{width:12px;height:12px;color:var(--accent-ink);opacity:0;transition:opacity .12s ease}.task-check:hover{border-color:var(--accent);transform:scale(1.08)}.task-check:hover svg{opacity:1;color:var(--accent)}.task-check.checked{background:var(--done);border-color:var(--done)}.task-check.checked svg{opacity:1;color:var(--surface)}.task-check.checking{background:var(--accent);border-color:var(--accent);animation:pop .35s cubic-bezier(0.3, 1.4, 0.5, 1)}.task-check.checking svg{opacity:1;color:var(--accent-ink)}.task-body{flex:1;min-width:0}.task-title{font-weight:550;overflow-wrap:anywhere}.task-title .recur-icon{display:inline-block;width:13px;height:13px;margin-right:6px;vertical-align:-1px;color:var(--ink-faint)}.task-meta{display:flex;flex-wrap:wrap;align-items:center;gap:6px 12px;margin-top:3px;font-size:12px;color:var(--ink-soft)}.task-meta-project{display:inline-flex;align-items:center;gap:6px;max-width:180px}.task-meta-project span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-meta-due{font-family:var(--font-mono);font-size:11px}.task-meta-due.overdue{color:var(--danger);font-weight:700}.task-meta-done{font-family:var(--font-mono);font-size:11px;color:var(--ink-faint)}.tag-chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;padding:1px 8px;border-radius:20px;border:1px solid var(--line);color:var(--ink-soft)}.tag-chip .color-dot{width:6px;height:6px}.star-btn{flex-shrink:0;width:30px;height:30px;margin-top:-2px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-faint);transition:color .15s ease,background .15s ease}.star-btn svg{width:17px;height:17px}.star-btn:hover{color:var(--star);background:var(--star-soft)}.star-btn.starred{color:var(--star)}.star-btn.starred svg{animation:pop .3s cubic-bezier(0.3, 1.4, 0.5, 1)}.tl-empty{margin:56px auto 0;max-width:340px;text-align:center;color:var(--ink-soft);animation:rise .4s cubic-bezier(0.2, 0.8, 0.3, 1) both}.tl-empty-mark{font-family:var(--font-display);font-size:44px;font-weight:300;color:var(--ink-faint);margin-bottom:10px}.tl-load-more{display:block;margin:24px auto 0}.tl-loading{padding:40px;text-align:center;color:var(--ink-faint);font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase}@media(max-width: 860px){.tl-header{padding:18px 18px 4px}.tl-title{font-size:27px}.quick-add{margin:12px 18px 2px}.tl-scroll{padding:10px 18px 90px}}
.td{display:flex;flex-direction:column;min-height:0;background:var(--surface-raised);border-left:1px solid var(--line-soft);animation:td-slide .28s cubic-bezier(0.2, 0.8, 0.3, 1) both;overflow:hidden}@keyframes td-slide{from{opacity:0;transform:translateX(28px)}to{opacity:1;transform:translateX(0)}}@media(max-width: 1180px){.td{position:fixed;top:0;right:0;bottom:0;width:min(440px,100vw);z-index:70;box-shadow:var(--shadow-panel)}}@media(max-width: 860px){.td{width:100vw;animation-name:td-slide-up}@keyframes td-slide-up{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}}.td-backdrop{display:none}@media(max-width: 1180px){.td-backdrop{display:block;position:fixed;inset:0;z-index:65;background:var(--backdrop);animation:fade-in .25s ease both}}.td-toolbar{display:flex;align-items:center;gap:6px;padding:14px 16px 10px;border-bottom:1px solid var(--line-soft)}.td-toolbar .spacer{flex:1}.td-complete-btn{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:20px;font-weight:650;font-size:13px;border:1.5px solid var(--line);transition:all .15s ease}.td-complete-btn svg{width:14px;height:14px}.td-complete-btn:hover{border-color:var(--done);color:var(--done)}.td-complete-btn.done{background:var(--done);border-color:var(--done);color:var(--surface)}.td-scroll{flex:1;overflow-y:auto;padding:18px 20px 30px}.td-title{width:100%;border:none;background:rgba(0,0,0,0);font-family:var(--font-display);font-size:23px;font-weight:720;letter-spacing:-0.02em;line-height:1.2;color:var(--ink);resize:none;padding:0 0 4px}.td-title:focus{outline:none}.td-title::placeholder{color:var(--ink-faint)}.td-desc{width:100%;min-height:64px;border:none;background:rgba(0,0,0,0);color:var(--ink-soft);resize:vertical;padding:4px 0 10px;line-height:1.5}.td-desc:focus{outline:none;color:var(--ink)}.td-desc::placeholder{color:var(--ink-faint)}.td-fields{display:flex;flex-direction:column;border-top:1px solid var(--line-soft);margin-top:8px}.td-field{display:grid;grid-template-columns:96px minmax(0, 1fr);align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line-soft)}.td-field-label{font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint)}.td-field-control{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.td-select,.td-date,.td-num{border:1px solid rgba(0,0,0,0);background:rgba(0,0,0,0);border-radius:8px;padding:5px 8px;color:var(--ink);max-width:100%;transition:border-color .15s ease,background .15s ease}.td-select:hover,.td-date:hover,.td-num:hover{background:var(--line-soft)}.td-select:focus,.td-date:focus,.td-num:focus{outline:none;border-color:var(--accent);background:var(--surface)}.td-select{appearance:none;padding-right:22px;background-image:url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 width=%2710%27 height=%276%27 viewBox=%270 0 10 6%27%3E%3Cpath d=%27M1 1l4 4 4-4%27 fill=%27none%27 stroke=%27%23999080%27 stroke-width=%271.6%27 stroke-linecap=%27round%27/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.td-num{width:56px}.td-clear{color:var(--ink-faint);font-size:15px;line-height:1;padding:4px;border-radius:6px}.td-clear:hover{color:var(--danger);background:var(--line-soft)}.weekday-chips{display:flex;gap:4px;flex-wrap:wrap}.weekday-chip{font-family:var(--font-mono);font-size:10.5px;font-weight:600;padding:4px 7px;border-radius:7px;border:1px solid var(--line);color:var(--ink-soft);transition:all .12s ease}.weekday-chip:hover{border-color:var(--accent)}.weekday-chip.on{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.td-tags{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.td-tag-toggle{font-size:12px;padding:3px 10px;border-radius:20px;border:1px solid var(--line);color:var(--ink-soft);display:inline-flex;align-items:center;gap:6px;transition:all .12s ease}.td-tag-toggle .color-dot{width:7px;height:7px}.td-tag-toggle:hover{border-color:var(--ink-soft)}.td-tag-toggle.on{background:var(--ink);border-color:var(--ink);color:var(--bg)}.td-tag-new{display:inline-flex;align-items:center}.td-tag-new input{width:110px;font-size:12px;padding:3px 10px;border-radius:20px;border:1px dashed var(--line);background:rgba(0,0,0,0);color:var(--ink)}.td-tag-new input::placeholder{color:var(--ink-faint)}.td-tag-new input:focus{outline:none;border-style:solid;border-color:var(--accent)}.td-actions{display:flex;align-items:center;gap:8px;padding:14px 0 4px}.td-comments{margin-top:22px}.td-comments-head{font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:10px}.td-comment{display:flex;gap:10px;padding:8px 0}.td-comment .avatar{width:26px;height:26px;font-size:11px}.td-comment-body{flex:1;min-width:0}.td-comment-meta{display:flex;align-items:baseline;gap:8px;font-size:12px}.td-comment-meta strong{font-weight:650}.td-comment-meta time{font-family:var(--font-mono);font-size:10px;color:var(--ink-faint)}.td-comment-text{color:var(--ink-soft);white-space:pre-wrap;overflow-wrap:anywhere;margin-top:1px}.td-comment-form{display:flex;gap:8px;margin-top:10px}.td-comment-form input{flex:1}.td-footer{padding:12px 20px;border-top:1px solid var(--line-soft);font-size:11px;font-family:var(--font-mono);color:var(--ink-faint)}.td-muted-note{color:var(--done);font-family:var(--font-mono);font-size:11px;margin:2px 0 8px}.modal-backdrop{position:fixed;inset:0;z-index:90;background:var(--backdrop);display:flex;align-items:center;justify-content:center;padding:20px;animation:fade-in .2s ease both}.modal{width:min(400px,100%);background:var(--surface-raised);border-radius:16px;border:1px solid var(--line-soft);box-shadow:var(--shadow-pop);padding:22px;animation:rise .25s cubic-bezier(0.2, 0.8, 0.3, 1) both}.modal h2{font-size:21px;font-weight:750;letter-spacing:-0.02em;margin-bottom:16px}.modal-field{margin-bottom:14px}.modal-field .kicker{display:block;margin-bottom:6px}.palette{display:flex;flex-wrap:wrap;gap:8px}.palette-swatch{width:26px;height:26px;border-radius:50%;border:2px solid rgba(0,0,0,0);transition:transform .12s ease,border-color .12s ease}.palette-swatch:hover{transform:scale(1.12)}.palette-swatch.on{border-color:var(--ink);transform:scale(1.12)}.segmented{display:inline-flex;border:1px solid var(--line);border-radius:10px;padding:3px;gap:3px}.segmented button{padding:6px 13px;border-radius:7px;font-size:13px;font-weight:600;color:var(--ink-soft);display:inline-flex;align-items:center;gap:6px}.segmented button svg{width:12px;height:12px}.segmented button.on{background:var(--ink);color:var(--bg)}.modal-hint{font-size:12px;color:var(--ink-faint);margin-top:6px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}
.login-page{height:100dvh;display:grid;grid-template-columns:minmax(0, 1.1fr) minmax(0, 1fr);overflow:hidden}.login-hero{position:relative;background:var(--ink);color:var(--bg);padding:48px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}.login-hero::before{content:"";position:absolute;right:-160px;bottom:-160px;width:460px;height:460px;border-radius:50%;background:conic-gradient(from 90deg, var(--accent) 0 50%, transparent 50% 100%);opacity:.9;animation:hero-turn 26s linear infinite}@keyframes hero-turn{to{transform:rotate(360deg)}}.login-hero .brand-row{padding:0;animation:rise .5s cubic-bezier(0.2, 0.8, 0.3, 1) both}.login-hero .brand-row .brand-name{color:inherit;opacity:.7}.login-hero-text{position:relative;z-index:1}.login-kicker{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;opacity:.6;margin-bottom:18px;animation:rise .5s cubic-bezier(0.2, 0.8, 0.3, 1) .1s both}.login-title{font-family:var(--font-display);font-size:clamp(38px,5vw,62px);font-weight:790;letter-spacing:-0.03em;line-height:1.02;white-space:pre-line;animation:rise .5s cubic-bezier(0.2, 0.8, 0.3, 1) .18s both}.login-subtitle{margin-top:20px;max-width:400px;font-size:16px;opacity:.65;line-height:1.55;animation:rise .5s cubic-bezier(0.2, 0.8, 0.3, 1) .26s both}.login-side{display:flex;align-items:center;justify-content:center;padding:40px;background:var(--bg)}.login-card{width:min(360px,100%);display:flex;flex-direction:column;gap:12px;animation:rise .5s cubic-bezier(0.2, 0.8, 0.3, 1) .3s both}.login-google{padding:13px 20px;font-size:15px}.login-google svg{width:18px;height:18px}.login-divider{display:flex;align-items:center;gap:12px;margin:14px 0 4px;font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}.login-divider::before,.login-divider::after{content:"";flex:1;height:1px;background:var(--line)}.login-dev-hint{font-size:12px;color:var(--ink-faint);text-align:center}.login-dev-btn{justify-content:flex-start;gap:12px;padding:11px 16px}.login-dev-btn .avatar{width:28px;height:28px;font-size:12px}.login-dev-btn small{display:block;color:var(--ink-faint);font-weight:400;font-size:11px}.login-error{color:var(--danger);font-size:13px;text-align:center}@media(max-width: 820px){.login-page{grid-template-columns:minmax(0, 1fr);grid-template-rows:auto minmax(0, 1fr);overflow-y:auto}.login-hero{padding:28px 24px 44px;gap:30px}.login-hero::before{width:260px;height:260px;right:-110px;bottom:-110px}.login-side{padding:28px 24px 48px}}.login-account-row{display:flex;align-items:center;gap:6px}.login-account-row .login-dev-btn{flex:1}.login-forget{background:none;border:none;cursor:pointer;font-size:18px;line-height:1;padding:6px;color:var(--ink-soft, #8a8272);border-radius:50%}.login-forget:hover{color:var(--accent, #c2491d)}.login-dev-add{display:flex;gap:8px}.login-dev-add input{flex:1;padding:10px 12px;border:1px solid var(--line, #d8d0bd);border-radius:10px;background:var(--surface, #fbf7ec);font:inherit;color:inherit}

/*# sourceMappingURL=main.fdeda718c496e3efc6a0.css.map*/