@import "https://fonts.googleapis.com/css2?family=Barlow:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Barlow+Condensed:wght@600;700&display=swap";:root{--navy:#253047;--navy-dark:#1a2234;--navy-light:#2e3d5c;--navy-pale:#e8ecf5;--gold:#b9984b;--gold-light:#d4b46a;--gold-pale:#f5eed8;--gold-border:#c8a85a;--page-bg:#f0f2f7;--surface:#fff;--surface2:#f4f6fb;--surface3:#eaecf4;--text:#1a2234;--text2:#4b5563;--text3:#9ca3af;--grey-50:#fafafa;--grey-100:#f3f4f6;--grey-200:#e5e7eb;--grey-300:#d1d5db;--grey-400:#9ca3af;--grey-500:#6b7280;--green:#1a7a4a;--green-bg:#dcf5e8;--green-border:#86efac;--red:#b91c1c;--red-bg:#fee2e2;--red-border:#fca5a5;--red-hover:#fef2f2;--orange:#b45309;--orange-bg:#fef3c7;--orange-border:#fcd34d;--h:40px;--radius:8px;--radius-lg:12px;--radius-xl:16px;--pad:24px;--fs-sm:12px;--fs-md:14px;--fs-lg:16px;--fs-h:18px;--sidebar-w:230px;--sidebar-collapsed:60px;--shadow:0 4px 16px #2530471f;--shadow-sm:0 2px 8px #25304714;--shadow-card:0 2px 12px #2530471a;--shadow-sidebar:4px 0 24px #25304726;font-family:Barlow,sans-serif;font-size:var(--fs-md)}[data-theme=dark]{--page-bg:#0f1923;--surface:#16253a;--surface2:#1d3050;--surface3:#243860;--text:#f0f4fb;--text2:#8fa3bf;--text3:#4d6480;--grey-50:#1a2a3a;--grey-100:#1d3050;--grey-200:#243860;--grey-300:#2e4878;--grey-400:#4d6480;--grey-500:#7a9ab8;--shadow:0 4px 20px #00000073;--shadow-sm:0 2px 8px #0000004d;--shadow-card:0 2px 12px #0006}[data-theme=dark] .sidebar{background:var(--surface);border-right-color:var(--grey-200)}[data-theme=dark] .nav-item{color:var(--text2);background:0 0}[data-theme=dark] .nav-item:hover{color:var(--gold-light);background:#c4a45a1a}[data-theme=dark] .nav-item.active{background:var(--navy);color:#fff}[data-theme=dark] .sidebar-collapse-btn{background:var(--surface2);color:var(--text2);border-top-color:var(--grey-200)}[data-theme=dark] .sidebar-collapse-btn:hover{background:var(--surface3);color:var(--gold-light)}[data-theme=dark] .sidebar-user{background:var(--surface);border-top-color:var(--grey-200)}[data-theme=dark] .form-card,[data-theme=dark] .panel{background:var(--surface);border-color:var(--grey-200)}[data-theme=dark] .form-group input,[data-theme=dark] .form-group select,[data-theme=dark] .form-group textarea{background:var(--surface2);border-color:var(--grey-300);color:var(--text)}[data-theme=dark] .form-group label{color:var(--text2)}[data-theme=dark] th{background:var(--navy-light)}[data-theme=dark] td{background:var(--surface);color:var(--text);border-color:var(--grey-200)}[data-theme=dark] tr:nth-child(2n) td{background:var(--surface2)}[data-theme=dark] tr.clickable-row:hover td{background:#c4a45a14!important}[data-theme=dark] .btn-secondary{background:var(--surface2);border-color:var(--grey-300);color:var(--text)}[data-theme=dark] .btn-secondary:hover{border-color:var(--gold-border);background:#c4a45a26}[data-theme=dark] .fsel{background:var(--surface);border-color:var(--grey-300);color:var(--text)}[data-theme=dark] .metric-card{background:var(--surface);border-color:var(--grey-200)}[data-theme=dark] .page-title{color:var(--text)}[data-theme=dark] .wo-section-header{background:var(--surface2)}[data-theme=dark] .wo-section-header:hover{background:var(--surface3)}[data-theme=dark] .upload-table td{background:var(--surface);border-color:var(--grey-200)}[data-theme=dark] .upload-table tr:nth-child(2n) td{background:var(--surface2)}[data-theme=dark] .panel-header,[data-theme=dark] .wo-sticky-header{background:var(--surface);border-color:var(--grey-200)}[data-theme=dark] .act-btn{background:var(--surface2);border-color:var(--grey-300);color:var(--text)}[data-theme=dark] .search-bar{background:var(--surface);border-color:var(--grey-300);color:var(--text)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--page-bg);color:var(--text);min-height:100vh;line-height:1.5;transition:background .25s,color .25s;overflow-x:hidden}#loading{z-index:300;background:var(--navy-dark);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:fixed;inset:0}.spinner{border:3px solid #b9984b4d;border-top-color:var(--gold);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}#auth-screen{z-index:100;background:var(--navy-dark);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}#auth-screen:before{content:"";pointer-events:none;background:radial-gradient(70% 60% at 50% 40%,#b9984b1f 0%,#0000 70%);position:absolute;inset:0}.auth-card{z-index:1;border-radius:var(--radius-xl);background:#fff;width:420px;max-width:calc(100vw - 32px);max-height:calc(100vh - 32px);padding:44px;position:relative;overflow-y:auto;box-shadow:0 20px 60px #0006}.auth-link{color:var(--navy);font-size:var(--fs-sm);cursor:pointer;background:0 0;border:none;padding:0;font-family:Barlow,sans-serif;font-weight:600;text-decoration:underline}.auth-link:hover{color:var(--gold)}.auth-msg-ok{color:var(--green);font-size:var(--fs-sm);text-align:center;min-height:18px;margin-top:12px}.auth-back{align-items:center;gap:6px;margin-bottom:20px;display:flex}.auth-view-title{color:var(--navy);margin-bottom:6px;font-family:Barlow Condensed,sans-serif;font-size:20px;font-weight:700}.auth-view-sub{font-size:var(--fs-sm);color:#6b7280;margin-bottom:22px;line-height:1.5}.auth-logo-wrap{text-align:center;margin-bottom:28px}.auth-logo-img{object-fit:contain;width:auto;max-width:180px;height:auto;max-height:110px}.auth-logo-mark{color:var(--navy);letter-spacing:-2px;text-align:center;font-family:Barlow Condensed,sans-serif;font-size:44px;font-weight:700;line-height:1}.auth-divider{background:var(--gold);width:40px;height:3px;margin:12px auto}.auth-logo-sub{font-size:var(--fs-sm);letter-spacing:3px;text-transform:uppercase;color:#4b5563;text-align:center;margin-bottom:28px;font-weight:600}.auth-err{color:var(--red);font-size:var(--fs-sm);text-align:center;min-height:18px;margin-top:12px}#auth-screen .form-group input{color:#1a2234;height:var(--h);background:#f3f4f6;border:1px solid #d1d5db}#auth-screen .form-group input:focus{border-color:var(--navy);box-shadow:0 0 0 3px #2530471f}#auth-screen .form-group label{color:#4b5563}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--grey-300);box-shadow:var(--shadow-sidebar);z-index:50;flex-direction:column;transition:width .25s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-logo{min-height:unset;flex-direction:column;flex-shrink:0;align-items:center;gap:10px;padding:16px 14px;display:flex}.sidebar-logo-img{object-fit:contain;flex-shrink:0;width:auto;max-width:38px;max-height:60px;transition:all .25s}.sidebar.collapsed .sidebar-logo-img{max-width:36px;max-height:36px}.sidebar-logo-text{white-space:normal;flex-direction:column;transition:opacity .2s,width .2s;display:flex;overflow:hidden}.sidebar.collapsed .sidebar-logo-text{opacity:0;pointer-events:none;width:0;display:none}.sidebar-logo-name{font-size:var(--fs-sm);color:var(--navy);word-break:break-word;white-space:normal;font-weight:600;line-height:1.3}.sidebar-nav{flex-direction:column;flex:1;align-items:stretch;padding:8px;display:flex;overflow:hidden auto}.sidebar.collapsed .sidebar-nav{align-items:center}.nav-section-label{letter-spacing:2px;text-transform:uppercase;color:var(--grey-400);white-space:nowrap;padding:10px 10px 4px;font-size:10px;font-weight:700;transition:opacity .2s,max-height .2s;overflow:hidden}.sidebar.collapsed .nav-section-label{opacity:0;max-height:0;padding:0}.nav-item{width:100%;height:var(--h);cursor:pointer;color:var(--navy);font-size:var(--fs-md);border-radius:var(--radius);-webkit-user-select:none;user-select:none;white-space:nowrap;box-sizing:border-box;background:0 0;border:1px solid #0000;justify-content:flex-start;align-items:center;gap:10px;margin-bottom:2px;padding:0 10px;font-weight:500;transition:all .15s;display:flex;position:relative}.nav-item:hover{background:var(--gold-pale);color:var(--navy-dark);border-color:#b9984b59}.nav-item:active{transform:scale(.97)}.nav-item.active{background:var(--navy);border-color:var(--navy-dark);color:#fff;font-weight:600}.sidebar.collapsed .nav-item{width:var(--h);justify-content:center;margin:0 auto 2px;padding:0}.sidebar.collapsed .nav-label,.sidebar.collapsed .nav-section-label{display:none}.sidebar.collapsed .nav-item:after{content:attr(data-label);background:var(--navy);color:#fff;font-size:var(--fs-sm);border-radius:var(--radius);white-space:nowrap;pointer-events:none;opacity:0;z-index:200;box-shadow:var(--shadow);padding:6px 12px;font-weight:500;transition:all .18s;position:absolute;top:50%;left:calc(100% + 10px);transform:translateY(-50%)translate(-6px)}.sidebar.collapsed .nav-item:hover:after{opacity:1;transform:translateY(-50%)translate(0)}.nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:17px;display:flex}.nav-label{font-size:var(--fs-md);overflow:hidden}.sidebar-user{border-top:1px solid var(--grey-200);flex-shrink:0;padding:12px 14px}.sidebar.collapsed .sidebar-user{display:none}.user-name{color:var(--text);font-weight:600;font-size:var(--fs-md);white-space:nowrap;overflow:hidden}.role-badge{letter-spacing:1px;text-transform:uppercase;border-radius:4px;margin-top:3px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.role-admin{background:var(--gold-pale);color:var(--gold-border)}.role-dispatcher{color:#1d4ed8;background:#dbeafe}.role-tech{color:#166534;background:#dcfce7}.btn-signout{border:1px solid var(--grey-300);border-radius:var(--radius);width:100%;height:var(--h);color:var(--text2);font-family:Barlow,sans-serif;font-size:var(--fs-sm);cursor:pointer;background:0 0;justify-content:center;align-items:center;margin-top:8px;padding:0 12px;transition:all .15s;display:flex}.btn-signout:hover{border-color:var(--navy);color:var(--navy)}.sidebar-collapse-btn{background:var(--surface2);border:none;border-top:1px solid var(--grey-200);cursor:pointer;width:100%;height:40px;color:var(--text2);flex-shrink:0;justify-content:center;align-items:center;font-size:16px;transition:all .15s;display:flex}.sidebar-collapse-btn:hover{background:var(--surface3);color:var(--navy)}.sidebar-collapse-btn:active{transform:scale(.98)}.theme-toggle{width:var(--h);height:var(--h);background:var(--surface2);border:1px solid var(--grey-300);border-radius:var(--radius);cursor:pointer;color:var(--text2);flex-shrink:0;justify-content:center;align-items:center;font-size:16px;transition:all .15s;display:flex}.theme-toggle:hover{border-color:var(--navy);color:var(--navy)}.main{margin-left:var(--sidebar-w);min-height:100vh;transition:margin-left .25s cubic-bezier(.4,0,.2,1)}.main.collapsed{margin-left:var(--sidebar-collapsed)}.page{display:none}.page.active{display:block}.sticky-header{z-index:40;background:var(--surface);border-bottom:2px solid var(--navy);box-shadow:var(--shadow-sm);padding:12px var(--pad);margin:0 0 24px;position:sticky;top:0}.sticky-header-r1{min-height:var(--h);justify-content:space-between;align-items:center;gap:12px;display:flex}.sticky-header-r1-left{align-items:center;gap:10px;display:flex}.sticky-header-r2{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:8px;display:flex}.sticky-header-r2-left{flex-wrap:wrap;flex:1;align-items:center;gap:10px;display:flex}.sticky-header-r2-right{align-items:center;gap:10px;display:flex}.btn-icon{width:var(--h);height:var(--h);border-radius:var(--radius);border:1px solid var(--grey-300);background:var(--surface);color:var(--navy);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;transition:all .15s;display:flex}.btn-icon:hover{background:var(--grey-100);border-color:var(--navy)}.btn-icon:active{transform:scale(.96)}.btn-icon.danger{border-color:var(--red-border);color:var(--red)}.btn-icon.danger:hover{background:var(--red-bg)}.btn-icon.primary{background:var(--navy);border-color:var(--navy-dark);color:#fff}.btn-icon.primary:hover{background:var(--navy-light)}.btn-primary{height:var(--h);background:var(--navy);color:#fff;border:1px solid var(--navy-dark);border-radius:var(--radius);font-family:Barlow Condensed,sans-serif;font-size:var(--fs-lg);letter-spacing:.5px;text-transform:uppercase;cursor:pointer;white-space:nowrap;align-items:center;gap:6px;padding:0 20px;font-weight:700;transition:all .15s;display:inline-flex;box-shadow:0 2px 6px #25304733}.btn-primary:hover{background:var(--navy-light);border-color:var(--navy)}.btn-primary:active{background:var(--navy-dark);transform:scale(.98)}.btn-primary:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-secondary{height:var(--h);background:var(--surface2);color:var(--navy);border:1px solid var(--grey-300);border-radius:var(--radius);font-family:Barlow,sans-serif;font-size:var(--fs-md);cursor:pointer;white-space:nowrap;align-items:center;gap:6px;padding:0 16px;font-weight:600;transition:all .15s;display:inline-flex}.btn-secondary:hover{background:var(--gold-pale);border-color:var(--gold-border);color:var(--navy-dark)}.btn-secondary:active{background:var(--grey-200);transform:scale(.98)}.btn-danger{height:var(--h);background:var(--red-bg);color:var(--red);border:1px solid var(--red-border);border-radius:var(--radius);font-family:Barlow,sans-serif;font-size:var(--fs-md);cursor:pointer;white-space:nowrap;align-items:center;gap:6px;padding:0 16px;font-weight:600;transition:all .15s;display:inline-flex}.btn-danger:hover{background:#fecaca;border-color:#f87171}.btn-danger:active{transform:scale(.98)}.btn-excel{height:var(--h);background:var(--surface);color:var(--green);border:1px solid var(--green-border);border-radius:var(--radius);font-family:Barlow,sans-serif;font-size:var(--fs-md);cursor:pointer;align-items:center;gap:6px;padding:0 14px;font-weight:500;transition:all .15s;display:inline-flex}.btn-excel:hover{background:var(--green-bg)}.btn-gen{background:var(--surface);height:36px;color:var(--navy);border:1px solid var(--grey-300);border-radius:var(--radius);font-family:Barlow,sans-serif;font-size:var(--fs-sm);cursor:pointer;white-space:nowrap;align-items:center;gap:5px;padding:0 12px;font-weight:500;transition:all .15s;display:inline-flex}.btn-gen:hover{background:var(--gold-pale);border-color:var(--gold-border)}.btn-gen:disabled{opacity:.35;cursor:not-allowed}.form-card{background:var(--surface);border:1px solid var(--grey-200);border-radius:var(--radius-lg);padding:var(--pad);box-shadow:var(--shadow-card);margin-bottom:20px}.form-card-title{font-family:Barlow Condensed,sans-serif;font-size:var(--fs-h);color:var(--navy);border-bottom:2px solid var(--navy-pale);margin-bottom:18px;padding-bottom:10px;font-weight:700}.form-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px;display:grid}.fg-full{grid-column:1/-1}.fg-half{grid-column:span 2}.sec-div{font-size:var(--fs-sm);letter-spacing:2px;text-transform:uppercase;color:var(--text2);border-bottom:1px solid var(--grey-200);grid-column:1/-1;margin-top:8px;padding-bottom:8px;font-weight:700}.form-group label{font-size:var(--fs-sm);letter-spacing:.8px;text-transform:uppercase;color:var(--text2);flex-wrap:wrap;align-items:center;gap:4px;font-weight:700;display:flex}.req-star{color:var(--red);font-weight:700}.opt-tag{text-transform:none;letter-spacing:0;color:var(--text3);font-size:10px;font-weight:400}.form-group input,.form-group select{height:var(--h);background:var(--surface2);border:1px solid var(--grey-300);border-radius:var(--radius);color:var(--text);font-family:Barlow,sans-serif;font-size:var(--fs-md);outline:none;width:100%;padding:0 12px;transition:border-color .2s,box-shadow .2s}.form-group textarea{background:var(--surface2);border:1px solid var(--grey-300);border-radius:var(--radius);color:var(--text);font-family:Barlow,sans-serif;font-size:var(--fs-md);resize:vertical;outline:none;width:100%;min-height:80px;padding:10px 12px;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--navy);background:var(--surface);box-shadow:0 0 0 3px #25304717}.form-group input.err-field,.form-group select.err-field,.form-group textarea.err-field{border-color:var(--red);background:var(--red-bg)}.form-group .err-msg{color:var(--red);font-size:var(--fs-sm);margin-top:2px;display:none}.form-group.has-err label{color:var(--red)}.form-group.has-err .err-msg{display:block}.form-group select option{background:var(--surface);color:var(--text)}.form-group input[readonly]{opacity:.6;cursor:default;background:var(--grey-100)}.form-actions{padding-top:var(--pad);padding-bottom:var(--pad);border-top:1px solid var(--grey-200);flex-wrap:wrap;align-items:center;gap:10px;margin-top:20px;display:flex}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.upload-field{background:var(--surface2);border:2px dashed var(--grey-300);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:12px;padding:12px 16px;transition:border-color .15s;display:flex}.upload-field:hover{border-color:var(--navy)}.upload-field input[type=file]{display:none}.upload-label{font-size:var(--fs-sm);color:var(--text2);flex:1}.upload-label.has-file{color:var(--green);font-weight:500}.upload-btn{background:var(--navy);color:#fff;border-radius:var(--radius);height:32px;font-size:var(--fs-sm);cursor:pointer;white-space:nowrap;border:none;align-items:center;padding:0 14px;transition:background .15s;display:inline-flex}.upload-btn:hover{background:var(--navy-light)}.upload-status{letter-spacing:.8px;text-transform:uppercase;border-radius:20px;padding:3px 9px;font-size:10px;font-weight:700}.us-pending{background:var(--orange-bg);color:var(--orange);border:1px solid var(--orange-border)}.us-completed{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}.approve-btn{background:var(--green-bg);border:1px solid var(--green-border);border-radius:var(--radius);height:32px;color:var(--green);font-size:var(--fs-sm);cursor:pointer;align-items:center;padding:0 10px;transition:all .15s;display:inline-flex}.approve-btn:hover{background:#bbf7d0}.attach-list{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.attach-item{background:var(--surface);border:1px solid var(--grey-300);border-radius:var(--radius);height:32px;font-size:var(--fs-sm);color:var(--text);cursor:pointer;align-items:center;gap:6px;padding:0 10px;text-decoration:none;transition:all .15s;display:inline-flex}.attach-item:hover{border-color:var(--navy);color:var(--navy)}.attach-thumb{object-fit:cover;border-radius:var(--radius);border:1px solid var(--grey-300);cursor:pointer;width:40px;height:40px;transition:transform .15s}.attach-thumb:hover{transform:scale(1.1)}.upload-table{border-collapse:separate;border-spacing:0;border:1px solid var(--grey-200);border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-sm);overflow:hidden}.upload-table th{background:var(--navy);color:#fff;height:var(--h);font-size:var(--fs-sm);letter-spacing:2px;text-transform:uppercase;border-right:1px solid #ffffff26;padding:0 14px;font-weight:700}.upload-table td{border:1px solid var(--grey-200);vertical-align:middle;font-size:var(--fs-md);padding:10px 14px}.upload-table tr:nth-child(2n) td{background:var(--grey-50)}.metrics-grid{margin-bottom:var(--pad);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;display:grid}.metric-card{background:var(--surface);border:1px solid var(--grey-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:18px 20px 16px;transition:transform .18s,box-shadow .18s;position:relative;overflow:hidden}.metric-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.metric-card:before{content:"";background:var(--navy);width:4px;height:100%;position:absolute;top:0;left:0}.metric-label{font-size:var(--fs-sm);letter-spacing:2px;text-transform:uppercase;color:var(--text2);margin-bottom:8px;font-weight:700}.metric-value{color:var(--navy);font-family:Barlow Condensed,sans-serif;font-size:28px;font-weight:700;line-height:1}.metric-sub{font-size:var(--fs-sm);color:var(--text3);margin-top:4px}.mv-gold{color:var(--gold-border)}.mv-green{color:var(--green)}.mv-red{color:var(--red)}.panel{background:var(--surface);border:1px solid var(--grey-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);margin-bottom:20px;overflow:hidden}.panel-header{padding:12px var(--pad);border-bottom:1px solid var(--grey-200);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.panel-title{font-family:Barlow Condensed,sans-serif;font-size:var(--fs-h);color:var(--navy);font-weight:700}.tbl-wrap{overflow-x:auto}table{border-collapse:separate;border-spacing:0;width:100%;font-size:var(--fs-md)}th{text-align:left;height:var(--h);font-size:var(--fs-sm);letter-spacing:1.5px;text-transform:uppercase;color:#fff;white-space:nowrap;background:var(--navy);border-right:1px solid #ffffff1f;padding:0 14px;font-weight:700}th:last-child{border-right:none}td{height:var(--h);border-bottom:1px solid var(--grey-200);border-right:1px solid var(--grey-200);color:var(--text);vertical-align:middle;font-weight:500;font-size:var(--fs-md);padding:0 14px}td:last-child{border-right:none}td.td-actions{align-items:center;gap:6px;height:100%;display:flex}tr:nth-child(2n) td{background:var(--surface2)}tr:nth-child(odd) td{background:var(--surface)}tr.clickable-row{cursor:pointer;transition:all .12s}tr.clickable-row:hover td{background:#b9984b1a!important}tr.clickable-row:hover td:first-child{border-left:3px solid var(--gold-border)}tr.row-warn td{background:#fffbeb!important}tr.row-warn:hover td{background:#fef3c7!important}.panel table{border-radius:0}.badge{letter-spacing:.8px;text-transform:uppercase;white-space:nowrap;border-radius:20px;align-items:center;height:24px;padding:0 10px;font-size:10px;font-weight:700;display:inline-flex}.b-opened{color:#1d4ed8;background:#dbeafe;border:1px solid #93c5fd}.b-assigned{background:var(--gold-pale);color:var(--gold-border);border:1px solid #fbbf24}.b-blocked{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}.b-pending-ap{color:#7c3aed;background:#f3e8ff;border:1px solid #d8b4fe}.b-completed{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}.b-invoiced{background:var(--orange-bg);color:var(--orange);border:1px solid var(--orange-border)}.b-paid{color:#15803d;border:1px solid var(--green-border);background:#dcfce7}.b-applied{color:#0369a1;background:#e0f2fe;border:1px solid #7dd3fc}.b-pending{color:#7c3aed;background:#f3e8ff;border:1px solid #d8b4fe}.b-active{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}.comp-done{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border);border-radius:20px;align-items:center;height:22px;padding:0 9px;font-size:10px;font-weight:700;display:inline-flex}.comp-pend{background:var(--orange-bg);color:var(--orange);border:1px solid var(--orange-border);border-radius:20px;align-items:center;height:22px;padding:0 9px;font-size:10px;font-weight:700;display:inline-flex}.warn-pill{background:var(--orange-bg);color:var(--orange);border:1px solid var(--orange-border);border-radius:4px;align-items:center;gap:3px;height:22px;margin-left:6px;padding:0 8px;font-size:10px;font-weight:700;display:inline-flex}.ac-wrap{position:relative}.ac-list{background:var(--surface);border:1px solid var(--grey-300);border-radius:var(--radius);z-index:100;max-height:200px;box-shadow:var(--shadow);display:none;position:absolute;top:calc(100% + 2px);left:0;right:0;overflow-y:auto}.ac-list.open{display:block}.ac-item:last-child{border-bottom:none}.nte-table{border-collapse:separate;border-spacing:0;border:1px solid var(--grey-200);border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-sm);overflow:hidden}.nte-table th{background:var(--navy);color:#fff;height:var(--h);font-size:var(--fs-sm);letter-spacing:1px;text-transform:uppercase;border-right:1px solid #ffffff26;padding:0 10px;font-weight:700}.nte-table th:last-child{border-right:none}.nte-table td{border-bottom:1px solid var(--grey-200);border-right:1px solid var(--grey-100);background:var(--surface);vertical-align:middle;padding:6px 8px}.nte-table tr:nth-child(2n) td{background:var(--surface2)}.nte-table input{background:var(--surface2);border:1px solid var(--grey-300);height:32px;color:var(--text);font-family:Barlow,sans-serif;font-size:var(--fs-md);border-radius:6px;outline:none;width:100%;padding:0 8px}.nte-table input:focus{border-color:var(--navy);background:var(--surface)}.nte-total-row td{color:var(--navy);font-weight:700;background:var(--navy-pale)!important}.nte-add-btn{background:var(--surface);border:1px dashed var(--grey-300);border-radius:var(--radius);height:36px;color:var(--text2);font-size:var(--fs-md);cursor:pointer;align-items:center;gap:6px;margin-top:10px;padding:0 16px;transition:all .15s;display:inline-flex}.nte-add-btn:hover{border-color:var(--navy);color:var(--navy);background:var(--navy-pale)}.nte-del-btn{color:var(--red);cursor:pointer;background:0 0;border:none;align-items:center;padding:0 4px;font-size:16px;display:flex}.filter-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.fsel{height:var(--h);background:var(--surface);border:1px solid var(--grey-300);border-radius:var(--radius);color:var(--text);font-family:Barlow,sans-serif;font-size:var(--fs-md);outline:none;padding:0 12px;transition:border-color .15s}.fsel:focus{border-color:var(--navy)}.search-bar{height:var(--h);background:var(--surface);border:1px solid var(--grey-300);border-radius:var(--radius);color:var(--text);font-family:Barlow,sans-serif;font-size:var(--fs-md);outline:none;min-width:200px;padding:0 12px 0 36px;transition:border-color .15s}.search-bar:focus{border-color:var(--navy)}.search-wrap{align-items:center;display:inline-flex;position:relative}.search-icon{color:var(--grey-400);pointer-events:none;font-size:15px;position:absolute;left:10px}.act-btn{background:var(--surface);border:1px solid var(--grey-300);border-radius:var(--radius);height:32px;color:var(--navy);font-size:var(--fs-sm);cursor:pointer;white-space:nowrap;align-items:center;gap:5px;padding:0 12px;font-family:Barlow,sans-serif;font-weight:500;transition:all .15s;display:inline-flex}.act-btn:hover{background:var(--gold-pale);border-color:var(--gold-border)}.act-btn:active{transform:scale(.96)}.act-btn.del{border-color:var(--red-border);color:var(--red);background:var(--red-bg);justify-content:center;width:32px;padding:0}.act-btn.del:hover{background:#fecaca}.act-btn:disabled{opacity:.35;cursor:not-allowed}.hist-entry{background:var(--surface2);border:1px solid var(--grey-200);border-radius:var(--radius);margin-bottom:8px;padding:12px 16px}.hist-meta{font-size:var(--fs-sm);color:var(--text2);flex-wrap:wrap;gap:12px;margin-bottom:4px;display:flex}.hist-type{letter-spacing:.8px;text-transform:uppercase;border-radius:10px;padding:1px 7px;font-size:10px;font-weight:700}.ht-status{background:var(--gold-pale);color:var(--gold-border)}.ht-update{color:#1d4ed8;background:#dbeafe}.hist-text{font-size:var(--fs-md);color:var(--text)}.checklist{background:var(--red-bg);border:1px solid var(--red-border);border-radius:var(--radius);margin-bottom:16px;padding:14px 16px}.checklist-title{font-size:var(--fs-sm);color:var(--red);margin-bottom:8px;font-weight:700}.checklist-item{font-size:var(--fs-sm);color:var(--red);align-items:center;gap:6px;padding:3px 0;display:flex}.checklist-item:before{content:"✗";font-weight:700}#banner-alert{z-index:998;opacity:0;border-radius:var(--radius-lg);font-size:var(--fs-md);pointer-events:none;align-items:center;gap:12px;width:calc(100% - 48px);max-width:520px;padding:12px 24px;font-weight:500;transition:all .35s cubic-bezier(.34,1.56,.64,1);display:flex;position:fixed;bottom:28px;left:50%;transform:translate(-50%)translateY(80px);box-shadow:0 8px 32px #25304740}#banner-alert.show{opacity:1;pointer-events:auto;transform:translate(-50%)translateY(0)}#banner-alert.alert-warn{background:var(--orange-bg);border:2px solid var(--orange-border);color:var(--orange)}#banner-alert.alert-err{background:var(--red-bg);border:2px solid var(--red-border);color:var(--red)}#banner-alert.alert-ok{background:var(--green-bg);border:2px solid var(--green-border);color:var(--green)}#banner-alert.alert-info{background:var(--navy);border:2px solid var(--gold-border);color:#fff}.banner-close{cursor:pointer;color:inherit;opacity:.7;background:0 0;border:none;margin-left:auto;padding:0;font-size:18px}.banner-close:hover{opacity:1}.modal-ov.open{display:flex}.modal{background:var(--surface);border:1px solid var(--grey-200);border-radius:var(--radius-xl);width:700px;max-width:96vw;max-height:90vh;padding:28px;overflow-y:auto;box-shadow:0 20px 60px #0d1f3540}.modal-actions{border-top:1px solid var(--grey-200);justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;display:flex}.doc-preview{color:#111;border-radius:var(--radius);border:1px solid var(--grey-200);background:#fff;padding:32px;font-family:Barlow,sans-serif;font-size:13px;line-height:1.6}.doc-preview h1{margin-bottom:4px;font-size:22px;font-weight:700}.doc-preview h2{color:#253047;border-bottom:1px solid #e5e7eb;margin:16px 0 8px;padding-bottom:4px;font-size:15px;font-weight:700}.doc-preview .doc-header{border-bottom:3px solid #253047;justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding-bottom:16px;display:flex}.doc-preview .doc-company{color:#555;font-size:11px}.doc-preview .doc-table{border-collapse:collapse;width:100%;margin:12px 0}.doc-preview .doc-table th{color:#fff;text-align:left;background:#253047;padding:8px 12px;font-size:11px;font-weight:700}.doc-preview .doc-table td{border-bottom:1px solid #eee;padding:8px 12px}.doc-preview .doc-total{text-align:right;color:#253047;margin-top:12px;font-size:16px;font-weight:700}.doc-preview .field-row{grid-template-columns:160px 1fr;gap:4px 12px;margin-bottom:6px;display:grid}.doc-preview .field-label{color:#555;font-weight:600}.doc-sign-line{color:#555;border-top:1px solid #999;margin-top:40px;padding-top:8px;font-size:12px}.wo-row-d{border-bottom:1px solid var(--grey-200);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.wo-row-d:last-child{border-bottom:none}.wo-id-d{color:var(--navy);font-family:Barlow Condensed,sans-serif;font-weight:700;font-size:var(--fs-lg)}.empty-st{text-align:center;color:var(--text3);padding:40px 20px}.empty-icon{opacity:.4;margin-bottom:8px;font-size:28px}.comp-warn-box{background:var(--orange-bg);border:1px solid var(--orange-border);border-radius:var(--radius);font-size:var(--fs-sm);color:var(--orange);padding:10px 14px;line-height:1.6}.wo-sticky-header{z-index:40;background:var(--surface);border-bottom:2px solid var(--navy);box-shadow:var(--shadow-sm);padding:10px var(--pad);margin:0;position:sticky;top:0}.wo-header-r1{min-height:var(--h);justify-content:space-between;align-items:center;gap:12px;display:flex}.wo-header-r1-left{align-items:center;gap:10px;display:flex}.wo-header-r2{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:8px;display:flex}.wo-header-r2-left{flex-wrap:wrap;flex:1;align-items:center;gap:10px;display:flex}.wo-header-r2-right{align-items:center;gap:10px;display:flex}.wo-header-title{font-family:Barlow Condensed,sans-serif;font-size:var(--fs-h);color:var(--navy);font-weight:700}.wo-header-title span{color:var(--gold-border)}.wo-header-spacer{height:120px}.wo-form-card{border-radius:var(--radius-lg);padding:0;overflow:hidden}.wo-section{border-bottom:1px solid var(--grey-200)}.wo-section:last-child{border-bottom:none}.wo-section-header{padding:14px var(--pad);cursor:pointer;background:var(--navy);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;transition:background .15s;display:flex}.wo-section-header:hover{background:var(--navy-light)}.wo-section-title{font-family:Barlow Condensed,sans-serif;font-size:var(--fs-lg);color:#fff;letter-spacing:.3px;font-weight:700}.wo-section-chevron{color:#ffffffb3;font-size:14px;transition:transform .2s}.wo-section.collapsed .wo-section-chevron{transform:rotate(-90deg)}.wo-section.collapsed .wo-section-body{display:none}.wo-section-body{padding:20px var(--pad)}.wo-hr{border:none;border-top:1px solid var(--grey-200);margin:16px 0}.wo-hr-major{border:none;border-top:1px solid var(--grey-200);margin:0}.wo-row-4{grid-template-columns:2fr 1fr 1fr 1fr;gap:16px;display:grid}.wo-row-3{grid-template-columns:2fr 1fr 1fr;gap:16px;display:grid}.wo-addr-desc-grid{grid-template-columns:1fr 1fr;align-items:start;gap:20px;margin-top:16px;display:grid}@media (width<=900px){.wo-row-4,.wo-row-3{grid-template-columns:1fr 1fr}.wo-addr-desc-grid{grid-template-columns:1fr}}@media (width<=600px){.wo-row-4,.wo-row-3{grid-template-columns:1fr}}.wo-edit-btn{background:var(--orange-bg);border:1px solid var(--orange-border);border-radius:var(--radius);height:32px;color:var(--orange);cursor:pointer;align-items:center;padding:0 10px;font-size:13px;display:inline-flex}.wo-edit-btn:hover{background:#fef3c7}.wo-alert{display:none}.danger-row{padding:var(--pad);border-top:1px solid var(--grey-200);justify-content:flex-end;display:flex}@media (width<=768px){.sidebar{width:var(--sidebar-collapsed)!important}.main{margin-left:var(--sidebar-collapsed)!important}.sidebar .nav-label,.sidebar .nav-section-label,.sidebar .sidebar-logo-text,.sidebar-user{display:none}.sidebar .nav-item{width:var(--h);justify-content:center;margin:0 auto 2px;padding:0}.page{padding:16px}.form-grid{grid-template-columns:1fr}.metrics-grid{grid-template-columns:1fr 1fr}.wo-sticky-header{margin:0}.sticky-header{margin:0 0 16px}}#app{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-w);flex:1;min-height:100vh;transition:margin-left .25s cubic-bezier(.4,0,.2,1)}.main-content.collapsed{margin-left:var(--sidebar-collapsed)}.sb-top{flex-direction:column;flex:1;display:flex;overflow:hidden}.sb-bottom{border-top:1px solid var(--grey-200);flex-direction:row;align-items:center;gap:4px;padding:8px;display:flex}.sb-logo{align-items:center;gap:10px;padding:16px 14px 8px;display:flex}.sb-logo-icon{color:var(--navy);flex-shrink:0;font-family:Barlow Condensed,sans-serif;font-size:28px;font-weight:700}.sb-logo-text{color:var(--navy);font-size:12px;font-weight:600;line-height:1.3}.sb-user{border-bottom:1px solid var(--grey-200);align-items:center;gap:10px;padding:10px 14px;display:flex}.sb-avatar{background:var(--navy);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex}.sb-user-info{overflow:hidden}.sb-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sb-nav{flex:1;padding:8px;overflow-y:auto}.sb-icon-btn{border-radius:var(--radius);border:1px solid var(--grey-300);cursor:pointer;background:0 0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:all .15s;display:flex}.sb-icon-btn:hover{background:var(--gold-pale);border-color:var(--gold-border)}.page-header{padding:16px var(--pad);border-bottom:2px solid var(--navy);background:var(--surface);z-index:40;box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex;position:sticky;top:0}.page-title{font-family:Barlow Condensed,sans-serif;font-size:var(--fs-h);color:var(--navy);font-weight:700}.page-title span{color:var(--gold-border)}.form-sticky-header{z-index:40;background:var(--surface);border-bottom:2px solid var(--navy);padding:10px var(--pad);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;gap:12px;display:flex;position:sticky;top:0}.sticky-left{align-items:center;gap:12px;display:flex}.sticky-actions{align-items:center;gap:8px;display:flex}.btn-back{border:1px solid var(--grey-300);border-radius:var(--radius);height:var(--h);color:var(--navy);font-family:Barlow,sans-serif;font-size:var(--fs-md);cursor:pointer;background:0 0;padding:0 12px;font-weight:500;transition:all .15s}.btn-back:hover{background:var(--gold-pale);border-color:var(--gold-border)}.btn-outline{height:var(--h);border:1px solid var(--grey-300);border-radius:var(--radius);color:var(--navy);font-family:Barlow,sans-serif;font-size:var(--fs-md);cursor:pointer;background:0 0;padding:0 16px;font-weight:500;transition:all .15s}.btn-outline:hover{border-color:var(--navy);background:var(--gold-pale)}.btn-sm{background:var(--surface);border:1px solid var(--grey-300);border-radius:var(--radius);height:32px;color:var(--navy);font-size:var(--fs-sm);cursor:pointer;align-items:center;gap:5px;padding:0 12px;font-family:Barlow,sans-serif;transition:all .15s;display:inline-flex}.btn-sm:hover{background:var(--gold-pale);border-color:var(--gold-border)}.btn-gold{background:var(--gold-pale)!important;border-color:var(--gold-border)!important;color:var(--navy)!important}.btn-link{color:var(--navy);font-size:var(--fs-sm);cursor:pointer;background:0 0;border:none;margin-top:8px;padding:0;font-family:Barlow,sans-serif;font-weight:600;text-decoration:underline;display:block}.btn-link:hover{color:var(--gold)}.btn-dev{width:100%;height:var(--h);background:var(--orange-bg);border:1px solid var(--orange-border);border-radius:var(--radius);color:var(--orange);cursor:pointer;font-family:Barlow,sans-serif;font-weight:600}.w-full{width:100%}.auth-screen{z-index:100;background:var(--navy-dark);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-brand{text-align:center;margin-bottom:28px}.auth-logo{color:var(--navy);letter-spacing:-2px;font-family:Barlow Condensed,sans-serif;font-size:44px;font-weight:700;line-height:1}.auth-brand-name{color:#4b5563;margin-top:4px;font-size:14px;font-weight:600}.auth-brand-sub{letter-spacing:3px;text-transform:uppercase;color:#9ca3af;margin-top:2px;font-size:11px;font-weight:600}.auth-err{font-size:var(--fs-sm);text-align:center;min-height:18px;margin-bottom:12px}.card{background:var(--surface);border:1px solid var(--grey-200);border-radius:var(--radius-lg);padding:var(--pad);box-shadow:var(--shadow-card);margin-bottom:20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{font-family:Barlow Condensed,sans-serif;font-size:var(--fs-h);color:var(--navy);font-weight:700}.form-body{padding:var(--pad);max-width:1100px}.form-row{flex-wrap:wrap;gap:16px;margin-bottom:16px;display:flex}.form-row>.form-group{flex:1;min-width:160px}.form-ctrl{height:var(--h);background:var(--surface2);border:1px solid var(--grey-300);border-radius:var(--radius);color:var(--text);font-family:Barlow,sans-serif;font-size:var(--fs-md);outline:none;width:100%;padding:0 12px;transition:border-color .2s,box-shadow .2s}.form-ctrl:focus{border-color:var(--navy);background:var(--surface);box-shadow:0 0 0 3px #25304717}.form-ctrl.err-field{border-color:var(--red);background:var(--red-bg)}textarea.form-ctrl{resize:vertical;height:auto;min-height:80px;padding:10px 12px}select.form-ctrl{cursor:pointer}.form-label{font-size:var(--fs-sm);letter-spacing:.8px;text-transform:uppercase;color:var(--text2);margin-bottom:5px;font-weight:700;display:block}.form-group.has-err .form-label{color:var(--red)}.form-group{flex-direction:column;gap:5px;display:flex}.form-section{background:var(--surface);border:1px solid var(--grey-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);margin-bottom:16px;overflow:hidden}.section-header{padding:14px var(--pad);cursor:pointer;background:var(--navy);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;display:flex}.section-header:hover{background:var(--navy-light)}.section-title{font-family:Barlow Condensed,sans-serif;font-size:var(--fs-lg);color:#fff;font-weight:700}.section-toggle{color:#ffffffb3;font-size:13px}.section-body{padding:20px var(--pad)}.metrics-row{margin-bottom:var(--pad);padding:0 var(--pad);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;display:grid}.dash-grid{padding:0 var(--pad) var(--pad);grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=900px){.dash-grid{grid-template-columns:1fr}}.table-wrap{padding:0 var(--pad) var(--pad);overflow-x:auto}.data-table{border-collapse:separate;border-spacing:0;width:100%;font-size:var(--fs-md);border:1px solid var(--grey-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}.data-table th{text-align:left;height:var(--h);font-size:var(--fs-sm);letter-spacing:1.5px;text-transform:uppercase;color:#fff;white-space:nowrap;background:var(--navy);border-right:1px solid #ffffff1f;padding:0 14px;font-weight:700}.data-table td{height:var(--h);border-bottom:1px solid var(--grey-200);border-right:1px solid var(--grey-200);color:var(--text);vertical-align:middle;padding:0 14px;font-weight:500}.data-table tr:nth-child(2n) td{background:var(--surface2)}.data-table tr:nth-child(odd) td{background:var(--surface)}.data-table tr.clickable-row{cursor:pointer}.data-table tr.clickable-row:hover td{background:#b9984b1a!important}.data-table tr.clickable-row:hover td:first-child{border-left:3px solid var(--gold-border)}.data-table tr.row-warn td{background:#fffbeb!important}.filters-bar{padding:0 var(--pad);flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.filter-search{min-width:220px}.nte-footer{justify-content:space-between;align-items:center;margin-top:10px;display:flex}.nte-total-row{color:var(--navy);font-weight:700}.modal-ov{z-index:200;background:#0d1f3599;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box{background:var(--surface);border:1px solid var(--grey-200);border-radius:var(--radius-xl);width:700px;max-width:96vw;max-height:90vh;padding:28px;position:relative;overflow-y:auto;box-shadow:0 20px 60px #0d1f3540}.modal-close{cursor:pointer;color:var(--text2);background:0 0;border:none;font-size:20px;position:absolute;top:16px;right:16px}.modal-close:hover{color:var(--navy)}.modal-title{font-family:Barlow Condensed,sans-serif;font-size:var(--fs-h);color:var(--navy);border-bottom:2px solid var(--navy-pale);margin-bottom:20px;padding-bottom:12px;font-weight:700}.alert-banner{border-radius:var(--radius);font-size:var(--fs-sm);align-items:center;gap:8px;margin-bottom:12px;padding:10px 14px;display:flex}.alert-banner.alert-warn{background:var(--orange-bg);border:1px solid var(--orange-border);color:var(--orange)}.alert-banner.alert-err{background:var(--red-bg);border:1px solid var(--red-border);color:var(--red)}.ac-list{background:var(--surface);border:1px solid var(--grey-300);border-radius:var(--radius);z-index:100;max-height:200px;box-shadow:var(--shadow);position:absolute;top:calc(100% + 2px);left:0;right:0;overflow-y:auto}.ac-item{height:var(--h);cursor:pointer;font-size:var(--fs-md);color:var(--text);border-bottom:1px solid var(--grey-100);align-items:center;padding:0 12px;display:flex}.ac-item:hover{background:var(--gold-pale);color:var(--navy)}
