:root{--bg-page:#f0f2f5;--bg-surface:#fff;--bg-surface-hover:#f8fafc;--bg-elevated:#fff;--bg-subtle:#f8fafc;--border-light:#e9edf2;--border:#d1d9e6;--border-focus:#2563eb;--text-primary:#0b1a33;--text-secondary:#566b84;--text-tertiary:#8a9bb5;--text-inverse:#fff;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-light:#dbeafe;--accent-subtle:#eff6ff;--danger:#ef4444;--danger-hover:#dc2626;--danger-light:#fef2f2;--success:#10b981;--success-light:#ecfdf5;--amber:#f59e0b;--amber-light:#fffbeb;--party-a-bg:#eff6ff;--party-b-bg:#ecfdf5;--party-c-bg:#fffbeb;--weekend-bg:#f8f9fb;--today-border:#2563eb;--today-bg:#eff6ff;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 4px 12px #0000000f, 0 1px 3px #0000000a;--shadow-lg:0 12px 40px #0000001a, 0 4px 12px #0000000f;--shadow-xl:0 24px 60px #00000026;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:18px;--font:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono:"JetBrains Mono", "SF Mono", Consolas, monospace;--transition:.2s cubic-bezier(.4, 0, .2, 1);--transition-slow:.35s cubic-bezier(.4, 0, .2, 1);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}[data-theme=dark]{--bg-page:#18181b;--bg-surface:#222225;--bg-surface-hover:#2a2a2e;--bg-elevated:#2a2a2e;--bg-subtle:#18181b;--border-light:#2e2e34;--border:#3a3a42;--border-focus:#818cf8;--text-primary:#e4e4e7;--text-secondary:#a1a1aa;--text-tertiary:#71717a;--text-inverse:#18181b;--accent:#818cf8;--accent-hover:#93a0ff;--accent-light:#1e1e3a;--accent-subtle:#12122a;--danger:#f87171;--danger-hover:#fca5a5;--danger-light:#2a1414;--success:#6ee7b7;--success-light:#14281e;--amber:#fbbf24;--amber-light:#2a2010;--party-a-bg:#1a1a30;--party-b-bg:#16261e;--party-c-bg:#262016;--weekend-bg:#141418;--today-border:#818cf8;--today-bg:#12122a;--shadow-sm:0 1px 2px #00000040;--shadow-md:0 4px 12px #00000059;--shadow-lg:0 12px 40px #00000073;--shadow-xl:0 24px 60px #0000008c;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}@media (prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=dark]){--bg-page:#18181b;--bg-surface:#222225;--bg-surface-hover:#2a2a2e;--bg-elevated:#2a2a2e;--bg-subtle:#18181b;--border-light:#2e2e34;--border:#3a3a42;--border-focus:#818cf8;--text-primary:#e4e4e7;--text-secondary:#a1a1aa;--text-tertiary:#71717a;--text-inverse:#18181b;--accent:#818cf8;--accent-hover:#93a0ff;--accent-light:#1e1e3a;--accent-subtle:#12122a;--danger:#f87171;--danger-hover:#fca5a5;--danger-light:#2a1414;--success:#6ee7b7;--success-light:#14281e;--amber:#fbbf24;--amber-light:#2a2010;--party-a-bg:#1a1a30;--party-b-bg:#16261e;--party-c-bg:#262016;--weekend-bg:#141418;--today-border:#818cf8;--today-bg:#12122a;--shadow-sm:0 1px 2px #00000040;--shadow-md:0 4px 12px #00000059;--shadow-lg:0 12px 40px #00000073;--shadow-xl:0 24px 60px #0000008c;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:var(--font);color:var(--text-primary);background:var(--bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--transition-slow), color var(--transition-slow);line-height:1.5}#root{flex-direction:column;min-height:100vh;display:flex}.app{background:var(--bg-page);height:100vh;transition:background var(--transition-slow);flex-direction:column;display:flex;overflow:hidden}.app-loading{height:100vh;color:var(--text-secondary);background:var(--bg-page);flex-direction:column;justify-content:center;align-items:center;gap:20px;display:flex}.loading-spinner{border:3px solid var(--border-light);border-top-color:var(--accent);border-radius:50%;width:44px;height:44px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{background:var(--danger-light);color:var(--danger);text-align:center;cursor:pointer;border-bottom:1px solid var(--border);padding:10px 20px;font-size:13px;font-weight:500}.board-header{background:var(--bg-surface);border-bottom:1px solid var(--border-light);height:60px;transition:background var(--transition-slow), border-color var(--transition-slow);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 24px;display:flex}.header-left{align-items:center;gap:12px;display:flex}.header-logo{background:var(--accent);border-radius:var(--radius-md);color:#fff;letter-spacing:-.5px;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:800;display:flex}.header-title{color:var(--text-primary);letter-spacing:-.3px;font-size:20px;font-weight:700}.header-subtitle{color:var(--text-tertiary);margin-left:4px;font-size:12px;font-weight:400}.header-center{align-items:center;gap:12px;display:flex}.week-display{text-align:center;min-width:220px}.week-range{color:var(--text-primary);font-size:15px;font-weight:600;display:block}.month-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500}.nav-btn{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:all var(--transition);box-shadow:var(--shadow-sm);padding:6px 14px;font-size:15px;font-weight:600}.nav-btn:hover{background:var(--bg-surface-hover);color:var(--text-primary);border-color:var(--accent)}.header-right{align-items:center;gap:8px;display:flex}.theme-toggle{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-surface);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;font-size:16px;display:flex}.theme-toggle:hover{background:var(--bg-surface-hover);color:var(--accent);border-color:var(--accent)}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);border:none;padding:8px 18px;font-size:13px;font-weight:600;box-shadow:0 1px 3px #2563eb33}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 2px 8px #2563eb4d}.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);padding:8px 18px;font-size:13px;font-weight:500}.btn-secondary:hover{background:var(--bg-surface-hover);border-color:var(--accent)}.btn-danger{color:var(--danger);border:1px solid var(--danger);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);background:0 0;padding:8px 18px;font-size:13px;font-weight:500}.btn-danger:hover{background:var(--danger-light)}.board-layout{background:var(--border-light);transition:background var(--transition-slow);flex:1;gap:1px;display:flex;overflow:hidden}.board-side{background:var(--bg-surface);width:280px;min-width:280px;transition:background var(--transition-slow);flex-shrink:0;overflow-y:auto}.board-center{background:var(--bg-page);transition:background var(--transition-slow);flex-direction:column;flex:1;display:flex;overflow:hidden}.planning-board{flex:1;padding:12px;overflow:auto}.board-scroll{min-width:750px}.board-grid{flex-direction:column;gap:4px;display:flex}.week-row{background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);transition:background var(--transition-slow), border-color var(--transition-slow), box-shadow var(--transition-slow);display:flex;overflow:hidden}.week-label{background:var(--bg-subtle);border-right:2px solid var(--border-light);width:85px;min-width:85px;color:var(--text-tertiary);transition:background var(--transition-slow);flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:6px 4px;font-size:11px;display:flex}.month-badge{background:var(--accent);color:#fff;letter-spacing:.3px;text-transform:uppercase;border-radius:20px;padding:2px 10px;font-size:9px;font-weight:700}.week-number{color:var(--text-tertiary);font-size:10px;font-weight:500}.week-days{flex:1;display:flex}.day-cell{border-right:1px solid var(--border-light);min-height:100px;transition:background var(--transition-slow);flex:1}.day-cell:last-child{border-right:none}.day-cell.day-weekend{background:var(--weekend-bg)}.day-cell.day-today{position:relative}.day-cell.day-today:before{content:"";background:var(--today-border);z-index:1;height:3px;position:absolute;top:0;left:0;right:0}.day-cell.day-today .day-label,.day-cell.day-today .day-date-marker{background:var(--today-bg)}.day-date-marker{text-align:center;background:var(--danger-light);border-bottom:1px solid var(--border-light);transition:background var(--transition-slow);padding:3px 6px;font-size:10px;font-weight:700;color:var(--danger)!important}.day-label{color:var(--text-tertiary);text-align:center;border-bottom:1px solid var(--border-light);text-transform:uppercase;letter-spacing:.3px;transition:background var(--transition-slow), color var(--transition-slow);padding:3px 6px;font-size:10px;font-weight:600}.day-subrows{flex-direction:column;height:calc(100% - 22px);display:flex}.cell-subrow{border-bottom:1px dashed var(--border-light);min-height:26px;transition:all var(--transition);flex:1;justify-content:center;align-items:center;display:flex;position:relative}.cell-subrow:last-child{border-bottom:none}.cell-subrow.subrow-over{outline:2px dashed var(--accent);outline-offset:-2px;background:var(--accent-light)!important}.cell-add-btn{border:1.5px dashed var(--border);width:22px;height:22px;color:var(--text-tertiary);cursor:pointer;opacity:0;transition:all var(--transition);background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex}.cell-subrow:hover .cell-add-btn{opacity:1}.cell-add-btn:hover{background:var(--accent-subtle);border-color:var(--accent);color:var(--accent)}.job-chip{cursor:grab;width:30px;height:30px;transition:all var(--transition);touch-action:none;border-radius:50%;justify-content:center;align-items:center;font-weight:700;display:inline-flex;box-shadow:0 1px 4px #00000026}.job-chip:hover{z-index:10;transform:scale(1.2);box-shadow:0 4px 12px #00000040}.job-chip:active{cursor:grabbing;transform:scale(1.1)}.chip-id{color:#fff;text-shadow:0 1px 2px #0003;font-size:11px}.job-panel{flex-direction:column;height:100%;display:flex}.panel-header{align-items:center;gap:8px;padding:16px 16px 12px;display:flex}.panel-header h3{color:var(--text-primary);letter-spacing:-.2px;font-size:15px;font-weight:700}.panel-header-count{color:var(--text-tertiary);background:var(--bg-subtle);border-radius:20px;padding:1px 8px;font-size:11px;font-weight:500}.panel-search{padding:0 12px 8px}.panel-filters{flex-wrap:wrap;gap:4px;padding:0 12px 10px;display:flex}.filter-btn{border:1px solid var(--border-light);cursor:pointer;color:var(--text-secondary);transition:all var(--transition);background:0 0;border-radius:20px;padding:4px 12px;font-size:11px;font-weight:500}.filter-btn:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.filter-btn.filter-active{background:var(--accent);color:#fff;border-color:var(--accent)}.panel-list{flex-direction:column;flex:1;gap:6px;padding:0 12px 8px;display:flex;overflow-y:auto}.panel-empty{color:var(--text-tertiary);text-align:center;padding:32px 16px;font-size:13px}.panel-add-btn{margin:4px 12px 12px}.job-card{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--bg-surface);cursor:pointer;transition:all var(--transition);touch-action:none;box-shadow:var(--shadow-sm);padding:10px 12px}.job-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-1px)}.job-card.card-completed{opacity:.55}.job-card.card-active{border-left:3px solid var(--accent);padding-left:10px}.card-top{justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px;display:flex}.card-id{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:11px;font-weight:700;display:inline-flex;box-shadow:0 1px 3px #00000026}.card-status{background:var(--bg-subtle);color:var(--text-tertiary);white-space:nowrap;border:1px solid var(--border-light);border-radius:20px;padding:2px 8px;font-size:10px;font-weight:500}.card-status[data-status=in_progress]{background:var(--accent-subtle);color:var(--accent);border-color:var(--accent-light)}.card-status[data-status=completed]{background:var(--success-light);color:var(--success);border-color:#0000}.card-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.card-address{color:var(--text-tertiary);text-overflow:ellipsis;white-space:nowrap;margin-top:1px;font-size:11px;overflow:hidden}.panel-add-form{border-top:1px solid var(--border-light);background:var(--bg-subtle);flex-direction:column;gap:8px;margin-top:auto;padding:12px;display:flex}.add-form-actions{gap:8px;margin-top:4px;display:flex}.form-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);background:var(--bg-surface);transition:all var(--transition);outline:none;padding:8px 12px;font-family:inherit;font-size:13px}.form-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-light)}.form-input::placeholder{color:var(--text-tertiary)}select.form-input{appearance:auto;cursor:pointer}.dialog-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000073;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.dialog-content{background:var(--bg-elevated);border-radius:var(--radius-lg);width:480px;max-width:90vw;max-height:80vh;box-shadow:var(--shadow-xl);border:1px solid var(--border-light);transition:background var(--transition-slow), border-color var(--transition-slow);flex-direction:column;animation:.2s slideUp;display:flex}.dialog-lg{width:580px}.dialog-header{justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.dialog-header h3{color:var(--text-primary);letter-spacing:-.3px;font-size:17px;font-weight:700}.dialog-close{cursor:pointer;color:var(--text-tertiary);border-radius:var(--radius-sm);transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;width:32px;height:32px;padding:4px;font-size:22px;line-height:1;display:flex}.dialog-close:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.dialog-body{flex-direction:column;flex:1;gap:14px;padding:4px 24px 16px;display:flex;overflow-y:auto}.dialog-footer{justify-content:space-between;align-items:center;gap:8px;padding:14px 24px 20px;display:flex}.footer-right{gap:8px;margin-left:auto;display:flex}.form-group{flex-direction:column;gap:5px;display:flex}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;font-size:12px;font-weight:600}.form-row{gap:12px;display:flex}.form-row .form-group{flex:1}.job-select-list{border:1px solid var(--border-light);border-radius:var(--radius-sm);background:var(--bg-surface);flex-direction:column;gap:2px;max-height:260px;padding:4px;display:flex;overflow-y:auto}.job-select-item{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);align-items:center;gap:10px;padding:8px 10px;display:flex}.job-select-item:hover{background:var(--bg-surface-hover)}.job-select-item.selected{background:var(--accent-light);border:1px solid var(--accent)}.job-id-badge{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:11px;font-weight:700;display:inline-flex;box-shadow:0 1px 3px #00000026}.job-name{color:var(--text-primary);flex:1;font-size:13px;font-weight:600}.job-status-tag{color:var(--text-tertiary);background:var(--bg-subtle);border-radius:20px;padding:2px 8px;font-size:10px;font-weight:500}.no-results{color:var(--text-tertiary);text-align:center;padding:24px 16px;font-size:13px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);transition:background var(--transition);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}
