:root{--bg:#f5f7fa;--surface:#fff;--border:#e2e8ed;--border-strong:#cbd5e0;--text:#1e293b;--text-muted:#64748b;--text-faint:#94a3b8;--primary:#0f766e;--primary-dark:#0b5e57;--accent:#4ade80;--accent-fg:#064e3b;--warn:#f59e0b;--error:#dc2626;--header-dark:#2c4a5b;--header-teal:#1f9b8e;--header-cell:#2c4a5b;--row-hover:#f8fafc;--tentative:#f59e0b;--confirmed:#10b981;--requested:#6366f1;--time-off:#94a3b8;--resource-row-bg:#eef2f5;--pill-neutral-bg:#e2e8f0;--pill-neutral-fg:#475569;--error-soft-bg:#fef2f2;--warn-soft-bg:#fef3c7;--warn-soft-fg:#78350f;--tentative-soft-bg:#fef3c7;--tentative-soft-fg:#92400e;--confirmed-soft-bg:#d1fae5;--confirmed-soft-fg:#065f46;--requested-soft-bg:#e0e7ff;--requested-soft-fg:#3730a3;--cell-input-focus-bg:#fff;--danger-hover:#b91c1c;--util-over-severe:#b91c1c;--util-over:#dc2626;--util-near:#f59e0b;--util-under:#94a3b8;--util-healthy:#34d399;--holiday-bg:#fbbf24;--holiday-fg:#78350f;--modal-scrim:#0f172a80;--shadow-modal:0 20px 50px #00000040;--shadow-popover:0 12px 30px #0f172a2e, 0 2px 6px #0f172a14}:root[data-theme=dark]{--bg:#0f172a;--surface:#1e293b;--border:#334155;--border-strong:#475569;--text:#e2e8f0;--text-muted:#94a3b8;--text-faint:#64748b;--primary:#2dd4bf;--primary-dark:#14b8a6;--accent:#4ade80;--accent-fg:#064e3b;--warn:#fbbf24;--error:#f87171;--header-dark:#0b1f2b;--header-teal:#0d7a70;--header-cell:#0b1f2b;--row-hover:#273449;--tentative:#f59e0b;--confirmed:#10b981;--requested:#818cf8;--time-off:#64748b;--resource-row-bg:#273449;--pill-neutral-bg:#334155;--pill-neutral-fg:#cbd5e0;--error-soft-bg:#3b1d1d;--warn-soft-bg:#3a2c10;--warn-soft-fg:#fde68a;--tentative-soft-bg:#3a2c10;--tentative-soft-fg:#fcd34d;--confirmed-soft-bg:#0f3a2a;--confirmed-soft-fg:#6ee7b7;--requested-soft-bg:#1f2147;--requested-soft-fg:#c7d2fe;--cell-input-focus-bg:#1e293b;--danger-hover:#dc2626;--util-over-severe:#f87171;--util-over:#ef4444;--util-near:#fbbf24;--util-under:#64748b;--util-healthy:#34d399;--holiday-bg:#b45309;--holiday-fg:#fde68a;--modal-scrim:#0009;--shadow-modal:0 20px 50px #00000080;--shadow-popover:0 12px 30px #00000073, 0 2px 6px #0000004d;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*{box-sizing:border-box}html,body,#root{color:var(--text);background:var(--bg);min-height:100%;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;font-size:13px}a{color:var(--primary);cursor:pointer;text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);border-radius:4px;padding:6px 12px;font-family:inherit;font-size:13px;transition:background 80ms}button:hover:not(:disabled){background:var(--row-hover)}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}button.primary:hover:not(:disabled){background:var(--primary-dark)}button.icon-btn{justify-content:center;align-items:center;width:30px;height:30px;padding:0;display:inline-flex}button.icon-btn.on{background:var(--primary);color:#fff;border-color:var(--primary)}button.linklike{color:var(--primary);font-size:inherit;font-weight:inherit;background:0 0;border:none;border-radius:0;padding:0}button.linklike:hover:not(:disabled){background:0 0;text-decoration:underline}input,select{border:1px solid var(--border-strong);background:var(--surface);color:var(--text);border-radius:4px;padding:6px 8px;font-family:inherit;font-size:13px}.app-shell{flex-direction:column;min-height:100vh;display:flex}.app-topbar{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:24px;height:48px;padding:0 16px;display:flex}.app-brand{color:var(--primary);letter-spacing:.02em;cursor:pointer;font-size:14px;font-weight:700;text-decoration:none}.app-brand:hover{text-decoration:none}.app-nav{flex:1;gap:4px;display:flex}.app-nav a{color:var(--text);border-radius:4px;padding:8px 12px;font-weight:500}.app-nav a:hover{background:var(--row-hover);text-decoration:none}.app-nav a.active{background:var(--header-dark);color:#fff}.app-user{background:var(--row-hover);cursor:pointer;color:inherit;border:none;border-radius:18px;align-items:center;gap:8px;padding:4px 10px;display:flex}.app-user:hover{background:var(--border)}.theme-toggle{border:1px solid var(--border-strong);background:var(--surface);color:var(--text-muted);border-radius:50%;width:30px;height:30px}.theme-toggle:hover:not(:disabled){color:var(--text);background:var(--row-hover)}.app-user .avatar{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:700;display:inline-flex}.app-user .role{color:var(--text-muted);font-size:11px}.app-main{flex:1;padding:16px}.loading-screen{min-height:100vh;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.view-tabs{border-bottom:1px solid var(--border);margin-bottom:12px;display:flex}.view-tabs a{color:var(--text-muted);border-bottom:2px solid #0000;padding:10px 16px;font-weight:500}.view-tabs a.active{color:var(--primary);border-bottom-color:var(--primary)}.toolbar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;display:flex}.toolbar .spacer{flex:1}.dash-grid-2col{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}@media (width<=900px){.dash-grid-2col{grid-template-columns:1fr}}.pager{margin-top:8px}.pager-inner{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.pager-inner .spacer{flex:1}.error-banner{background:var(--error-soft-bg);color:var(--error);border-radius:4px;margin-bottom:8px;padding:8px 12px;font-size:12px}.grid{background:var(--surface);border:1px solid var(--border);border-radius:4px;width:100%;overflow-x:auto}.grid-table{border-collapse:collapse;width:100%;font-size:12.5px}.grid-table th{background:var(--header-cell);color:#fff;text-align:left;border-right:1px solid #ffffff1a;padding:8px 10px;font-weight:600}.grid-table th.col-week{background:var(--header-teal);text-align:center;min-width:78px;font-size:11px;line-height:1.3}.grid-table th.col-week small{opacity:.85;font-weight:400;display:block}.grid-table th.col-total{background:var(--header-teal);text-align:center}.grid-table td{border-bottom:1px solid var(--border);border-right:1px solid var(--border);background:var(--surface);padding:6px 10px}.grid-table tr.resource-row td{background:var(--resource-row-bg);font-weight:600}.grid-table tr.booking-row td.col-resource{color:var(--text-muted);padding-left:28px;font-weight:500}.grid-table td.col-week,.grid-table td.col-total{text-align:right;font-variant-numeric:tabular-nums}.grid-table td.col-week.editable{cursor:text;padding:0}.grid-table td.col-week.editable input{text-align:right;font-variant-numeric:tabular-nums;background:0 0;border:none;width:100%;padding:6px 10px;font-family:inherit;font-size:12.5px}.grid-table td.col-week.editable input:focus{outline:2px solid var(--primary);background:var(--cell-input-focus-bg)}.grid-table td.col-week.over{border-bottom:2px solid var(--error);color:var(--error);font-weight:600}.holiday-dot{background:var(--warn);vertical-align:middle;border-radius:50%;width:6px;height:6px;margin-left:4px;display:inline-block}.grid-table th.col-week.has-holiday{background:linear-gradient(180deg, var(--header-teal) 0%, var(--header-teal) 88%, var(--warn) 88%, var(--warn) 100%)}.bt{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.bt-tentative{background:var(--tentative-soft-bg);color:var(--tentative-soft-fg)}.bt-confirmed{background:var(--confirmed-soft-bg);color:var(--confirmed-soft-fg)}.bt-requested{background:var(--requested-soft-bg);color:var(--requested-soft-fg)}.bt-time_off{background:var(--pill-neutral-bg);color:var(--pill-neutral-fg)}.panel{background:var(--surface);border:1px solid var(--border);border-radius:6px;margin-bottom:12px;padding:14px 16px}.muted{color:var(--text-muted)}.faint{color:var(--text-faint)}.center{text-align:center}.note{color:var(--text-faint);margin:8px 0 0;font-size:11px;font-style:italic}.error{color:var(--error);margin:6px 0 12px;font-size:12px}.login-card .notice{background:var(--row-hover);color:var(--text);border:1px solid var(--border);border-left:3px solid var(--primary);border-radius:4px;margin:0 0 16px;padding:8px 12px;font-size:13px}.login-wrap{background:linear-gradient(135deg,#0f766e 0%,#134e4a 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--surface);box-shadow:var(--shadow-modal);border-radius:10px;width:360px;padding:32px}.login-card h1{color:var(--primary);margin:0 0 8px;font-size:22px}.login-card p{color:var(--text-muted);margin:0 0 24px}.field{flex-direction:column;gap:4px;margin-bottom:14px;display:flex}.field label{color:var(--text-muted);font-size:12px;font-weight:600}button.danger{background:var(--error);color:#fff;border-color:var(--error)}button.danger:hover:not(:disabled){background:var(--danger-hover)}.modal-backdrop{background:var(--modal-scrim);z-index:50;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);max-width:92vw;max-height:92vh;box-shadow:var(--shadow-modal);border-radius:8px;padding:20px 24px;overflow-y:auto}.modal h2{margin:0 0 12px;font-size:16px}textarea{border:1px solid var(--border-strong);resize:vertical;background:var(--surface);width:100%;color:var(--text);border-radius:4px;padding:6px 8px;font-family:inherit;font-size:13px}.audit-table{table-layout:fixed}.audit-table td,.audit-table th{white-space:nowrap}.audit-ell{text-overflow:ellipsis;max-width:0;overflow:hidden}.audit-table .icon-btn svg{display:block}.audit-kv{grid-template-columns:max-content 1fr;gap:6px 16px;margin:0;font-size:13px;display:grid}.audit-kv dt{color:var(--text-muted);font-weight:600}.audit-kv dd{word-break:break-word;white-space:normal;margin:0}.bm-section{border-bottom:1px solid var(--border);padding:10px 0}.bm-section:last-of-type{border-bottom:none}.bm-row{flex-direction:column;gap:4px;margin-bottom:10px;display:flex}.bm-row>label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600}.bm-row.two-col{flex-direction:row;gap:14px}.bm-row.two-col>div{flex-direction:column;flex:1;gap:4px;display:flex}.bm-row.two-col>div>label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600}.bm-seg{gap:4px;display:inline-flex}.bm-seg .seg{border:1px solid var(--border-strong);background:var(--surface);color:var(--text-muted);cursor:pointer;border-radius:4px;padding:6px 12px;font-size:12px;font-weight:500}.bm-seg .seg:hover{background:var(--row-hover)}.bm-seg .seg.on{color:#fff}.bm-seg .seg.on.bt-tentative{background:var(--tentative);border-color:var(--tentative)}.bm-seg .seg.on.bt-confirmed{background:var(--confirmed);border-color:var(--confirmed)}.bm-seg .seg.on.bt-requested{background:var(--requested);border-color:var(--requested)}.bm-seg .seg.on.bt-time_off{background:var(--time-off);border-color:var(--time-off);color:var(--surface)}.bm-preview{color:var(--text-muted);background:var(--row-hover);font-variant-numeric:tabular-nums;border-radius:4px;margin-top:8px;padding:8px 10px;font-size:12px}.bm-preview.has-error{background:var(--error-soft-bg);color:var(--error)}.bm-error{color:var(--error);margin-top:6px;font-size:12px}.callout{border:1px solid var(--border);background:var(--row-hover);border-radius:4px;margin:12px 0;padding:10px 12px;font-size:12.5px;line-height:1.5}.callout strong{margin-bottom:2px;display:block}.callout-warn{background:var(--warn-soft-bg);border-color:var(--warn);color:var(--warn-soft-fg)}.bm-custom-grid{background:var(--row-hover);border-radius:4px;margin-top:6px;padding:8px 10px}.bm-custom-grid-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:11px;font-weight:600}.bm-custom-row{justify-content:space-between;align-items:center;padding:3px 0;display:flex}.planner-shell{background:var(--surface);border:1px solid var(--border);border-radius:4px;display:flex;overflow:hidden}.planner-left{border-right:1px solid var(--border-strong);background:var(--surface);flex-shrink:0;overflow-y:hidden}.planner-resource-row{background:var(--resource-row-bg);border-bottom:1px solid var(--border);align-items:center;padding:0 10px;font-size:12.5px;display:flex}.planner-booking-label{white-space:nowrap;text-overflow:ellipsis;border-bottom:1px solid var(--border);align-items:center;padding:0 10px 0 22px;font-size:11px;display:flex;overflow:hidden}.planner-canvas{background:var(--surface);flex:1;overflow:auto hidden}.ws-project-name{cursor:help;-webkit-text-decoration:underline dotted var(--border-strong);text-decoration:underline dotted var(--border-strong);text-underline-offset:2px}.ws-project-name:hover{-webkit-text-decoration-color:var(--text);text-decoration-color:var(--text)}.planner-popover{background:var(--surface);border:1px solid var(--border-strong);box-shadow:var(--shadow-popover);z-index:60;pointer-events:none;border-radius:6px;padding:12px 14px;font-size:12.5px;line-height:1.4;position:fixed}.planner-popover-header{align-items:center;gap:6px;margin-bottom:6px;display:flex}.planner-popover-title{margin-bottom:2px;font-size:13px;font-weight:700}.planner-popover-stats{background:var(--row-hover);border-radius:4px;grid-template-columns:1fr 1fr;gap:10px;margin:4px 0 8px;padding:10px;display:grid}.planner-popover-stat{flex-direction:column;gap:1px;display:flex}.planner-popover-meta{border-top:1px solid var(--border);margin-top:4px;padding-top:6px;font-size:11.5px}.planner-popover-meta>div{margin-top:2px}.planner-popover-footer{margin-top:8px;font-size:10.5px;font-style:italic}.ws-cell-holiday{background:var(--warn);border-radius:50%;width:6px;height:6px;position:absolute;top:-2px;right:-8px}.ws-cell-pto{background:var(--pill-neutral-bg);color:var(--pill-neutral-fg);vertical-align:middle;letter-spacing:.03em;border-radius:3px;margin-left:6px;padding:1px 4px;font-size:9px;font-weight:700;display:inline-block}.overflow-nav{align-items:center;min-width:0;position:relative}.overflow-nav-measure{visibility:hidden;pointer-events:none;white-space:nowrap;display:flex;position:absolute;top:0;left:-99999px}.overflow-nav-measure>span{flex:none;display:inline-flex}.overflow-more{flex:none;position:relative}.overflow-more-btn{font:inherit;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:4px;padding:8px 12px;font-weight:500;display:inline-flex}.overflow-more-btn:hover{background:var(--row-hover)}.overflow-more-caret{font-size:10px;line-height:1}.overflow-more-menu{background:var(--surface);border:1px solid var(--border);z-index:50;border-radius:6px;flex-direction:column;min-width:180px;margin-top:4px;padding:4px;display:flex;position:absolute;top:100%;right:0;box-shadow:0 6px 20px #00000024}.overflow-more-menu a{color:var(--text);white-space:nowrap;cursor:pointer;border-radius:4px;padding:8px 12px;font-weight:500}.overflow-more-menu a:hover{background:var(--row-hover);text-decoration:none}.overflow-more-menu a.active{background:var(--row-hover);color:var(--primary)}.view-tabs .overflow-more-btn{color:var(--text-muted);border-bottom:2px solid #0000;border-radius:0;padding:10px 16px}.view-tabs .overflow-more-btn:hover{color:var(--text);background:0 0}.help-body{color:var(--text-muted);font-size:13.5px}.help-body h3{color:var(--text);margin:0 0 10px;font-size:16px}.help-body h4{text-transform:uppercase;letter-spacing:.4px;color:var(--text);margin:16px 0 4px;font-size:13px}.help-body code{background:var(--row-hover);border:1px solid var(--border);color:var(--text);border-radius:5px;padding:1px 6px;font-size:12px}.help-body ul{margin:6px 0;padding-left:18px}.help-body li{margin:6px 0}.help-body b{color:var(--text)}.help-body table td{font-size:13px}
