:root{--bg: #0f172a;--surface: #1e293b;--surface-2: #273449;--border: #334155;--text: #e2e8f0;--muted: #94a3b8;--accent: #6366f1;--accent-hover: #4f46e5}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}.app-header{padding:20px 28px;border-bottom:1px solid var(--border)}.app-header h1{margin:0;font-size:1.5rem}.app-header p{margin:4px 0 0;color:var(--muted);font-size:.9rem}.banner-error{background:#7f1d1d;color:#fecaca;padding:10px 28px;font-size:.9rem}.layout{display:flex;gap:24px;padding:24px 28px;align-items:flex-start}.sidebar{flex:0 0 300px}.content{flex:1;min-width:0}.task-form{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:14px;position:sticky;top:24px}.task-form h2{margin:0;font-size:1.1rem}.task-form label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--muted)}.task-form input,.task-form textarea,.task-form select{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:9px 11px;color:var(--text);font-size:.92rem;font-family:inherit;resize:vertical}.task-form input:focus,.task-form textarea:focus,.task-form select:focus{outline:none;border-color:var(--accent)}.task-form button{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:11px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s}.task-form button:hover:not(:disabled){background:var(--accent-hover)}.task-form button:disabled{opacity:.6;cursor:not-allowed}.form-error{color:#fca5a5;font-size:.85rem;margin:0}.board{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.column{background:var(--surface);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;min-height:200px;transition:border-color .15s,background .15s}.column-over{border-color:var(--accent);background:var(--surface-2)}.column-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.column-header h3{margin:0;font-size:.95rem}.column-header .count{background:var(--surface-2);color:var(--muted);border-radius:999px;padding:2px 9px;font-size:.8rem}.column-body{padding:12px;display:flex;flex-direction:column;gap:10px;flex:1}.empty-hint{color:var(--muted);font-size:.82rem;text-align:center;padding:20px 0;border:1px dashed var(--border);border-radius:8px;margin:0}.task-card{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:12px}.task-card-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.priority-dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto}.drag-handle{margin-left:auto;cursor:grab;color:var(--muted);font-size:1rem;line-height:1}.drag-handle:active{cursor:grabbing}.delete-btn{background:transparent;border:none;color:var(--muted);font-size:1.2rem;line-height:1;cursor:pointer;padding:0 2px}.delete-btn:hover{color:#fca5a5}.task-card h4{margin:0 0 4px;font-size:.95rem}.task-card p{margin:0;font-size:.85rem;color:var(--muted);white-space:pre-wrap}.dragging-overlay{box-shadow:0 12px 30px #00000080;cursor:grabbing}.loading{color:var(--muted)}@media (max-width: 860px){.layout{flex-direction:column}.sidebar{flex:1 1 auto;width:100%}.task-form{position:static}.board{grid-template-columns:1fr}}.center{text-align:center;margin-top:60px}.app-header{display:flex;align-items:center;justify-content:space-between}.brand{display:flex;align-items:center;gap:12px}.user-box{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:.9rem}.board-select{background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:.9rem}.ghost{background:transparent;border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 12px;cursor:pointer}.ghost:hover{border-color:var(--accent)}.ghost.small{padding:5px 10px;font-size:.85rem}.link{background:none;border:none;color:var(--accent);cursor:pointer;padding:0;font:inherit;text-decoration:underline}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:32px;width:340px;display:flex;flex-direction:column;gap:14px}.login-card h1{margin:0;text-align:center}.login-sub{margin:0 0 8px;text-align:center;color:var(--muted)}.login-card label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--muted)}.login-card input{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:9px 11px;color:var(--text);font-size:.92rem}.login-card input:focus{outline:none;border-color:var(--accent)}.login-card>button{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:11px;font-weight:600;cursor:pointer;margin-top:6px}.login-card>button:hover:not(:disabled){background:var(--accent-hover)}.login-switch{text-align:center;font-size:.85rem;color:var(--muted);margin:0}.form-row,.modal-row{display:flex;gap:12px}.form-row label,.modal-row label{flex:1}.label-picker{display:flex;flex-direction:column;gap:8px}.picker-title{font-size:.85rem;color:var(--muted)}.label-options{display:flex;flex-wrap:wrap;gap:6px}.task-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.label-chip{font-size:.72rem;padding:2px 8px;border-radius:999px;color:#fff;font-weight:600}.label-chip.selectable{border:1px solid;cursor:pointer;background:transparent}.due-chip{font-size:.72rem;padding:2px 8px;border-radius:999px;background:var(--bg);color:var(--muted);border:1px solid var(--border)}.due-chip.overdue{color:#fca5a5;border-color:#7f1d1d}.icon-btn{background:transparent;border:none;color:var(--muted);font-size:1rem;line-height:1;cursor:pointer;padding:0 3px}.icon-btn:hover{color:var(--text)}.icon-btn.delete:hover{color:#fca5a5}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px;width:440px;max-width:92vw;display:flex;flex-direction:column;gap:14px}.modal h2{margin:0;font-size:1.15rem}.modal label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--muted)}.modal input,.modal textarea,.modal select{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:9px 11px;color:var(--text);font-size:.92rem;font-family:inherit}.modal input:focus,.modal textarea:focus,.modal select:focus{outline:none;border-color:var(--accent)}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.modal-actions button:last-child{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:9px 16px;font-weight:600;cursor:pointer}.share-add,.comment-add{display:flex;gap:8px}.share-add input,.comment-add input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 10px;color:var(--text)}.share-add button,.comment-add button{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:8px 14px;cursor:pointer;font-weight:600}.member-list,.comment-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.member-list li{display:flex;align-items:center;justify-content:space-between;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 12px}.member-email{color:var(--muted);font-size:.8rem;margin-left:8px}.member-right{display:flex;align-items:center;gap:8px}.role-tag{font-size:.7rem;padding:2px 8px;border-radius:999px}.role-tag.owner{background:var(--accent);color:#fff}.role-tag.member{background:var(--surface-2);color:var(--muted)}.comments{border-top:1px solid var(--border);margin-top:6px;padding-top:14px}.comments h3{margin:0 0 10px;font-size:1rem}.comment{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 12px}.comment-head{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--muted)}.comment-head strong{color:var(--text)}.comment-time{margin-right:auto}.comment p{margin:4px 0 0;font-size:.9rem}.comment-empty{color:var(--muted);font-size:.85rem;list-style:none}.bell-wrap{position:relative}.bell-badge{background:#ef4444;color:#fff;border-radius:999px;font-size:.7rem;padding:0 6px;margin-left:2px}.bell-panel{position:absolute;right:0;top:36px;width:280px;z-index:60;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;box-shadow:0 12px 30px #00000080}.bell-head{display:flex;justify-content:space-between;font-size:.85rem;color:var(--muted);margin-bottom:8px}.bell-overdue{color:#fca5a5}.bell-empty{color:var(--muted);font-size:.85rem;text-align:center}.bell-panel ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.bell-panel li{display:flex;flex-direction:column;padding:6px 8px;border-radius:6px;background:var(--bg)}.bell-panel li.overdue{border-left:3px solid #ef4444}.bell-title{font-size:.88rem}.bell-meta{font-size:.74rem;color:var(--muted)}.attachments,.comments{border-top:1px solid var(--border);margin-top:6px;padding-top:14px}.attachments h3{margin:0 0 10px;font-size:1rem}.att-list{list-style:none;padding:0;margin:0 0 10px;display:flex;flex-direction:column;gap:6px}.att{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:6px 10px}.att-name{background:none;border:none;color:var(--accent);cursor:pointer;font:inherit;padding:0;text-align:left;flex:1}.att-size{color:var(--muted);font-size:.75rem}.att-empty{color:var(--muted);font-size:.85rem;list-style:none}.att-upload{display:inline-block;cursor:pointer;font-size:.85rem;color:var(--accent);border:1px dashed var(--border);border-radius:8px;padding:8px 12px;text-align:center}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:70;display:flex;justify-content:flex-end}.drawer{width:360px;max-width:90vw;height:100%;background:var(--surface);border-left:1px solid var(--border);padding:20px;overflow-y:auto}.drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.drawer-head h2{margin:0;font-size:1.1rem}.activity-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.activity{border-left:2px solid var(--accent);padding-left:10px}.activity p{margin:0;font-size:.88rem}.activity-time{font-size:.74rem;color:var(--muted)}.activity-empty{color:var(--muted);font-size:.85rem}.filter-bar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.filter-bar select,.filter-search{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 10px;color:var(--text);font-size:.9rem}.filter-search{flex:1;min-width:180px}.filter-bar select:focus,.filter-search:focus{outline:none;border-color:var(--accent)}.subtask-badge{font-size:.72rem;padding:2px 8px;border-radius:999px;background:var(--bg);color:var(--muted);border:1px solid var(--border)}.subtask-badge.complete{color:#10b981;border-color:#10b981}.checklist{border-top:1px solid var(--border);margin-top:6px;padding-top:14px}.checklist h3{margin:0 0 8px;font-size:1rem;display:flex;gap:8px;align-items:center}.check-count{font-size:.78rem;color:var(--muted)}.check-progress{height:6px;background:var(--bg);border-radius:999px;overflow:hidden;margin-bottom:10px}.check-bar{height:100%;background:#10b981;transition:width .2s}.subtask-list{list-style:none;padding:0;margin:0 0 8px;display:flex;flex-direction:column;gap:4px}.subtask{display:flex;align-items:center;justify-content:space-between}.subtask label{display:flex;align-items:center;gap:8px;font-size:.9rem;cursor:pointer}.subtask label.done{color:var(--muted);text-decoration:line-through}.subtask-add{display:flex;gap:8px}.subtask-add input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:7px 10px;color:var(--text)}.subtask-add button{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:0 14px;cursor:pointer;font-weight:700}.view-toggle{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden}.view-toggle button{background:transparent;color:var(--muted);border:none;padding:6px 12px;cursor:pointer;font-size:.85rem}.view-toggle button.on{background:var(--accent);color:#fff}.presence{display:flex;align-items:center}.avatar{width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:700;margin-left:-6px;border:2px solid var(--surface)}.avatar.more{background:var(--surface-2);color:var(--muted)}.calendar{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px}.cal-head{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:12px}.cal-head h3{margin:0;font-size:1.05rem}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.cal-weekdays{margin-bottom:6px}.cal-weekday{text-align:center;font-size:.75rem;color:var(--muted)}.cal-cell{min-height:90px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:4px}.cal-cell.empty{background:transparent;border:none}.cal-cell.today{border-color:var(--accent)}.cal-day{font-size:.78rem;color:var(--muted)}.cal-tasks{display:flex;flex-direction:column;gap:3px;margin-top:3px}.cal-task{text-align:left;background:var(--surface-2);border:none;border-left:3px solid var(--accent);border-radius:4px;padding:3px 5px;font-size:.72rem;color:var(--text);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-task.done{opacity:.55;text-decoration:line-through}@media (max-width: 860px){.cal-cell{min-height:60px}}.subtask-grip{cursor:grab;color:var(--muted);font-size:.9rem}.subtask-grip:active{cursor:grabbing}.subtask{gap:8px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px}.stat{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px;text-align:center}.stat-value{display:block;font-size:1.5rem;font-weight:700}.stat-label{font-size:.72rem;color:var(--muted)}@media (max-width: 560px){.stats-grid{grid-template-columns:repeat(2,1fr)}}[data-theme=light]{--bg: #f1f5f9;--surface: #ffffff;--surface-2: #f8fafc;--border: #cbd5e1;--text: #0f172a;--muted: #64748b;--accent: #6366f1;--accent-hover: #4f46e5}.recur-badge{font-size:.72rem}.burnup-title{margin:4px 0 8px;font-size:.95rem}.burnup-svg{width:100%;height:auto;background:var(--bg);border:1px solid var(--border);border-radius:8px}.burnup-svg .axis{stroke:var(--border);stroke-width:1}.burnup-svg .axis-label{fill:var(--muted);font-size:9px}.burnup-svg .line-created{stroke:#6366f1;stroke-width:2}.burnup-svg .line-done{stroke:#10b981;stroke-width:2}.burnup-svg .area-done{fill:#10b98126;stroke:none}.burnup-legend{display:flex;gap:16px;justify-content:center;font-size:.78rem;color:var(--muted);margin-top:6px}.burnup-legend i{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:4px}.dot-created{background:#6366f1}.dot-done{background:#10b981}.mention{color:var(--accent);font-weight:600}.mention-picker{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:8px}.mention-chip{background:var(--surface-2);border:1px solid var(--border);color:var(--accent);border-radius:999px;padding:2px 8px;font-size:.75rem;cursor:pointer}.mention-chip:hover{border-color:var(--accent)}.assignee-avatar{width:18px;height:18px;border-radius:50%;background:var(--accent);color:#fff;font-size:.65rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;margin-left:4px}.swimlanes{display:flex;flex-direction:column;gap:18px}.swimlane{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px}.swimlane-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}.swimlane-head h3{margin:0;font-size:1rem}.swimlane-head .count{background:var(--surface-2);color:var(--muted);border-radius:999px;padding:2px 9px;font-size:.8rem}.lang-select{background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:5px 8px;font-size:.8rem}.readonly-note{color:var(--muted);font-size:.9rem;text-align:center}.form-info{color:#10b981;font-size:.85rem;margin:0}.login-links{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}.banner-warn{background:#78350f;color:#fde68a;padding:10px 28px;font-size:.9rem}.banner-warn .link{color:#fde68a;text-decoration:underline}.verify-ok{color:#bbf7d0}.social-login{display:flex;flex-direction:column;gap:8px}.social-sep{text-align:center;color:var(--muted);font-size:.8rem}.social-btn{display:block;text-align:center;text-decoration:none;background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:10px;font-weight:600;font-size:.9rem}.social-btn:hover{border-color:var(--accent)}
