:root{--bg: #ffffff;--bg-subtle: #f9f8f8;--bg-hover: #f6f6f7;--sidebar-bg: #1e1f21;--sidebar-text: #e6e6e7;--sidebar-muted: #9ca0a6;--sidebar-hover: #2a2b2d;--sidebar-active: #34353800;--border: #ededed;--border-strong: #e0e0e0;--text: #1e1f21;--muted: #6d6e6f;--accent: #796eff;--primary: #f06a6a;--primary-hover: #e25c5c;--green: #5da283;--green-bright: #14a44d;--danger: #e8384f;--urgent: #e8384f;--high: #ec8b00;--medium: #4186e0;--low: #8a8f98;--lead-w: 56px;--col-prio: 120px;--col-status: 132px;--col-due: 118px;--col-actions: 40px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;-webkit-font-smoothing:antialiased}.center{min-height:100vh;display:flex;align-items:center;justify-content:center}.muted{color:var(--muted)}.error{color:var(--danger);margin:0}.layout{display:flex;height:100vh;overflow:hidden}.content{flex:1;min-width:0;overflow-y:auto;background:var(--bg)}.sidebar{width:248px;flex-shrink:0;background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;padding:14px 10px;gap:4px}.sidebar-brand{display:flex;align-items:center;gap:8px;font-size:17px;font-weight:700;padding:6px 8px 12px}.nav-item{display:flex;align-items:center;gap:11px;width:100%;text-align:left;border:none;background:transparent;color:var(--sidebar-text);border-radius:7px;padding:8px 10px;font-size:14px;cursor:pointer;font:inherit}.nav-item:hover{background:var(--sidebar-hover)}.nav-item.active{background:var(--sidebar-hover);font-weight:600}.nav-item .nav-ico{width:18px;text-align:center;flex-shrink:0;opacity:.9}.nav-count{margin-left:auto;font-size:12px;color:var(--sidebar-muted);background:#ffffff14;border-radius:10px;padding:0 7px;line-height:18px}.sidebar-section{display:flex;align-items:center;justify-content:space-between;padding:14px 10px 4px;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--sidebar-muted)}.sidebar-add{border:none;background:transparent;color:var(--sidebar-muted);cursor:pointer;font-size:18px;line-height:1;padding:0 4px;border-radius:5px}.sidebar-add:hover{background:var(--sidebar-hover);color:var(--sidebar-text)}.project-nav{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1}.project-nav .nav-item.archived{opacity:.5}.proj-dot{width:12px;height:12px;border-radius:4px;flex-shrink:0}.proj-dot.lg{width:16px;height:16px;border-radius:5px}.nav-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-add-form{display:flex;gap:6px;padding:4px 8px 8px}.sidebar-add-form input{flex:1;background:var(--sidebar-hover);border:1px solid transparent;color:var(--sidebar-text);border-radius:6px;padding:6px 8px;font:inherit;font-size:13px}.sidebar-foot{margin-top:auto;display:flex;flex-direction:column;gap:2px;padding-top:8px;border-top:1px solid rgba(255,255,255,.07)}.sidebar-foot .toggle{color:var(--sidebar-muted);padding:6px 10px}button{font:inherit;cursor:pointer}.btn-primary{border:none;background:var(--primary);color:#fff;border-radius:7px;padding:8px 16px;font-weight:600}.btn-primary:hover{background:var(--primary-hover)}.btn-primary:disabled{opacity:.5;cursor:default}.btn-ghost{border:1px solid var(--border-strong);background:#fff;color:var(--text);border-radius:7px;padding:6px 12px}.btn-ghost:hover{background:var(--bg-subtle)}.icon-btn{border:none;background:transparent;color:var(--muted);border-radius:6px;padding:5px 7px;line-height:1}.icon-btn:hover{background:var(--bg-hover);color:var(--text)}.icon-btn.danger:hover{color:var(--danger)}input,select{font:inherit;background:#fff;border:1px solid var(--border-strong);color:var(--text);border-radius:7px;padding:7px 10px}input:focus,select:focus,button:focus-visible{outline:2px solid var(--accent);outline-offset:-1px}input[type=checkbox]{accent-color:var(--accent)}.login{display:flex;flex-direction:column;gap:14px;width:320px;text-align:center;background:#fff;border:1px solid var(--border);border-radius:14px;padding:30px 26px;box-shadow:0 8px 30px #0000000f}.login h1{margin:0}.login button{border:none;background:var(--primary);color:#fff;border-radius:8px;padding:9px;font-weight:600}.view-header{position:sticky;top:0;z-index:4;background:var(--bg);border-bottom:1px solid var(--border);padding:16px 28px 14px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}.view-title{display:flex;align-items:center;gap:10px;min-width:0}.view-title h1{margin:0;font-size:19px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.view-sub{color:var(--muted);font-size:13px}.view-actions{margin-left:auto;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.view-body{padding:18px 28px 80px;max-width:1100px}.filter-toggle{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:13px;white-space:nowrap}.view-desc{margin:0;padding:12px 28px 0;color:var(--muted);max-width:760px}.status-pill{font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px;white-space:nowrap}.status-pill.status-active{background:#e6f4ea;color:#197b46}.status-pill.status-on_hold{background:#fdf2d6;color:#946b00}.status-pill.status-completed{background:#eceaff;color:#5b50d6}.status-pill.status-archived{background:#eee;color:#777}.list{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:#fff}.list-head,.task-row{display:flex;align-items:center;gap:4px}.list-head{padding:8px 14px;border-bottom:1px solid var(--border-strong);background:var(--bg-subtle);font-size:12px;font-weight:600;color:var(--muted)}.row-lead{width:var(--lead-w);flex-shrink:0;display:flex;align-items:center;gap:6px;padding-left:2px}.col-name,.cell-name{flex:1;min-width:0;display:flex;align-items:center;gap:8px}.col-prio,.cell-prio{width:var(--col-prio);flex-shrink:0}.col-status,.cell-status{width:var(--col-status);flex-shrink:0}.col-due,.cell-due{width:var(--col-due);flex-shrink:0}.col-actions,.cell-actions{width:var(--col-actions);flex-shrink:0;text-align:right}.task-list{list-style:none;margin:0;padding:0}.task-row{padding:6px 14px;border-bottom:1px solid var(--border);background:#fff}.task-row:last-child{border-bottom:none}.task-row:hover{background:var(--bg-subtle)}.task-row.selected{background:#f0effe;box-shadow:inset 2px 0 0 var(--accent)}.task-row.drop-before{box-shadow:inset 0 2px 0 0 var(--accent)}.task-row.drop-after{box-shadow:inset 0 -2px 0 0 var(--accent)}.task-row.done .task-title{text-decoration:line-through;color:var(--muted)}.check{width:19px;height:19px;padding:0;border-radius:50%;border:1.5px solid #c4c6cb;background:#fff;color:transparent;font-size:11px;line-height:1;display:flex;align-items:center;justify-content:center;flex-shrink:0}.check:hover{border-color:var(--green-bright);color:var(--green-bright)}.check.checked{background:var(--green-bright);border-color:var(--green-bright);color:#fff}.drag-handle{color:#c4c6cb;letter-spacing:-2px;cursor:grab;-webkit-user-select:none;user-select:none;width:12px;opacity:0;transition:opacity .1s}.task-row:hover .drag-handle{opacity:1}.drag-handle:active{cursor:grabbing}.task-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:text}.sub-caret{color:var(--muted);flex-shrink:0}.cell-prio select,.cell-status select,.cell-due input,.cell-name .note-toggle{border-color:transparent;background:transparent;width:100%;padding:4px 6px;font-size:13px;color:var(--muted)}.cell-due input{color-scheme:light}.cell-prio select:hover,.cell-status select:hover,.cell-due input:hover{border-color:var(--border-strong);background:#fff}select.prio-select{font-weight:600}.cell-name .note-toggle{width:auto;flex-shrink:0;margin-left:auto}.note-toggle{border:none;border-radius:6px}.note-toggle:hover{background:var(--bg-hover)}.note-toggle.has-notes{color:var(--accent)}.note-count{font-size:11px;margin-left:1px}.cell-actions .icon-btn{opacity:0}.task-row:hover .cell-actions .icon-btn{opacity:1}.prio-urgent{color:var(--urgent)}.prio-high{color:var(--high)}.prio-medium{color:var(--medium)}.prio-low{color:var(--low)}.notes-row{list-style:none;border-bottom:1px solid var(--border);background:var(--bg-subtle)}.notes-inner{padding:10px 14px 12px calc(var(--lead-w) + 14px)}.note-static{white-space:pre-wrap;font-size:13px;margin:0 0 8px;color:var(--muted);word-break:break-word}.note-row{display:flex;gap:10px;align-items:baseline;padding:3px 0;font-size:13px}.note-date{color:var(--muted);font-size:12px;white-space:nowrap;flex-shrink:0;min-width:92px}.note-body{flex:1;word-break:break-word}.inline-form{display:flex;gap:8px;margin-top:8px}.inline-form input{flex:1}.add-task-row{display:flex;align-items:center;gap:8px;padding:9px 14px 9px calc(var(--lead-w) + 14px);border-top:1px solid var(--border);color:var(--muted)}.add-task-row input{flex:1;border-color:transparent;background:transparent;padding:4px 0}.add-task-row input:focus{outline:none}.add-task-row .plus{color:var(--muted)}.home-greeting{text-align:center;padding:30px 20px 8px}.home-greeting .date{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.05em}.home-greeting h1{margin:6px 0 2px;font-size:26px}.home-stats{color:var(--muted);font-size:13px}.card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:4px 0;margin-bottom:16px}.card-head{display:flex;align-items:center;gap:8px;padding:12px 16px 8px;font-weight:600;font-size:14px}.card.empty{text-align:center;color:var(--muted);padding:26px}.home-row{display:flex;align-items:center;gap:10px;padding:8px 16px;border-top:1px solid var(--border)}.home-row:hover{background:var(--bg-subtle)}.home-row .task-title{flex:1}.home-row .project-name{font-size:12px;color:var(--muted);background:var(--bg-subtle);border:1px solid var(--border);border-radius:999px;padding:2px 9px;white-space:nowrap}.badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;white-space:nowrap}.badge.prio-urgent{background:color-mix(in srgb,var(--urgent) 14%,#fff)}.badge.prio-high{background:color-mix(in srgb,var(--high) 16%,#fff)}.badge.prio-medium{background:color-mix(in srgb,var(--medium) 14%,#fff)}.badge.prio-low{background:#f0f1f2}.due{font-size:12px;color:var(--muted);white-space:nowrap}.due.overdue{color:var(--danger);font-weight:600}.cal-row{display:flex;align-items:center;gap:12px;padding:8px 16px;border-top:1px solid var(--border)}.cal-time{color:var(--accent);font-size:13px;font-weight:600;white-space:nowrap;min-width:110px}.cal-row a.cal-title{flex:1;color:var(--text);text-decoration:none}.cal-row a.cal-title:hover{color:var(--accent)}.cal-loc{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.section-head{font-size:13px;font-weight:700;color:var(--text);margin:18px 0 4px;display:flex;align-items:center;gap:8px}.section-head .count{color:var(--muted);font-weight:500}.mytask-row .proj-pill{border:1px solid var(--border-strong);background:#fff;border-radius:999px;padding:2px 10px 2px 8px;font-size:12px;color:var(--text);display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.mytask-row .proj-pill:hover{background:var(--bg-subtle)}.cell-project{width:200px;flex-shrink:0;overflow:hidden}.email-row{display:flex;gap:16px;align-items:flex-start;padding:14px 16px;border:1px solid var(--border);border-radius:12px;background:#fff;margin-bottom:12px}.email-row.unread{border-color:color-mix(in srgb,var(--accent) 40%,var(--border))}.email-main{flex:1;min-width:0}.email-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.unread-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0}.email-date{font-size:12px}.email-subject{display:block;color:var(--text);font-weight:600;margin:4px 0;text-decoration:none}.email-subject:hover{color:var(--accent)}.email-snippet{margin:0;font-size:13px;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.email-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.connect-card{max-width:520px;text-align:center;padding:34px 28px;margin:40px auto}.connect-card h2{margin:0 0 8px}code{background:var(--bg-subtle);border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-size:12px}@media(max-width:820px){.layout{flex-direction:column;height:auto;min-height:100vh}.sidebar{width:100%;flex-direction:row;flex-wrap:wrap;align-items:center;padding:8px 10px;gap:6px}.sidebar-brand{padding:4px 8px}.project-nav{display:flex;width:100%;overflow-x:auto;gap:6px}.project-nav .nav-item{width:auto}.sidebar-section,.sidebar-foot{display:none}.content{overflow:visible}.view-header,.list-head{position:static}.cell-status,.col-status,.cell-project{display:none}.view-body{padding:14px 14px 70px}}.cell-name.clickable{cursor:pointer;align-self:stretch}.cell-name.clickable:hover .task-title{text-decoration:underline}.row-badge{font-size:11px;color:var(--muted);background:var(--bg-subtle);border:1px solid var(--border);border-radius:999px;padding:1px 7px;flex-shrink:0}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000047;display:flex;justify-content:flex-end;z-index:50}.drawer{width:560px;max-width:92vw;height:100%;background:#fff;border-left:1px solid var(--border);display:flex;flex-direction:column;box-shadow:-8px 0 30px #00000014;animation:drawer-in .14s ease-out}@keyframes drawer-in{0%{transform:translate(24px);opacity:.4}to{transform:translate(0);opacity:1}}.drawer-top{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.complete-btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border-strong);background:#fff;color:var(--text);border-radius:8px;padding:6px 14px;font-weight:500}.complete-btn:hover{background:var(--bg-subtle);border-color:var(--green-bright)}.complete-btn.done{background:#e9f7ef;border-color:var(--green-bright);color:#14633a}.drawer-body{flex:1;overflow-y:auto;padding:18px 22px 60px}.parent-link{border:none;background:transparent;color:var(--muted);font-size:13px;padding:0 0 8px;cursor:pointer}.parent-link:hover{color:var(--accent)}.detail-title{width:100%;border:1px solid transparent;border-radius:8px;font-size:21px;font-weight:600;color:var(--text);padding:6px 8px;resize:none;font-family:inherit;line-height:1.3}.detail-title:hover{border-color:var(--border)}.detail-title:focus{border-color:var(--accent);outline:none}.detail-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px 18px;margin:14px 0 4px;padding:14px 8px;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.field{display:flex;align-items:center;gap:10px}.field-label{width:74px;flex-shrink:0;color:var(--muted);font-size:13px}.field-value{font-size:14px}.field select,.field input{flex:1;min-width:0}.detail-section{margin-top:22px}.detail-section h4{margin:0 0 10px;font-size:13px;font-weight:700;color:var(--text)}.detail-desc{width:100%;border:1px solid var(--border-strong);border-radius:8px;padding:9px 11px;font:inherit;font-size:14px;resize:vertical;min-height:60px}.subtask-list{list-style:none;margin:0 0 6px;padding:0;display:flex;flex-direction:column}.subtask-row{display:flex;align-items:center;gap:10px;padding:7px 4px;border-bottom:1px solid var(--border)}.subtask-row.done .subtask-title{text-decoration:line-through;color:var(--muted)}.subtask-title{border:none;background:transparent;font:inherit;font-size:14px;color:var(--text);text-align:left;cursor:pointer;flex:1;padding:0}.subtask-title:hover{text-decoration:underline}.add-task-row.sub{border-top:none;padding:7px 4px}.attach-list{list-style:none;margin:0 0 10px;padding:0}.attach-row{display:flex;align-items:center;gap:10px;padding:7px 8px;border:1px solid var(--border);border-radius:8px;margin-bottom:6px;background:var(--bg-subtle)}.attach-ico{font-size:16px;flex-shrink:0}.attach-name{flex:1;color:var(--text);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attach-name:hover{color:var(--accent);text-decoration:underline}.attach-size{font-size:12px;color:var(--muted);white-space:nowrap;flex-shrink:0}@media(max-width:820px){.drawer{width:100%;max-width:100%}.detail-fields{grid-template-columns:1fr}}.detail-meta{margin:28px 0 0;padding-top:12px;border-top:1px solid var(--border);font-size:12px;color:var(--muted)}.drawer-top-actions{display:flex;align-items:center;gap:4px}.detail-desc-view{border:1px solid transparent;border-radius:8px;padding:9px 11px;min-height:42px;white-space:pre-wrap;word-break:break-word;cursor:text;font-size:14px}.detail-desc-view:hover{border-color:var(--border-strong)}.detail-desc-view a,.note-body a{color:var(--accent);text-decoration:underline;word-break:break-all}.home-task{border:none;background:transparent;padding:0;font:inherit;color:var(--text);text-align:left;cursor:pointer;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-task:hover{text-decoration:underline}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000057;display:flex;align-items:center;justify-content:center;z-index:60;padding:20px}.modal{background:#fff;border:1px solid var(--border);border-radius:14px;width:420px;max-width:100%;max-height:90vh;overflow-y:auto;padding:18px 20px 22px;box-shadow:0 12px 40px #0000002e}.modal-head{display:flex;align-items:center;justify-content:space-between}.modal-head h3{margin:0;font-size:17px}.modal-sub{margin:2px 0 14px;font-size:13px}.modal-tabs{display:flex;gap:6px;border-bottom:1px solid var(--border);margin-bottom:16px}.modal-tabs .tab{border:none;background:transparent;color:var(--muted);padding:8px 4px;margin-bottom:-1px;border-bottom:2px solid transparent;font-size:14px}.modal-tabs .tab.active{color:var(--text);border-bottom-color:var(--accent);font-weight:600}.modal-form{display:flex;flex-direction:column;gap:10px}.modal-form input{width:100%}.ok-msg{color:#197b46;margin:0;font-size:13px}.modal-note{font-size:12px;margin:4px 0 14px}.member-list{list-style:none;margin:0 0 10px;padding:0}.member-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--border);font-size:14px}.member-avatar{width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.member-avatar.sm{width:20px;height:20px;font-size:11px}.granola-group{padding-bottom:6px}.granola-meeting{display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);padding-bottom:10px}.granola-link{color:var(--accent);text-decoration:none;font-size:12px;font-weight:500}.granola-row{display:flex;gap:16px;align-items:flex-start;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--border)}.granola-row:first-of-type{border-top:none}.granola-main{flex:1;min-width:0}.granola-text{font-size:14px}.granola-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}.customer-chip,.suggest-chip{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--muted);background:var(--bg-subtle);border:1px solid var(--border);border-radius:999px;padding:2px 9px;white-space:nowrap}.granola-actions{display:flex;align-items:center;gap:6px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}@media(max-width:640px){.granola-row{flex-direction:column}.granola-actions{justify-content:flex-start}}.focus-star{border:none;background:transparent;color:#c4c6cb;font-size:16px;line-height:1;padding:2px 4px;border-radius:6px;flex-shrink:0}.focus-star:hover,.focus-star.on{color:var(--high)}.cell-name .focus-star{margin-left:2px}.btn-ghost.focus-active{border-color:var(--high);color:#9a6700;background:color-mix(in srgb,var(--high) 12%,#fff)}
