:root{--brand:#1d4ed8;--brand-dark:#1e40af;--bg:#f6f8fb;--surface:#ffffff;--text:#0f172a;--muted:#64748b;--border:#e2e8f0;--border-strong:#cbd5e1;--neutral:#475569;--neutral-bg:#f1f5f9;--ok:#047857;--ok-bg:#d1fae5;--warn:#b45309;--warn-bg:#fef3c7;--bad:#b91c1c;--bad-bg:#fee2e2;--precon:#64748b;--underground:#b45309;--topout:#1d4ed8;--final:#047857;--shadow:0 1px 3px rgba(15,23,42,.08), 0 6px 18px rgba(15,23,42,.06)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;font-size:14px}a{color:var(--brand);text-decoration:none}code,.mono{font-family:ui-monospace,Menlo,monospace}.app{min-height:100%;display:flex;flex-direction:column}.wrap{max-width:1400px;margin:0 auto;width:100%;padding:18px}.topbar{position:sticky;top:0;z-index:20;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;padding:10px 18px}.topbar .logo{height:34px}.topbar .spacer{flex:1}.tabs{display:flex;gap:4px}.tab{border:0;background:transparent;color:var(--muted);font-weight:600;font-size:14px;padding:8px 12px;border-radius:8px;cursor:pointer}.tab:hover{background:var(--neutral-bg)}.tab.on{background:var(--brand);color:#fff}.menu{position:relative}.menu-btn{display:flex;align-items:center;gap:8px;border:1px solid var(--border-strong);background:#fff;border-radius:9px;padding:6px 10px;cursor:pointer;font-weight:600;color:var(--text)}.menu-pop{position:absolute;right:0;top:110%;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);min-width:200px;padding:6px;z-index:30}.menu-pop a,.menu-pop button{display:flex;width:100%;text-align:left;gap:8px;align-items:center;border:0;background:none;padding:9px 10px;border-radius:8px;cursor:pointer;font:inherit;color:var(--text)}.menu-pop a:hover,.menu-pop button:hover{background:var(--neutral-bg)}.avatar{width:28px;height:28px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}.btn{font:inherit;cursor:pointer;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);padding:7px 12px;border-radius:6px;font-weight:600}.btn:hover{background:#f3f6f8}.btn.primary{background:var(--brand);border-color:var(--brand);color:#fff}.btn.primary:hover{background:var(--brand-dark)}.btn.danger{background:var(--bad-bg);border-color:#f3d6d6;color:var(--bad)}.btn.sm{padding:4px 9px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow)}.card h2{font-size:14px;margin:0;padding:13px 16px;border-bottom:1px solid var(--border);font-weight:700;display:flex;align-items:center;gap:8px}.card h2 .count{color:var(--muted);font-weight:600;font-size:12px;margin-left:auto}.kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin:16px 0}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px;box-shadow:var(--shadow);cursor:pointer;border:2px solid transparent}.kpi.active{border-color:var(--brand)}.kpi .n{font-size:24px;font-weight:800;line-height:1}.kpi .l{font-size:11px;color:var(--muted);margin-top:6px;text-transform:uppercase;letter-spacing:.4px}.kpi .dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:5px}.controls{display:flex;flex-wrap:wrap;gap:10px;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px;margin-bottom:14px}.seg{display:inline-flex;border:1px solid var(--border);border-radius:9px;overflow:hidden}.seg button{border:0;background:#fff;padding:7px 12px;cursor:pointer;color:var(--muted);font-weight:600;font-size:13px}.seg button.on{background:var(--brand);color:#fff}label.lbl{font-size:12px;color:var(--muted);font-weight:600}select,input[type=text],input[type=search],input[type=date],input[type=number],textarea{border:1px solid var(--border-strong);border-radius:8px;padding:7px 9px;font:inherit;background:#fff;color:var(--text)}textarea{min-height:54px;resize:vertical;width:100%}.gantt-scroll{overflow-x:auto}.gantt{position:relative;min-width:760px}.grow{display:flex;border-bottom:1px solid var(--border);min-height:46px}.grow:hover{background:#f8fafb}.glabel{flex:0 0 280px;width:280px;padding:7px 12px;position:sticky;left:0;background:#fff;z-index:3;border-right:1px solid var(--border);cursor:pointer}.grow:hover .glabel{background:#f8fafb}.glabel .pn{font-weight:700;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.glabel .pmeta{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.gtrack{position:relative;flex:1}.axis{position:sticky;top:0;z-index:4;background:#fff;border-bottom:1px solid var(--border)}.axis .glabel{display:flex;align-items:center;font-weight:700;font-size:12px;color:var(--muted);text-transform:uppercase}.axis .gtrack{height:38px}.tick{position:absolute;top:0;bottom:0;border-left:1px solid var(--border)}.tick.major{border-left:1px solid var(--border-strong)}.tlabel{position:absolute;top:5px;font-size:11px;color:var(--muted);font-weight:600;white-space:nowrap;padding-left:5px}.tlabel.sub{top:21px;font-size:10px;font-weight:500;opacity:.8}.today{position:absolute;top:0;bottom:0;width:2px;background:#e23b3b;z-index:2;pointer-events:none}.today .flag{position:absolute;top:0;left:3px;background:#e23b3b;color:#fff;font-size:9px;padding:1px 4px;border-radius:3px;font-weight:700}.bar{position:absolute;height:24px;top:50%;transform:translateY(-50%);border-radius:6px;cursor:grab;display:flex;align-items:center;overflow:hidden;box-shadow:0 1px 2px #0003}.bar.upcoming{opacity:.5;background-image:repeating-linear-gradient(45deg,transparent,transparent 4px,rgba(255,255,255,.45) 4px,rgba(255,255,255,.45) 8px)}.bar .blabel{font-size:11px;font-weight:700;color:#fff;padding:0 8px;white-space:nowrap;text-shadow:0 1px 1px rgba(0,0,0,.3)}.rhandle{position:absolute;right:0;top:0;bottom:0;width:8px;cursor:ew-resize}.rhandle:hover{background:#ffffff80}.twocol{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width:1000px){.twocol{grid-template-columns:1fr}.kpis{grid-template-columns:repeat(3,1fr)}}.ms-list{list-style:none;margin:0;padding:6px 0;max-height:360px;overflow:auto}.ms-list li{display:flex;gap:10px;align-items:center;padding:8px 16px;border-bottom:1px solid #f0f3f5;cursor:pointer}.ms-list li:hover{background:#f8fafb}.ms-date{flex:0 0 64px;font-weight:700;font-size:12px}.ms-date small{display:block;font-weight:500;color:var(--muted);font-size:10px}.pill{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;color:#fff;white-space:nowrap}.late{color:var(--bad);font-weight:800}table.tbl{width:100%;border-collapse:collapse}table.tbl th,table.tbl td{text-align:left;padding:8px 12px;border-bottom:1px solid #f0f3f5;font-size:13px;vertical-align:top}table.tbl th{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c182473;z-index:40}.drawer{position:fixed;top:0;right:0;height:100%;width:440px;max-width:94vw;background:#fff;box-shadow:-8px 0 30px #0000002e;z-index:41;display:flex;flex-direction:column}.drawer .dhead{padding:16px 18px;background:linear-gradient(120deg,var(--brand),var(--brand-dark));color:#fff;position:relative}.drawer .dhead h3{margin:4px 0 2px;font-size:18px}.drawer .dbody{padding:6px 18px 24px;overflow:auto}.dclose{position:absolute;top:14px;right:14px;background:#fff3;border:0;color:#fff;width:30px;height:30px;border-radius:8px;cursor:pointer;font-size:16px}.field{margin:10px 0}.field label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:700;margin-bottom:4px}.field input,.field select,.field textarea{width:100%}.frow{display:flex;gap:8px}.frow>*{flex:1}.editbar{border-top:1px solid var(--border);padding:12px 18px;display:flex;gap:8px;align-items:center}.badge{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;color:#fff}.modal-wrap{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c182480;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:#fff;border-radius:14px;width:420px;max-width:94vw;box-shadow:var(--shadow);overflow:hidden}.modal h3{margin:0;padding:16px 18px;border-bottom:1px solid var(--border);font-size:16px}.modal .mbody{padding:14px 18px}.modal .mfoot{padding:12px 18px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}.login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login .box{background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:30px;width:380px;max-width:92vw;text-align:center}.login img{height:48px;margin-bottom:8px}.login h1{font-size:18px;margin:6px 0 2px}.login p{color:var(--muted);margin:0 0 20px;font-size:13px}.gbtn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;border:1px solid var(--border-strong);background:#fff;border-radius:9px;padding:11px;font-weight:600;cursor:pointer;font-size:14px}.gbtn:hover{background:#f3f6f8}.divider{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:12px;margin:16px 0}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}.muted{color:var(--muted)}.err{background:var(--bad-bg);color:var(--bad);border-radius:8px;padding:8px 10px;font-size:13px;margin:10px 0}.empty{padding:24px;text-align:center;color:var(--muted)}.center{display:flex;align-items:center;justify-content:center;min-height:60vh;color:var(--muted)}.diff{font-size:12px;background:var(--neutral-bg);border-radius:8px;padding:8px;margin-top:6px}.diff .k{font-weight:700}
