:root{--brand-teal: #005368;--brand-teal-light: #0e6f86;--brand-green: #5aa445;--brand-green-light: #6cc154;--bg: #f6f8fa;--surface: #ffffff;--surface-2: #fafbfc;--surface-hover: #f1f3f5;--border: #e1e4e8;--border-strong: #d0d7de;--text: #1f2330;--text-muted: #57606a;--accent: var(--brand-teal);--accent-hover: var(--brand-teal-light);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06);--shadow-lg: 0 12px 36px rgba(0, 0, 0, .12);--status-not-started: #94a3b8;--status-in-progress: #f59e0b;--status-blocked: #e2445c;--status-done: var(--brand-green);--prio-urgent: #e2445c;--prio-high: #f59e0b;--prio-medium: #3b82f6;--prio-low: #94a3b8;--sidebar-bg: #003a4a;--sidebar-bg-darker: #002834;--sidebar-fg: #ffffff;--sidebar-muted: #88a8b1;--sidebar-hover: #005368;--sidebar-active: rgba(90, 164, 69, .18);--sidebar-border: rgba(255, 255, 255, .08);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 10px;--sidebar-w: 240px}[data-theme=dark]{--bg: #0b1418;--surface: #11202a;--surface-2: #0f1c25;--surface-hover: #162a35;--border: #1f3037;--border-strong: #2a4250;--text: #e5edf0;--text-muted: #8a9aa0;--accent: var(--brand-green);--accent-hover: var(--brand-green-light);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 12px 36px rgba(0, 0, 0, .6)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input,textarea,select{font-family:inherit}.full-screen-msg{min-height:100vh;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.full-screen-msg.error{color:var(--status-blocked)}.app{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--sidebar-bg);color:var(--sidebar-fg);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;border-right:1px solid var(--sidebar-border)}.sidebar-top{padding:20px 14px;flex:1;overflow-y:auto}.sidebar-brand{color:var(--sidebar-fg);display:flex;align-items:center;gap:10px;padding:4px 8px 18px;border-bottom:1px solid var(--sidebar-border);margin-bottom:16px}.sidebar-brand-sub{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--sidebar-muted);background:#5aa4452e;padding:2px 8px;border-radius:999px}.sidebar-nav{display:flex;flex-direction:column;gap:2px}.sidebar-board{background:transparent;border:none;color:var(--sidebar-fg);text-align:left;padding:8px 12px;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500}.sidebar-board:hover{background:var(--sidebar-hover)}.sidebar-board.active{background:var(--sidebar-active)}.sidebar-board-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.sidebar-board-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-board-count{background:#ffffff14;color:var(--sidebar-muted);padding:1px 7px;border-radius:999px;font-size:10px;font-weight:600}.sidebar-board-add{background:transparent;border:1px dashed var(--sidebar-border);color:var(--sidebar-muted);text-align:left;padding:8px 12px;border-radius:var(--radius-md);cursor:pointer;font-size:12px;margin-top:6px}.sidebar-board-add:hover{background:var(--sidebar-hover);color:var(--sidebar-fg)}.sidebar-section-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--sidebar-muted);padding:0 12px;margin-bottom:6px;margin-top:16px}.sidebar-my-work{margin-bottom:4px}.sidebar-my-work-icon{font-size:14px;flex-shrink:0}.row-board-chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;color:#fff;font-size:10.5px;font-weight:600;white-space:nowrap;max-width:110px;overflow:hidden;text-overflow:ellipsis}.activity-list{list-style:none;padding:0;margin:0}.activity-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.activity-item:last-child{border-bottom:none}.activity-dot{width:8px;height:8px;border-radius:50%;background:var(--brand-green);margin-top:6px;flex-shrink:0}.activity-body{flex:1;min-width:0}.activity-actor{font-weight:600;color:var(--text)}.activity-text{color:var(--text);font-size:13px}.activity-value{background:var(--surface-hover);padding:1px 6px;border-radius:3px;font-size:12px;font-weight:500;color:var(--text)}.activity-time{font-size:11px;color:var(--text-muted);margin-top:2px}.sidebar-bottom{padding:12px 14px 16px;border-top:1px solid var(--sidebar-border);background:var(--sidebar-bg-darker);display:flex;flex-direction:column;gap:12px}.sidebar-invite{background:var(--brand-green);color:#fff;border:none;padding:9px 12px;border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-weight:600;letter-spacing:.01em}.sidebar-invite:hover{background:var(--brand-green-light)}.sidebar-invite span{margin-right:4px;font-weight:700}.sidebar-user{display:flex;align-items:center;gap:10px;padding:4px}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:var(--brand-green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.sidebar-user-meta{min-width:0;flex:1}.sidebar-user-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:11px;color:var(--sidebar-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-actions{display:flex;gap:6px}.sidebar-icon-btn{flex:1;background:#ffffff0d;border:1px solid var(--sidebar-border);color:var(--sidebar-fg);padding:6px 8px;border-radius:var(--radius-md);cursor:pointer;font-size:14px}.sidebar-icon-btn:hover{background:var(--sidebar-hover)}.board{flex:1;padding:28px 32px;max-width:100%;min-width:0}.board-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:18px;gap:16px}.board-title h1{margin:0;font-size:22px;font-weight:600}.board-subtitle{margin:4px 0 0;color:var(--text-muted);font-size:13px}.board-actions{display:flex;gap:8px}.btn{padding:8px 14px;border-radius:var(--radius-md);border:1px solid var(--border-strong);background:var(--surface);color:var(--text);cursor:pointer;font-size:13px;font-weight:500}.btn:hover{background:var(--surface-hover)}.btn.ghost{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.ghost:hover{background:var(--accent-hover)}.board-toolbar{display:flex;align-items:center;gap:14px;margin-bottom:14px;flex-wrap:wrap}.search{position:relative;display:flex;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:0 10px;min-width:260px;flex:1;max-width:360px;height:36px}.search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #0053682e}.search-icon{font-size:13px;opacity:.6}.search input{flex:1;border:none;background:transparent;padding:8px;font:inherit;color:var(--text);outline:none;min-width:0}.search-clear{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;line-height:1;padding:0 4px}.search-clear:hover{color:var(--text)}.filters{display:flex;gap:4px;flex-wrap:wrap}.filter{padding:6px 14px;background:transparent;border:1px solid var(--border);border-radius:999px;cursor:pointer;color:var(--text-muted);font-size:12px}.filter:hover{background:var(--surface-hover)}.filter.active{background:var(--accent);color:#fff;border-color:var(--accent)}.columns{display:grid;grid-template-columns:repeat(4,minmax(220px,1fr));gap:14px}@media(max-width:1100px){.columns{grid-template-columns:repeat(2,1fr)}}@media(max-width:700px){.columns{grid-template-columns:1fr}}.column{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px;min-height:260px;display:flex;flex-direction:column;transition:background .12s,border-color .12s}.column.drag-over{background:var(--surface-hover);border-color:var(--accent);outline:2px dashed var(--accent);outline-offset:-3px}.column-head{display:flex;align-items:center;gap:8px;padding:4px 6px 12px;border-bottom:1px solid var(--border);margin-bottom:12px}.column-head h2{margin:0;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text);flex:1}.column-dot{width:8px;height:8px;border-radius:50%}.dot-not_started{background:var(--status-not-started)}.dot-in_progress{background:var(--status-in-progress)}.dot-blocked{background:var(--status-blocked)}.dot-done{background:var(--status-done)}.column-count{background:var(--surface);border:1px solid var(--border);color:var(--text-muted);padding:1px 8px;border-radius:999px;font-size:11px;font-weight:600}.column-body{display:flex;flex-direction:column;gap:8px;flex:1}.column-empty{padding:32px 12px;text-align:center;color:var(--text-muted)}.column-empty-icon{font-size:28px;margin-bottom:6px;opacity:.7}.column-empty-text{font-size:12px;font-style:italic}.todo{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--prio-medium);border-radius:var(--radius-md);cursor:grab;box-shadow:var(--shadow-sm);transition:transform .08s,box-shadow .12s,opacity .12s}.todo:active{cursor:grabbing}.todo:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.todo.dragging{opacity:.4;transform:rotate(1deg)}.todo.no-drag{cursor:pointer}.todo.no-drag:hover{transform:none}.todo.priority-urgent{border-left-color:var(--prio-urgent)}.todo.priority-high{border-left-color:var(--prio-high)}.todo.priority-medium{border-left-color:var(--prio-medium)}.todo.priority-low{border-left-color:var(--prio-low)}.todo-head{padding:10px 12px;display:flex;flex-direction:column;gap:6px}.todo-title{font-weight:500;font-size:13.5px;color:var(--text);line-height:1.35}.todo.overdue .todo-title{color:var(--status-blocked)}.todo-meta{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.badge{font-size:10.5px;padding:2px 7px;border-radius:4px;background:var(--surface-hover);color:var(--text-muted);font-weight:500}.badge.private{background:#e2445c1f;color:var(--status-blocked)}.badge.due.overdue{background:var(--status-blocked);color:#fff}.badge.prio-urgent{background:var(--prio-urgent);color:#fff}.badge.prio-high{background:var(--prio-high);color:#fff}.badge.prio-medium{background:#3b82f624;color:var(--prio-medium)}.badge.prio-low{background:var(--surface-hover);color:var(--text-muted)}.badge.assignee{background:var(--brand-green);color:#fff;font-weight:600;padding:2px 6px;border-radius:999px;min-width:22px;text-align:center}.todo-body{padding:0 12px 12px;border-top:1px solid var(--border)}.todo-desc{white-space:pre-wrap;color:var(--text-muted);margin:8px 0;font-size:12.5px}.todo-controls{display:flex;flex-wrap:wrap;gap:10px;align-items:end;margin-top:8px}.todo-controls label{display:flex;flex-direction:column;gap:4px;font-size:11px;color:var(--text-muted)}.todo-controls select,.todo-controls input{padding:5px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);font:inherit;background:var(--surface);color:var(--text)}.todo-controls .danger{background:var(--status-blocked);color:#fff;border:none;padding:6px 12px;border-radius:var(--radius-sm);cursor:pointer}.todo-footer{margin-top:10px;font-size:11px;color:var(--text-muted)}.quick-add-trigger{background:transparent;border:1px dashed var(--border-strong);color:var(--text-muted);padding:8px;border-radius:var(--radius-md);cursor:pointer;font-size:12px;margin-top:4px}.quick-add-trigger:hover{background:var(--surface-hover);border-color:var(--accent);color:var(--accent)}.quick-add{background:var(--surface);border:1px solid var(--accent);border-radius:var(--radius-md);padding:8px;display:flex;flex-direction:column;gap:8px}.quick-add input{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font:inherit;background:var(--surface);color:var(--text)}.quick-add-actions{display:flex;gap:6px}.quick-add-actions button{flex:1;padding:6px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;font-size:12px}.quick-add-actions .primary{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:500}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}.login-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;width:100%;max-width:380px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-md)}.login-form h1{margin:0;font-size:22px;color:var(--text)}.login-sub{margin:0 0 6px;color:var(--text-muted);font-size:13px}.login-form label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-muted)}.login-form input{padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-md);font:inherit;background:var(--surface);color:var(--text)}.login-form input:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:var(--accent)}.login-form button{padding:10px 16px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;font-size:14px}.login-form button:hover{background:var(--accent-hover)}.login-form button:disabled{opacity:.5;cursor:not-allowed}.login-error{background:#e2445c1f;color:var(--status-blocked);padding:8px 12px;border-radius:var(--radius-sm);font-size:13px}.login-hint{font-size:11px;color:var(--text-muted);margin:4px 0 0;text-align:center}.forgot-link{background:transparent;border:none;color:var(--accent);font-size:12px;cursor:pointer;padding:4px;margin:0;align-self:center}.forgot-link:hover{text-decoration:underline;background:transparent!important}.login-hint code{background:var(--surface-hover);padding:1px 5px;border-radius:3px;font-size:11px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0b14188c;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;width:100%;max-width:420px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-lg)}.modal-card.new-todo-modal{max-width:560px}.modal-card h2{margin:0;font-size:18px;color:var(--text)}.modal-sub{margin:0 0 8px;color:var(--text-muted);font-size:13px}.modal-card label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-muted)}.modal-card input,.modal-card textarea,.modal-card select{padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-md);font:inherit;background:var(--surface);color:var(--text)}.modal-card input:focus,.modal-card textarea:focus,.modal-card select:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:var(--accent)}.modal-card textarea{min-height:60px;resize:vertical}.modal-error{background:#e2445c1f;color:var(--status-blocked);padding:8px 12px;border-radius:var(--radius-sm);font-size:13px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}.modal-actions button{padding:8px 16px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;font-weight:500}.modal-actions .primary{background:var(--accent);color:#fff;border-color:var(--accent)}.modal-actions .primary:hover{background:var(--accent-hover)}.modal-actions button:disabled{opacity:.5;cursor:not-allowed}.form-row{display:flex;gap:10px;flex-wrap:wrap}.form-row label{flex:1;min-width:120px}.toast{position:fixed;bottom:24px;right:24px;background:var(--brand-green);color:#fff;padding:12px 20px;border-radius:var(--radius-md);font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);cursor:pointer;z-index:90;animation:toast-in .2s ease-out}@keyframes toast-in{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.view-toggle{display:inline-flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:2px;margin-right:8px}.view-tab{background:transparent;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;color:var(--text-muted);font-weight:500}.view-tab:hover{color:var(--text)}.view-tab.active{background:var(--accent);color:#fff}.todo-table{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:visible}.todo-table-head{display:grid;grid-template-columns:minmax(280px,1fr) 140px 110px 180px 110px 40px;gap:0;padding:10px 16px;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.todo-group{border-bottom:1px solid var(--border)}.todo-group:last-child{border-bottom:none}.todo-group-head{width:100%;display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--surface-2);border:none;border-top:1px solid var(--border);text-align:left;cursor:pointer;font-size:12px;font-weight:600;color:var(--text)}.todo-group-head:first-child{border-top:none}.todo-group-head:hover{background:var(--surface-hover)}.chevron{font-size:10px;color:var(--text-muted);width:12px}.status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-dot-not_started{background:var(--status-not-started)}.status-dot-in_progress{background:var(--status-in-progress)}.status-dot-blocked{background:var(--status-blocked)}.status-dot-done{background:var(--status-done)}.group-label{flex:1}.group-count{background:var(--surface);border:1px solid var(--border);color:var(--text-muted);padding:1px 8px;border-radius:999px;font-size:11px;font-weight:600}.todo-row{display:grid;grid-template-columns:minmax(280px,1fr) 140px 110px 180px 110px 40px;gap:0;align-items:stretch;border-top:1px solid var(--border);transition:background .08s;background:var(--surface);position:relative;cursor:pointer}.todo-row:hover{background:var(--surface-hover)}.todo-row>div{display:flex;align-items:center;padding:0 12px;border-right:1px solid var(--border);min-height:40px}.todo-row>div:last-child{border-right:none}.todo-row:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--row-strip, transparent);pointer-events:none}.row-status-not_started{--row-strip: var(--status-not-started)}.row-status-in_progress{--row-strip: var(--status-in-progress)}.row-status-blocked{--row-strip: var(--status-blocked)}.row-status-done{--row-strip: var(--status-done)}.todo-row .row-delete{opacity:0}.todo-row:hover .row-delete{opacity:1}.row-private{background:#e2445c05}.td-title{display:flex;align-items:center;gap:8px;min-width:0;padding-left:16px!important}.title-indicators{display:inline-flex;align-items:center;gap:6px;flex-shrink:0}.row-indicator{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:999px;background:var(--surface-hover);color:var(--text-muted);font-size:11px;font-weight:500;white-space:nowrap}.row-indicator.updates{background:#0073ea1f;color:var(--prio-medium)}.row-indicator.subtasks{background:#5aa4451f;color:var(--brand-green)}.row-indicator.subtasks.complete{background:var(--brand-green);color:#fff}.td-status{padding:0!important}.td-status .cell-pop{width:100%;height:100%}.td-status .cell-pop>button.status-chip{width:100%;height:100%;min-height:40px;border-radius:0;padding:6px 10px;font-size:11px}.td-priority{padding:4px 8px!important}.td-priority .cell-pop,.td-priority .prio-chip{width:100%}.title-text{background:transparent;border:1px solid transparent;padding:5px 8px;border-radius:4px;cursor:text;text-align:left;font:inherit;color:var(--text);width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.title-text:hover:not(.no-edit){background:var(--surface);border-color:var(--border)}.title-text.no-edit{cursor:default}.title-input{width:100%;padding:5px 8px;border:1px solid var(--accent);border-radius:4px;font:inherit;background:var(--surface);color:var(--text);outline:none}.row-private-badge{font-size:10px;padding:2px 6px;border-radius:3px;background:#e2445c24;color:var(--status-blocked);font-weight:600;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.row-delete{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:18px;line-height:1;padding:4px 8px;border-radius:4px;transition:opacity .12s,background .12s,color .12s}.row-delete:hover{background:#e2445c1f;color:var(--status-blocked)}.inline-add-trigger{display:block;width:100%;padding:8px 16px;background:transparent;border:none;border-top:1px solid var(--border);color:var(--text-muted);text-align:left;cursor:pointer;font-size:12.5px}.inline-add-trigger:hover{background:var(--surface-hover);color:var(--accent)}.inline-add-row{padding:6px 16px;border-top:1px solid var(--border);background:var(--surface-hover)}.inline-add-row input{width:100%;padding:8px 10px;border:1px solid var(--accent);border-radius:4px;font:inherit;background:var(--surface);color:var(--text);outline:none}.inline-add-row input:focus{box-shadow:0 0 0 3px #0053682e}.title-display{cursor:pointer}.todo-table-empty{padding:60px 20px;text-align:center;color:var(--text-muted)}.todo-table-empty .empty-icon{font-size:36px;margin-bottom:12px}.todo-table-empty strong{color:var(--text)}.cell-pop{position:relative;display:inline-flex}.popover{position:absolute;top:calc(100% + 6px);left:0;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:6px;display:flex;flex-direction:column;gap:3px;z-index:50;min-width:160px;animation:pop-in .12s ease-out}@keyframes pop-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.popover-status,.popover-prio{min-width:150px}.popover-assignee{min-width:220px;max-height:280px;overflow-y:auto}.popover-date{padding:10px}.popover-date input[type=date]{padding:8px 10px;border:1px solid var(--border);border-radius:4px;font:inherit;background:var(--surface);color:var(--text)}.popover-clear{margin-top:8px;padding:6px 10px;background:transparent;border:1px solid var(--border);color:var(--status-blocked);border-radius:4px;cursor:pointer;font-size:12px}.status-chip{display:inline-flex;align-items:center;justify-content:center;padding:5px 10px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border:none;cursor:pointer;color:#fff;width:100%;text-align:center;transition:filter .1s,transform .05s}.status-chip:hover:not(:disabled){filter:brightness(1.08)}.status-chip:active:not(:disabled){transform:scale(.98)}.status-chip:disabled{opacity:.85;cursor:not-allowed}.status-chip.status-not_started{background:var(--status-not-started);color:#fff}.status-chip.status-in_progress{background:var(--status-in-progress);color:#fff}.status-chip.status-blocked{background:var(--status-blocked);color:#fff}.status-chip.status-done{background:var(--status-done);color:#fff}.status-chip.is-current{outline:2px solid var(--text);outline-offset:2px}.prio-chip{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:4px;font-size:11px;font-weight:600;border:none;cursor:pointer;width:100%;text-align:center}.prio-chip:hover:not(:disabled){filter:brightness(1.08)}.prio-chip:disabled{opacity:.85;cursor:not-allowed}.prio-chip.prio-urgent{background:var(--prio-urgent);color:#fff}.prio-chip.prio-high{background:var(--prio-high);color:#fff}.prio-chip.prio-medium{background:#3b82f624;color:var(--prio-medium)}.prio-chip.prio-low{background:var(--surface-hover);color:var(--text-muted)}.prio-chip.is-current{outline:2px solid var(--text);outline-offset:2px}[data-theme=dark] .prio-chip.prio-medium{background:#3b82f638;color:#82b1ff}[data-theme=dark] .prio-chip.prio-low{background:var(--surface-hover);color:var(--text-muted)}.assignee-chip{display:inline-flex;align-items:center;gap:8px;padding:4px 8px;border-radius:4px;background:transparent;border:1px solid transparent;cursor:pointer;font:inherit;color:var(--text);width:100%;text-align:left}.assignee-chip:hover:not(:disabled){background:var(--surface);border-color:var(--border)}.assignee-chip:disabled{cursor:not-allowed;opacity:.75}.avatar-sm{width:22px;height:22px;border-radius:50%;background:var(--brand-green);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}.assignee-name{font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.assignee-unassigned{color:var(--text-muted);font-size:14px}.assignee-option{display:flex;align-items:center;gap:8px;padding:6px 10px;background:transparent;border:none;border-radius:4px;cursor:pointer;text-align:left;font:inherit;color:var(--text)}.assignee-option:hover{background:var(--surface-hover)}.assignee-option.is-current{background:var(--surface-hover);font-weight:600}.date-chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:4px;background:transparent;border:1px solid transparent;cursor:pointer;font:inherit;color:var(--text);font-size:12.5px}.date-chip:hover:not(:disabled){background:var(--surface);border-color:var(--border)}.date-chip:disabled{cursor:not-allowed;opacity:.75}.date-empty{color:var(--text-muted)}.date-overdue{color:var(--status-blocked);font-weight:600}@media(max-width:900px){.todo-table-head,.todo-row{grid-template-columns:minmax(220px,1fr) 130px 100px 100px 40px}.td-assignee,.th-assignee{display:none}}@media(max-width:640px){.todo-table-head,.todo-row{grid-template-columns:minmax(180px,1fr) 120px 40px}.td-priority,.th-priority,.td-due,.th-due{display:none}}.recurrence-chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:4px;background:transparent;border:1px solid transparent;cursor:pointer;font:inherit;color:var(--text);font-size:12.5px}.recurrence-chip:hover:not(:disabled){background:var(--surface);border-color:var(--border)}.recurrence-chip:disabled{cursor:not-allowed;opacity:.75}.recurrence-chip.empty{color:var(--text-muted)}.recurrence-chip.active{color:var(--brand-green);font-weight:500}.popover-recurrence{min-width:180px}.recurrence-option{display:flex;align-items:center;gap:8px;padding:8px 10px;background:transparent;border:none;border-radius:4px;cursor:pointer;text-align:left;font:inherit;color:var(--text)}.recurrence-option:hover{background:var(--surface-hover)}.recurrence-option.is-current{background:var(--surface-hover);font-weight:600}.calendar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.calendar-head{display:flex;align-items:center;gap:8px;margin-bottom:14px}.calendar-head h2{margin:0;font-size:16px;flex:1}.calendar-head button{background:var(--surface);border:1px solid var(--border);padding:6px 12px;border-radius:var(--radius-md);cursor:pointer;font-size:13px;color:var(--text)}.calendar-head button:hover{background:var(--surface-hover)}.calendar-today{font-weight:500}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:0 0 8px;border-bottom:1px solid var(--border)}.calendar-weekdays>div{padding:4px 6px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:minmax(110px,1fr);gap:1px;background:var(--border)}.calendar-day{background:var(--surface);padding:6px;display:flex;flex-direction:column;gap:4px;min-height:110px}.calendar-day.out-of-month{background:var(--surface-2)}.calendar-day.out-of-month .calendar-day-num{color:var(--text-muted)}.calendar-day.today{background:#0053680f}.calendar-day.today .calendar-day-num{background:var(--accent);color:#fff;border-radius:50%;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center}.calendar-day-num{font-size:12px;font-weight:600;color:var(--text);padding:2px 4px;align-self:flex-start}.calendar-day-todos{display:flex;flex-direction:column;gap:3px;flex:1}.calendar-pill{display:flex;align-items:center;gap:4px;padding:3px 6px;border-radius:3px;font-size:11px;cursor:pointer;border:none;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff;font-weight:500}.calendar-pill.status-not_started{background:var(--status-not-started)}.calendar-pill.status-in_progress{background:var(--status-in-progress)}.calendar-pill.status-blocked{background:var(--status-blocked)}.calendar-pill.status-done{background:var(--status-done)}.calendar-pill.urgent{box-shadow:inset 0 0 0 2px var(--prio-urgent)}.calendar-pill .recur-mark{font-size:9px;opacity:.9}.calendar-more{font-size:10.5px;color:var(--text-muted);padding:2px 6px}.calendar-undated{margin-top:18px;padding-top:14px;border-top:1px solid var(--border)}.calendar-undated h3{margin:0 0 8px;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.calendar-undated-list{display:flex;flex-wrap:wrap;gap:6px}@media(max-width:720px){.calendar{padding:12px}.calendar-head h2{font-size:15px}.calendar-grid-wrapper{display:none!important}.calendar-agenda{display:flex!important;flex-direction:column;gap:18px;margin-top:4px}.agenda-day{display:flex;flex-direction:column;gap:8px}.agenda-day-head{display:flex;align-items:baseline;gap:10px;padding:4px 6px;border-bottom:1px solid var(--border)}.agenda-day-num{font-size:22px;font-weight:700;color:var(--text);line-height:1}.agenda-day.is-today .agenda-day-num{color:var(--accent)}.agenda-day-meta{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.agenda-items{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.agenda-item{display:flex;align-items:flex-start;gap:10px;width:100%;background:var(--surface-2);border:1px solid var(--border);border-left:4px solid var(--prio-medium);border-radius:var(--radius-md);padding:12px;cursor:pointer;text-align:left;font:inherit;color:var(--text)}.agenda-item.priority-urgent{border-left-color:var(--prio-urgent)}.agenda-item.priority-high{border-left-color:var(--prio-high)}.agenda-item.priority-low{border-left-color:var(--prio-low)}.agenda-item:active{background:var(--surface-hover)}.agenda-status-dot{width:10px;height:10px;border-radius:50%;margin-top:5px;flex-shrink:0}.agenda-status-dot.status-not_started{background:var(--status-not-started)}.agenda-status-dot.status-in_progress{background:var(--status-in-progress)}.agenda-status-dot.status-blocked{background:var(--status-blocked)}.agenda-status-dot.status-done{background:var(--status-done)}.agenda-item-body{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}.agenda-item-title{font-size:14px;font-weight:500}.agenda-item-meta{font-size:11.5px;color:var(--text-muted);display:flex;flex-wrap:wrap;gap:6px;align-items:center}.prio-tag{padding:1px 7px;border-radius:3px;color:#fff;font-weight:600;font-size:10px}.prio-tag.prio-urgent{background:var(--prio-urgent)}.prio-tag.prio-high{background:var(--prio-high)}.prio-tag.prio-low{background:var(--surface-hover);color:var(--text-muted)}.agenda-empty{padding:30px 16px;text-align:center;color:var(--text-muted);font-size:13px}.fab{display:inline-flex!important;align-items:center;justify-content:center}.btn-new-task{display:none}.board{padding-bottom:100px!important}}.timeline{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;gap:16px}.timeline-bucket{display:flex;flex-direction:column;gap:6px}.timeline-bucket-head{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;padding:6px 10px;border-left:3px solid var(--accent);background:var(--surface-2);border-radius:var(--radius-sm)}.timeline-bucket-head.bucket-overdue{border-left-color:var(--status-blocked);color:var(--status-blocked)}.timeline-bucket-head.bucket-today{border-left-color:var(--status-in-progress)}.timeline-bucket-head.bucket-tomorrow{border-left-color:var(--accent)}.timeline-bucket-head.bucket-this-week,.timeline-bucket-head.bucket-next-week{border-left-color:var(--brand-green)}.timeline-bucket-head.bucket-no-due-date{border-left-color:var(--text-muted);color:var(--text-muted)}.timeline-bucket-count{margin-left:auto;background:var(--surface);border:1px solid var(--border);color:var(--text-muted);padding:1px 8px;border-radius:999px;font-size:11px}.timeline-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}.timeline-item{display:grid;grid-template-columns:14px 110px 1fr auto;align-items:center;gap:12px;width:100%;background:transparent;border:1px solid transparent;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;text-align:left;font:inherit;color:var(--text)}.timeline-item:hover{background:var(--surface-hover);border-color:var(--border)}.timeline-dot{width:10px;height:10px;border-radius:50%}.timeline-dot.status-not_started{background:var(--status-not-started)}.timeline-dot.status-in_progress{background:var(--status-in-progress)}.timeline-dot.status-blocked{background:var(--status-blocked)}.timeline-dot.status-done{background:var(--status-done)}.timeline-due{font-size:12px;color:var(--text-muted);font-weight:500}.timeline-title{font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.timeline-meta{display:inline-flex;align-items:center;gap:6px}.timeline-prio{font-size:10.5px;padding:2px 7px;border-radius:4px;font-weight:600;color:#fff}.timeline-prio.prio-urgent{background:var(--prio-urgent)}.timeline-prio.prio-high{background:var(--prio-high)}.timeline-prio.prio-low{background:var(--surface-hover);color:var(--text-muted)}.timeline-assignee{width:22px;height:22px;border-radius:50%;background:var(--brand-green);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}.timeline-recur{font-size:13px;color:var(--brand-green)}.timeline-empty{padding:60px 20px;text-align:center;color:var(--text-muted)}@media(max-width:720px){.timeline-item{grid-template-columns:14px 80px 1fr auto;gap:8px}.timeline-due{font-size:10.5px}.timeline-title{font-size:12.5px}}.color-swatches{display:flex;gap:8px;padding:4px 0}.swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;outline:none}.swatch:hover{transform:scale(1.08)}.swatch.selected{border-color:var(--text);box-shadow:0 0 0 2px var(--surface)}.fab{display:none;position:fixed;bottom:22px;right:22px;width:56px;height:56px;border-radius:50%;background:var(--brand-green);color:#fff;border:none;font-size:30px;line-height:1;font-weight:300;cursor:pointer;box-shadow:0 6px 18px #0003,0 2px 6px #0000001f;z-index:90;transition:transform .1s ease-out}.fab:hover{background:var(--brand-green-light)}.fab:active{transform:scale(.95)}.calendar-agenda{display:none}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0b141880;display:flex;justify-content:flex-end;z-index:120;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:drawer-fade .15s ease-out}@keyframes drawer-fade{0%{background:#0b141800}to{background:#0b141880}}.drawer{width:100%;max-width:540px;background:var(--surface);border-left:1px solid var(--border);height:100vh;overflow-y:auto;display:flex;flex-direction:column;box-shadow:-8px 0 32px #0003;animation:drawer-slide .18s ease-out}@keyframes drawer-slide{0%{transform:translate(40px);opacity:.4}to{transform:translate(0);opacity:1}}.drawer-head{display:flex;align-items:center;gap:12px;padding:18px 20px 14px;border-bottom:1px solid var(--border)}.drawer-close{width:28px;height:28px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);cursor:pointer;font-size:18px;line-height:1;color:var(--text-muted);flex-shrink:0}.drawer-close:hover{background:var(--surface-hover);color:var(--text)}.drawer-title{flex:1;background:transparent;border:1px solid transparent;font-size:18px;font-weight:600;color:var(--text);padding:6px 8px;border-radius:var(--radius-md);outline:none;font-family:inherit}.drawer-title:hover:not(:disabled):not(:focus){border-color:var(--border)}.drawer-title:focus{border-color:var(--accent);background:var(--surface)}.drawer-title:disabled{cursor:default}.drawer-title.no-edit{color:var(--text)}.drawer-fields{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 20px;padding:16px 20px;border-bottom:1px solid var(--border)}.drawer-field{display:flex;flex-direction:column;gap:6px;min-width:0}.drawer-field>label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.drawer-description{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:6px}.drawer-description>label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.drawer-description textarea{min-height:70px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-md);font:inherit;background:var(--surface);color:var(--text);resize:vertical;outline:none}.drawer-description textarea:focus{border-color:var(--accent)}.drawer-description textarea:disabled{background:var(--surface-2)}.drawer-tabs{display:flex;gap:4px;padding:0 20px;border-bottom:1px solid var(--border);background:var(--surface-2)}.drawer-tabs button{padding:12px 14px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);cursor:pointer;font-weight:500;font-size:13px;margin-bottom:-1px}.drawer-tabs button:hover{color:var(--text)}.drawer-tabs button.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-count{margin-left:6px;background:var(--surface-hover);color:var(--text-muted);padding:1px 7px;border-radius:999px;font-size:10px;font-weight:600}.drawer-tabs button.active .tab-count{background:var(--accent);color:#fff}.drawer-body{padding:16px 20px 24px;flex:1}.update-compose{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.update-compose textarea{min-height:56px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-md);font:inherit;background:var(--surface);color:var(--text);resize:vertical;outline:none}.update-compose textarea:focus{border-color:var(--accent)}.update-compose button{align-self:flex-end;padding:6px 14px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-weight:500;cursor:pointer;font-size:12px}.update-compose button:disabled{opacity:.5;cursor:not-allowed}.updates-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.update-item{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 12px}.update-head{display:flex;align-items:center;gap:8px;margin-bottom:4px;font-size:12px}.update-author{font-weight:600;color:var(--text)}.update-time{color:var(--text-muted);flex:1}.update-delete{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;line-height:1}.update-delete:hover{color:var(--status-blocked)}.update-body{white-space:pre-wrap;font-size:13px;color:var(--text)}.empty-row{list-style:none;padding:16px 0;color:var(--text-muted);font-style:italic;font-size:12.5px}.subtasks-list{list-style:none;padding:0;margin:0 0 12px}.subtask-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:var(--radius-sm)}.subtask-item:hover{background:var(--surface-hover)}.subtask-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--brand-green);cursor:pointer}.subtask-title{flex:1;font-size:13px}.subtask-title.done{text-decoration:line-through;color:var(--text-muted)}.subtask-delete{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;line-height:1;opacity:0}.subtask-item:hover .subtask-delete{opacity:1}.subtask-delete:hover{color:var(--status-blocked)}.subtask-add input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-md);font:inherit;background:var(--surface);color:var(--text);outline:none}.subtask-add input:focus{border-color:var(--accent)}.files-placeholder{text-align:center;padding:30px 20px;color:var(--text-muted)}.files-placeholder .files-icon{font-size:36px;opacity:.8;margin-bottom:8px}.files-placeholder h3{margin:0 0 8px;color:var(--text);font-size:15px}.files-placeholder p{margin:0;font-size:12.5px;line-height:1.5}@media(max-width:720px){.drawer{max-width:100%}.drawer-fields{grid-template-columns:1fr}.drawer-tabs{padding:0 10px}.drawer-tabs button{padding:10px 6px;font-size:12px}.tab-count{margin-left:4px;padding:1px 5px;font-size:9.5px}}.hamburger{display:none;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:8px 12px;font-size:18px;line-height:1;cursor:pointer;color:var(--text);margin-right:12px;flex-shrink:0}.hamburger:hover{background:var(--surface-hover)}.sidebar-mobile-close{display:none;background:#ffffff14;border:none;color:var(--sidebar-fg);font-size:22px;line-height:1;width:30px;height:30px;border-radius:var(--radius-md);cursor:pointer;margin-left:auto}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0b141880;z-index:80;opacity:0;pointer-events:none;transition:opacity .18s}.sidebar-backdrop.open{opacity:1;pointer-events:auto}.view-tab-icon{display:none}@media(max-width:720px){.app{flex-direction:column}.board{padding:14px}.sidebar{position:fixed;top:0;left:0;width:84%;max-width:320px;height:100vh;z-index:100;transform:translate(-100%);transition:transform .22s ease-out;box-shadow:6px 0 24px #0000004d}.sidebar.mobile-open{transform:translate(0)}.sidebar-backdrop{display:block}.sidebar-mobile-close{display:inline-flex;align-items:center;justify-content:center}.hamburger{display:inline-flex;align-items:center;justify-content:center;min-width:40px;min-height:40px}.board-header{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:12px}.board-title{display:flex;align-items:center;min-width:0}.board-title h1{font-size:18px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.board-subtitle{font-size:11px}.board-actions{display:flex;flex-wrap:nowrap;gap:6px;overflow-x:auto;scrollbar-width:none;justify-content:flex-end}.board-actions::-webkit-scrollbar{display:none}.view-toggle{flex-shrink:0}.view-tab-label{display:none}.view-tab-icon{display:inline;font-size:14px}.view-toggle{margin-right:4px}.view-tab{padding:8px 12px;min-width:40px;min-height:36px}.btn-new-task{padding:8px 12px;min-height:40px}.btn-new-task-label{display:inline}.btn-new-task-icon{display:inline;font-weight:700}.board-toolbar{gap:8px}.search{max-width:100%;min-width:0;width:100%}.filters{overflow-x:auto;flex-wrap:nowrap;margin-left:-14px;margin-right:-14px;padding:4px 14px;scrollbar-width:none;width:calc(100% + 28px)}.filters::-webkit-scrollbar{display:none}.filter{padding:8px 16px;font-size:13px;flex-shrink:0;min-height:36px}.status-chip,.prio-chip{padding:6px 10px;min-height:30px;font-size:11px}.inline-add-trigger{padding:14px 16px;font-size:13px;min-height:48px}.inline-add-row{padding:8px 14px}.inline-add-row input{padding:12px;font-size:14px;min-height:44px}.todo-group-head{padding:12px 14px;min-height:44px}.todo-table{border-radius:var(--radius-md);overflow:hidden}.todo-table-head{display:none}.todo-row{display:flex!important;flex-wrap:wrap;align-items:center!important;gap:8px 6px;padding:14px 14px 14px 18px!important;border-radius:0;position:relative}.todo-row:before{width:4px}.todo-row>div{border-right:none!important;padding:0!important;min-height:30px!important;display:inline-flex!important;align-items:center;flex:0 0 auto}.td-title{flex:1 1 100%!important;flex-wrap:wrap;gap:6px!important;padding-left:0!important}.title-display{font-size:14.5px;font-weight:500;line-height:1.35;white-space:normal;overflow:visible;padding-right:36px}.title-indicators{gap:4px}.td-status .cell-pop>button.status-chip{width:auto;min-height:28px;border-radius:4px;padding:4px 10px}.td-priority .prio-chip{width:auto;min-height:28px;padding:4px 10px}.td-assignee .assignee-chip,.td-due .date-chip{padding:4px 8px}.td-actions{position:absolute!important;top:8px;right:8px;min-height:0!important}.row-delete{opacity:1;padding:6px 10px;font-size:16px;min-width:32px;min-height:32px}.td-assignee:has(.assignee-unassigned),.td-due:has(.date-empty:disabled){display:none!important}.popover{max-width:calc(100vw - 32px);right:0;left:auto}.popover-status,.popover-prio{min-width:130px}.popover-assignee{min-width:200px}.todo-row{position:relative}}@media(max-width:380px){.btn-new-task-label{display:none}.btn-new-task{min-width:40px;padding:8px 12px}}
