*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#f0f2f5;--color-surface:#fff;--color-border:#d1d5db;--color-border-light:#e5e7eb;--color-text:#1f2937;--color-text-secondary:#6b7280;--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-danger:#ef4444;--color-danger-hover:#dc2626;--party-a:#eff6ff;--party-b:#ecfdf5;--party-c:#fffbeb;color:var(--color-text);background:var(--color-bg);font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5}body{min-height:100vh;margin:0}#root{flex-direction:column;min-height:100vh;display:flex}.app{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-loading{height:100vh;color:var(--color-text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.loading-spinner{border:4px solid var(--color-border-light);border-top-color:var(--color-primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{color:var(--color-danger);text-align:center;cursor:pointer;background:#fef2f2;border-bottom:1px solid #fecaca;padding:8px 16px;font-size:13px}.board-header{background:var(--color-surface);border-bottom:2px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.header-left{align-items:baseline;gap:8px;display:flex}.header-title{color:var(--color-primary);letter-spacing:-.5px;font-size:24px;font-weight:700}.header-subtitle{color:var(--color-text-secondary);font-size:13px}.header-center{align-items:center;gap:12px;display:flex}.week-display{text-align:center;min-width:200px}.week-range{font-size:15px;font-weight:600;display:block}.month-label{color:var(--color-text-secondary);font-size:12px}.nav-btn{background:var(--color-bg);border:1px solid var(--color-border);cursor:pointer;color:var(--color-text);border-radius:6px;padding:6px 14px;font-size:16px;font-weight:600;transition:all .15s}.nav-btn:hover{background:var(--color-border-light)}.header-right{gap:8px;display:flex}.btn-primary{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s}.btn-primary:hover{background:var(--color-primary-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);cursor:pointer;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:500}.btn-secondary:hover{background:var(--color-border-light)}.btn-danger{color:var(--color-danger);border:1px solid var(--color-danger);cursor:pointer;background:0 0;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:500}.btn-danger:hover{background:#fef2f2}.board-layout{flex:1;display:flex;overflow:hidden}.board-side{background:var(--color-surface);border-right:1px solid var(--color-border);flex-shrink:0;width:260px;min-width:260px;overflow-y:auto}.right-side{border-right:none;border-left:1px solid var(--color-border)}.board-center{flex-direction:column;flex:1;display:flex;overflow:hidden}.planning-board{flex:1;padding:8px;overflow:auto}.board-scroll{min-width:700px}.board-grid{flex-direction:column;gap:2px;display:flex}.week-row{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;display:flex;overflow:hidden}.week-label{border-right:2px solid var(--color-border);width:80px;min-width:80px;color:var(--color-text-secondary);background:#f8fafc;flex-direction:column;justify-content:center;align-items:center;gap:2px;padding:4px;font-size:11px;display:flex}.month-badge{background:var(--color-primary);color:#fff;white-space:nowrap;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:600}.week-days{flex:1;display:flex}.day-cell{border-right:1px solid var(--color-border-light);flex:1;min-height:100px}.day-cell:last-child{border-right:none}.day-cell.day-weekend{background:#f9fafb}.day-cell.day-today{border:2px solid var(--color-primary);border-top:none;border-bottom:none}.day-date-marker{text-align:center;background:#fff5f5;border-bottom:1px solid #fecaca;padding:2px 4px;font-size:10px;font-weight:700}.day-label{color:var(--color-text-secondary);text-align:center;border-bottom:1px solid var(--color-border-light);padding:2px 4px;font-size:10px;font-weight:600}.day-subrows{flex-direction:column;height:calc(100% - 20px);display:flex}.cell-subrow{border-bottom:1px dashed var(--color-border-light);flex:1;justify-content:center;align-items:center;min-height:26px;transition:background .15s;display:flex;position:relative}.cell-subrow:last-child{border-bottom:none}.cell-subrow.subrow-over{outline:2px dashed var(--color-primary);outline-offset:-2px;background:#dbeafe!important}.cell-add-btn{border:1px dashed var(--color-border);width:20px;height:20px;color:var(--color-text-secondary);cursor:pointer;opacity:0;background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:14px;transition:opacity .15s,background .15s;display:flex}.cell-subrow:hover .cell-add-btn{opacity:1}.cell-add-btn:hover{background:var(--color-bg);border-color:var(--color-primary);color:var(--color-primary)}.job-chip{cursor:grab;touch-action:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;transition:transform .1s,box-shadow .1s;display:inline-flex}.job-chip:hover{transform:scale(1.15);box-shadow:0 2px 8px #0003}.job-chip:active{cursor:grabbing}.chip-id{color:#fff;font-size:11px;font-weight:700}.job-panel{flex-direction:column;height:100%;display:flex}.panel-header{border-bottom:1px solid var(--color-border-light);padding:12px}.panel-header h3{font-size:15px;font-weight:600}.panel-search{padding:8px 12px}.panel-filters{flex-wrap:wrap;gap:4px;padding:0 12px 8px;display:flex}.filter-btn{border:1px solid var(--color-border);cursor:pointer;color:var(--color-text-secondary);background:0 0;border-radius:12px;padding:3px 10px;font-size:11px;transition:all .15s}.filter-btn:hover{background:var(--color-bg)}.filter-btn.filter-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.panel-list{flex-direction:column;flex:1;gap:6px;padding:8px 12px;display:flex;overflow-y:auto}.panel-empty{color:var(--color-text-secondary);text-align:center;padding:24px;font-size:13px}.panel-add-btn{margin:8px 12px}.job-card{border:1px solid var(--color-border-light);background:var(--color-surface);cursor:pointer;touch-action:none;border-radius:6px;padding:8px 10px;transition:box-shadow .15s,border-color .15s}.job-card:hover{border-color:var(--color-primary);box-shadow:0 1px 4px #0000001a}.job-card.card-completed{opacity:.6}.job-card.card-active{border-left:3px solid var(--color-primary)}.card-top{justify-content:space-between;align-items:center;gap:6px;margin-bottom:4px;display:flex}.card-id{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:700;display:inline-flex}.card-status{background:var(--color-bg);color:var(--color-text-secondary);white-space:nowrap;border-radius:8px;padding:1px 6px;font-size:10px}.card-name{text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.card-address{color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.panel-add-form{border-top:1px solid var(--color-border-light);flex-direction:column;gap:6px;padding:8px 12px;display:flex}.add-form-actions{gap:6px;display:flex}.form-input{border:1px solid var(--color-border);width:100%;color:var(--color-text);background:var(--color-surface);border-radius:6px;outline:none;padding:6px 10px;font-family:inherit;font-size:13px;transition:border-color .15s}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #2563eb26}select.form-input{appearance:auto}.dialog-overlay{z-index:1000;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dialog-content{background:var(--color-surface);border-radius:12px;flex-direction:column;width:480px;max-width:90vw;max-height:80vh;display:flex;box-shadow:0 20px 60px #00000026}.dialog-lg{width:580px}.dialog-header{border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.dialog-header h3{font-size:16px;font-weight:600}.dialog-close{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;padding:0;font-size:24px;line-height:1}.dialog-close:hover{color:var(--color-text)}.dialog-body{flex-direction:column;flex:1;gap:12px;padding:16px 20px;display:flex;overflow-y:auto}.dialog-footer{border-top:1px solid var(--color-border-light);justify-content:space-between;align-items:center;gap:8px;padding:12px 20px;display:flex}.footer-right{gap:8px;margin-left:auto;display:flex}.form-group{flex-direction:column;gap:4px;display:flex}.form-group label{color:var(--color-text-secondary);font-size:12px;font-weight:500}.form-row{gap:12px;display:flex}.form-row .form-group{flex:1}.job-select-list{border:1px solid var(--color-border-light);border-radius:6px;flex-direction:column;gap:4px;max-height:240px;padding:4px;display:flex;overflow-y:auto}.job-select-item{cursor:pointer;border-radius:4px;align-items:center;gap:8px;padding:8px;transition:background .1s;display:flex}.job-select-item:hover{background:var(--color-bg)}.job-select-item.selected{background:#dbeafe}.job-id-badge{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:700;display:inline-flex}.job-name{flex:1;font-size:13px;font-weight:500}.job-status-tag{color:var(--color-text-secondary);background:var(--color-bg);border-radius:8px;padding:1px 6px;font-size:10px}.no-results{color:var(--color-text-secondary);text-align:center;padding:16px;font-size:13px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}
