:root{--paper: #f1f3f2;--surface: #ffffff;--ink: #101b26;--ink-2: #46545f;--muted: #8a949c;--line: #e0e5e3;--signal: #0e7a5f;--signal-dark: #0a5c48;--signal-wash: #e3f0ec;--warn: #c98500;--warn-wash: #faf3e2;--danger: #d03b3b;--danger-wash: #fbeaea;--tech-1: #2a78d6;--tech-2: #1baf7a;--tech-3: #eda100;--tech-4: #008300;--chart-created: #2a78d6;--chart-scheduled: #0e7a5f;--grid: #e1e0d9;--radius: 6px;--sans: system-ui, -apple-system, "Segoe UI", sans-serif;--mono: ui-monospace, "SF Mono", Menlo, monospace}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{font-family:var(--sans);background:var(--paper);color:var(--ink);font-size:14px;line-height:1.45}a{color:var(--signal);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;cursor:pointer}input,select,textarea{font:inherit;color:var(--ink)}.eyebrow{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}.shell{display:flex;min-height:100vh}.sidebar{width:216px;flex-shrink:0;background:var(--ink);color:#e8edf0;display:flex;flex-direction:column;padding:20px 0;position:sticky;top:0;height:100vh}.sidebar .brand{padding:0 20px 20px;border-bottom:1px solid rgba(255,255,255,.12)}.brand-name{font-weight:800;font-size:15px;letter-spacing:.18em;text-transform:uppercase}.brand-name .dot{color:var(--tech-2)}.brand-sub{font-size:11px;color:#e8edf08c;letter-spacing:.08em;margin-top:2px}.sidebar nav{padding:14px 10px;display:flex;flex-direction:column;gap:2px;flex:1}.sidebar nav a{color:#e8edf0c7;padding:9px 12px;border-radius:var(--radius);font-weight:500}.sidebar nav a:hover{background:#ffffff12;text-decoration:none}.sidebar nav a.active{background:#1baf7a29;color:#fff}.sidebar .whoami{padding:14px 20px 0;border-top:1px solid rgba(255,255,255,.12);font-size:12px}.whoami .name{font-weight:600;color:#fff}.whoami .role{color:#e8edf08c}.whoami button{margin-top:8px;background:none;border:1px solid rgba(255,255,255,.25);color:#e8edf0d9;border-radius:var(--radius);padding:4px 10px;font-size:12px}.whoami button:hover{border-color:#fff9}.main{flex:1;padding:28px 32px 60px;min-width:0}.page-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.page-head h1{font-size:22px;font-weight:750;margin:0;letter-spacing:-.01em}.page-head .sub{color:var(--muted);font-size:13px}.card{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:18px 20px}.card+.card{margin-top:16px}.card h2{font-size:14px;font-weight:700;margin:0 0 12px}table.wo-table{width:100%;border-collapse:collapse}.wo-table th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);padding:8px 10px;border-bottom:1px solid var(--line);white-space:nowrap}.wo-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.wo-table th.sortable:hover{color:var(--ink-2)}.wo-table th .sort-arrow{color:var(--signal)}.wo-table td{padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:top}.wo-table tr.clickable{cursor:pointer}.wo-table tr.clickable:hover td{background:#f6f9f8}.wo-table .cell-main{font-weight:600}.wo-table .cell-sub{color:var(--muted);font-size:12.5px;max-width:380px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:2px 9px 2px 7px;border-radius:99px;border:1px solid var(--line);background:var(--surface);white-space:nowrap}.pill:before{content:"";width:7px;height:7px;border-radius:99px;background:var(--muted)}.pill.s-created:before{background:var(--muted)}.pill.s-assigned:before{background:var(--tech-1)}.pill.s-in_progress:before{background:var(--warn)}.pill.s-done:before{background:var(--signal)}.pill.s-sent_to_visma{background:var(--signal-wash);border-color:transparent}.pill.s-sent_to_visma:before{background:var(--signal-dark)}.pill.s-cancelled{color:var(--muted)}.pill.s-cancelled:before{background:var(--danger)}.type-tag{font-size:11.5px;font-weight:600;color:var(--ink-2)}.btn{border:1px solid var(--line);background:var(--surface);color:var(--ink);border-radius:var(--radius);padding:7px 14px;font-weight:600;font-size:13.5px}.btn:hover{border-color:var(--muted)}.btn.primary{background:var(--signal);border-color:var(--signal);color:#fff}.btn.primary:hover{background:var(--signal-dark)}.btn.danger{color:var(--danger);border-color:#e7c3c3}.btn.danger:hover{background:var(--danger-wash)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.sm{padding:4px 10px;font-size:12.5px}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.field label{font-size:12px;font-weight:650;color:var(--ink-2)}.field input,.field select,.field textarea{border:1px solid var(--line);border-radius:var(--radius);padding:7px 10px;background:var(--surface);width:100%}.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--signal);outline-offset:-1px;border-color:var(--signal)}.field textarea{resize:vertical;min-height:64px}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));column-gap:16px}.form-grid .span-2{grid-column:span 2}.form-grid .span-all{grid-column:1 / -1}@media(max-width:700px){.form-grid .span-2{grid-column:span 1}}.filter-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:14px}.filter-row input,.filter-row select{border:1px solid var(--line);border-radius:var(--radius);padding:6px 10px;background:var(--surface)}.error-banner{background:var(--danger-wash);border:1px solid #e7c3c3;color:#8c2626;border-radius:var(--radius);padding:9px 12px;margin-bottom:14px;font-size:13px}.ok-banner{background:var(--signal-wash);border:1px solid #bcdcd2;color:var(--signal-dark);border-radius:var(--radius);padding:9px 12px;margin-bottom:14px;font-size:13px}.modal-backdrop{position:fixed;inset:0;background:#101b2673;display:flex;align-items:flex-start;justify-content:center;padding:8vh 16px 16px;z-index:40;overflow-y:auto}.modal{background:var(--surface);border-radius:12px;padding:22px 24px;width:100%;max-width:560px;box-shadow:0 18px 50px #101b264d}.modal h2{margin:0 0 14px;font-size:16px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.occ-strip{display:flex;flex-direction:column;gap:8px;margin:12px 0 4px}.occ-row{display:grid;grid-template-columns:110px 1fr 64px;gap:10px;align-items:center;padding:7px 10px;border:1px solid var(--line);border-radius:var(--radius);cursor:pointer;background:var(--surface)}.occ-row:hover{border-color:var(--muted)}.occ-row.selected{border-color:var(--signal);outline:2px solid var(--signal);outline-offset:-1px}.occ-row .occ-name{font-weight:650;font-size:13px}.occ-bar{height:10px;background:var(--paper);border-radius:99px;overflow:hidden;position:relative}.occ-bar .fill{position:absolute;inset:0 auto 0 0;border-radius:99px;background:var(--signal);min-width:2px}.occ-bar .fill.warn{background:var(--warn)}.occ-bar .fill.over{background:var(--danger)}.occ-count{font-family:var(--mono);font-size:12.5px;text-align:right;color:var(--ink-2)}.occ-count .over{color:var(--danger);font-weight:700}.detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px;align-items:start}@media(max-width:950px){.detail-grid{grid-template-columns:1fr}}.kv{display:grid;grid-template-columns:170px 1fr;row-gap:8px;column-gap:14px}.kv dt{color:var(--muted);font-size:12.5px;padding-top:1px}.kv dd{margin:0;white-space:pre-wrap;word-break:break-word}.action-stack{display:flex;flex-direction:column;gap:8px}.action-stack .btn{width:100%}.checklist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.checklist li{display:flex;gap:8px;align-items:baseline;font-size:13px}.checklist .mark{font-weight:800}.checklist .ok .mark{color:var(--signal)}.checklist .miss,.checklist .miss .mark{color:var(--warn)}.tech-section{margin-bottom:26px}.tech-section>.eyebrow{display:block;margin-bottom:8px}.tech-section.current-week{background:var(--signal-wash);border:1px solid var(--signal);border-radius:12px;padding:14px 16px;box-shadow:0 2px 10px #0e7a5f1f}.tech-section.current-week>.eyebrow{color:var(--signal-dark)}.tech-section.tone-upcoming>.eyebrow,.tech-section.tone-previous>.eyebrow{border-left:3px solid;padding-left:8px}.tech-section.tone-upcoming>.eyebrow{color:var(--tech-1);border-color:var(--tech-1)}.tech-section.tone-previous>.eyebrow{color:var(--muted);border-color:var(--muted)}.wo-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px}.wo-card{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:14px 16px;cursor:pointer;display:flex;flex-direction:column;gap:6px}.wo-card:hover{border-color:var(--muted)}.wo-card .top{display:flex;justify-content:space-between;align-items:center;gap:8px}.wo-card .customer{font-weight:700}.wo-card .desc{color:var(--ink-2);font-size:13px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.wo-card .meta{color:var(--muted);font-size:12px}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--ink);padding:20px}.login-card{background:var(--surface);border-radius:14px;padding:34px 36px;width:100%;max-width:640px}.login-card h1{font-size:18px;letter-spacing:.16em;text-transform:uppercase;margin:0}.login-card h1 .dot{color:var(--signal)}.login-card .sub{color:var(--muted);margin:4px 0 22px}.login-roles{display:flex;flex-direction:column;gap:16px}.login-users{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.user-chip{border:1px solid var(--line);background:var(--surface);border-radius:99px;padding:7px 14px;font-weight:600}.user-chip:hover{border-color:var(--signal);color:var(--signal)}.chart-figure{margin:0}.chart-figure figcaption{font-size:13px;font-weight:700;margin-bottom:2px}.chart-figure .chart-sub{font-size:12px;color:var(--muted);margin-bottom:10px}.legend{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:8px}.legend .item{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink-2)}.legend button.item{border:0;background:none;padding:0;font:inherit;cursor:pointer}.legend button.item.off{opacity:.4;text-decoration:line-through}.legend .swatch{width:10px;height:10px;border-radius:3px}.chart-tip{position:fixed;pointer-events:none;background:var(--ink);color:#fff;border-radius:6px;padding:7px 10px;font-size:12px;z-index:60;transform:translate(-50%,calc(-100% - 10px));white-space:nowrap;box-shadow:0 4px 14px #00000040}.chart-tip .tip-title{font-weight:700;margin-bottom:2px}.chart-tip .tip-row{display:flex;align-items:center;gap:6px}.chart-tip .swatch{width:8px;height:8px;border-radius:2px}.stat-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:16px}.stat-tile{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:14px 16px}.stat-tile .value{font-size:26px;font-weight:750;letter-spacing:-.02em}.stat-tile .label{font-size:12px;color:var(--muted);font-weight:600}.charts-grid{display:grid;grid-template-columns:1fr;gap:16px}.inline-form{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}.inline-form .field{margin-bottom:0;min-width:150px}.empty{color:var(--muted);padding:22px 0;text-align:center;font-size:13.5px}@media(max-width:800px){.shell{flex-direction:column}.sidebar{width:100%;height:auto;position:static;flex-direction:row;align-items:center;flex-wrap:wrap;padding:10px}.sidebar .brand{border:none;padding:6px 12px}.sidebar nav{flex-direction:row;flex-wrap:wrap;padding:0}.sidebar .whoami{border:none;padding:6px 12px}.main{padding:18px 14px 40px}.tech-section .wo-table thead{display:none}.tech-section .wo-table,.tech-section .wo-table tbody,.tech-section .wo-table tr{display:block}.tech-section .wo-table tr{border:1px solid var(--line);border-radius:10px;padding:6px 12px;margin-bottom:10px;background:var(--surface)}.tech-section .wo-table td{display:flex;justify-content:space-between;gap:12px;align-items:baseline;padding:6px 0;border-bottom:1px solid var(--line);text-align:right}.tech-section .wo-table tr td:last-child{border-bottom:0}.tech-section .wo-table td:before{content:attr(data-label);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);text-align:left}.tech-section.current-week .wo-table tr{background:#fff}}
