:root{--bg: #0f1419;--panel: #1a2230;--panel2: #222b3b;--border: #2a3447;--text: #e8edf5;--muted: #8a96aa;--accent: #4f8cff;--th-bg: #172033;--ok: #2ecc71;--warn: #f5a623;--bad: #ef4444;--info: #5fb6ff;--soft: #7a8cb0}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,sans-serif;font-size:14px}a{color:var(--accent)}.app{max-width:1280px;margin:0 auto;padding:16px 20px 60px}header.top{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding-bottom:12px;border-bottom:1px solid var(--border);margin-bottom:16px}header.top h1{font-size:18px;margin:0}header.top .spacer{flex:1}select,input[type=text],input[type=date]{background:var(--panel2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:6px 9px;font-size:14px}button{background:var(--panel2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:6px 12px;cursor:pointer;font-size:14px}button:hover{border-color:var(--accent)}button.primary{background:#0e7490;border-color:#0e7490}button.primary:hover{background:#0891b2}.tabs{display:flex;gap:6px;margin-bottom:16px}.tabs button{padding:8px 16px}.tabs button.active{background:var(--panel);border-color:var(--accent);color:var(--accent)}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-bottom:20px}.card{position:relative;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px 18px;transition:border-color .15s}.card:hover{border-color:var(--accent)}.card .label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.card .value{font-size:28px;font-weight:600;line-height:1;white-space:nowrap}.card .value.compact{font-size:18px}.card .sub{color:var(--muted);font-size:12px;margin-top:8px}.card .accent{position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:12px 0 0 12px}.card.c-total .accent{background:var(--accent)}.card.c-done .accent{background:var(--ok)}.card.c-progress .accent{background:var(--info)}.card.c-upcoming .accent{background:var(--soft)}.card.c-late .accent{background:var(--bad)}.card.c-warn .accent{background:var(--warn)}.card.c-slip .accent{background:#ff7ab8}.card.c-paid .accent{background:#9f7aea}.panel{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:20px}.panel h2{font-size:14px;margin:0 0 12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}table{width:100%;border-collapse:collapse;font-size:13px}th,td{text-align:left;padding:7px 10px;border-bottom:1px solid var(--border)}th{color:var(--muted);font-weight:500;position:sticky;top:0;background:var(--th-bg);text-transform:uppercase;font-size:11px;letter-spacing:.04em}td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}tr:hover td{background:var(--panel2)}.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap;background:var(--panel2)}.badge .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.badge.bs{background:#4f8cff1f;color:#a8c4ff;font-weight:500}.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:999px;background:var(--panel2);color:var(--muted);font-size:12px;border:1px solid transparent;cursor:pointer;-webkit-user-select:none;user-select:none}.chip:hover{color:var(--text)}.chip.active{border-color:var(--accent);color:var(--text);background:#4f8cff1f}.chip .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}td.dates b{color:var(--text);font-weight:500}td.comment-col{max-width:260px;font-size:12.5px;line-height:1.4;white-space:normal}.contract-pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:12px;white-space:nowrap;background:var(--panel2);color:var(--muted)}.contract-pill.yes{background:#2ecc711f;color:#7ee2a8}.contract-pill.no{background:#ef44441f;color:#ff9b9b}.pill{display:inline-block;padding:1px 7px;border-radius:6px;background:var(--panel2);border:1px solid var(--border);color:var(--muted);font-size:12px}.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:12px}.filters label{color:var(--muted);font-size:12px;display:flex;gap:5px;align-items:center}.table-wrap{max-height:560px;overflow:auto;border:1px solid var(--border);border-radius:8px}.table-wrap.fill{max-height:calc(100vh - 300px);min-height:340px}td.dates{white-space:nowrap}.muted{color:var(--muted)}.delay{color:#f87171;font-weight:600}.right{text-align:right}.bar{height:8px;border-radius:4px;background:var(--panel2);overflow:hidden;display:flex}.bar>span{height:100%}.note{color:var(--muted);font-size:12px;margin-top:8px}.error{color:#f87171;padding:8px 0}.dropzone{border:1px dashed var(--border);border-radius:8px;padding:18px;text-align:center;color:var(--muted)}.bs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.bs-card{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:12px 14px}.bs-card .bs-name{font-size:13px;font-weight:600;color:var(--text)}.bs-card .bs-counts{margin-top:6px;color:var(--muted);font-size:12px}.bs-card .bs-bar{display:flex;height:6px;border-radius:3px;overflow:hidden;margin-top:8px;background:var(--panel2)}.bs-card .bs-bar>span{display:block;height:100%}.bs-card .bs-bar .b-on{background:var(--ok)}.bs-card .bs-bar .b-prog{background:var(--info)}.bs-card .bs-bar .b-upc{background:var(--soft)}.bs-card .bs-delay{margin-top:6px;color:var(--bad);font-size:12px;font-weight:600}.bs-card .bs-delay.zero{color:var(--muted);font-weight:400}.bs-card.clickable{cursor:pointer;transition:border-color .15s,box-shadow .15s}.bs-card.clickable:hover{border-color:var(--accent)}.bs-card.active{border-color:var(--accent);box-shadow:0 0 0 2px #4f8cff40}.grp-title{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:16px 0 8px;display:flex;align-items:center;gap:12px}.grp-reset{color:#ff8a8a;cursor:pointer;font-size:12px;text-transform:none;letter-spacing:normal}.grp-reset:hover{color:#ffb0b0}.timeline{padding:6px 2px}.tl-track{position:relative;height:26px;background:var(--panel2);border:1px solid var(--border);border-radius:6px;overflow:hidden}.tl-zone{position:absolute;top:0;height:100%}.tl-zone.done{left:0;background:linear-gradient(90deg,#15803d,#22c55e)}.tl-zone.lag{background:repeating-linear-gradient(45deg,#f59e0b,#f59e0b 5px,transparent 5px,transparent 10px)}.tl-today{position:absolute;top:-4px;width:3px;height:calc(100% + 8px);background:#38bdf8;box-shadow:0 0 6px #38bdf8}.tl-labels{display:flex;justify-content:space-between;font-size:12px;margin-top:6px}
