*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:14px;color:#1e293b;background:#f1f5f9}.shell{display:flex;flex-direction:column;height:100%}.main{flex:1;overflow:auto;display:flex;flex-direction:column}.topnav{display:flex;align-items:center;gap:4px;background:#0f172a;color:#e2e8f0;padding:0 16px;height:48px;flex-shrink:0}.topnav a{color:#94a3b8;text-decoration:none;padding:6px 12px;border-radius:6px;font-weight:500}.topnav a:hover{color:#fff;background:#ffffff14}.topnav a.active{color:#fff;background:#ffffff24}.topnav .btn.ghost{color:#94a3b8}.topnav .btn.ghost:hover{color:#fff;background:#ffffff14}.nav-user{margin:0 8px 0 4px;color:#cbd5e1}.spacer{flex:1}.sep{width:1px;height:20px;background:#cbd5e1;margin:0 6px}.page{padding:20px 28px;max-width:1100px;width:100%;margin:0 auto}.page-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.page-header h1{margin:0;font-size:20px}.page-center{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:8px;color:#64748b}.muted{color:#64748b}.error{color:#dc2626;font-size:13px}.badge{background:#8b5cf6;color:#fff;font-size:10px;padding:2px 6px;border-radius:8px;margin-left:8px;vertical-align:middle}.muted-badge{background:#94a3b8}.btn{border:1px solid #cbd5e1;background:#fff;color:#1e293b;border-radius:6px;padding:6px 12px;cursor:pointer;font-size:13px;font-weight:500;white-space:nowrap}.btn:hover{background:#f8fafc;border-color:#94a3b8}.btn.primary{background:#4f46e5;border-color:#4f46e5;color:#fff}.btn.primary:hover{background:#4338ca}.btn.ghost{border-color:transparent;background:transparent}.btn.ghost:hover{background:#e2e8f0}.btn.ghost.active{background:#e0e7ff;color:#4f46e5}.btn.wide{width:100%}.btn.danger-outline{border-color:#fca5a5;color:#dc2626;margin-top:12px}.btn.danger-outline:hover{background:#fef2f2}.btn:disabled{opacity:.6;cursor:default}.btn-icon{border:none;background:transparent;cursor:pointer;padding:2px 6px;border-radius:4px;color:#64748b;font-size:13px}.btn-icon:hover{background:#e2e8f0;color:#1e293b}.btn-icon.danger:hover{background:#fee2e2;color:#dc2626}input,select,textarea{font:inherit;border:1px solid #cbd5e1;border-radius:6px;padding:6px 8px;background:#fff;color:inherit}input:focus,select:focus,textarea:focus{outline:2px solid #c7d2fe;border-color:#818cf8}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;font-weight:500;font-size:13px}.field-label{font-weight:500;font-size:13px;margin-bottom:6px}.field-row{display:flex;gap:12px}.field-row label{display:flex;flex-direction:column;gap:4px;font-size:13px;font-weight:500;flex:1;margin-bottom:12px}.field-inline{display:flex;align-items:center;gap:6px;font-size:13px}.check-inline{display:flex;align-items:center;gap:6px;font-size:13px;color:#64748b}.login-wrap{display:flex;align-items:center;justify-content:center;height:100%;background:linear-gradient(135deg,#0f172a,#312e81)}.login-card{background:#fff;border-radius:12px;padding:32px;width:340px;box-shadow:0 20px 60px #0000004d}.login-logo{font-size:22px;font-weight:700;margin-bottom:20px;color:#0f172a}.login-logo span{color:#4f46e5}.login-logo.sm{font-size:15px;margin:0 16px 0 0;color:#fff}.folder-block{margin:6px 0}.folder-head{display:flex;align-items:center;gap:8px;padding:8px 10px;font-weight:600;border-radius:8px}.folder-head:hover{background:#e2e8f0}.folder-actions{display:none;gap:2px}.folder-head:hover .folder-actions{display:inline-flex}.proj-row{display:flex;align-items:center;gap:10px;padding:10px 12px;margin:4px 0 4px 24px;background:#fff;border:1px solid #e2e8f0;border-radius:8px}.proj-row:hover{border-color:#a5b4fc;box-shadow:0 1px 4px #4f46e514}.proj-dot{width:10px;height:10px;border-radius:3px;display:inline-block;flex-shrink:0}.proj-name{font-weight:600;color:#1e293b;text-decoration:none}.proj-name:hover{color:#4f46e5}.proj-meta{font-size:12px}.proj-progress{flex:1;max-width:140px;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}.proj-progress div{height:100%;background:#4f46e5}.proj-actions{display:flex;align-items:center;gap:4px;margin-left:auto}.proj-actions select{font-size:12px;padding:3px 4px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:100}.dialog{background:#fff;border-radius:12px;padding:24px;width:440px;max-height:80vh;overflow:auto;box-shadow:0 20px 60px #0000004d}.dialog h2{margin:0 0 12px;font-size:17px}.dialog h3{margin:16px 0 8px;font-size:14px;color:#475569}.dialog-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.share-row{display:flex;align-items:center;justify-content:space-between;padding:5px 0}.table{border-collapse:collapse;width:100%;background:#fff;border-radius:8px;overflow:hidden}.table th,.table td{text-align:left;padding:8px 10px;border-bottom:1px solid #e2e8f0}.table th{background:#f8fafc;font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:#64748b}.table tr.inactive td{opacity:.45}.table-scroll{overflow-x:auto}.workload .total-col{background:#f8fafc}.totals-row td{border-top:2px solid #cbd5e1}.admin-grid{display:grid;grid-template-columns:3fr 2fr;gap:32px;max-width:1300px}.admin-grid h1{font-size:18px}.user-form{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}.user-form input{flex:1;min-width:110px}.group-toolbar{margin-bottom:8px}.group-row{display:flex;align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin:4px 0;padding:4px 8px}.group-row.active{border-color:#818cf8}.group-name{flex:1;text-align:left;border:none;background:none;cursor:pointer;font:inherit;font-weight:600;padding:6px}.group-members{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:12px;margin-top:8px}.group-members h3{margin:0 0 8px;font-size:13px}.avatar{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;color:#fff;font-size:7px;font-weight:700;flex-shrink:0;border:1px solid #fff}.avatar.sm{width:20px;height:20px;font-size:8px;vertical-align:middle}.avatar.more{background:#94a3b8}.gantt-page{display:flex;flex-direction:column;height:100%;overflow:hidden}.toolbar{display:flex;align-items:center;gap:4px;padding:6px 10px;background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;scrollbar-width:thin}.toolbar>*{flex-shrink:0}.toolbar .btn{padding:5px 9px;font-size:12px}.toolbar .check-inline{white-space:nowrap;font-size:12px}.toolbar-title{font-size:14px;margin:0 4px;font-weight:600;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.seg{display:inline-flex;border:1px solid #cbd5e1;border-radius:7px;overflow:hidden}.seg button{border:none;background:#fff;padding:5px 10px;cursor:pointer;font-size:12px;color:#475569;font-weight:500}.seg button+button{border-left:1px solid #e2e8f0}.seg button:hover:not(:disabled){background:#f1f5f9}.seg button.active{background:#4f46e5;color:#fff}.seg button:disabled{color:#cbd5e1;cursor:default}.hover-col{position:absolute;top:0;bottom:0;background:#4f46e50f;pointer-events:none;z-index:1}.hover-row{position:absolute;left:0;right:0;background:#4f46e50d;pointer-events:none;z-index:1}.wl-hover-col{position:absolute;top:0;bottom:0;z-index:2}.wl-row:hover{background:#4f46e50d}.gantt{flex:1;display:flex;overflow:hidden;background:#fff}.gantt-left{flex-shrink:0;border-right:2px solid #cbd5e1;display:flex;flex-direction:column}.gantt-left-header,.grow{display:flex;align-items:stretch}.gantt-left-header{border-bottom:1px solid #e2e8f0;background:#f8fafc;font-size:10px;text-transform:uppercase;letter-spacing:.03em;color:#64748b;align-items:flex-end;padding-bottom:4px;flex-shrink:0}.gantt-left-body{position:relative;flex:1;overflow:hidden}.grow{position:absolute;left:0;right:0;border-bottom:1px solid #f1f5f9;cursor:pointer;background:#fff;font-size:12px}.grow:hover{background:#f8fafc}.grow.selected{background:#eef2ff}.grow.is-group{background:#f8fafc;font-weight:600}.grow.is-group.selected{background:#eef2ff}.gcell{display:flex;align-items:center;padding:0 4px;overflow:hidden;flex-shrink:0}.gc-name{flex:1;min-width:0;gap:3px}.gc-people{width:62px}.gc-people .avatar{margin-left:-5px}.gc-people .avatar:first-child{margin-left:0}.gc-date{width:52px;font-size:11px;color:#475569}.gc-hours{width:44px;font-size:11px;color:#475569;justify-content:flex-end}.gc-pct{width:38px;font-size:11px;color:#475569;justify-content:flex-end;padding-right:6px}.gc-pct input[type=checkbox]{width:12px;height:12px}.name-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.name-input{flex:1;min-width:0;padding:1px 3px;font-size:12px}.caret{border:none;background:none;cursor:pointer;width:14px;padding:0;color:#64748b;font-size:10px}.type-dot{width:6px;height:6px;border-radius:50%;background:#94a3b8;flex-shrink:0;margin-right:2px}.type-dot.milestone{transform:rotate(45deg);border-radius:1px;background:#f59e0b}.type-dot.group{background:#475569;border-radius:2px}.gantt-right{flex:1;overflow:auto;position:relative}.gantt-timeline-header{position:sticky;top:0;z-index:6;background:#f8fafc;border-bottom:1px solid #e2e8f0}.month-cell{position:absolute;top:0;height:18px;display:flex;align-items:center;padding-left:6px;font-size:11px;font-weight:600;color:#334155;border-left:1px solid #e2e8f0;overflow:hidden;white-space:nowrap}.day-cell{position:absolute;top:18px;height:26px;display:flex;align-items:center;justify-content:center;font-size:10px;color:#94a3b8;border-left:1px solid #f1f5f9;overflow:hidden}.day-cell.two{flex-direction:column;justify-content:center;line-height:1.1;gap:0}.day-cell.two span{font-size:9.5px;color:#64748b}.day-cell.two .dl{font-size:8px;color:#b6c2d1}.gantt-rows{overflow:hidden}.weekend{position:absolute;top:0;bottom:0;background:#f1f5f9}.today-line{position:absolute;top:0;bottom:0;width:2px;background:#ef4444;z-index:1}.row-stripe{position:absolute;left:0;right:0;border-bottom:1px solid #f1f5f9}.row-stripe.is-group{background:#f1f5f999}.bar{position:absolute;z-index:2;border-radius:3px;cursor:grab;touch-action:none}.bar:active{cursor:grabbing}.task-bar{height:12px;box-shadow:0 1px 1px #00000026}.task-bar.selected{outline:2px solid #4f46e5;outline-offset:1px}.bar-progress{height:100%;background:#ffffff59;border-radius:3px 0 0 3px;pointer-events:none}.bar-handle{position:absolute;top:0;bottom:0;width:6px;cursor:ew-resize}.bar-handle.left{left:-2px}.bar-handle.right{right:-2px}.bar-link{position:absolute;top:50%;margin-top:-4px;width:8px;height:8px;border-radius:50%;background:#fff;border:2px solid #4f46e5;cursor:crosshair;opacity:0;z-index:3}.bar-link.right{right:-11px}.bar-link.left{left:-11px}.bar-link.ms-left{left:-13px;top:50%;transform:rotate(-45deg)}.bar-link.ms-right{right:-13px;top:50%;transform:rotate(-45deg)}.bar:hover .bar-link{opacity:1}.group-bar{height:7px;background:#475569;border-radius:2px}.group-bar:before,.group-bar:after{content:"";position:absolute;bottom:-4px;border:4px solid transparent;border-top-color:#475569}.group-bar:before{left:0}.group-bar:after{right:0}.group-bar.selected{outline:2px solid #4f46e5;outline-offset:1px}.milestone{width:12px;height:12px;transform:rotate(45deg);border-radius:2px;box-shadow:0 1px 1px #0003}.milestone.selected{outline:2px solid #4f46e5}.bar-label{position:absolute;z-index:2;font-size:9.5px;color:#64748b;white-space:nowrap;pointer-events:none;line-height:14px}.dep-layer{position:absolute;top:0;left:0;pointer-events:none;z-index:3}.dep-path{fill:none;stroke:#f43f5e;stroke-width:1.5;opacity:.75}.dep-temp{fill:none;stroke:#4f46e5;stroke-width:1.5;stroke-dasharray:4 3}.grow.is-project{background:#eef2f7;font-weight:700;border-bottom:1px solid #cbd5e1}.grow.is-project.selected{background:#e0e7ff}.grow.is-project .gc-name{font-size:13.5px}.project-bar{height:14px;opacity:.85}.project-bar:before,.project-bar:after{border-top-color:inherit;display:none}.grip{cursor:grab;color:#cbd5e1;font-size:11px;width:14px;flex-shrink:0;opacity:0;-webkit-user-select:none;user-select:none;touch-action:none}.grow:hover .grip{opacity:1}.grip:hover{color:#64748b}.name-label{touch-action:none}.drop-line{position:absolute;left:0;right:0;height:2px;background:#4f46e5;z-index:20;pointer-events:none}.drop-line:before{content:"";position:absolute;left:0;top:-3px;width:8px;height:8px;border-radius:50%;background:#4f46e5}.drop-inside{position:absolute;left:0;right:0;border:2px solid #4f46e5;border-radius:4px;background:#4f46e514;z-index:20;pointer-events:none}.drag-ghost{position:absolute;bottom:8px;left:8px;background:#0f172a;color:#fff;padding:4px 10px;border-radius:6px;font-size:12px;z-index:30;pointer-events:none;max-width:80%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:.9}.multi-panel{position:fixed;bottom:16px;left:50%;transform:translate(-50%);z-index:80;background:#fff;border:1px solid #cbd5e1;border-radius:12px;box-shadow:0 12px 40px #0f172a40;max-width:95vw}.multi-bar{display:flex;align-items:center;gap:10px;padding:8px 14px}.multi-body{display:flex;align-items:center;gap:14px;padding:10px 14px;border-top:1px solid #e2e8f0;flex-wrap:wrap;max-width:900px}.multi-open-bar{position:fixed;bottom:16px;left:50%;transform:translate(-50%);z-index:80;background:#fff;border:1px solid #cbd5e1;border-radius:12px;box-shadow:0 12px 40px #0f172a40;display:flex;align-items:center;gap:12px;padding:10px 16px}.proj-row>input[type=checkbox]{flex-shrink:0}.grow,.gantt-rows,.bar-label,.gantt-left-header,.wl-grid,.proj-nav,.month-cell,.day-cell{user-select:none;-webkit-user-select:none}.grow input,.name-input{user-select:text;-webkit-user-select:text}.v-splitter{width:5px;cursor:col-resize;background:#cbd5e1;flex-shrink:0;touch-action:none}.v-splitter:hover{background:#818cf8}.h-splitter{height:5px;cursor:row-resize;background:#cbd5e1;flex-shrink:0;touch-action:none}.h-splitter:hover{background:#818cf8}.gantt-left{border-right:none!important}.proj-nav{position:absolute;right:12px;top:100px;z-index:40;display:flex;flex-direction:column;gap:2px;background:#fffffff5;border:1px solid #cbd5e1;border-radius:10px;padding:6px;box-shadow:0 8px 24px #0f172a1f;max-width:200px;max-height:60vh;overflow-y:auto}.proj-nav-item{display:flex;align-items:center;border-radius:6px;color:#334155}.proj-nav-item:hover{background:#eef2ff}.proj-nav-item.active{background:#e0e7ff}.proj-nav-item.active .proj-nav-name{font-weight:600}.proj-nav-go{display:flex;align-items:center;gap:6px;border:none;background:none;cursor:pointer;padding:4px 6px 4px 8px;font-size:11.5px;text-align:left;color:inherit;flex:1;min-width:0}.proj-nav-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.proj-nav-close{border:none;background:none;cursor:pointer;color:#cbd5e1;font-size:10px;padding:4px 8px 4px 4px;flex-shrink:0;opacity:0}.proj-nav-item:hover .proj-nav-close{opacity:1}.proj-nav-close:hover{color:#dc2626}.row-del{border:none;background:none;cursor:pointer;color:#cbd5e1;font-size:10px;padding:0 4px;margin-left:auto;flex-shrink:0;opacity:0}.grow:hover .row-del{opacity:1}.row-del:hover{color:#dc2626}.assign-warning{background:#fef3c7;border:1px solid #fcd34d;border-radius:6px;padding:8px;font-size:12px;margin-top:6px;display:flex;flex-direction:column;gap:6px}.ua-missing{color:#dc2626;font-weight:600;font-size:12px;white-space:nowrap}.cap-grid{display:flex;gap:8px}.cap-day{display:flex;flex-direction:column;gap:4px;font-size:12px;font-weight:600;text-align:center}.cap-day input{width:52px;text-align:center}.save-indicator{display:inline-flex;align-items:center;gap:6px;font-size:11px;white-space:nowrap}.save-indicator.ok{color:#16a34a}.save-indicator.saving{color:#f59e0b}.save-indicator.error{color:#dc2626;font-weight:600;max-width:420px;overflow:hidden}.save-indicator.error .btn{padding:2px 8px;font-size:11px}.history-list{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:12px}.hist-row{display:flex;align-items:center;gap:10px;padding:6px 12px;border-bottom:1px solid #f1f5f9;font-size:13px}.hist-badge{font-size:10px;padding:2px 7px;border-radius:8px;background:#e2e8f0;color:#475569;white-space:nowrap}.hist-badge.a-item-create{background:#dcfce7;color:#15803d}.hist-badge.a-item-delete{background:#fee2e2;color:#b91c1c}.hist-badge.a-item-update{background:#dbeafe;color:#1d4ed8}.hist-badge.a-dep-add,.hist-badge.a-dep-remove{background:#fce7f3;color:#be185d}.hist-badge.a-assign-set{background:#fef3c7;color:#b45309}.hist-item{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:340px}.log-when{font-size:11px;white-space:nowrap;width:100px;flex-shrink:0}.log-detail{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.log-action{font-weight:600;font-size:12px;white-space:nowrap}.log-row{display:flex;align-items:baseline;gap:6px;overflow:hidden;flex:1;min-width:0;flex-wrap:wrap}.log-entry{display:flex;align-items:flex-start;gap:6px;padding:4px 0;border-bottom:1px solid #f1f5f9}.item-history{max-height:240px;overflow-y:auto;font-size:12px}.day-detail{width:620px}.dd-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}.dd-header h2{margin:0;font-size:17px}.dd-avatar{width:40px;height:40px;font-size:14px}.dd-date{text-transform:capitalize;font-size:13px}.dd-stats{display:flex;gap:18px}.dd-stat{display:flex;flex-direction:column;align-items:center}.dd-stat strong{font-size:16px}.dd-stat span{font-size:11px;color:#64748b}.dd-body{max-height:50vh;overflow-y:auto}.dd-project{margin-bottom:12px}.dd-proj-head{display:flex;align-items:center;gap:8px;padding:6px 8px;background:#f8fafc;border-radius:6px;margin-bottom:2px;font-size:13px}.dd-row{display:flex;align-items:center;gap:8px;padding:5px 8px;border-bottom:1px solid #f1f5f9}.dd-filter{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 4px;border-bottom:1px solid #f1f5f9;font-size:13px;cursor:pointer}.ddt-row{position:relative;display:flex;align-items:center;gap:8px;padding:4px 8px;margin:3px 0;border:1px solid transparent;border-radius:6px;overflow:hidden}.ddt-row>*{position:relative;z-index:1}.ddt-fill{position:absolute;left:0;top:0;bottom:0;z-index:0!important;border-radius:5px 0 0 5px}.ddt-row.complete{background:#f8fafc;border-color:#e2e8f0}.ddt-row.complete .dd-name{color:#94a3b8;text-decoration:line-through}.ddt-row.complete .dd-hours{color:#cbd5e1}.dd-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;background:none;border:none;text-align:left;cursor:pointer;color:#1e293b;padding:2px 0;font-family:inherit}.dd-name:hover{color:#4f46e5;text-decoration:underline}.dd-hours{color:#64748b;font-size:12px;white-space:nowrap}.dd-pct{width:58px;padding:3px 6px;font-size:12px}.wl-cell{cursor:pointer}.weekend.holiday{background:#fef3c7}.tabs{display:flex;border:1px solid #cbd5e1;border-radius:8px;overflow:hidden}.tab{border:none;background:#fff;padding:6px 14px;cursor:pointer;font-size:13px;font-weight:500;color:#475569}.tab+.tab{border-left:1px solid #cbd5e1}.tab.active{background:#4f46e5;color:#fff}.star{border:none;background:none;cursor:pointer;font-size:17px;color:#cbd5e1;padding:0 2px;line-height:1;flex-shrink:0}.star:hover,.star.active{color:#f59e0b}.holidays-section{margin-top:28px}.holidays-section h1{font-size:18px}.ctx-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200}.ctx-menu{position:fixed;background:#fff;border:1px solid #cbd5e1;border-radius:10px;box-shadow:0 12px 40px #0f172a38;padding:5px;min-width:220px}.ctx-title{font-size:11px;color:#94a3b8;padding:4px 10px 6px;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-bottom:1px solid #f1f5f9;margin-bottom:3px}.ctx-menu button{display:block;width:100%;text-align:left;border:none;background:none;cursor:pointer;padding:6px 10px;font-size:13px;color:#1e293b;border-radius:6px;font-family:inherit}.ctx-menu button:hover{background:#eef2ff;color:#4f46e5}.ctx-menu button.danger{color:#dc2626}.ctx-menu button.danger:hover{background:#fee2e2;color:#b91c1c}.ctx-sep{height:1px;background:#f1f5f9;margin:3px 0}.gantt-outer{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.gantt-outer .gantt{flex:1}.wl-grid{flex-shrink:0;display:flex;flex-direction:column;border-top:2px solid #cbd5e1;background:#fff}.wl-header{display:flex;align-items:center;height:30px;border-bottom:1px solid #e2e8f0;font-size:12px;flex-shrink:0}.wl-title{display:flex;align-items:center;gap:12px;padding:0 8px;border-right:2px solid #cbd5e1;height:100%;flex-shrink:0}.wl-mode{display:flex;align-items:center;gap:4px;font-weight:400;cursor:pointer}.wl-legend{padding:0 10px;font-size:11px}.wl-body{overflow-y:auto;flex:1}.wl-row{display:flex;border-bottom:1px solid #f1f5f9}.wl-name{display:flex;align-items:center;gap:6px;padding:0 8px;font-size:12px;border-right:2px solid #cbd5e1;flex-shrink:0;overflow:hidden}.wl-name-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wl-cells{flex:1;position:relative;overflow:hidden}.wl-cell{position:absolute;top:1px;bottom:1px;border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:600;color:#fff;overflow:hidden}.wl-name{font-size:11px}.wl-cell.w-low{background:#93c5fd}.wl-cell.w-mid{background:#3b82f6}.wl-cell.w-over{background:#ef4444}.toolbar-select{font-size:12px;padding:4px 6px;max-width:150px}.assign-total{font-size:12px;margin-top:6px}.drawer{position:fixed;top:48px;right:0;bottom:0;width:340px;background:#fff;border-left:1px solid #e2e8f0;box-shadow:-8px 0 24px #0f172a14;z-index:50;display:flex;flex-direction:column}.drawer-header{display:flex;align-items:center;gap:8px;padding:12px;border-bottom:1px solid #e2e8f0}.drawer-title{flex:1;font-weight:600;border:1px solid transparent;padding:4px 6px}.drawer-title:hover,.drawer-title:focus{border-color:#cbd5e1}.drawer-body{flex:1;overflow-y:auto;padding:16px}.assign-row{display:flex;align-items:center;justify-content:space-between;padding:3px 0}.assign-check{display:flex;align-items:center;gap:8px;font-weight:400;cursor:pointer;padding:2px 0}.hours-input{width:64px;padding:3px 6px;font-size:12px}.dep-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:13px}.dep-dir{color:#64748b;font-size:11px;white-space:nowrap}.dep-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.color-row{display:flex;gap:6px}.color-swatch{width:22px;height:22px;border-radius:6px;border:2px solid transparent;cursor:pointer}.color-swatch.active{border-color:#0f172a}
