*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f5f6f8;--surface: #ffffff;--border: #e0e3e8;--border-light: #eef0f3;--text: #1a1d23;--text-muted: #6b7280;--text-light: #9ca3af;--primary: #4f6ef7;--primary-hover: #3b5de7;--danger: #ef4444;--row-height: 76px;--slot-height: 32px;--header-height: 44px;--member-width: 170px;--day-width: 120px;--radius: 6px;--radius-sm: 3px}html,body,#root{height:100vh;margin:0;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}#root{display:flex;flex-direction:column}.app-header[style*="display: none"]+.grid-wrapper{display:none}.app-header{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);padding:0 12px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;gap:12px}.app-header h1{font-size:15px;font-weight:700;letter-spacing:-.02em;white-space:nowrap}.header-center{display:flex;align-items:center;gap:6px}.header-right{display:flex;align-items:center;gap:8px}.nav-btn{height:28px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;font-size:12px;font-weight:500;color:var(--text);padding:0 8px;transition:background .1s}.nav-btn:hover{background:var(--bg)}.btn{padding:5px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:4px;transition:background .1s}.btn:hover{background:var(--bg)}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.active-project-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.project-list{padding:6px 0}.project-row{display:flex;align-items:center;gap:10px;padding:8px 14px;cursor:pointer;transition:background .06s;font-size:13px}.project-row:hover{background:var(--bg)}.project-name-input{flex:1;border:none;background:transparent;outline:none;font-size:13px;font-family:inherit;color:var(--text);padding:2px 4px;border-radius:3px;min-width:0}.project-name-input:focus{background:#0000000a}.project-color-input{width:20px;height:20px;border:none;border-radius:50%;padding:0;cursor:pointer;flex-shrink:0;background:none;-webkit-appearance:none;appearance:none}.project-color-input::-webkit-color-swatch-wrapper{padding:0}.project-color-input::-webkit-color-swatch{border:2px solid rgba(0,0,0,.1);border-radius:50%}.project-delete{width:20px;height:20px;border:none;background:transparent;color:var(--text-light);cursor:pointer;border-radius:50%;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0;transition:opacity .1s}.project-row:hover .project-delete{opacity:1}.project-delete:hover{background:#fee2e2;color:var(--danger)}.project-add-row{color:var(--text-muted)}.member-list{padding:6px 0}.member-manage-row{display:flex;align-items:center;gap:10px;padding:8px 14px;font-size:13px;transition:background .06s}.member-manage-row:hover{background:var(--bg)}.member-manage-row .member-avatar{margin-right:0}.member-manage-details{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.member-manage-name{outline:none;border-radius:3px;padding:1px 3px;min-width:0;cursor:default;font-weight:500}.member-manage-name:focus{background:#0000000f;cursor:text}.member-manage-email{font-size:11px;color:var(--text-muted);border:none;background:transparent;outline:none;padding:1px 3px;font-family:inherit;border-radius:3px;width:100%}.member-manage-email:focus{background:#0000000a}.member-manage-email::placeholder{color:var(--text-light)}.member-manage-delete{width:20px;height:20px;border:none;background:transparent;color:var(--text-light);cursor:pointer;border-radius:50%;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0;transition:opacity .1s}.member-manage-row:hover .member-manage-delete{opacity:1}.member-manage-delete:hover{background:#fee2e2;color:var(--danger)}.member-add-row{cursor:pointer;color:var(--text-muted)}.grid-wrapper{flex:1;display:flex;overflow:hidden}.member-column{width:var(--member-width);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;scrollbar-width:none}.member-column::-webkit-scrollbar{display:none}.member-column-header{height:56px;display:flex;align-items:flex-end;padding:0 10px 8px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:2}.member-row{height:var(--row-height);display:flex;align-items:center;padding:0 10px;border-bottom:1px solid var(--border-light);position:relative;cursor:grab}.member-row.member-dragging{opacity:.4}.member-row.member-drag-over{border-top:2px solid var(--primary)}.member-info{display:flex;flex-direction:column;min-width:0}.member-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-role{font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-avatar{width:24px;height:24px;border-radius:50%;margin-right:7px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#fff}.member-avatar-img{object-fit:cover}.member-remove{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:18px;height:18px;border:none;background:transparent;color:var(--text-light);cursor:pointer;border-radius:50%;font-size:13px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .1s}.member-row:hover .member-remove{opacity:1}.member-remove:hover{background:#fee2e2;color:var(--danger)}.timeline-scroll{flex:1;overflow:auto}.timeline-header{border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:2}.day-header-row{display:flex;height:36px}.day-header{flex-shrink:0;width:var(--day-width);display:flex;align-items:center;justify-content:center;gap:4px;font-size:10px;font-weight:600;border-right:1px solid var(--border)}.day-header .day-name{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.day-header .day-date{color:var(--text)}.day-header.today .day-date{background:var(--primary);color:#fff;border-radius:8px;padding:1px 5px}.day-header.weekend{background:var(--bg);color:var(--text-light)}.day-header.week-start{border-left:2px solid var(--border)}.week-separator{position:absolute;top:0;bottom:0;width:2px;background:var(--border);z-index:3}.timeline-body{position:relative}.timeline-row{height:var(--row-height);border-bottom:1px solid var(--border-light);display:flex}.day-cell{flex-shrink:0;width:var(--day-width);border-right:1px solid var(--border);display:flex;flex-direction:column;position:relative}.day-cell.today{background:#4f6ef708}.day-cell.weekend{background:var(--bg)}.day-cell.week-start{border-left:2px solid var(--border)}.slot-cell{flex:1;position:relative;cursor:pointer;transition:background .06s;min-height:0}.slot-cell+.slot-cell{border-top:1px dashed var(--border-light)}.slot-cell:hover{background:#4f6ef70f}.slot-cell.drag-over{background:#4f6ef724}.block{position:absolute;inset:1px 2px;border-radius:var(--radius-sm);font-size:10px;font-weight:500;color:#fff;cursor:grab;overflow:hidden;z-index:1;display:flex;align-items:center;-webkit-user-select:none;user-select:none;transition:box-shadow .1s}.block:hover{box-shadow:0 1px 5px #0003;z-index:4}.block:active{cursor:grabbing}.block-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 4px;min-width:0;outline:none;border-radius:2px}.block-label:focus{background:#ffffff40;cursor:text}.block-delete{width:14px;height:14px;border:none;background:#0003;color:inherit;cursor:pointer;border-radius:50%;font-size:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-right:2px;opacity:0;transition:opacity .1s;line-height:1}.block:hover .block-delete{opacity:1}.block-delete:hover{background:#00000059}.block.dragging{opacity:.4}.context-menu{position:fixed;z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 6px 20px #00000024;padding:4px 0;min-width:150px}.context-menu[hidden]{display:none}.context-menu-item{display:flex;align-items:center;gap:7px;padding:5px 10px;font-size:12px;cursor:pointer;transition:background .06s;color:var(--text)}.context-menu-item:hover{background:var(--bg)}.context-menu-item.danger{color:var(--danger)}.context-menu-item.active{font-weight:600}.context-menu-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.context-menu-check{width:10px;text-align:center;font-size:10px;flex-shrink:0}.context-menu-separator{height:1px;background:var(--border-light);margin:3px 0}.context-menu-label{padding:4px 10px 2px;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light)}.modal-overlay{position:fixed;inset:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:100}.modal-overlay[hidden]{display:none}.modal{background:var(--surface);border-radius:8px;width:320px;max-width:90vw;box-shadow:0 16px 48px #0003}.modal-sm{width:300px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:14px;font-weight:600}.modal-close{width:24px;height:24px;border:none;background:transparent;font-size:16px;cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--bg)}.modal form{padding:14px}.form-group{margin-bottom:10px}.form-group label{display:block;font-size:10px;font-weight:600;color:var(--text-muted);margin-bottom:3px;text-transform:uppercase;letter-spacing:.04em}.form-group input{width:100%;padding:6px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;color:var(--text);background:var(--surface);outline:none}.form-group input:focus{border-color:var(--primary)}.form-actions{display:flex;justify-content:flex-end;gap:6px;padding-top:4px}.timeline-scroll::-webkit-scrollbar{height:8px;width:8px}.timeline-scroll::-webkit-scrollbar-track{background:var(--bg)}.timeline-scroll::-webkit-scrollbar-thumb{background:#c4c8cf;border-radius:4px}.timeline-scroll::-webkit-scrollbar-thumb:hover{background:#a0a5ad}.login-screen{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:500}.login-screen[hidden]{display:none}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:40px;text-align:center;box-shadow:0 8px 30px #00000014;max-width:340px;width:100%}.login-card h1{font-size:20px;font-weight:700;margin-bottom:8px}.login-card p{font-size:13px;color:var(--text-muted);margin-bottom:24px}.login-btn{width:100%;justify-content:center;padding:10px 16px;font-size:13px}.login-btn-pill{border-radius:999px;gap:8px}.week-label-row{display:flex;height:20px;position:sticky;top:0;background:var(--surface);z-index:3}.week-label{flex-shrink:0;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-light);display:flex;align-items:center;padding-left:8px;border-right:1px solid var(--border)}.week-label.week-start{border-left:2px solid var(--border)}.login-error{margin-top:12px;font-size:12px;color:var(--danger)}.login-error[hidden]{display:none}
