:root{--brand-900: #0b2a4a;--brand-700: #154a7c;--brand-600: #1e88e5;--brand-500: #3b9bef;--brand-100: #d7e9fb;--brand-50: #eef6fe;--bg: #f5f7fa;--surface: #ffffff;--surface-2: #f8fafc;--line: #e7ecf2;--line-2: #eef2f7;--text: #14202e;--text-2: #5b6b7f;--text-3: #8a97a8;--open: #1e88e5;--open-bg: #e6f1fd;--pending: #b7791f;--pending-bg: #fdf3e0;--closed: #15803d;--closed-bg: #dcf6e6;--faulty: #dc2626;--faulty-bg: #fdeaea;--retired: #64748b;--retired-bg: #eef1f5;--radius: 14px;--radius-sm: 10px;--radius-lg: 20px;--shadow-sm: 0 1px 2px rgba(16,40,70,.06), 0 1px 3px rgba(16,40,70,.04);--shadow: 0 4px 14px rgba(16,40,70,.08);--shadow-lg: 0 12px 40px rgba(16,40,70,.16);--fs: 15px;--nav-h: 60px;--safe-b: env(safe-area-inset-bottom, 0px)}body[data-tenant=sh]{--brand-900: #0b2a4a;--brand-700: #245c3a;--brand-600: #2e7d46;--brand-500: #3a9657;--brand-100: #d7ecdd;--brand-50: #eef7f1;--open: #2e7d46;--open-bg: #e3f3e8}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:Inter,-apple-system,Segoe UI,Roboto,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:var(--fs);line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4{margin:0;color:var(--brand-900);font-weight:700;letter-spacing:-.01em}a{color:var(--brand-600);text-decoration:none}.app{min-height:100%;padding-bottom:calc(var(--nav-h) + var(--safe-b) + 8px)}@media(min-width:860px){.app{padding-bottom:0}}.topbar{background:var(--surface);border-bottom:1px solid var(--line);padding:0 16px;height:58px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:30;-webkit-backdrop-filter:saturate(1.1);backdrop-filter:saturate(1.1)}.topbar .brand-wrap{display:flex;align-items:center;gap:10px;min-width:0}.topbar .logo-dot{width:30px;height:30px;border-radius:9px;flex:0 0 auto;background:linear-gradient(135deg,var(--brand-600),var(--brand-900));display:grid;place-items:center;color:#fff;font-weight:800;font-size:15px}.brand{font-weight:700;font-size:16px;color:var(--brand-900);letter-spacing:-.01em;white-space:nowrap}.brand .tenant-chip{font-size:11px;font-weight:600;color:var(--brand-600);background:var(--brand-50);padding:2px 8px;border-radius:999px;margin-left:8px}.topnav{display:none;gap:4px}@media(min-width:860px){.topnav{display:flex}}.topnav a{display:inline-flex;align-items:center;gap:7px;padding:8px 13px;border-radius:10px;color:var(--text-2);font-weight:600;font-size:14px;transition:background .15s,color .15s}.topnav a:hover{background:var(--surface-2);color:var(--brand-900)}.topnav a.active{background:var(--brand-50);color:var(--brand-600)}.userbox{display:flex;align-items:center;gap:12px}.userbox .uname{font-size:13px;color:var(--text-2);font-weight:600;display:none}@media(min-width:560px){.userbox .uname{display:inline}}.icon-btn{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--surface);color:var(--text-2);cursor:pointer;padding:0}.icon-btn:hover{background:var(--surface-2);color:var(--brand-900)}.icon-btn.active{background:var(--brand-50);color:var(--brand-600);border-color:var(--brand-100)}@media(min-width:860px){.admin-quick{display:none}}.offline{background:#b54708;font-size:12.5px;padding:7px 16px;color:#fff;text-align:center;font-weight:600}.wrap{max-width:860px;margin:0 auto;padding:18px 16px 28px}.page-title{font-size:22px;margin-bottom:4px}.page-sub{color:var(--text-2);font-size:14px;margin-bottom:18px}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px}.page-head .page-title,.page-head .page-sub{margin-bottom:0}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:16px;box-shadow:var(--shadow-sm)}.card.flush{padding:0;overflow:hidden}.card h3{font-size:15px;margin:0 0 14px;display:flex;align-items:center;gap:8px}.card h3 .sub{font-weight:500;color:var(--text-3);font-size:13px}.card-section-title{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-weight:700;margin:0 0 10px}label{display:block;font-size:12.5px;color:var(--text-2);margin:12px 0 5px;font-weight:600}label:first-child{margin-top:0}input,select,textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);font-size:15px;background:var(--surface);color:var(--text);font-family:inherit;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand-500);box-shadow:0 0 0 3px var(--brand-50)}input::placeholder,textarea::placeholder{color:var(--text-3)}input[readonly]{background:var(--surface-2);color:var(--text-2);cursor:not-allowed}textarea{min-height:80px;resize:vertical}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235b6b7f' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.row{display:flex;gap:12px}.row>*{flex:1;min-width:0}@media(max-width:520px){.row.stack-sm{flex-direction:column}}.field-error{color:var(--faulty);font-size:12px;margin-top:5px}.input-error{border-color:var(--faulty)!important;box-shadow:0 0 0 3px var(--faulty-bg)!important}.help{font-size:12px;color:var(--text-3);margin-top:6px}button,.btn{background:var(--brand-600);color:#fff;border:0;padding:11px 16px;border-radius:var(--radius-sm);font-size:14.5px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;transition:filter .15s,background .15s,transform .05s}button:hover,.btn:hover{filter:brightness(1.05)}button:active,.btn:active{transform:translateY(1px)}button.secondary,.btn.secondary{background:var(--brand-50);color:var(--brand-700)}button.secondary:hover{background:var(--brand-100);filter:none}button.neutral{background:var(--surface-2);color:var(--text);border:1px solid var(--line)}button.ghost{background:transparent;color:var(--brand-600);padding:8px 10px}button.ghost:hover{background:var(--brand-50);filter:none}button.danger{background:var(--faulty)}button.block{width:100%}button:disabled{opacity:.55;cursor:not-allowed}.btn-row{display:flex;gap:10px;flex-wrap:wrap}.btn-sm{padding:7px 11px;font-size:13px;border-radius:8px}.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:999px;white-space:nowrap;background:var(--retired-bg);color:var(--retired)}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.badge.open{background:var(--open-bg);color:var(--open)}.badge.pending{background:var(--pending-bg);color:var(--pending)}.badge.closed{background:var(--closed-bg);color:var(--closed)}.badge.faulty{background:var(--faulty-bg);color:var(--faulty)}.badge.active{background:var(--closed-bg);color:var(--closed)}.badge.retired{background:var(--retired-bg);color:var(--retired)}.badge.plain:before{display:none}.badge.type{background:var(--brand-50);color:var(--brand-700)}.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:18px}@media(min-width:720px){.stats{grid-template-columns:repeat(4,1fr)}}.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:15px 16px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.stat .stat-ico{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:var(--brand-50);color:var(--brand-600);margin-bottom:10px}.stat .stat-val{font-size:26px;font-weight:800;color:var(--brand-900);line-height:1.1;letter-spacing:-.02em}.stat .stat-label{font-size:12.5px;color:var(--text-2);margin-top:3px;font-weight:500}.stat.amber .stat-ico{background:var(--pending-bg);color:var(--pending)}.stat.green .stat-ico{background:var(--closed-bg);color:var(--closed)}.stat.star .stat-ico{background:#fef3c7;color:#d4920a}.quick{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px}@media(min-width:720px){.quick{grid-template-columns:repeat(4,1fr)}}.quick a{display:flex;align-items:center;gap:10px;padding:13px 14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);color:var(--brand-900);font-weight:600;font-size:14px;box-shadow:var(--shadow-sm);transition:border-color .15s,transform .05s}.quick a:hover{border-color:var(--brand-500)}.quick a:active{transform:translateY(1px)}.quick a .qi{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;background:var(--brand-50);color:var(--brand-600);flex:0 0 auto}.list{display:flex;flex-direction:column;gap:10px}.jobcard{display:block;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 15px;box-shadow:var(--shadow-sm);transition:border-color .15s,transform .05s;color:var(--text)}.jobcard:hover{border-color:var(--brand-500)}.jobcard:active{transform:translateY(1px)}.jobcard .jc-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.jobcard .jc-ref{font-weight:700;color:var(--brand-900);font-size:14.5px}.jobcard .jc-cust{font-size:15px;font-weight:600;margin-top:6px;color:var(--text)}.jobcard .jc-meta{font-size:13px;color:var(--text-2);margin-top:4px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.jobcard .jc-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--text-3)}.jobcard .jc-amount{font-weight:700;color:var(--brand-900)}.empty{text-align:center;padding:40px 20px;color:var(--text-3)}.empty .ei{width:48px;height:48px;margin:0 auto 12px;color:var(--line);display:grid;place-items:center}.empty h4{color:var(--text-2);font-size:15px;margin-bottom:4px}.section{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:12px;box-shadow:var(--shadow-sm);overflow:hidden}.section>.sec-head{width:100%;background:transparent;color:var(--brand-900);border:0;padding:15px 16px;display:flex;align-items:center;gap:11px;cursor:pointer;font-size:15px;font-weight:700;justify-content:flex-start}.section>.sec-head:hover{background:var(--surface-2);filter:none}.section>.sec-head .sec-ico{width:30px;height:30px;border-radius:9px;background:var(--brand-50);color:var(--brand-600);display:grid;place-items:center;flex:0 0 auto}.section>.sec-head .sec-grow{flex:1;text-align:left;min-width:0}.section>.sec-head .sec-hint{font-weight:500;font-size:12.5px;color:var(--text-3)}.section>.sec-head .chev{color:var(--text-3);transition:transform .2s;flex:0 0 auto}.section.open>.sec-head .chev{transform:rotate(180deg)}.section>.sec-body{padding:0 16px 16px}.section>.sec-body.pad-top{padding-top:2px}.timeline{position:relative;margin:4px 0 0;padding-left:6px}.tl-item{position:relative;padding:0 0 16px 22px;border-left:2px solid var(--line)}.tl-item:last-child{border-left-color:transparent;padding-bottom:0}.tl-item:before{content:"";position:absolute;left:-7px;top:2px;width:12px;height:12px;border-radius:50%;background:var(--brand-600);border:2px solid var(--surface);box-shadow:0 0 0 1px var(--brand-100)}.tl-date{font-size:12.5px;color:var(--text-3);font-weight:600}.tl-title{font-weight:600;margin:2px 0}.tl-body{font-size:13.5px;color:var(--text-2)}.dl{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px}@media(max-width:480px){.dl{grid-template-columns:1fr}}.dl .dt{font-size:12px;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.dl .dd{font-size:14.5px;color:var(--text);margin-top:2px;font-weight:500}.group-head{display:flex;align-items:center;gap:8px;margin:22px 0 10px}.group-head:first-child{margin-top:4px}.group-head .gh-title{font-size:14px;font-weight:700;color:var(--brand-900)}.group-head .gh-count{font-size:12px;color:var(--text-3);background:var(--surface-2);padding:1px 8px;border-radius:999px}.group-head .gh-line{flex:1;height:1px;background:var(--line)}.toolbar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.search{position:relative;flex:1;min-width:180px}.search input{padding-left:38px}.search .si{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none}.toolbar select{width:auto;min-width:140px;flex:0 0 auto}.lineitem{display:grid;grid-template-columns:1fr 64px 92px 38px;gap:8px;align-items:center;margin-bottom:8px}.lineitem input{padding:9px 10px}.totals{text-align:right;line-height:1.9}.totals .grand{font-weight:700;font-size:18px;color:var(--brand-900)}.stars span{font-size:32px;cursor:pointer;color:#d8dee7;transition:color .12s}.stars span.on{color:#f5a623}canvas.sig{width:100%;height:180px;border:1.5px dashed var(--brand-500);border-radius:var(--radius-sm);touch-action:none;background:var(--surface)}.photos{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.photos img{width:92px;height:92px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--line)}.scanner-wrap{border-radius:var(--radius-sm);overflow:hidden;background:#000;position:relative;margin-top:10px}.scanner-wrap video,.scanner-wrap #qr-reader{width:100%!important}#qr-reader{border:0!important}#qr-reader img[alt="Info icon"]{display:none}.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.chip{display:inline-flex;align-items:center;gap:7px;padding:7px 10px 7px 12px;background:var(--brand-50);color:var(--brand-700);border-radius:999px;font-size:13px;font-weight:600;border:1px solid var(--brand-100)}.chip button{background:transparent;color:var(--brand-700);padding:0;width:18px;height:18px;border-radius:50%}.chip button:hover{background:#0000000f;filter:none}.picker-list{max-height:240px;overflow-y:auto;border:1px solid var(--line);border-radius:var(--radius-sm);margin-top:8px}.picker-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid var(--line-2);cursor:pointer}.picker-row:last-child{border-bottom:0}.picker-row:hover{background:var(--surface-2)}.picker-row.sel{background:var(--brand-50)}.picker-row .pr-name{font-weight:600;font-size:14px}.picker-row .pr-meta{font-size:12px;color:var(--text-2)}.picker-row .pr-check{margin-left:auto;color:var(--brand-600)}.skel{background:linear-gradient(90deg,#eef2f7 25%,#f6f9fc,#eef2f7 75%);background-size:200% 100%;animation:shimmer 1.3s infinite;border-radius:8px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skel-line{height:12px;margin-bottom:9px}.skel-card{height:78px;border-radius:var(--radius);margin-bottom:10px}.skel-stat{height:96px;border-radius:var(--radius)}.bottomnav{position:fixed;bottom:0;left:0;right:0;z-index:40;background:var(--surface);border-top:1px solid var(--line);display:flex;justify-content:space-around;align-items:stretch;height:calc(var(--nav-h) + var(--safe-b));padding-bottom:var(--safe-b);box-shadow:0 -2px 12px #1028460f}@media(min-width:860px){.bottomnav{display:none}}.bottomnav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--text-3);font-size:10.5px;font-weight:600;position:relative}.bottomnav a.active{color:var(--brand-600)}.bottomnav a .bn-ico{display:grid;place-items:center}.bottomnav a.fab{flex:0 0 auto;margin-top:-22px}.bottomnav a.fab .bn-ico{width:54px;height:54px;border-radius:50%;color:#fff;background:linear-gradient(135deg,var(--brand-500),var(--brand-600));box-shadow:0 6px 18px color-mix(in srgb,var(--brand-600) 45%,transparent)}.bottomnav a.fab{color:var(--brand-600)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0b1c2e80;z-index:70;display:flex;align-items:flex-end;justify-content:center;padding:0;animation:fadein .15s ease}@media(min-width:600px){.modal-backdrop{align-items:center;padding:20px}}@keyframes fadein{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);width:100%;max-width:520px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:var(--shadow-lg);max-height:92vh;display:flex;flex-direction:column;animation:slideup .2s ease}@media(min-width:600px){.modal{border-radius:var(--radius-lg);max-height:88vh}}@keyframes slideup{0%{transform:translateY(16px);opacity:.6}to{transform:translateY(0);opacity:1}}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line)}.modal-body{padding:16px 18px;overflow-y:auto}.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:14px 18px;border-top:1px solid var(--line)}.modal-foot button{flex:1}@media(min-width:600px){.modal-foot button{flex:0 0 auto;min-width:120px}}.toast{position:fixed;bottom:calc(var(--nav-h) + var(--safe-b) + 16px);left:50%;transform:translate(-50%);background:var(--brand-900);color:#fff;padding:12px 18px;border-radius:12px;z-index:80;font-size:14px;box-shadow:var(--shadow-lg);max-width:calc(100% - 32px);text-align:center;animation:toastin .2s ease}@media(min-width:860px){.toast{bottom:24px}}@keyframes toastin{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.update-banner{position:fixed;top:0;left:0;right:0;background:var(--brand-600);color:#fff;padding:10px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:90;font-size:14px;box-shadow:var(--shadow)}.update-banner .update-actions{display:flex;gap:8px}.update-banner button{background:#fff;color:var(--brand-600);padding:6px 12px;font-size:13px}.update-banner button.ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5)}.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(120% 120% at 50% 0%,#163a5f 0%,var(--brand-900) 55%,#061a30 100%)}.login-card{background:var(--surface);border-radius:var(--radius-lg);padding:32px 26px;width:100%;max-width:380px;box-shadow:var(--shadow-lg)}.login-logo{width:52px;height:52px;border-radius:15px;background:linear-gradient(135deg,var(--brand-600),var(--brand-900));display:grid;place-items:center;color:#fff;font-weight:800;font-size:24px;margin-bottom:18px}.login-brand{font-size:23px;font-weight:800;color:var(--brand-900);letter-spacing:-.02em}.login-sub{font-size:13.5px;color:var(--text-2);margin-bottom:22px}.login-err{background:var(--faulty-bg);color:#b42318;font-size:13px;padding:10px 12px;border-radius:var(--radius-sm);margin-top:14px;display:flex;align-items:center;gap:8px}.login-foot{text-align:center;font-size:12px;color:var(--text-3);margin-top:18px}.public-bar{background:var(--brand-900);color:#fff;padding:16px;display:flex;align-items:center;gap:12px}.public-bar .logo-dot{background:#ffffff26}.public-bar .brand{color:#fff}.public-hero{background:linear-gradient(135deg,var(--brand-700),var(--brand-900));color:#fff;padding:26px 20px}.public-hero h2{color:#fff;font-size:22px}.public-hero .ph-sub{color:#fffc;margin-top:4px;font-size:14px}.label-sheet{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}@media(min-width:600px){.label-sheet{grid-template-columns:repeat(3,1fr)}}.qrlabel{border:1.5px dashed #9aa6b4;border-radius:10px;padding:12px;text-align:center;background:#fff;break-inside:avoid}.qrlabel img{width:130px;height:130px}.qrlabel .ql-name{font-weight:800;font-size:15px;color:#0b2a4a;margin-top:6px}.qrlabel .ql-site{font-size:12px;color:#5b6b7f}.qrlabel .ql-brand{font-size:10px;color:#8a97a8;margin-top:4px;letter-spacing:.04em}.qrlabel .ql-scan{font-size:10.5px;color:#5b6b7f;margin-top:2px}@media print{.topbar,.bottomnav,.toast,.update-banner,.no-print,.offline{display:none!important}body{background:#fff}.app{padding:0}.wrap{max-width:none;padding:0}.label-sheet{grid-template-columns:repeat(3,1fr);gap:10px}.qrlabel{border-color:#bbb}}.muted{color:var(--text-2)}.tiny{font-size:12px}.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}.mb0{margin-bottom:0}.center{text-align:center}.spread{display:flex;align-items:center;justify-content:space-between;gap:10px}.flex{display:flex;align-items:center;gap:8px}.grow{flex:1;min-width:0}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
