:root{--bg:#f4f6f9;--panel:#fff;--ink:#1f2733;--muted:#64748b;--line:#e3e8ef;--brand:#1f5fa6;--brand-dark:#16487f;--good:#15803d;--good-bg:#dcfce7;--warn:#b45309;--warn-bg:#fef3c7;--bad:#b91c1c;--bad-bg:#fee2e2;--row-alt:#f8fafc;--calc:#f1f5f9;--neg:#b91c1c}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:13px}button{font-family:inherit;cursor:pointer}a{cursor:pointer}code{background:#eef2f7;border:1px solid var(--line);border-radius:4px;padding:0 4px;font-size:11px}.center{display:grid;place-items:center;height:100vh}.pad{padding:24px}.muted{color:var(--muted)}.neg{color:var(--neg)}.err{color:var(--bad);font-size:12px}.ok-note{color:var(--good);font-size:12px}.consent{display:flex;align-items:flex-start;gap:8px;font-size:12px;margin:4px 0 8px;line-height:1.4}.consent input{margin-top:2px}.consent a{text-decoration:underline}.btn.danger{border-color:var(--bad);color:var(--bad)}.btn.danger:hover:not(:disabled){background:var(--bad);color:#fff}.ghost-btn{background:none;border:1px solid var(--border,#d0d5dd);border-radius:6px;padding:5px 10px;margin-right:8px;cursor:pointer;font-size:13px;color:inherit}.ghost-btn:hover{background:#0000000a}.onboarding{max-width:680px;margin:32px auto;padding:0 16px}.onboarding h1{margin:0 0 4px}.onb-actions{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0}.getting-started{margin:8px 0 0;padding-left:20px}.getting-started li{margin:0 0 12px}.getting-started li b{display:block}.getting-started li span{color:var(--muted,#667085);font-size:13px}.legal-page{max-width:760px;margin:24px auto;padding:0 16px}.legal-card{background:#fff;border:1px solid var(--border,#e4e7ec);border-radius:10px;padding:28px 32px}.legal-back{display:inline-block;margin-bottom:12px;font-size:13px}.md h1{font-size:24px;margin:0 0 12px}.md h2{font-size:17px;margin:22px 0 6px}.md h3{font-size:15px;margin:16px 0 4px}.md p{margin:0 0 10px;line-height:1.55}.md ul{margin:0 0 10px;padding-left:20px}.md li{margin:0 0 4px;line-height:1.5}.md blockquote{margin:0 0 16px;padding:10px 14px;background:#fff7ed;border-left:3px solid #f59e0b;border-radius:4px;font-size:13px}.app{display:flex;flex-direction:column;height:100vh;min-width:1100px}header{display:flex;align-items:center;gap:16px;background:var(--brand);color:#fff;padding:0 20px;height:54px;flex:0 0 auto}.logo{display:flex;align-items:center;gap:9px;font-weight:700;font-size:15px}.logo .mark{width:24px;height:24px;border-radius:5px;background:#fff;color:var(--brand);display:grid;place-items:center;font-weight:800}.proj-select{background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.35);border-radius:6px;padding:6px 10px;font-size:13px}.proj-select option{color:#1f2733}.proj-meta{color:#ffffffd9;font-size:12px}.spacer{flex:1}.um{position:relative}.um-btn{display:flex;align-items:center;gap:9px;background:#ffffff1f;border:1px solid rgba(255,255,255,.3);border-radius:8px;padding:5px 9px;color:#fff;font-size:12px}.avatar{width:26px;height:26px;border-radius:50%;background:var(--brand-dark);display:grid;place-items:center;font-weight:700}.um-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:29}.um-menu{position:absolute;right:0;top:115%;background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:10px;box-shadow:0 12px 30px #0003;width:220px;z-index:30;overflow:hidden}.um-menu .hd{padding:12px 14px;border-bottom:1px solid var(--line);font-size:12px;color:var(--muted)}.um-menu button{display:block;width:100%;text-align:left;border:none;background:none;padding:10px 14px;font-size:13px}.um-menu button:hover{background:var(--row-alt)}.body{display:flex;flex:1;min-height:0}nav.side{flex:0 0 188px;background:var(--panel);border-right:1px solid var(--line);padding:14px 10px;display:flex;flex-direction:column;gap:3px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:7px;color:var(--muted);font-weight:600;font-size:13px;text-decoration:none}.nav-item:hover{background:var(--row-alt);color:var(--ink)}.nav-item.active{background:#eaf2fb;color:var(--brand-dark)}.nav-item .ic{width:18px;text-align:center}main{flex:1;min-width:0;overflow:auto;padding:20px 24px 60px}.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:16px;gap:16px;flex-wrap:wrap}.page-head h1{font-size:20px;margin:0}.page-head .sub{color:var(--muted);font-size:12px;margin-top:3px}.kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:18px}.kpi{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:12px 14px}.kpi .label{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px}.kpi .val{font-size:17px;font-weight:700;margin-top:5px}.btn{border:1px solid var(--line);background:#fff;border-radius:7px;padding:7px 13px;font-weight:600;font-size:12px;color:var(--ink)}.btn:hover{background:var(--row-alt)}.btn.primary{background:var(--brand);border-color:var(--brand);color:#fff}.btn.primary:hover{background:var(--brand-dark)}.btn.block{width:100%;padding:11px;font-size:14px}input,select{font-family:inherit;font-size:12px;border:1px solid var(--line);border-radius:6px;padding:7px 9px;color:var(--ink);background:#fff}input:focus,select:focus{outline:2px solid #bcd4ef;border-color:var(--brand)}.table-wrap{background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:auto}table.budget{border-collapse:separate;border-spacing:0;width:max-content;min-width:100%;font-size:12px}table.budget th,table.budget td{padding:7px 10px;border-bottom:1px solid var(--line);white-space:nowrap;text-align:right}table.budget thead th{position:sticky;top:0;z-index:3;background:#eef2f7;color:#46556a;font-size:10.5px;text-transform:uppercase;letter-spacing:.3px;font-weight:700;border-bottom:2px solid #d4dce6}table.budget th.l,table.budget td.l{text-align:left}.col-code{position:sticky;left:0;background:inherit;min-width:96px}.col-desc{position:sticky;left:96px;background:inherit;min-width:230px;box-shadow:6px 0 6px -6px #0000001f}thead .col-code,thead .col-desc{z-index:5;background:#eef2f7}tr.cat{background:#eaf1f9;font-weight:700}tr.cat .col-code,tr.cat .col-desc{background:#eaf1f9}tr.sub{background:#f3f7fb;font-weight:600}tr.sub .col-code,tr.sub .col-desc{background:#f3f7fb}tr.leaf,tr.leaf .col-code,tr.leaf .col-desc{background:#fff}tr.leaf:hover,tr.leaf:hover .col-code,tr.leaf:hover .col-desc{background:#eef6ff}tr.grand{font-weight:800;background:#dfe8f2}tr.grand .col-code,tr.grand .col-desc{background:#dfe8f2}tr.grand td{border-top:2px solid #b9c7d8}.twirl{display:inline-block;width:14px;cursor:pointer;color:var(--muted);font-size:10px}.editable{cursor:pointer;border-radius:4px;padding:1px 3px}.editable:hover{box-shadow:inset 0 0 0 1px #b9cfe6;background:#f0f7ff}.cell-input{width:100%;padding:3px 5px;font-size:12px;border:1px solid var(--brand);border-radius:4px}table.inv{border-collapse:separate;border-spacing:0;width:100%;font-size:12px;background:var(--panel)}table.inv th,table.inv td{padding:9px 12px;border-bottom:1px solid var(--line);text-align:left}table.inv thead th{background:#eef2f7;color:#46556a;font-size:10.5px;text-transform:uppercase;letter-spacing:.3px;font-weight:700}.pill{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11px;font-weight:700}.pill.good{background:var(--good-bg);color:var(--good)}.pill.warn{background:var(--warn-bg);color:var(--warn)}.pill.bad{background:var(--bad-bg);color:var(--bad)}.banner{background:#fff8e6;border:1px solid #f3e2b3;color:#8a6d1f;border-radius:8px;padding:9px 13px;font-size:12px;margin-bottom:14px}.legend{font-size:11px;color:var(--muted);margin-top:10px;display:flex;gap:18px;flex-wrap:wrap}.cat-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:14px 16px}.drow{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--line);font-size:12px}.auth-wrap{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#1f5fa6,#16487f);padding:20px}.auth-card{background:#fff;border-radius:14px;box-shadow:0 24px 60px #0000004d;width:100%;max-width:400px;padding:28px}.auth-card .logo{color:var(--brand);justify-content:center;font-size:18px}.auth-card .mark{background:var(--brand);color:#fff}.auth-subtitle{text-align:center;color:var(--muted);font-size:12px;margin-top:4px}.auth-tabs{display:flex;gap:6px;margin:18px 0 16px;background:#f1f5f9;padding:4px;border-radius:8px}.auth-tabs button{flex:1;border:none;background:none;padding:8px;border-radius:6px;font-weight:600;font-size:13px;color:var(--muted)}.auth-tabs button.active{background:#fff;color:var(--brand-dark);box-shadow:0 1px 3px #0000001a}.field{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}.field label{font-size:11px;font-weight:700;color:#46556a;text-transform:uppercase;letter-spacing:.3px}.sig-styles{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:10px 0}.sig-style{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:56px;padding:8px;border:1px solid var(--line, #d8dde5);border-radius:8px;background:#fff;cursor:pointer;overflow:hidden}.sig-style:hover{border-color:var(--accent, #2563eb)}.sig-style.active{border-color:var(--accent, #2563eb);box-shadow:0 0 0 1px var(--accent, #2563eb) inset;background:#f5f8ff}.sig-style span{white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}.sig-preview{display:flex;align-items:center;justify-content:center;min-height:84px;border:1px dashed var(--line, #d8dde5);border-radius:8px;background:repeating-conic-gradient(#f6f7f9,#f6f7f9 25%,#fff 0%,#fff 50%) 50% / 16px 16px}} .rel{position:relative}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9}.col-menu{position:absolute;top:110%;left:0;z-index:10;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 12px 30px #0000002e;padding:10px 12px;width:210px;max-height:340px;overflow:auto}.col-menu-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:12px}.col-menu-hd a{font-size:11px;color:var(--brand)}.col-menu label{display:flex;gap:7px;align-items:center;padding:3px 2px;font-size:12px;cursor:pointer}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:grid;place-items:center;z-index:50;padding:24px}.modal{background:#fff;border-radius:12px;width:100%;max-width:680px;max-height:90vh;overflow:auto;box-shadow:0 20px 60px #0000004d}.modal.lg{max-width:860px}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#fff;z-index:2}.modal-head h3{margin:0;font-size:16px}.modal-body{padding:18px 20px}.modal-foot{padding:14px 20px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px;position:sticky;bottom:0;background:#fff}.x{border:none;background:none;font-size:20px;color:var(--muted);line-height:1}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field.full{grid-column:1 / -1}.field .help{font-size:11px;color:var(--muted);font-weight:400;text-transform:none;letter-spacing:0}.banner.info{background:#eef6ff;border-color:#bcd4ef;color:#16487f}.toasts{position:fixed;right:18px;bottom:18px;display:flex;flex-direction:column;gap:8px;z-index:80}.toast{background:#1f2733;color:#fff;padding:10px 14px;border-radius:8px;font-size:12px;box-shadow:0 8px 24px #00000040;min-width:200px}.toast.good{background:#15803d}.toast.bad{background:#b91c1c}.kpi .meta{font-size:11px;margin-top:4px;color:var(--muted)}.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:12px}.cat-card-hd{display:flex;justify-content:space-between;align-items:center}.cat-card-hd h4{margin:0;font-size:13px}.small{font-size:11px}.bar{height:7px;border-radius:5px;background:#e9eef4;overflow:hidden;margin-top:9px}.bar>span{display:block;height:100%}.search{flex:1;max-width:240px}.link{color:var(--brand);font-weight:600;cursor:pointer}.center-cell{text-align:center;padding:22px}.alloc-cell{white-space:normal;max-width:300px}.chip{display:inline-block;background:#eef2f7;border:1px solid var(--line);border-radius:5px;padding:1px 6px;font-size:11px;margin:1px 3px 1px 0;white-space:nowrap}.stat{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11px;font-weight:700;border:none}.stat.pending_approval{background:#fef3c7;color:#b45309}.stat.approved{background:var(--good-bg);color:var(--good)}.stat.paid{background:#ede9fe;color:#6d28d9}select.stat{padding:3px 8px;font-weight:700}.dropzone{border:2px dashed #c5d3e2;border-radius:10px;padding:20px;text-align:center;color:var(--muted);background:#f8fbff;cursor:pointer;margin-bottom:16px}.dropzone strong{color:var(--brand)}.mt4{margin-top:4px}.mt8{margin-top:8px}.mt16{margin-top:16px}.ocrbar{height:6px;border-radius:4px;background:#e2e8f0;overflow:hidden;margin-top:8px}.ocrbar>span{display:block;height:100%;background:var(--brand)}.auto-badge{font-size:9px;background:#dcfce7;color:#15803d;border-radius:4px;padding:1px 5px;margin-left:6px;font-weight:700;vertical-align:middle}input.autofilled{background:#f0fdf4;border-color:#86efac}.section-label{font-size:11px;font-weight:700;color:#46556a;text-transform:uppercase;letter-spacing:.3px}.alloc-row{display:grid;grid-template-columns:2.4fr 1fr 1.2fr auto;gap:8px;align-items:end;margin-bottom:8px}.alloc-row .field label{font-size:10px}.alloc-foot{display:flex;justify-content:space-between;align-items:center;margin-top:4px}.alloc-sum{font-weight:700;font-size:12px}.inv-preview{border:1px solid var(--line);border-radius:10px;padding:24px 28px;max-width:560px;margin:0 auto}.inv-preview-hd{display:flex;justify-content:space-between;border-bottom:2px solid var(--ink);padding-bottom:10px}.vbig{font-size:18px;font-weight:800;letter-spacing:.5px}.inv-preview-meta{display:flex;justify-content:space-between;margin:14px 0;font-size:12px}table.mini{width:100%;border-collapse:collapse;font-size:12px}table.mini th,table.mini td{border-bottom:1px solid #f1f5f9;padding:6px 0;text-align:left}.inv-preview-total{display:flex;justify-content:space-between;border-top:2px solid var(--ink);margin-top:8px;padding-top:10px;font-size:15px;font-weight:800}.filter-bar{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap;margin-bottom:10px}.filt{display:flex;flex-direction:column;gap:3px;font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.3px}.filt select,.filt input{font-weight:400;text-transform:none;letter-spacing:0}.filt .range{display:flex;align-items:center;gap:4px}.filt .range input{width:90px}.warn-banner{background:#fff8e6;border:1px solid #f3e2b3;color:#8a6d1f;border-radius:8px;padding:9px 13px;font-size:12.5px;margin-bottom:14px;font-weight:600}.acct-section{padding:12px 0;border-bottom:1px solid var(--line)}.acct-section:last-of-type{border-bottom:none}.acct-row{display:flex;gap:8px;align-items:center}.acct-row input{flex:1}.mb14{margin-bottom:14px}.rtabs{display:flex;gap:4px;border-bottom:2px solid var(--line);margin-bottom:16px}.rtabs button{border:none;background:none;padding:9px 14px;font-weight:600;font-size:13px;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-2px}.rtabs button.active{color:var(--brand-dark);border-bottom-color:var(--brand)}.rtabs button:hover{color:var(--ink)}.kpis-3{grid-template-columns:repeat(3,1fr)}.banner.exec{font-size:13px;line-height:1.55}.chart-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:16px 18px;margin-bottom:16px}.chart-card h3{font-size:14px;margin:0 0 2px}.csub{color:var(--muted);font-size:12px;margin-bottom:10px}.swatch{display:inline-block;width:11px;height:11px;border-radius:3px;vertical-align:middle;margin-right:5px}.cont-panel{margin-bottom:16px}.cont-hd{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:10px}.cont-hd h4{margin:0;font-size:14px}.stack-bar{display:flex;height:14px;border-radius:6px;overflow:hidden;margin-top:12px;background:#eef2f7}.stack-bar>span{display:block;height:100%}.orient{display:flex;gap:10px;margin-top:10px}.orient-btn{flex:1;padding:16px;text-align:center}.mt0{margin-top:0}.help{font-size:11px;color:var(--muted)}.gantt-wrap{background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden}.gantt{display:flex;align-items:flex-start}.gantt-left{flex:0 0 auto;border-right:1px solid var(--line);background:var(--panel)}.gantt-lhead{display:flex;align-items:center;padding:0 10px;gap:6px;background:#eef2f7;border-bottom:2px solid #d4dce6;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:#46556a}.gantt-lrow{display:flex;align-items:center;padding:0 10px;gap:6px;border-bottom:1px solid var(--line);font-size:12px}.gantt-lrow.parent{font-weight:700;background:#f3f7fb}.gantt-name{cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-name:hover{color:var(--brand);text-decoration:underline}.crit-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--bad);margin-left:6px;vertical-align:1px}.gantt-rowact{display:flex;gap:2px;justify-content:flex-end;opacity:0;transition:opacity .1s}.gantt-lrow:hover .gantt-rowact{opacity:1}.gantt-rowact button{border:none;background:none;font-size:12px;padding:2px 3px;border-radius:4px}.gantt-rowact button:hover{background:#e3e8ef}.gantt-right{flex:1;overflow-x:auto}.gantt-right svg{-webkit-user-select:none;user-select:none}table.cf-config td{vertical-align:top}table.cf-config select,table.cf-config input{font-size:11px}table.inv tfoot td{border-top:2px solid #d4dce6}.map-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px 14px}.map-grid .field{margin-bottom:0}.map-grid select{width:100%}table.inv tr.cf-parent{background:#f3f7fb}
