:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;color:#213547;background-color:#f5f5f5}*{margin:0;padding:0;box-sizing:border-box}body{min-height:100vh}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:250px;background:#1a1a2e;color:#fff;display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.sidebar-brand{padding:1rem 1rem .75rem;border-bottom:1px solid #2a2a4e;text-align:center}.sidebar-logo{width:100%;max-width:160px;height:auto;filter:brightness(0) invert(1)}.sidebar-nav{display:flex;flex-direction:column;padding:.5rem 0}.sidebar-nav a{display:block;padding:.5rem 1rem;color:#aaa;text-decoration:none;font-size:.85rem}.sidebar-nav a:hover{background:#16213e;color:#fff}.sidebar-nav a.active{background:#16213e;color:#fff;border-left:3px solid #4361ee;padding-left:calc(1rem - 3px)}.nav-badge{float:right;background:#e63946;color:#fff;font-size:.7rem;font-weight:600;line-height:1;padding:.15rem .4rem;border-radius:999px;min-width:1.1rem;text-align:center}.sidebar-divider{border-top:1px solid #2a2a4e;margin:.25rem 0}.sidebar-section{flex:1;overflow-y:auto}.sidebar-section-toggle{display:block;width:100%;text-align:left;background:none;border:none;color:#888;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.6rem 1rem;cursor:pointer}.sidebar-section-toggle:hover{color:#ccc}.sidebar-project-list{padding-bottom:.5rem}.sidebar-project-item{display:block;width:100%;text-align:left;background:none;border:none;color:#aaa;font-size:.82rem;padding:.35rem 1rem .35rem 1.25rem;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-project-item:hover{background:#16213e;color:#fff}.sidebar-project-item.active{color:#fff;background:#16213e;border-left:3px solid #4361ee;padding-left:calc(1.25rem - 3px)}.sidebar-board-list{padding:.15rem 0 .25rem}.sidebar-board-item{display:block;width:100%;text-align:left;background:none;border:none;color:#888;font-size:.78rem;padding:.25rem 1rem .25rem 2rem;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-board-item:hover{background:#16213e;color:#ccc}.sidebar-board-item.active{color:#4361ee;background:#0f1529}.sidebar-empty{color:#555;font-size:.8rem;padding:.5rem 1.25rem}.sidebar-user{padding:.75rem 1rem;font-size:.8rem;color:#999;border-top:1px solid #2a2a4e;margin-top:auto}.btn-logout{background:transparent;color:#999;border:1px solid #555;font-size:.75rem;padding:.25rem .5rem;border-radius:4px;margin-top:.4rem}.btn-logout:hover{color:#fff;border-color:#999}.main-content{flex:1;padding:1.5rem 2rem;overflow-y:auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-header h1{font-size:1.5rem}table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}th,td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #eee}th{background:#f8f9fa;font-weight:600;font-size:.85rem;text-transform:uppercase;color:#666}button{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.btn-primary{background:#4361ee;color:#fff}.btn-primary:hover{background:#3a56d4}.btn-danger{background:#e63946;color:#fff}.btn-danger:hover{background:#c1121f}.btn-sm{padding:.3rem .6rem;font-size:.8rem}.status-badge{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600}.status-New{background:#e3f2fd;color:#1565c0}.status-Active,.status-InProgress{background:#e8f5e9;color:#2e7d32}.status-OnHold,.status-InReview{background:#fff3e0;color:#e65100}.status-Completed{background:#e0f2f1;color:#00695c}.status-Cancelled{background:#fce4ec;color:#c62828}.priority-Low{color:#666}.priority-Normal{color:#1565c0}.priority-High{color:#e65100}.priority-Critical{color:#c62828;font-weight:700}.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background:#1a1a2e}.login-form{background:#fff;padding:2rem;border-radius:8px;width:360px;box-shadow:0 4px 12px #0000004d}.login-form h2{margin-bottom:1.5rem;text-align:center}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.3rem;font-size:.85rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:4px;font-size:.9rem}.error-message{color:#c62828;font-size:.85rem;margin-bottom:1rem}.inline-form{background:#fff;padding:1.25rem;border-radius:8px;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.kanban-page{display:flex;flex-direction:column;height:100%}.kanban-board{display:flex;gap:.75rem;overflow-x:auto;align-items:flex-start;flex:1;min-height:0}.kanban-column{min-width:260px;flex:1;background:#f0f0f0;border-radius:8px;display:flex;flex-direction:column;transition:background .15s;border:2px solid transparent;max-height:100%}.kanban-column-over{background:#e3f2fd;border-color:#4361ee}.kanban-column-header{display:flex;align-items:center;gap:.5rem;padding:.75rem .75rem .5rem}.kanban-column-header h3{font-size:.85rem;color:#555;flex:1;margin:0}.kanban-column-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.kanban-column-count{background:#ddd;color:#555;font-size:.75rem;font-weight:600;padding:.1rem .5rem;border-radius:10px}.kanban-column-body{padding:0 .75rem .75rem;flex:1;min-height:60px;overflow-y:auto}.kanban-card{background:#fff;padding:.75rem;border-radius:6px;margin-bottom:.5rem;box-shadow:0 1px 2px #0000001a;cursor:grab;transition:box-shadow .15s,opacity .15s}.kanban-card:hover{box-shadow:0 3px 8px #00000026}.kanban-card:active{cursor:grabbing}.kanban-card-selected{outline:2px solid #4361ee;outline-offset:-2px;background:#eef1ff}.kanban-card-dragging{opacity:.4}.kanban-card h4{font-size:.85rem;margin-bottom:.3rem}.kanban-card-desc{font-size:.75rem;color:#777;margin-bottom:.35rem;white-space:pre-wrap;overflow-wrap:anywhere;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:5;line-clamp:5}.kanban-card-footer{display:flex;align-items:center;gap:.5rem;margin-top:.45rem;font-size:.75rem;color:#555}.kanban-priority{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;font-size:.9rem;font-weight:700;line-height:1;cursor:help;flex-shrink:0}.kanban-card-assignee{display:flex;align-items:center;gap:.4rem;min-width:0;flex:1}.kanban-card-assignee-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kanban-avatar{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#4361ee;color:#fff;font-size:.62rem;font-weight:700;flex-shrink:0;line-height:1}.kanban-filterbar{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;margin-bottom:.85rem}.kanban-filter-label{font-size:.8rem;color:#777;margin-right:.25rem}.kanban-filter-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .6rem;border:1px solid #ccc;border-radius:14px;background:#fff;color:#555;font-size:.78rem;cursor:pointer;transition:background .12s,border-color .12s,color .12s}.kanban-filter-chip:hover{border-color:#4361ee}.kanban-filter-chip.active{background:#4361ee;border-color:#4361ee;color:#fff}.kanban-filter-chip.active .kanban-avatar{background:#fff;color:#4361ee}.kanban-empty{color:#bbb;font-size:.8rem;text-align:center;padding:2rem .5rem;border:2px dashed #ddd;border-radius:6px}.kanban-drop-line{height:3px;background:#4361ee;border-radius:2px;margin:2px 0;box-shadow:0 0 4px #4361ee80}.toast-container{position:fixed;top:60px;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;max-width:480px}.toast-error{background:#c62828;color:#fff;padding:.75rem 1rem;border-radius:6px;box-shadow:0 4px 12px #0000004d;display:flex;align-items:flex-start;gap:.75rem;animation:toast-in .2s ease-out}.toast-message{flex:1;font-size:.85rem;word-break:break-word}.toast-close{background:none;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:0;line-height:1;opacity:.7}.toast-close:hover{opacity:1}@keyframes toast-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;justify-content:center;align-items:flex-start;padding-top:5vh;z-index:5000;overflow-y:auto}.modal-content{background:#fff;border-radius:8px;width:640px;max-width:95vw;box-shadow:0 8px 32px #0000004d;animation:modal-in .15s ease-out}@keyframes modal-in{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #eee}.modal-header h2{font-size:1.1rem;margin:0}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#999;padding:0;line-height:1}.modal-close:hover{color:#333}.modal-body{padding:1.25rem}.modal-footer{display:flex;gap:.5rem;padding:1rem 1.25rem;border-top:1px solid #eee}.btn-secondary{background:#e0e0e0;color:#333}.btn-secondary:hover{background:#d0d0d0}.task-link{color:#4361ee;text-decoration:none;cursor:pointer}.task-link:hover{text-decoration:underline}.context-menu{background:#fff;border-radius:6px;box-shadow:0 4px 16px #0003;min-width:160px;padding:.3rem 0;animation:modal-in .1s ease-out}.context-menu-header{padding:.4rem 1rem;font-size:.75rem;font-weight:600;color:#4361ee;border-bottom:1px solid #eee;margin-bottom:.2rem}.context-menu-item{display:block;width:100%;text-align:left;background:none;border:none;padding:.5rem 1rem;font-size:.85rem;cursor:pointer;color:#333}.context-menu-item:hover{background:#f0f0f0}.context-menu-danger{color:#c62828}.context-menu-danger:hover{background:#fce4ec}.context-menu-divider{border-top:1px solid #eee;margin:.2rem 0}.context-menu-submenu{position:relative;cursor:default}.context-submenu{position:absolute;left:100%;top:-.3rem;background:#fff;border-radius:6px;box-shadow:0 4px 16px #0003;min-width:180px;padding:.3rem 0;z-index:6001}.context-submenu-left{left:auto;right:100%}.task-comments{margin-top:1.5rem}.task-comments-title{font-size:1rem;margin-bottom:.75rem}.task-comments-empty{color:#999;font-size:.85rem}.comment-list{list-style:none;padding:0;margin:0 0 1rem;display:flex;flex-direction:column;gap:.75rem}.comment-item{border:1px solid #e6e6e6;border-radius:6px;padding:.6rem .8rem;background:#fafafa}.comment-head{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.comment-author{font-weight:600;font-size:.85rem;color:#333}.comment-date{font-size:.75rem;color:#999}.comment-del{margin-left:auto;background:none;border:none;color:#bbb;font-size:1rem;line-height:1;cursor:pointer;padding:0 .2rem}.comment-del:hover{color:#e63946}.comment-body.ql-snow{border:none}.comment-body .ql-editor{padding:0;font-size:.9rem;color:#222}.comment-atts{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.comment-att-img{max-width:220px;max-height:220px;border-radius:4px;border:1px solid #ddd;display:block;object-fit:cover}.comment-att-loading{width:120px;height:80px;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#999;border:1px dashed #ccc;border-radius:4px}.comment-att-file{background:#eef1ff;border:1px solid #c9d2ff;color:#3a56d4;border-radius:4px;padding:.3rem .6rem;font-size:.8rem;cursor:pointer}.comment-att-file:hover{background:#e0e6ff}.comment-att-size{color:#999}.comment-editor-loading{min-height:122px;display:flex;align-items:center;justify-content:center;border:1px solid #ccc;border-radius:4px;font-size:.85rem;color:#999}.comment-composer .ql-container{min-height:90px;font-size:.9rem}.comment-composer .ql-editor{min-height:90px}.comment-dropzone{margin-top:.5rem;border:1px dashed #c4c4c4;border-radius:6px;padding:.6rem;text-align:center;font-size:.8rem;color:#888;cursor:pointer}.comment-dropzone.dragover{border-color:#4361ee;background:#eef1ff;color:#3a56d4}.comment-pending{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:.25rem}.comment-pending li{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:#555}.comment-pending li button{background:none;border:none;color:#bbb;cursor:pointer;font-size:.9rem;line-height:1}.comment-pending li button:hover{color:#e63946}.comment-actions{margin-top:.75rem;display:flex;justify-content:flex-end}.badge{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.72rem;font-weight:600}.badge-ok{background:#e3f4e9;color:#1e7c3a}.badge-pending{background:#fff3e0;color:#b25800}.project-checklist{display:flex;flex-direction:column;gap:.35rem;max-height:260px;overflow-y:auto;border:1px solid #e0e0e0;border-radius:6px;padding:.6rem .8rem}.project-checklist-item{display:flex;align-items:center;gap:.5rem;font-size:.88rem;cursor:pointer}.users-filterbar{display:flex;align-items:center;gap:1rem;margin-bottom:.85rem}.users-filter-toggle{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:#555;cursor:pointer}.kanban-zoom{display:flex;align-items:center;gap:.5rem;margin-left:auto}.kanban-zoom-label{font-size:.8rem;color:#777}.kanban-zoom input[type=range]{width:140px;cursor:pointer}.kanban-zoom-pct{font-size:.8rem;color:#555;min-width:2.6rem;text-align:right}.kanban-toggle{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:#555;cursor:pointer;-webkit-user-select:none;user-select:none}.keyword-filter{margin-left:auto;width:220px;padding:.4rem .7rem;border:1px solid #ccc;border-radius:16px;background:#fff;font-size:.85rem;outline:none;transition:border-color .12s,box-shadow .12s}.keyword-filter:focus{border-color:#4361ee;box-shadow:0 0 0 2px #4361ee2e}.kw-hit{background:#ffe27a;color:inherit;border-radius:2px;padding:0 1px}.board-chips{display:flex;flex-wrap:wrap;gap:.25rem}.board-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.12rem .5rem;border:1px solid #d0d7e2;border-radius:10px;background:#f4f6fb;color:#445;font-size:.72rem;white-space:nowrap}.board-chip-link{cursor:pointer;transition:background .12s,border-color .12s}.board-chip-link:hover{background:#e6edff;border-color:#4361ee;color:#1a2b6b}.board-chip-sep{color:#99a}.kanban-zoom+.keyword-filter,.keyword-filter+.kanban-zoom{margin-left:.75rem}.chat-page{display:flex;flex-direction:column;height:calc(100vh - 3rem)}.chat-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;flex-shrink:0}.chat-header h1{font-size:1.4rem}.chat-status{font-size:.75rem;padding:.15rem .5rem;border-radius:999px}.chat-status.online{color:#1a7f37;background:#e7f6ea}.chat-status.offline{color:#9a6700;background:#fff3d6}.chat-messages{flex:1;overflow-y:auto;background:#fff;border:1px solid #e3e3e3;border-radius:8px;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.chat-empty{color:#999;font-size:.85rem;margin:auto}.chat-msg{display:flex;justify-content:flex-start}.chat-msg.mine{justify-content:flex-end}.chat-bubble{max-width:70%;background:#f0f1f5;border-radius:10px;padding:.45rem .65rem}.chat-msg.mine .chat-bubble{background:#4361ee;color:#fff}.chat-author{font-size:.72rem;font-weight:600;color:#4361ee;margin-bottom:.15rem}.chat-body{font-size:.9rem;white-space:pre-wrap;word-break:break-word}.chat-meta{display:flex;align-items:center;gap:.4rem;justify-content:flex-end;font-size:.68rem;opacity:.7;margin-top:.2rem}.chat-del{background:none;border:none;color:inherit;cursor:pointer;font-size:.85rem;line-height:1;padding:0;opacity:.6}.chat-del:hover{opacity:1}.chat-composer{display:flex;gap:.5rem;align-items:flex-end;margin-top:.75rem;flex-shrink:0}.chat-composer textarea{flex:1;resize:none;padding:.55rem .7rem;border:1px solid #c4c4c4;border-radius:6px;font-family:inherit;font-size:.9rem}.chat-composer .btn-primary{height:fit-content}
