*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{--bg:#ffffff;--surface:#f8f9fa;--surface-light:#f1f3f5;--surface-lighter:#fafbfc;--fg:#1a1a2e;--muted:rgba(26,26,46,0.5);--muted-light:rgba(26,26,46,0.3);--border:rgba(26,26,46,0.08);--border-med:rgba(26,26,46,0.15);--accent:#C41A1A;--accent-light:rgba(196,26,26,0.08);--accent-hover:#A81515;--success:#1f8a65;--success-bg:rgba(31,138,101,0.08);--warning:#c08532;--warning-bg:rgba(192,133,50,0.08);--info:#4a7fbf;--info-bg:rgba(74,127,191,0.08);--error:#cf2d56;--font-display:-apple-system,BlinkMacSystemFont,"SF Pro Display",system-ui,sans-serif;--font-body:-apple-system,BlinkMacSystemFont,"SF Pro Text",system-ui,sans-serif;--font-mono:"JetBrains Mono","IBM Plex Mono",ui-monospace,Menlo,monospace;--radius:8px;--radius-sm:6px;--radius-lg:12px;--sidebar-w:240px;--detail-w:420px;--mobile-header-h:52px;--safe-bottom:env(safe-area-inset-bottom,0px);--shadow-sm:0 1px 3px rgba(0,0,0,0.06);--shadow-md:0 4px 16px rgba(0,0,0,0.08);--shadow-lg:0 12px 40px rgba(0,0,0,0.12)}body{font-family:var(--font-body);background:var(--bg);color:var(--fg);line-height:1.5;overflow:hidden}.app,body{height:100vh}.app{display:flex;min-height:0}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:0;overflow-y:auto}.sidebar-header{padding:20px 20px 16px;border-bottom:1px solid var(--border)}.sidebar-logo{font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:-.3px;display:flex;align-items:center;gap:8px}.sidebar-logo .logo-mark{width:28px;height:28px;background:var(--accent);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700}.sidebar-section{padding:12px 12px 4px}.sidebar-section-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:0 8px 6px}.sidebar-nav{list-style:none;display:flex;flex-direction:column;gap:1px}.sidebar-nav li a,.sidebar-nav li button{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border:none;background:transparent;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--fg);text-align:left;text-decoration:none;transition:background .15s;cursor:pointer}.sidebar-nav li a:hover,.sidebar-nav li button:hover{background:rgba(26,26,46,.06)}.sidebar-nav li a.active,.sidebar-nav li button.active{background:rgba(26,26,46,.08);font-weight:600}.sidebar-nav-projects li button.active{font-weight:500}.sidebar-nav li a .nav-icon,.sidebar-nav li button .nav-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;opacity:.6}.sidebar-nav li a .badge,.sidebar-nav li button .badge{margin-left:auto;font-size:11px;font-weight:600;background:var(--accent-light);color:var(--accent);padding:1px 7px;border-radius:99px;min-width:20px;text-align:center}.sidebar-bottom{margin-top:auto;padding:12px;border-top:1px solid var(--border)}.sidebar-user-wrap{position:relative}.sidebar-user{display:flex;align-items:center;gap:10px;width:100%;padding:8px;border-radius:var(--radius-sm);border:none;background:transparent;cursor:pointer;text-align:left;color:inherit;font:inherit;transition:background .15s}.sidebar-user.open,.sidebar-user:hover{background:var(--surface-lighter)}.sidebar-user-chevron{flex-shrink:0;font-size:10px;color:var(--muted-light);transition:transform .15s}.sidebar-user.open .sidebar-user-chevron{transform:rotate(180deg)}.sidebar-user-menu{position:absolute;left:0;right:0;bottom:calc(100% + 6px);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);padding:4px;z-index:10}.sidebar-user-menu-item{display:block;width:100%;padding:8px 10px;border:none;border-radius:4px;background:transparent;font-size:13px;text-align:left;cursor:pointer;color:var(--fg)}.sidebar-user-menu-item:hover{background:var(--surface-lighter)}.sidebar-user-menu-item--danger{color:var(--accent)}.sidebar-user-menu-item--danger:hover{background:var(--accent-light)}.sidebar-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;overflow:hidden}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:13px;font-weight:600;line-height:1.3}.sidebar-user-role{font-size:11px;color:var(--muted)}.main{flex:1;position:relative}.main,.main>.page.active{display:flex;flex-direction:column;min-height:0;overflow:hidden}.main>.page.active{flex:1}.topbar{padding:16px 24px;display:grid;grid-template-columns:auto 1fr auto;grid-template-areas:"title filters actions";align-items:center;gap:16px;border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0}.topbar-title{grid-area:title;font-family:var(--font-display);font-size:20px;font-weight:600;letter-spacing:-.3px}.topbar-actions{grid-area:actions;margin-left:auto;display:flex;align-items:center;gap:10px}.topbar-primary{display:contents}.topbar-filters{grid-area:filters;min-width:0}.topbar--simple{grid-template-columns:1fr auto;grid-template-areas:"title actions"}.topbar--simple .topbar-primary{display:contents}.mobile-header,.sidebar-backdrop{display:none}.filter-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);z-index:20;min-width:140px;padding:4px}.filter-dropdown-item{display:block;width:100%;text-align:left;padding:6px 10px;font-size:13px;border:none;background:transparent;cursor:pointer;border-radius:4px}.filter-dropdown-item:hover{background:var(--surface-lighter)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--surface)}.login-card{width:100%;max-width:400px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px 28px;box-shadow:var(--shadow-md)}.login-card .form-input{font-size:16px}.perm-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.view-toggle{display:flex;background:var(--surface);border-radius:var(--radius-sm);padding:2px;gap:2px}.view-toggle button{font-family:var(--font-body);font-size:13px;font-weight:500;padding:5px 14px;border:none;border-radius:5px;background:transparent;color:var(--muted);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px}.view-toggle button.active{background:#fff;color:var(--fg);box-shadow:var(--shadow-sm)}.view-toggle button:hover:not(.active){color:var(--fg)}.filters{display:flex;gap:8px;align-items:center}.filter-group{position:relative;flex-shrink:0}.filter-chip{font-family:var(--font-body);font-size:12px;font-weight:500;padding:4px 12px;border-radius:99px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:4px}.filter-chip:hover{border-color:var(--border-med);color:var(--fg)}.filter-chip.active{background:var(--fg);color:var(--bg);border-color:var(--fg)}.filter-chip .arrow{font-size:10px;opacity:.6}.btn{font-family:var(--font-body);font-size:13px;font-weight:500;padding:7px 16px;border-radius:var(--radius-sm);border:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .15s;line-height:1.4}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--surface);color:var(--fg);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--border-med)}.btn-ghost{background:transparent;color:var(--muted);padding:6px 10px}.btn-ghost:hover{background:rgba(26,26,46,.06);color:var(--fg)}.btn-sm{font-size:12px;padding:4px 10px}.btn-icon{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:transparent;border:none;cursor:pointer;color:var(--muted);transition:all .15s}.btn-icon:hover{background:rgba(26,26,46,.06);color:var(--fg)}.content{flex:1;min-height:0;padding:20px 24px}.main>.content{overflow-y:auto}.main>.page.active>.content{display:flex;flex-direction:column;overflow:hidden}.task-table-wrap{flex:1;min-height:0;overflow:auto;-webkit-overflow-scrolling:touch}.task-table{width:100%;border-collapse:separate;border-spacing:0}.task-table thead th{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:8px 12px;border-bottom:1px solid var(--border-med);text-align:left;position:sticky;top:0;z-index:3;background:var(--bg);box-shadow:0 1px 0 var(--border-med)}.task-table tbody tr{border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;background:var(--bg)}.task-table tbody tr:hover{background:var(--surface-lighter)}.task-table td{padding:10px 12px;font-size:13px;vertical-align:middle}.subtask-row td:first-child{width:32px}.subtask-row td:nth-child(2){padding-left:44px}.subtask-row .task-title-cell--sub{padding-left:28px}.subtask-row .task-title-text{font-weight:400;color:var(--muted)}.task-table--no-select .subtask-row td:first-child{width:auto;padding-left:44px}.task-title-cell{gap:8px;min-width:0}.task-expand,.task-title-cell{display:flex;align-items:center}.task-expand{width:20px;height:20px;justify-content:center;border-radius:4px;cursor:pointer;color:var(--muted-light);transition:all .15s;flex-shrink:0}.task-expand:hover{background:rgba(26,26,46,.06);color:var(--fg)}.task-expand.has-children{color:var(--muted)}.task-title-text{font-weight:500;line-height:1.4}.task-subtask-indicator{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:3px;flex-shrink:0}.status-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:500;padding:3px 10px;border-radius:99px;white-space:nowrap}.status-todo{background:var(--surface);color:var(--muted)}.status-progress{background:var(--info-bg);color:var(--info)}.status-review{background:var(--warning-bg);color:var(--warning)}.status-done{background:var(--success-bg);color:var(--success)}.status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.status-todo .status-dot{background:var(--muted-light)}.status-progress .status-dot{background:var(--info)}.status-review .status-dot{background:var(--warning)}.status-done .status-dot{background:var(--success)}.priority{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:500}.priority-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.priority-high .priority-dot{background:var(--accent)}.priority-high{color:var(--accent)}.priority-medium .priority-dot{background:var(--warning)}.priority-medium{color:var(--warning)}.priority-low .priority-dot{background:var(--success)}.priority-low{color:var(--success)}.assignee{gap:6px;font-size:13px}.assignee,.assignee-avatar{display:flex;align-items:center}.assignee-avatar{width:22px;height:22px;border-radius:50%;justify-content:center;font-size:10px;font-weight:600;color:#fff;flex-shrink:0}.due-date{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}.due-date.overdue{color:var(--accent)}.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;height:100%;align-content:start}.kanban-column{background:var(--surface-lighter);border-radius:var(--radius-lg);padding:12px;display:flex;flex-direction:column;min-height:200px;max-height:calc(100vh - 160px)}.kanban-column-header{display:flex;align-items:center;justify-content:space-between;padding:4px 4px 12px;flex-shrink:0}.kanban-column-title{font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px}.kanban-column-count{font-size:11px;font-weight:600;color:var(--muted);background:var(--surface);padding:1px 7px;border-radius:99px}.kanban-cards{display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1;padding-bottom:4px;min-height:48px}.kanban-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:12px;cursor:pointer;transition:all .15s}.kanban-card:hover{box-shadow:var(--shadow-sm);border-color:var(--border-med)}.kanban-card.draggable{cursor:grab;touch-action:none}.kanban-card.draggable:active{cursor:grabbing}.kanban-card.dragging{opacity:0;pointer-events:none}.kanban-card-overlay{box-shadow:var(--shadow-md);cursor:grabbing;width:var(--kanban-card-width,280px);pointer-events:none}.kanban-column.drop-over{background:var(--surface-light);outline:2px dashed var(--border-med);outline-offset:-2px}.kanban-card-title{font-size:13px;font-weight:500;margin-bottom:8px;line-height:1.4}.kanban-card-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.kanban-card-tags{display:flex;gap:4px;flex-wrap:wrap}.kanban-card-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:8px}.kanban-card .subtask-count{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:3px}.kanban-card .assignee-avatar{width:20px;height:20px;font-size:9px}.detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(26,26,46,.2);z-index:100;opacity:0;pointer-events:none;transition:opacity .2s}.detail-overlay.open{opacity:1;pointer-events:auto}.detail-panel{position:fixed;top:0;right:0;bottom:0;width:var(--detail-w);background:var(--bg);border-left:1px solid var(--border);z-index:101;transform:translateX(100%);transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden}.detail-panel.open{transform:translateX(0)}.detail-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-shrink:0}.detail-body{flex:1;overflow-y:auto;padding:20px}.detail-section{margin-bottom:24px}.detail-section-title{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.detail-title{font-family:var(--font-display);font-size:20px;font-weight:600;letter-spacing:-.3px;line-height:1.3}.detail-desc{font-size:14px;color:var(--muted);line-height:1.6;margin-top:8px}.detail-meta-grid{display:grid;grid-template-columns:100px 1fr;gap:10px 12px;font-size:13px}.detail-meta-label{color:var(--muted);font-weight:500}.detail-meta-value{font-weight:500}.detail-subtask-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:6px;font-size:13px}.detail-subtask-check{width:16px;height:16px;border:1.5px solid var(--border-med);border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer}.detail-subtask-check.checked{background:var(--success);border-color:var(--success);color:#fff}.add-subtask-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:8px 10px;margin-top:6px;border:1px dashed var(--border-med);border-radius:var(--radius-sm);background:transparent;font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--muted);cursor:pointer;transition:all .15s}.add-subtask-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.subtask-input-row{display:flex;align-items:center;gap:6px;margin-top:6px}.subtask-input-row .form-input,.subtask-input-row .form-select{font-size:13px;padding:6px 10px}.subtask-input-row .form-select{width:72px;padding:6px 8px;font-size:12px}.log-item{display:flex;gap:10px;padding:8px 0;font-size:12px;border-bottom:1px solid var(--border)}.log-item:last-child{border-bottom:none}.log-dot{width:8px;height:8px;border-radius:50%;background:var(--surface);border:2px solid var(--border-med);flex-shrink:0;margin-top:4px}.log-content{flex:1}.log-content strong{font-weight:600}.log-time{color:var(--muted-light);font-size:11px;margin-top:2px;font-variant-numeric:tabular-nums}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(26,26,46,.3);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}.modal-overlay.open{opacity:1;pointer-events:auto}.modal{background:var(--bg);border-radius:var(--radius-lg);width:540px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);transform:translateY(12px);transition:transform .25s cubic-bezier(.4,0,.2,1)}.modal-overlay.open .modal{transform:translateY(0)}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:-.2px}.modal-body{padding:20px 24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:5px}.form-input,.form-select,.form-textarea{width:100%;font-family:var(--font-body);font-size:14px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-lighter);color:var(--fg);transition:border-color .15s;outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--border-med)}.form-textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.members-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.members-grid{display:flex;flex-direction:column;gap:1px;background:var(--border);border-radius:var(--radius);overflow:hidden}.member-row{display:grid;grid-template-columns:1fr 140px 120px;align-items:center;gap:16px;padding:14px 16px;background:var(--bg);font-size:13px}.member-row.header{background:var(--surface-lighter);font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:10px 16px}.member-info{gap:12px}.member-avatar,.member-info{display:flex;align-items:center}.member-avatar{width:36px;height:36px;border-radius:50%;justify-content:center;color:#fff;font-size:14px;font-weight:600}.member-name{font-weight:600;line-height:1.3}.member-email{font-size:11px;color:var(--muted)}.role-badge{font-size:12px;font-weight:500;padding:3px 10px;border-radius:99px;display:inline-flex;align-items:center}.role-admin{background:var(--accent-light);color:var(--accent)}.role-member{background:var(--info-bg);color:var(--info)}.role-observer{background:var(--surface);color:var(--muted)}.member-actions{display:flex;gap:6px}.perm-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:16px}.perm-table th{text-align:left;padding:8px 12px;font-weight:600;color:var(--muted);border-bottom:1px solid var(--border-med);font-size:11px;text-transform:uppercase;letter-spacing:.4px}.perm-table td{padding:8px 12px;border-bottom:1px solid var(--border)}.perm-check{color:var(--success);font-weight:700}.perm-cross{color:var(--muted-light)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(26,26,46,.15);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:rgba(26,26,46,.25)}.page,.task-list-mobile{display:none}.page.active{display:block}.content>.page.active{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.status-flow{display:flex;align-items:center;gap:4px;margin:12px 0}.status-flow-step{padding:6px 14px;border-radius:99px;font-size:12px;font-weight:500;border:1px solid var(--border);cursor:pointer;transition:all .15s}.status-flow-step:hover{border-color:var(--border-med)}.status-flow-step.current{border-color:var(--accent);background:var(--accent-light);color:var(--accent)}.status-flow-arrow{color:var(--muted-light);font-size:14px}.batch-bar{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--fg);color:var(--bg);padding:10px 20px;border-radius:var(--radius);display:flex;align-items:center;gap:16px;font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);z-index:50;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s}.batch-bar.visible{opacity:1;pointer-events:auto}.batch-bar .batch-count{background:var(--accent);color:#fff;padding:2px 8px;border-radius:99px;font-size:12px}.batch-bar button{font-family:var(--font-body);font-size:12px;font-weight:500;padding:4px 12px;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);background:transparent;color:var(--bg);cursor:pointer;transition:all .15s}.batch-bar button:hover{background:rgba(255,255,255,.1)}.row-check{width:16px;height:16px;border:1.5px solid var(--border-med);border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.row-check:hover{border-color:var(--muted)}.row-check.checked{background:var(--accent);border-color:var(--accent);color:#fff}.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}.empty-state-icon{font-size:36px;margin-bottom:12px;opacity:.3}.empty-state-text{font-size:14px}.loading-state{display:flex;align-items:center;justify-content:center;padding:60px 20px;min-height:200px}.loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:loading-spin .65s linear infinite}@keyframes loading-spin{to{transform:rotate(1turn)}}@media (max-width:1023px){.kanban{grid-template-columns:repeat(2,1fr);gap:12px}.kanban-column{max-height:calc(100vh - 180px)}}@media (max-width:767px){.app{flex-direction:column;height:100dvh;overflow-x:hidden}.mobile-header{display:flex;align-items:center;gap:12px;height:var(--mobile-header-h);padding:0 12px;background:var(--bg);border-bottom:1px solid var(--border);flex-shrink:0;z-index:50}.mobile-header-title{font-family:var(--font-display);font-size:16px;font-weight:600;letter-spacing:-.2px}.mobile-header .btn-icon{width:44px;height:44px;flex-shrink:0}.sidebar-backdrop{display:block;position:fixed;inset:0;background:rgba(26,26,46,.4);z-index:199;opacity:0;pointer-events:none;transition:opacity .25s}.sidebar-backdrop.open{opacity:1;pointer-events:auto}.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:200;transform:translateX(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg)}.sidebar.open{transform:translateX(0)}.main{flex:1;min-height:0;width:100%;overflow:hidden}.content,.main{overflow-x:hidden}.content{padding:12px 16px}.content>.page.active{overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}.topbar{grid-template-columns:1fr;grid-template-areas:"primary" "filters";gap:10px;padding:12px 16px}.topbar-primary{display:flex;align-items:center;gap:8px;grid-area:primary;width:100%}.topbar-title{font-size:17px;flex:1;min-width:0}.topbar-actions{margin-left:auto;flex-shrink:0}.topbar--simple{grid-template-columns:1fr;grid-template-areas:"primary"}.topbar--simple .topbar-primary{display:flex;align-items:center;gap:8px;grid-area:primary;width:100%}.topbar-filters{grid-area:filters;overflow-x:hidden;min-width:0}.topbar-filters .filters{flex-wrap:wrap;min-width:0;width:100%}.filter-dropdown{left:0;right:auto;min-width:min(100%,200px)}.view-toggle button{padding:5px 10px;font-size:12px}.task-list-desktop{display:none!important}.task-list-mobile{display:flex;flex-direction:column;gap:10px;flex:1;min-height:0;width:100%;overflow-x:hidden;overflow-y:visible}.task-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px;cursor:pointer;transition:background .1s;width:100%;box-sizing:border-box}.task-card--sub,.task-card:active{background:var(--surface-lighter)}.task-card--sub{margin-left:12px}.task-card-header{display:flex;align-items:flex-start;gap:10px;min-width:0}.task-card-body{flex:1;min-width:0}.task-card-title-row{display:flex;align-items:center;gap:6px;min-width:0;margin-bottom:8px}.task-card-title-row .task-title-text{flex:1;min-width:0;word-break:break-word}.task-card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px 10px}.kanban{display:flex;flex-direction:column;overflow:visible;gap:16px;height:auto;width:100%;padding-bottom:8px}.kanban-column{min-width:0;width:100%;flex-shrink:0;max-height:none}.kanban-cards{max-height:min(420px,50vh)}.detail-panel{width:100%;max-width:100%}.detail-body{padding:16px}.status-flow{flex-wrap:wrap;gap:8px}.modal{width:calc(100% - 32px);max-height:90dvh;margin:16px}.modal-body{padding:16px 20px}.modal-footer{padding:12px 20px}.form-row{grid-template-columns:1fr}.batch-bar{left:16px;right:16px;transform:none;flex-wrap:wrap;gap:8px;bottom:calc(16px + var(--safe-bottom));justify-content:center;max-width:calc(100% - 32px)}.members-grid{border:none;background:transparent;gap:10px}.member-row.header{display:none}.member-row{grid-template-columns:1fr;gap:10px;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:0}.member-actions{justify-content:flex-end}.login-page{padding:16px}.login-card{padding:24px 20px}}@media (max-width:480px){.view-toggle button{font-size:0;padding:8px 10px;gap:0}.batch-bar{font-size:12px;padding:8px 12px}.batch-bar button{padding:4px 8px;font-size:11px}}body,html{height:100%}body:has(.app){overflow:hidden}a{color:inherit;text-decoration:none}