:root{color:#1e293b;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f1f5f9;font-family:system-ui,Segoe UI,Roboto,sans-serif;line-height:1.4}*{box-sizing:border-box}body{min-height:100vh;margin:0}#root{min-height:100vh}button{font-family:inherit}.board{--resource-w:200px;--row-h:30px;--axis-min-w:980px;color:#232a2f;background:#fff;border:1px solid #e2e8f0;border-radius:4px;width:100%;font-family:Roboto,sans-serif;font-size:12px;line-height:18px;overflow:auto}.board-header{z-index:3;min-width:calc(var(--resource-w) + var(--axis-min-w));background:#f7f7f7;border-bottom:1px solid #e2e8f0;display:flex;position:sticky;top:0}.board-resource{flex:0 0 var(--resource-w);width:var(--resource-w);box-sizing:border-box;z-index:2;background:#fff;border-right:1px solid #e2e8f0;justify-content:space-between;align-items:center;gap:8px;padding:5px 10px;display:flex;position:sticky;left:0}.board-resource--head{color:#232a2f;background:#f7f7f7;font-weight:500}.board-axis{min-width:var(--axis-min-w);flex:auto;position:relative}.board-axis--head{height:28px}.board-hour-label{color:#6b7378;white-space:nowrap;padding-top:6px;font-size:12px;position:absolute;top:0;transform:translate(-50%)}.board-hour-label:first-child{transform:translate(0)}.board-body{min-width:calc(var(--resource-w) + var(--axis-min-w))}.board-row{height:var(--row-h);border-bottom:1px solid #eef1f3;display:flex}.board-row:last-child{border-bottom:none}.board-staff-name{color:#232a2f;white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.board-staff-hours{color:#8a9298;text-align:right;white-space:nowrap;flex:none;font-size:12px}.board-lane{min-width:var(--axis-min-w);flex:auto;height:100%;position:relative}.board-gridline{pointer-events:none;width:0;position:absolute;top:0;bottom:0}.board-gridline--hour{border-left:1px solid #e6e9eb}.board-gridline--quarter{border-left:1px solid #f2f4f5}.board-block{box-sizing:border-box;color:#232a2f;cursor:default;border-radius:5px 5px 0 0;align-items:center;min-width:0;height:27px;padding:0 6px;font-size:12px;line-height:27px;display:flex;position:absolute;top:1px;overflow:hidden}.board-block-label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.board-empty{text-align:center;color:#8a9298;background:#fff;border:1px dashed #e2e8f0;border-radius:4px;padding:40px 16px;font-family:Roboto,sans-serif}.board-banner{color:#6b4f00;background:#fff8e1;border:1px solid #ffe6a0;border-radius:4px;align-items:center;gap:8px;margin-bottom:8px;padding:7px 12px;font-family:Roboto,sans-serif;font-size:12px;line-height:16px;display:flex}.board-banner-dot{background:#f0a500;border-radius:50%;flex:none;width:8px;height:8px}.board-banner-state--on{color:#1a7a3a}.board-banner-state--off{color:#8a6d00}.board-banner--flash{animation:.4s 3 board-banner-flash}@keyframes board-banner-flash{0%,to{background:#fff8e1}50%{background:#ffd97a}}.board-lane--editable{cursor:copy}.board-row--drop .board-lane{background:#4ca6ff14;box-shadow:inset 0 0 0 1px #4ca6ff80}.board-block--editable{cursor:grab}.board-block--editable:active{cursor:grabbing}.board-block--saving{opacity:.6;cursor:progress}.board-block--error{box-shadow:inset 0 0 0 2px #e23b3b}.board-block--ghost{color:#1e3a8a;pointer-events:none;opacity:.9;background:#4ca6ff59;border:1px dashed #2563eb}.board-resize{cursor:ew-resize;z-index:2;width:6px;position:absolute;top:0;bottom:0}.board-resize--left{left:0}.board-resize--right{right:0}.board-block--editable:hover .board-resize{background:#232a2f2e}.board-block-x{color:#c0392b;cursor:pointer;z-index:3;background:#ffffffd9;border:none;border-radius:50%;width:16px;height:16px;padding:0;font-size:14px;font-weight:700;line-height:14px;display:none;position:absolute;top:1px;right:2px}.board-block--editable:hover .board-block-x{display:block}.board-block-x:hover{color:#fff;background:#c0392b}.board-block-flag{color:#4b5563;white-space:nowrap;margin-left:6px;font-size:11px;font-style:italic}.board-block-flag--error{color:#fff;text-align:center;background:#e23b3b;border-radius:50%;width:14px;height:14px;font-style:normal;font-weight:700;line-height:14px}.board-create-overlay{z-index:50;background:#0f172a40;justify-content:center;align-items:center;font-family:Roboto,sans-serif;display:flex;position:fixed;inset:0}.board-create{color:#232a2f;background:#fff;border-radius:6px;width:380px;max-width:calc(100vw - 32px);padding:16px;font-size:13px;box-shadow:0 12px 40px #00000040}.board-create-head{color:#475569;margin-bottom:12px;font-size:13px}.board-create-field{flex-direction:column;gap:4px;margin-bottom:12px;display:flex}.board-create-field>span{color:#64748b;text-transform:uppercase;letter-spacing:.03em;font-size:11px;font-weight:600}.board-create-field input,.board-create-field select{background:#fff;border:1px solid #cbd5e1;border-radius:4px;padding:6px 8px;font-family:Roboto,sans-serif;font-size:13px}.board-create-search{gap:6px;display:flex}.board-create-search input{flex:auto}.board-create-search button{cursor:pointer;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:4px;flex:none;padding:6px 12px}.board-create-results{border:1px solid #e2e8f0;border-radius:4px;max-height:160px;margin:6px 0 0;padding:0;list-style:none;overflow:auto}.board-create-results li{border-bottom:1px solid #f1f5f9}.board-create-results li:last-child{border-bottom:none}.board-create-results button{text-align:left;cursor:pointer;background:#fff;border:none;width:100%;padding:7px 10px;font-size:13px}.board-create-results button:hover{background:#f1f5f9}.board-create-jobno{color:#94a3b8;font-size:12px}.board-create-row{gap:10px;display:flex}.board-create-row .board-create-field{flex:1 1 0}.board-create-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:4px;margin-bottom:12px;padding:7px 10px;font-size:12px}.board-create-actions{justify-content:flex-end;gap:8px;display:flex}.board-create-actions button{cursor:pointer;border:1px solid #cbd5e1;border-radius:4px;padding:7px 16px;font-size:13px}.board-create-cancel{color:#475569;background:#fff}.board-create-submit{color:#fff;background:#2563eb;border-color:#2563eb;font-weight:500}.board-create-submit:disabled{opacity:.6;cursor:progress}.board--week{--week-min-w:980px}.board--week .board-header,.board--week .board-body{min-width:calc(var(--resource-w) + var(--week-min-w))}.weekboard-days{min-width:var(--week-min-w);flex:auto;display:flex}.weekboard-days--head{background:#f7f7f7}.weekboard-day-head{box-sizing:border-box;border-left:1px solid #e6e9eb;flex:1 1 0;align-items:baseline;gap:6px;padding:5px 8px;display:flex}.weekboard-day-name{color:#232a2f;font-weight:500}.weekboard-day-num{color:#8a9298;font-size:12px}.weekboard-row{height:auto;min-height:var(--row-h);align-items:stretch}.weekboard-cell{box-sizing:border-box;border-left:1px solid #eef1f3;flex-direction:column;flex:1 1 0;gap:3px;min-width:0;padding:3px 4px;display:flex}.weekboard-tile{color:#232a2f;cursor:default;border-radius:4px;padding:2px 6px;font-size:12px;line-height:15px;overflow:hidden}.weekboard-tile-time{white-space:nowrap;text-overflow:ellipsis;font-weight:500;display:block;overflow:hidden}.weekboard-tile-name{color:#475569;white-space:nowrap;text-overflow:ellipsis;display:block;overflow:hidden}.po{color:#232a2f;grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;gap:16px;font-family:Roboto,sans-serif;font-size:12px;line-height:18px;display:grid}@media (width<=900px){.po{grid-template-columns:1fr}}.po-form,.po-recent,.po-success{background:#fff;border:1px solid #e2e8f0;border-radius:4px;padding:16px}.po-form-title{color:#232a2f;margin:0 0 12px;font-size:14px;font-weight:500}.po-field{margin-bottom:14px}.po-label{color:#6b7378;margin-bottom:4px;font-size:12px;font-weight:500;display:block}.po-optional{color:#9aa3a8;font-weight:400}.po-input,.po-select,.po-textarea{box-sizing:border-box;color:#232a2f;background:#fff;border:1px solid #ccc;border-radius:3px;width:100%;padding:6px 8px;font-family:Roboto,sans-serif;font-size:12px;line-height:18px}.po-select{cursor:pointer;height:32px}.po-textarea{resize:vertical}.po-input:focus,.po-select:focus,.po-textarea:focus{border-color:#1976d2;outline:none;box-shadow:0 0 0 2px #1976d226}.po-hint{color:#6b7378;margin-top:4px;font-size:12px}.po-error{color:#b91c1c;margin-top:4px;font-size:12px}.po-error--block{background:#fef2f2;border:1px solid #fecaca;border-radius:3px;margin:0 0 12px;padding:8px 10px}.po-results{border:1px solid #e2e8f0;border-radius:3px;max-height:260px;margin:6px 0 0;padding:0;list-style:none;overflow:auto}.po-result{text-align:left;color:#232a2f;cursor:pointer;background:#fff;border:0;border-bottom:1px solid #f0f2f4;width:100%;padding:8px 10px;font-family:Roboto,sans-serif;font-size:12px;display:block}.po-results li:last-child .po-result{border-bottom:0}.po-result:hover{background:#f1f5f9}.po-result strong{font-weight:500;display:block}.po-result-meta,.po-selected-meta{color:#6b7378;display:block}.po-selected{background:#f7fafe;border:1px solid #e2e8f0;border-radius:3px;justify-content:space-between;align-items:flex-start;gap:10px;padding:8px 10px;display:flex}.po-selected-main strong{font-weight:500}.po-link{color:#1976d2;cursor:pointer;white-space:nowrap;background:0 0;border:0;padding:0;font-family:Roboto,sans-serif;font-size:12px}.po-link:hover{text-decoration:underline}.po-btn{color:#232a2f;cursor:pointer;background:#fff;border:1px solid #ccc;border-radius:3px;height:32px;padding:0 16px;font-family:Roboto,sans-serif;font-size:13px}.po-btn--primary{color:#fff;background:#1976d2;border-color:#1976d2}.po-btn--primary:hover:not(:disabled){background:#1565c0;border-color:#1565c0}.po-btn:disabled{opacity:.55;cursor:default}.po-raise{width:100%;height:38px;font-weight:500}.po-fineprint{color:#9aa3a8;margin:8px 0 0;font-size:11px}.po-success{text-align:center;padding:28px 16px}.po-success-label{letter-spacing:.06em;text-transform:uppercase;color:#6b7378;font-size:12px}.po-number{color:#1976d2;word-break:break-all;margin:8px 0;font-size:48px;font-weight:700;line-height:1.1}.po-success-sub{color:#6b7378;margin-bottom:18px;font-size:12px}.po-recent-head{justify-content:space-between;align-items:baseline;display:flex}.po-recent-list{margin:6px 0 0;padding:0;list-style:none}.po-recent-item{border-bottom:1px solid #f0f2f4;align-items:baseline;gap:8px;padding:8px 0;display:flex}.po-recent-item:last-child{border-bottom:0}.po-recent-no{color:#1976d2;white-space:nowrap;font-weight:600}.po-recent-meta{color:#6b7378;text-overflow:ellipsis;white-space:nowrap;flex:auto;min-width:0;overflow:hidden}.po-recent-date{color:#9aa3a8;white-space:nowrap}.app{color:#232a2f;background:#fff;max-width:1600px;margin:0 auto;padding:16px;font-family:Roboto,sans-serif;font-size:12px;line-height:18px}.topbar{flex-wrap:wrap;align-items:baseline;gap:12px;margin-bottom:10px;display:flex}.topbar-title{color:#232a2f;margin:0;font-size:18px;font-weight:500}.surface-nav{align-items:center;gap:6px;display:flex}.toolbar{background:#f7f7f7;border:1px solid #e6e9eb;border-radius:4px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;padding:8px 10px;display:flex}.toolbar-group{align-items:center;gap:6px;display:flex}.toolbar-spacer{flex:auto}.step-btn,.refresh-btn,.view-tab{color:#232a2f;cursor:pointer;background:#fff;border:1px solid #ccc;border-radius:3px;height:26px;padding:0 12px;font-family:Roboto,sans-serif;font-size:12px;line-height:1}.step-btn:hover,.refresh-btn:hover,.view-tab:hover:not(:disabled){background:#f1f5f9}.refresh-btn:disabled,.view-tab:disabled{opacity:.6;cursor:default}.view-tab--active,.view-tab--active:hover{color:#fff;background:#1976d2;border-color:#1976d2}.date-input{box-sizing:border-box;color:#232a2f;background:#fff;border:1px solid #ccc;border-radius:3px;height:26px;padding:0 8px;font-family:Roboto,sans-serif;font-size:12px}.colour-toggle{color:#6b7378;white-space:nowrap;font-size:12px}.colour-toggle strong{color:#1976d2;font-weight:500}.zone-filter{white-space:nowrap;align-items:center;gap:6px;display:flex}.zone-filter-label{color:#6b7378;font-size:12px}.zone-select{box-sizing:border-box;color:#232a2f;cursor:pointer;background:#fff;border:1px solid #ccc;border-radius:3px;height:26px;padding:0 8px;font-family:Roboto,sans-serif;font-size:12px}.summary{color:#6b7378;white-space:nowrap;font-size:12px}.board-wrap{width:100%}.state{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:4px;padding:40px 16px;font-family:Roboto,sans-serif}.state--loading{color:#6b7378}.state--error{color:#b91c1c;background:#fef2f2;border-color:#fecaca;flex-direction:column;align-items:center;gap:10px;display:flex}.state-detail{color:#7f1d1d;word-break:break-word;max-width:640px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.auth-screen{background:#1c2b3a;justify-content:center;align-items:center;min-height:100vh;padding:24px;font-family:Roboto,sans-serif;display:flex}.auth-card{text-align:center;background:#fff;border-radius:8px;width:100%;max-width:360px;padding:36px 40px;box-shadow:0 12px 40px #00000059}.auth-card--quiet{color:#fff;box-shadow:none;background:0 0}.auth-brand{letter-spacing:1.5px;text-transform:uppercase;color:#4ca6ff;margin-bottom:8px;font-size:13px;font-weight:700}.auth-title{color:#232a2f;margin:0 0 8px;font-size:22px;font-weight:500}.auth-sub{color:#5a6670;margin:0 0 24px;font-size:13px;line-height:20px}.auth-btn{color:#fff;cursor:pointer;background:#2f6fed;border:none;border-radius:4px;width:100%;height:40px;padding:0 16px;font-family:Roboto,sans-serif;font-size:14px;font-weight:500}.auth-btn:hover:not(:disabled){background:#2560d6}.auth-btn:disabled{opacity:.6;cursor:default}.auth-pill{z-index:50;background:#fff;border:1px solid #e6e9eb;border-radius:999px;align-items:center;gap:8px;padding:4px 6px 4px 12px;font-size:12px;display:flex;position:fixed;top:10px;right:12px;box-shadow:0 2px 8px #00000014}.auth-pill-name{color:#5a6670;text-overflow:ellipsis;white-space:nowrap;max-width:180px;overflow:hidden}.auth-pill-btn{color:#232a2f;cursor:pointer;background:#f7f7f7;border:1px solid #ccc;border-radius:999px;height:24px;padding:0 12px;font-family:Roboto,sans-serif;font-size:12px}.auth-pill-btn:hover{background:#eee}
