:root{--ink:#0f172a;--slate:#334155;--muted:#64748b;--line:#e8edf3;--soft:#f5f8fc;--amber:#e08a2b;--blue:#2563eb;--green:#16a34a;--red:#dc4332;--bg:#f6f9fc;--accent:#2563eb;--accent-soft:#eaf1fe}*{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:224px;color:var(--slate);border-right:1px solid var(--line);background:#fff;flex-direction:column;flex-shrink:0;padding:18px 0;display:flex}.brand{color:var(--ink);letter-spacing:.3px;padding:4px 20px 18px;font-size:18px;font-weight:700}.brand span{color:var(--accent)}.nav a{color:var(--muted);border-left:3px solid #0000;padding:10px 20px;font-weight:500;transition:background-color .12s,color .12s;display:block}.nav a:hover{background:var(--soft);color:var(--ink)}.nav a.active{color:var(--accent);border-left-color:var(--accent);background:var(--accent-soft);font-weight:600}.sidebar-foot{color:var(--muted);border-top:1px solid var(--line);margin-top:auto;padding:16px 20px;font-size:12px}.sidebar-foot button{border:1px solid var(--line);color:var(--slate);background:0 0;border-radius:6px;margin-top:8px;padding:5px 10px}.sidebar-foot button:hover{background:var(--soft)}.main{flex:1;min-width:0}.topbar{border-bottom:1px solid var(--line);background:#fff;justify-content:space-between;align-items:center;height:56px;padding:0 28px;display:flex}.topbar h1{margin:0;font-size:17px}.topbar .co{color:var(--muted);font-size:12px}.content{max-width:1160px;margin:0 auto;padding:26px 28px}.nav-sec{text-transform:uppercase;letter-spacing:.6px;color:#6b7785;padding:14px 20px 4px;font-size:10px}.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:14px;margin-bottom:24px;display:grid}.kpi{border:1px solid var(--line);background:#fff;border-radius:12px;padding:14px 16px;box-shadow:0 1px 2px #1018280a}.kpi .label{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-size:11px}.kpi .value{letter-spacing:-.3px;font-variant-numeric:tabular-nums;margin-top:4px;font-size:23px;font-weight:700}.kpi .sub{color:var(--muted);margin-top:2px;font-size:12px}.card{border:1px solid var(--line);background:#fff;border-radius:12px;margin-bottom:20px;padding:18px 20px;box-shadow:0 1px 3px #1018280d}.card h2{margin:0 0 14px;font-size:15px}.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:.4px;color:var(--muted);border-bottom:2px solid var(--line);padding:9px 10px;font-size:11px}td{border-bottom:1px solid var(--line);padding:11px 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:11px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-block}.pill.lead{color:var(--slate);background:#eef1f4}.pill.bidding{color:var(--blue);background:#e3eef6}.pill.active{color:var(--green);background:#e2f1e8}.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:7px;padding:8px 15px;font-size:13px;font-weight:600;transition:background-color .12s,filter .12s,box-shadow .12s}.btn:hover{filter:brightness(1.06)}.btn.secondary{color:var(--slate);border:1px solid var(--line);background:#fff}.btn.secondary:hover{background:var(--soft);filter:none}.btn.sm{padding:5px 11px;font-size:12px}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}.field input,.field select,.field textarea{border:1px solid var(--line);background:#fff;border-radius:6px;width:100%;padding:8px 10px;font-family:inherit;font-size:13px;transition:border-color .12s,box-shadow .12s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue);outline:none;box-shadow:0 0 0 3px #1f5f8b26}.row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-panel{background:var(--soft);border:1px solid var(--line);border-radius:8px;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,#e3eef6);border:1px solid #c4dcec;border-radius:6px;padding:9px 12px;font-size:13px}.callout.amber{background:#fbe6cf;border-color:#f0cfa0}.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{background:#fff;border-radius:12px;width:480px;max-width:100%;max-height:85vh;padding:22px 24px;overflow:auto;box-shadow:0 20px 60px #1018284d}.modal h3{margin:0 0 14px;font-size:15px}.auth-wrap{background:linear-gradient(150deg,#1e3a8a,#2563eb 70%,#3b82f6);justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-card{background:#fff;border-radius:14px;width:360px;padding:32px;box-shadow:0 18px 50px #0f172a47}.auth-card .brand2{margin-bottom:4px;font-size:22px;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}}.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}
