:root{--red: #dc4c3e;--red-dark: #c3392b;--bg-sidebar: #fcfaf8;--bg-hover: #f3f2ef;--border: #f0f0f0;--text: #202020;--text-light: #808080;--text-mid: #555;--p1: #d1453b;--p2: #eb8909;--p3: #246fe0;--p4: #808080}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit;font-size:14px}a{color:inherit;text-decoration:none}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#fff}.auth-card{width:380px;padding:40px}.auth-logo{display:flex;align-items:center;gap:8px;font-size:26px;font-weight:800;color:var(--red);margin-bottom:28px}.auth-logo svg{width:28px;height:28px}.auth-card h1{font-size:22px;margin-bottom:20px}.field{margin-bottom:14px}.field label{display:block;font-weight:600;font-size:13px;margin-bottom:5px}.field input{width:100%;padding:11px 12px;border:1px solid #ddd;border-radius:5px}.field input:focus{outline:none;border-color:#999}.btn-primary{width:100%;background:var(--red);color:#fff;padding:12px;border-radius:5px;font-weight:700;font-size:15px}.btn-primary:hover{background:var(--red-dark)}.btn-primary:disabled{opacity:.6;cursor:default}.auth-switch{margin-top:18px;text-align:center;color:var(--text-light)}.auth-switch button{color:var(--red);font-weight:600}.auth-error{background:#fde8e6;color:#c3392b;padding:10px 12px;border-radius:5px;margin-bottom:14px;font-size:13px}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:280px;background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-top{padding:10px 12px 4px;display:flex;align-items:center;justify-content:space-between}.user-chip{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:5px;cursor:pointer}.user-chip:hover{background:var(--bg-hover)}.user-chip .name{font-weight:700;font-size:14px;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.avatar{width:26px;height:26px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.icon-btn{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-light)}.icon-btn:hover{background:var(--bg-hover)}.add-task-btn{display:flex;align-items:center;gap:8px;padding:6px 12px 10px;color:var(--red);font-weight:600}.add-task-btn .plus{width:22px;height:22px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px}.nav{padding:0 8px;overflow-y:auto;flex:1}.nav-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:6px;color:var(--text-mid);font-weight:500;cursor:pointer;position:relative}.nav-item:hover{background:var(--bg-hover)}.nav-item.active{background:#ffefe5;color:var(--red);font-weight:600}.nav-item .ic{width:20px;display:flex;justify-content:center;flex-shrink:0}.nav-item .label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-item .count{color:var(--text-light);font-size:12px}.dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.section-head{display:flex;align-items:center;justify-content:space-between;padding:16px 10px 4px;color:var(--text-light);font-weight:700;font-size:12px;text-transform:none}.section-head button{color:var(--text-light);opacity:0}.section-head:hover button{opacity:1}.main{flex:1;overflow-y:auto}.content{max-width:800px;margin:0 auto;padding:36px 48px 120px}.view-header{margin-bottom:18px}.view-title{font-size:22px;font-weight:700;display:flex;align-items:center;gap:10px}.view-sub{color:var(--text-light);font-size:13px;margin-top:2px}.shared-badge{font-size:12px;color:var(--text-light);display:inline-flex;align-items:center;gap:4px}.member-avatars{display:flex}.member-avatars .avatar{width:24px;height:24px;border:2px solid var(--bg-sidebar);margin-left:-6px}.header-row{display:flex;align-items:center;justify-content:space-between}.task-list{list-style:none}.task{display:flex;gap:10px;padding:9px 0;border-bottom:1px solid var(--border);align-items:flex-start;position:relative}.task.sub{padding-left:28px}.drag-handle{display:flex;align-items:center;justify-content:center;width:16px;flex-shrink:0;margin-top:3px;color:var(--text-light);cursor:grab;opacity:0;touch-action:none}.task:hover .drag-handle{opacity:1}.drag-handle:active{cursor:grabbing}.sortable-project-row{display:flex;align-items:center}.sortable-project-row .nav-item{flex:1}.proj-drag-handle{display:flex;align-items:center;width:14px;flex-shrink:0;color:var(--text-light);cursor:grab;opacity:0;touch-action:none;margin-left:4px}.sortable-project-row:hover .proj-drag-handle{opacity:1}.ctx-menu{background:#fff;border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 8px 32px #0000002e;min-width:200px;padding:5px;z-index:1000}.ctx-opt{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:8px 10px;border-radius:6px;font-size:14px;cursor:pointer;border:none;background:none;color:var(--text)}.ctx-opt:hover{background:var(--bg-hover)}.ctx-opt svg{width:16px;height:16px;flex-shrink:0;color:var(--text-light)}.ctx-has-sub{justify-content:space-between}.ctx-arrow{color:var(--text-light);font-size:11px;margin-left:auto}.ctx-check{margin-left:auto;color:var(--red)}.ctx-active{color:var(--red);font-weight:600}.ctx-sub{border-left:2px solid var(--border);margin:2px 0 2px 10px;padding-left:4px}.ctx-scroll{max-height:200px;overflow-y:auto}.ctx-sep{border-top:1px solid var(--border);margin:4px 0}.ctx-danger{color:var(--p1)!important}.ctx-danger svg{color:var(--p1)!important}.checkbox{width:18px;height:18px;border-radius:50%;border:1.5px solid #aaa;margin-top:2px;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:background .1s}.checkbox svg{opacity:0;width:11px;height:11px}.checkbox:hover svg{opacity:.5}.checkbox.done{background:gray;border-color:gray}.checkbox.done svg{opacity:1;color:#fff}.checkbox.p1{border-color:var(--p1);background:#fde8e6}.checkbox.p2{border-color:var(--p2);background:#fbf0e0}.checkbox.p3{border-color:var(--p3);background:#e6eefb}.task-body{flex:1;min-width:0;cursor:pointer}.task-content{color:var(--text)}.task.completed .task-content{color:var(--text-light);text-decoration:line-through}.task-desc{color:var(--text-light);font-size:13px;margin-top:1px}.task-meta{display:flex;align-items:center;gap:12px;margin-top:4px;flex-wrap:wrap}.due{font-size:12px;display:inline-flex;align-items:center;gap:4px}.due.overdue{color:var(--p1)}.due.today{color:#058527}.due.future{color:var(--text-light)}.chip{font-size:12px;color:var(--text-light);display:inline-flex;align-items:center;gap:4px}.label-chip{font-size:12px;color:#692fc2;display:inline-flex;align-items:center;gap:3px}.meta-sep{color:var(--text-light)}.task-assignees{display:flex;margin-left:auto}.task-assignees .avatar{width:22px;height:22px;margin-left:-5px;border:2px solid #fff;font-size:10px}.task-actions{display:flex;gap:2px;opacity:0;align-self:flex-start}.task:hover .task-actions{opacity:1}.task-actions button{color:var(--text-light);padding:3px;border-radius:4px}.task-actions button:hover{background:var(--bg-hover);color:var(--text)}.composer{border:1px solid #e0e0e0;border-radius:10px;padding:12px;margin:8px 0 14px;box-shadow:0 1px 3px #0000000d}.composer input.title-input{width:100%;border:none;font-size:15px;font-weight:500}.composer input:focus,.composer textarea:focus{outline:none}.composer textarea.desc-input{width:100%;border:none;resize:none;color:var(--text-mid);margin-top:4px}.composer-tools{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.tool{display:inline-flex;align-items:center;gap:5px;border:1px solid #ddd;border-radius:6px;padding:4px 9px;font-size:13px;color:var(--text-mid);background:#fff}.tool:hover{background:var(--bg-hover)}.tool.active{border-color:var(--red);color:var(--red)}.tool select{border:none;background:none;color:inherit;cursor:pointer}.composer-footer{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}.composer-footer .right{display:flex;gap:8px}.btn{padding:7px 14px;border-radius:5px;font-weight:600;font-size:13px}.btn-gray{background:#f0f0f0;color:var(--text-mid)}.btn-gray:hover{background:#e4e4e4}.btn-red{background:var(--red);color:#fff}.btn-red:hover{background:var(--red-dark)}.btn-red:disabled{opacity:.5;cursor:default}.add-inline{display:flex;align-items:center;gap:8px;color:var(--text-light);padding:8px 0;cursor:pointer;font-weight:500}.add-inline:hover{color:var(--red)}.add-inline .plus-sm{color:var(--red);font-size:18px;width:20px;text-align:center}.add-inline:hover .plus-sm{background:var(--red);color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:16px}.section-block{margin-top:20px}.section-title{font-weight:700;padding:4px 0;border-bottom:1px solid var(--border);margin-bottom:4px}.empty{text-align:center;padding:60px 20px;color:var(--text-light)}.empty h3{color:var(--text);margin-bottom:6px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:flex-start;justify-content:center;padding-top:60px;z-index:100}.modal{background:#fff;border-radius:10px;width:540px;max-width:92vw;max-height:80vh;overflow-y:auto;box-shadow:0 8px 40px #00000040}.modal-sm{width:420px}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.modal-head h2{font-size:16px}.modal-body{padding:18px}.modal-foot{display:flex;justify-content:flex-end;gap:8px;padding:14px 18px;border-top:1px solid var(--border)}.color-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.color-grid button{width:26px;height:26px;border-radius:50%;border:2px solid transparent}.color-grid button.sel{border-color:#333}.detail-content{font-size:18px;font-weight:500}.detail-content.done{text-decoration:line-through;color:var(--text-light)}.detail-section{margin-top:18px}.detail-section h4{font-size:12px;text-transform:uppercase;color:var(--text-light);margin-bottom:8px;letter-spacing:.03em}.comment{display:flex;gap:10px;margin-bottom:12px}.comment .c-body{flex:1}.comment .c-name{font-weight:600;font-size:13px}.comment .c-time{color:var(--text-light);font-size:11px;margin-left:6px}.comment-form{display:flex;gap:8px;margin-top:10px}.comment-form input{flex:1;padding:8px 10px;border:1px solid #ddd;border-radius:6px}.assignee-row{display:flex;align-items:center;gap:8px;padding:6px;border-radius:6px;cursor:pointer}.assignee-row:hover{background:var(--bg-hover)}.assignee-row.sel{background:#ffefe5}.assignee-name{flex:1}.member-line{display:flex;align-items:center;gap:8px;padding:7px 0}.member-line .name{flex:1}.member-line .email{color:var(--text-light);font-size:12px}.tag-owner{font-size:11px;background:#eee;padding:1px 6px;border-radius:4px;color:var(--text-light)}.dropdown{position:relative}.dropdown-menu{position:absolute;top:110%;left:0;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 6px 24px #00000026;min-width:220px;z-index:50;padding:6px;max-height:280px;overflow-y:auto}.dropdown-menu .opt{padding:7px 10px;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:8px;width:100%;text-align:left}.dropdown-menu .opt:hover{background:var(--bg-hover)}.menu-right{left:auto;right:0}.date-input-row{padding:8px 10px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:4px 0;display:flex;gap:8px}.date-field{flex:1;font-size:11px;color:var(--text-light);font-weight:600;display:flex;flex-direction:column;gap:3px}.date-input-row input{width:100%;padding:6px 8px;border:1px solid #ddd;border-radius:6px}.topbar{display:flex;align-items:center;gap:12px;padding:10px 24px;border-bottom:1px solid var(--border);position:sticky;top:0;background:#fff;z-index:10}.search{flex:1;max-width:420px;position:relative}.search input{width:100%;padding:8px 12px 8px 34px;border-radius:6px;border:1px solid transparent;background:var(--bg-hover)}.search input:focus{outline:none;background:#fff;border-color:#ddd}.search svg{position:absolute;left:10px;top:9px;color:var(--text-light)}.workspace-block{margin-top:6px}.ws-head{align-items:center}.ws-title{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--text-mid);text-transform:none;font-size:13px}.ws-logo{width:20px;height:20px;border-radius:5px;object-fit:cover;flex-shrink:0}.ws-logo-fallback{display:inline-flex;align-items:center;justify-content:center;background:var(--red);color:#fff;font-size:10px;font-weight:700}.ws-actions{display:flex;gap:2px;opacity:0}.ws-head:hover .ws-actions{opacity:1}.ws-empty{padding:5px 10px 5px 40px;color:var(--text-light);font-size:13px;cursor:pointer}.ws-empty:hover{color:var(--red)}.add-ws{display:flex;align-items:center;gap:8px;padding:10px;margin-top:14px;color:var(--text-light);font-weight:500;width:100%;border-radius:6px}.add-ws:hover{background:var(--bg-hover);color:var(--text)}.add-ws svg{width:16px;height:16px}.menu-group{padding:6px 10px 2px;font-size:11px;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:.03em}.tabs{display:flex;gap:4px;margin-top:14px;border-bottom:1px solid var(--border)}.tab{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;color:var(--text-light);font-weight:600;border-bottom:2px solid transparent;margin-bottom:-1px}.tab svg{width:16px;height:16px}.tab:hover{color:var(--text)}.tab.active{color:var(--red);border-bottom-color:var(--red)}.tab .count{background:var(--bg-hover);border-radius:9px;padding:0 6px;font-size:11px}.uploader{display:flex;align-items:center;gap:8px;padding:12px;border:1.5px dashed #d0d0d0;border-radius:8px;color:var(--text-light);cursor:pointer;font-weight:500;margin-top:8px}.uploader:hover{border-color:var(--red);color:var(--red);background:#fff8f6}.attachment-list{display:flex;flex-direction:column;gap:8px}.attachment{display:flex;align-items:center;gap:12px;padding:8px;border:1px solid var(--border);border-radius:8px}.att-preview{width:44px;height:44px;border-radius:6px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--bg-hover);flex-shrink:0}.att-preview img{width:100%;height:100%;object-fit:cover}.att-file-icon{color:var(--text-light)}.att-info{flex:1;min-width:0}.att-name{display:block;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.att-name:hover{color:var(--red);text-decoration:underline}.att-meta{font-size:12px;color:var(--text-light)}.att-task{color:var(--p3)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:8px}.stat-card{border:1px solid var(--border);border-radius:10px;padding:16px}.stat-value{font-size:24px;font-weight:800;color:var(--text)}.stat-label{color:var(--text-light);font-size:13px;margin-top:2px}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th{text-align:left;color:var(--text-light);font-weight:600;padding:8px 10px;border-bottom:2px solid var(--border);font-size:12px}.admin-table td{padding:10px;border-bottom:1px solid var(--border);vertical-align:middle}.role-badge{font-size:12px;padding:2px 10px;border-radius:12px;background:var(--bg-hover);color:var(--text-mid);font-weight:600}.role-badge.admin{background:#ffefe5;color:var(--red)}.hamburger{display:none}@media (max-width: 768px){.hamburger{display:flex}.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:200;transform:translate(-100%);transition:transform .25s ease;box-shadow:none}.sidebar.open{transform:translate(0);box-shadow:4px 0 24px #0000002e}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:199}.sidebar-overlay.open{display:block}.content{padding:20px 16px 80px}.topbar{padding:10px 12px;gap:8px}.auth-card{width:100%;max-width:380px;padding:30px 20px}.overlay{padding-top:20px;padding-left:12px;padding-right:12px;align-items:flex-start}.modal{width:100%;max-width:100%;max-height:calc(100vh - 40px)}.composer-tools{gap:6px}.tool{padding:4px 7px;font-size:12px}.task-actions{opacity:1}.admin-table th:nth-child(3),.admin-table td:nth-child(3),.admin-table th:nth-child(4),.admin-table td:nth-child(4){display:none}}.bottom-nav{display:none}@media (max-width: 768px){.sidebar,.hamburger,.sidebar-overlay{display:none!important}.sidebar-drawer{display:flex!important;position:fixed;left:0;top:0;bottom:0;z-index:300;width:280px;transform:translate(-100%);transition:transform .25s ease;box-shadow:none;flex-direction:column;background:var(--bg-sidebar);border-right:1px solid var(--border)}.sidebar-drawer.open{transform:translate(0);box-shadow:4px 0 24px #0003}.drawer-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:299}.drawer-overlay.open{display:block}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:200;background:#fff;border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom)}.bn-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 0;color:var(--text-light);font-size:11px;font-weight:500;cursor:pointer;border:none;background:none}.bn-item svg{width:22px;height:22px}.bn-item.active{color:var(--red)}.bn-add{flex:1;display:flex;align-items:center;justify-content:center;padding:8px 0;cursor:pointer;border:none;background:none}.bn-add-circle{width:44px;height:44px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;line-height:1;margin-bottom:0}.main{padding-bottom:60px}.content{padding:16px 14px 20px}.topbar{padding:10px 14px;gap:8px}.overlay{padding:16px 10px;align-items:flex-start}.modal{width:100%;max-width:100%}.auth-card{width:100%;max-width:380px;padding:28px 18px}.task-actions{opacity:1}.admin-table th:nth-child(3),.admin-table td:nth-child(3),.admin-table th:nth-child(4),.admin-table td:nth-child(4){display:none}}
