:root{--ink:#1d1d1f;--slate:#424245;--muted:#86868b;--line:#ededf0;--soft:#f4f5f8;--amber:#c07d1d;--blue:#0071e3;--green:#1c8a4d;--red:#d6492f;--bg:#fbfbfd;--accent:#0071e3;--accent-soft:#eaf3ff;--radius:16px;--radius-sm:10px;--shadow:0 1px 2px #1018280a, 0 1px 3px #10182808;--shadow-pop:0 10px 30px #1018281a;--head-spacing:-.022em}*{box-sizing:border-box}body{color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;font-size:14px}a{color:var(--blue);text-decoration:none}button{cursor:pointer;font-family:inherit}.app{min-height:100vh;display:flex}.sidebar{width:236px;color:var(--slate);border-right:1px solid var(--line);background:#fff;flex-direction:column;flex-shrink:0;align-self:flex-start;height:100vh;padding:18px 14px;display:flex;position:sticky;top:0;overflow-y:auto}.brand{color:var(--ink);letter-spacing:-.01em;padding:4px 10px 20px;font-size:18px;font-weight:700}.brand span{color:var(--accent)}.nav a{color:var(--slate);border-radius:var(--radius-sm);margin:1px 0;padding:9px 12px;font-weight:500;transition:background-color .13s,color .13s;display:block}.nav a:hover{background:var(--soft);color:var(--ink)}.nav a.active{color:var(--ink);background:#eceef2;font-weight:600}.sidebar-foot{color:var(--muted);border-top:1px solid var(--line);margin-top:auto;padding:16px 10px 4px;font-size:12px}.sidebar-foot button{border:1px solid var(--line);color:var(--slate);background:0 0;border-radius:8px;margin-top:8px;padding:6px 11px;transition:background-color .13s}.sidebar-foot button:hover{background:var(--soft)}.main{flex:1;min-width:0}.topbar{-webkit-backdrop-filter:saturate(160%)blur(10px);backdrop-filter:saturate(160%)blur(10px);z-index:30;border-bottom:1px solid var(--line);background:#fbfbfdd1;justify-content:space-between;align-items:center;height:60px;padding:0 30px;display:flex;position:sticky;top:0}.topbar h1{letter-spacing:var(--head-spacing);margin:0;font-size:19px;font-weight:600}.topbar .co{color:var(--muted);font-size:12px}.content{width:100%;max-width:none;margin:0;padding:28px 30px}.nav-sec{cursor:pointer;text-align:left;text-transform:uppercase;letter-spacing:.8px;color:#9a9aa0;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:space-between;align-items:center;gap:6px;width:100%;padding:16px 12px 6px;font-family:inherit;font-size:10.5px;font-weight:600;transition:color .13s;display:flex}.nav-sec:hover{color:var(--slate)}.nav-sec .chev{opacity:.65;flex-shrink:0;transition:transform .15s}.nav-sec.collapsed .chev{transform:rotate(-90deg)}.muted-sm{color:var(--muted);font-size:12px}.flex-row{align-items:center;gap:8px;display:flex}.code{white-space:nowrap;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.nowrap{white-space:nowrap}.kpis{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.kpi{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;padding:20px 22px}.kpi .label{letter-spacing:0;text-transform:none;color:var(--muted);font-size:12px;font-weight:500}.kpi .value{letter-spacing:var(--head-spacing);font-variant-numeric:tabular-nums;margin-top:6px;font-size:32px;font-weight:600;line-height:1.08}.kpi .sub{color:var(--muted);margin-top:7px;font-size:12.5px}.kpi-head{align-items:center;gap:10px;margin-bottom:12px;display:flex}.kpi-head .label{text-transform:none;letter-spacing:0;margin:0;font-size:12.5px}.kpi-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.kpi-icon.blue{background:var(--accent-soft);color:var(--accent)}.kpi-icon.green{color:var(--green);background:#e4f3ea}.kpi-icon.amber{color:var(--amber);background:#fbecd7}.kpi-icon.slate{background:var(--soft);color:var(--slate)}.card{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;margin-bottom:20px;padding:20px 22px}.card h2{letter-spacing:var(--head-spacing);margin:0 0 14px;font-size:16px;font-weight:600}.card-head{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.card-head h2{margin:0}table{border-collapse:collapse;width:100%}th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);border-bottom:1px solid var(--line);padding:10px;font-size:11px;font-weight:600}td{border-bottom:1px solid var(--line);padding:13px 10px}tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--soft)}.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.pill{border-radius:100px;padding:3px 10px;font-size:11.5px;font-weight:600;display:inline-block}.pill.lead{color:var(--slate);background:#eceef2}.pill.bidding{background:var(--accent-soft);color:var(--accent)}.pill.active{color:#1c7a45;background:#e4f3ea}.pill.complete{color:#5e35b1;background:#ece7f6}.pill.lost{color:var(--red);background:#fde8e8}.pill.neutral{color:var(--slate);background:#eef1f4}.pill.warn{color:var(--red);background:#fde8e8}.pos{color:var(--green);font-weight:600}.neg{color:var(--red);font-weight:600}.btn{background:var(--accent);color:#fff;border:none;border-radius:9px;padding:9px 16px;font-size:13px;font-weight:600;transition:background-color .12s,filter .12s,box-shadow .12s}.btn:hover{filter:brightness(1.05)}.btn:active{transform:translateY(.5px)}.btn.secondary{color:var(--slate);border:1px solid var(--line);background:#fff}.btn.secondary:hover{background:var(--soft);filter:none}.btn.sm{padding:6px 12px;font-size:12px}.btn:not(.secondary):not(.icon-only){min-width:104px}.btn.sm:not(.secondary):not(.icon-only){min-width:88px}button:focus-visible,a:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:6px}.field{margin-bottom:12px}.field label{color:var(--slate);margin-bottom:4px;font-size:12px;font-weight:600;display:block}input:not([type=checkbox]):not([type=radio]):not([type=file]):not([type=range]),select,textarea{border:1px solid var(--line);color:var(--ink);background:#fff;border-radius:9px;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .12s,box-shadow .12s}input:not([type=checkbox]):not([type=radio]):not([type=file]):not([type=range]):focus,select:focus,textarea:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #0071e326}.field input,.field select,.field textarea{width:100%}.row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-panel{background:var(--soft);border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:16px;padding:16px}.btn svg{margin-right:5px}.btn.icon-only svg{margin-right:0}.inline-form{flex-wrap:wrap;align-items:flex-end;gap:8px;display:flex}.inline-form .field{margin-bottom:0}.bar{background:var(--soft);border-radius:4px;min-width:80px;height:7px;overflow:hidden}.bar>span{background:var(--blue);height:100%;display:block}.error{color:var(--red);background:#fde8e8;border-radius:6px;margin-bottom:12px;padding:9px 12px;font-size:13px}.callout{background:var(--blue-soft,#eaf3ff);border-radius:var(--radius-sm);border:1px solid #cfe4fb;padding:10px 13px;font-size:13px}.callout.amber{background:#fbecd7;border-color:#f0d6a8}.green-soft{--green-soft:#e2f1e8}.blue-soft{--blue-soft:#e3eef6}.empty{color:var(--muted);padding:18px 4px;font-size:13px}.jump-nav{z-index:20;background:var(--bg);border-bottom:1px solid var(--line);flex-wrap:wrap;gap:6px;margin-bottom:10px;padding:8px 0 10px;display:flex;position:sticky;top:0}.jump-nav button{border:1px solid var(--line);color:var(--slate);background:#fff;border-radius:14px;padding:4px 12px;font-size:12px;font-weight:600}.jump-nav button:hover{background:var(--soft);border-color:#cdd6df}.modal-overlay{z-index:50;background:#10182880;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius);background:#fff;width:480px;max-width:100%;max-height:85vh;padding:24px 26px;overflow:auto;box-shadow:0 24px 70px #10182838}.modal h3{letter-spacing:var(--head-spacing);margin:0 0 14px;font-size:16px;font-weight:600}.auth-wrap{background:radial-gradient(120% 120% at 50% 0,#fff 0%,#f1f3f7 55%,#e7eaf0 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-card{border-radius:var(--radius);width:366px;box-shadow:var(--shadow-pop);border:1px solid var(--line);background:#fff;padding:34px}.auth-card .brand2{letter-spacing:-.01em;margin-bottom:4px;font-size:23px;font-weight:700}.auth-card .brand2 span{color:var(--accent)}.auth-card .muted{color:var(--muted);margin-bottom:20px;font-size:13px}.auth-card .btn{width:100%;margin-top:6px;padding:10px}.auth-toggle{text-align:center;color:var(--muted);margin-top:14px;font-size:13px}.auth-toggle button{color:var(--blue);background:0 0;border:none;font-weight:600}.demo-hint{background:var(--soft);border:1px dashed var(--line);color:var(--muted);border-radius:6px;margin-top:16px;padding:8px 10px;font-size:12px}.menu-btn{color:var(--ink);background:0 0;border:none;align-items:center;margin-left:-8px;padding:8px;display:none}.sidebar-backdrop{display:none}.table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}@media (width<=900px){.menu-btn{display:inline-flex}.sidebar{z-index:60;width:250px;transition:transform .2s;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(-100%);box-shadow:0 0 40px #00000059}.sidebar.open{transform:translate(0)}.sidebar-backdrop{z-index:55;background:#10182873;border:none;padding:0;display:block;position:fixed;inset:0}.kpis{grid-template-columns:repeat(2,1fr)}.content{padding:14px 12px}.row{grid-template-columns:1fr}.topbar{gap:8px;padding:0 12px}.topbar .co{display:none}.jump-nav{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.jump-nav button{white-space:nowrap;flex-shrink:0}}@media (width<=480px){.kpis{grid-template-columns:1fr}}.field-mode{max-width:560px;margin:0 auto}.field-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;display:flex}.field-head h2{margin:0;font-size:18px}.sync-badge{color:#8a541a;background:#fbe6cf;border:1px solid #f0cfa0;border-radius:14px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:700;display:inline-flex}.offline-pill{color:var(--red);background:#fde8e8;border-radius:14px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:700;display:inline-flex}.field-card{border:1px solid var(--line);background:#fff;border-radius:12px;width:100%;margin-bottom:10px;overflow:hidden;box-shadow:0 1px 2px #1018280a}.field-card-btn{text-align:left;width:100%;min-height:64px;color:var(--ink);background:0 0;border:none;align-items:center;gap:14px;padding:14px 16px;font-size:16px;font-weight:600;display:flex}.field-card-btn .fc-icon{background:var(--soft);width:42px;height:42px;color:var(--blue);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.field-card-btn .fc-sub{color:var(--muted);margin-top:2px;font-size:12px;font-weight:400;display:block}.field-card-body{border-top:1px solid var(--line);padding:12px 16px 16px}.field-mode .btn,.field-mode select,.field-mode input,.field-mode textarea{min-height:48px;font-size:15px}.field-mode input[type=checkbox]{min-height:0}.chip-row{flex-wrap:wrap;gap:8px;margin:6px 0 10px;display:flex}.chip{border:1px solid var(--line);min-width:48px;min-height:48px;color:var(--slate);background:#fff;border-radius:10px;font-size:15px;font-weight:600}.chip.on{background:var(--blue);border-color:var(--blue);color:#fff}.job-pick{flex-direction:column;gap:8px;margin-bottom:10px;display:flex}.job-pick button{text-align:left;border:1px solid var(--line);min-height:48px;color:var(--ink);background:#fff;border-radius:10px;padding:10px 14px;font-size:15px;font-weight:600}.job-pick button.on{border-color:var(--blue);background:#e3eef6}.job-pick button .jp-sub{color:var(--muted);font-size:12px;font-weight:400;display:block}.field-toast{z-index:80;background:var(--ink);color:#fff;border-radius:10px;padding:14px 16px;font-size:14px;font-weight:600;position:fixed;bottom:16px;left:12px;right:12px;box-shadow:0 10px 30px #0000004d}.field-toast.offline{background:var(--amber)}.po-row{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:10px;padding:12px 0;display:flex}.po-row:last-child{border-bottom:none}.doc-row{border-bottom:1px solid var(--line);align-items:center;gap:10px;min-height:52px;padding:8px 4px;font-size:15px;display:flex}.doc-row:last-child{border-bottom:none}.dispatch-board{-webkit-overflow-scrolling:touch;align-items:flex-start;gap:10px;padding-bottom:6px;display:flex;overflow-x:auto}.dispatch-col{background:var(--soft);border:1px solid var(--line);border-radius:10px;flex:1 0 200px;min-width:200px;padding:8px}.dispatch-col.drag-over{outline:2px dashed var(--blue);outline-offset:-2px}.dispatch-col-head{text-transform:uppercase;letter-spacing:.4px;color:var(--slate);justify-content:space-between;align-items:center;padding:2px 4px 8px;font-size:12px;font-weight:700;display:flex}.dispatch-col-head .count{border:1px solid var(--line);color:var(--muted);background:#fff;border-radius:10px;padding:0 8px;font-size:11px}.dispatch-card{border:1px solid var(--line);cursor:grab;background:#fff;border-left-width:3px;border-radius:8px;margin-bottom:8px;padding:8px 10px;font-size:13px;box-shadow:0 1px 2px #1018280d}.dispatch-card:active{cursor:grabbing}.dispatch-card .dc-meta{color:var(--muted);margin-top:2px;font-size:11px}.dispatch-card .dc-actions{flex-wrap:wrap;align-items:center;gap:6px;margin-top:6px;display:flex}.tech-filter{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.tech-filter button{border:1px solid var(--line);color:var(--slate);background:#fff;border-radius:14px;padding:4px 12px;font-size:12px;font-weight:600}.tech-filter button.on{background:var(--blue);border-color:var(--blue);color:#fff}.pill.superseded{background:var(--red,#b3402f);color:#fff}.doc-superseded td{opacity:.55}.invoice-print{background:#f0f2f5;min-height:100vh;padding:16px}.ip-actions{text-align:right;max-width:8.5in;margin:0 auto 12px}.ip-sheet{color:#111;background:#fff;width:8.5in;min-height:11in;margin:0 auto;padding:.55in .5in;font-size:11px;box-shadow:0 6px 24px #0000001f}.ip-head{justify-content:space-between;align-items:flex-start;display:flex}.ip-brand{max-width:3.4in}.ip-logo{object-fit:contain;max-width:3in;max-height:90px}.ip-logo-ph{letter-spacing:2px;color:#b3402f;font-size:24px;font-weight:800}.ip-co{margin-top:10px;font-size:14px;font-weight:700}.ip-co-addr{color:#333}.ip-titlebox{width:2.7in}.ip-title{text-align:right;margin-bottom:8px;font-size:30px;font-weight:800}.ip-info{border-collapse:collapse;width:100%}.ip-info th,.ip-info td{text-align:center;border:1px solid #222;padding:4px 8px}.ip-info th{font-weight:700}.ip-parties{border-collapse:collapse;width:100%;margin-top:18px}.ip-parties th{border:1px solid #222;padding:5px 8px;font-weight:700}.ip-parties td{vertical-align:top;border:1px solid #222;height:70px;padding:8px}.ip-sov{border-collapse:collapse;width:100%;margin-top:12px}.ip-sov th{text-align:left;background:#fff;border:1px solid #222;padding:5px 6px;font-weight:700}.ip-sov th.num,.ip-sov td.num{text-align:right}.ip-sov td{border-left:1px solid #222;border-right:1px solid #222;padding:2px 6px}.ip-sov tbody tr:first-child td{padding-top:6px}.ip-sov tfoot td{border:1px solid #222;padding:4px 6px}.ip-sov .ip-subtotal td{border-top:1px solid #222;font-weight:600}.ip-foot{justify-content:space-between;align-items:flex-start;gap:12px;margin-top:18px;display:flex}.ip-pay{flex:1;font-size:10px}.ip-gstno{text-align:center;padding:6px 14px;font-size:11px}.ip-totals{border-collapse:collapse;width:2.7in}.ip-totals th,.ip-totals td{border:1px solid #222;padding:8px 10px;font-size:13px}.ip-totals th{text-align:left;font-weight:700}.ip-totals td{text-align:right}.ip-totals .ip-grand th,.ip-totals .ip-grand td{font-size:15px;font-weight:800}@media print{.sidebar,.topbar,.ip-actions,.no-print{display:none!important}.app,.main,.content{max-width:none!important;margin:0!important;padding:0!important;display:block!important}.invoice-print{background:#fff;padding:0}.ip-sheet{box-shadow:none;width:auto;margin:0}@page{size:letter;margin:.4in}}.topsearch{position:relative}.topsearch-ico{color:var(--muted);pointer-events:none;position:absolute;top:50%;left:11px;transform:translateY(-50%)}.topsearch input{width:280px;padding:10px 12px 10px 34px!important}.topsearch input::placeholder{color:var(--muted)}.topsearch-menu{border:1px solid var(--line);width:340px;max-height:420px;box-shadow:var(--shadow-pop);z-index:40;background:#fff;border-radius:12px;padding:6px;position:absolute;top:calc(100% + 6px);right:0;overflow-y:auto}.topsearch-grp{text-transform:uppercase;letter-spacing:.6px;color:var(--muted);padding:8px 10px 4px;font-size:10.5px;font-weight:600}.topsearch-opt{cursor:pointer;border-radius:8px;align-items:baseline;gap:8px;padding:8px 10px;display:flex}.topsearch-opt.hi{background:var(--accent-soft)}.topsearch-label{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:500;overflow:hidden}.topsearch-sub{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;max-width:55%;margin-left:auto;font-size:12px;overflow:hidden}.topsearch-empty{color:var(--muted);padding:12px;font-size:13px}@media (width<=900px){.topsearch input{width:150px}.topsearch-menu{width:280px}}.combo{width:100%;position:relative}.combo-input{width:100%}.combo-menu{z-index:60;border:1px solid var(--line);background:#fff;border-radius:8px;max-height:260px;margin-top:2px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #0000001f}.combo-opt{cursor:pointer;white-space:nowrap;text-overflow:ellipsis;padding:8px 10px;font-size:13px;overflow:hidden}.combo-opt.hi{background:var(--soft)}.combo-opt.sel{font-weight:600}.combo-empty{color:var(--muted);padding:10px;font-size:13px}
