@font-face{font-family:Manrope Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(../media/manrope-cyrillic-ext-wght-normal.1dtltwig2y3wh.woff2)format("woff2-variations");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Manrope Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(../media/manrope-cyrillic-wght-normal.1hmx3sz6swr8m.woff2)format("woff2-variations");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Manrope Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(../media/manrope-greek-wght-normal.37b2k1x9f-55d.woff2)format("woff2-variations");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Manrope Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(../media/manrope-vietnamese-wght-normal.3xvzy9_grgcx4.woff2)format("woff2-variations");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Manrope Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(../media/manrope-latin-ext-wght-normal.0-hru0xfwhnbp.woff2)format("woff2-variations");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Manrope Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(../media/manrope-latin-wght-normal.1p_a2k8qd5zhp.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
:root{--font-body:"Manrope Variable", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display:"Manrope Variable", ui-sans-serif, system-ui, sans-serif;--ink:#12251d;--muted:#65756d;--paper:#f4f0e7;--surface:#fffdf8;--line:#d9ddd5;--green:#165c43;--green-2:#0d3d2c;--lime:#ccf06a;--amber:#e7a936;--red:#b6403a;--blue:#4274a8;--shadow:0 16px 45px #12251d14}*{box-sizing:border-box}html{background:var(--paper)}body{color:var(--ink);background:radial-gradient(circle at 95% 5%, #ccf06a2e, transparent 24rem), var(--paper);font-family:var(--font-body), sans-serif;font-synthesis:none;text-rendering:optimizelegibility;margin:0;font-weight:450}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}strong,b{font-weight:600}h1,h2,h3,p{margin-top:0}h1,h2,h3{font-family:var(--font-display), sans-serif;letter-spacing:-.035em;font-weight:600}.auth-shell{grid-template-columns:1.15fr .85fr;min-height:100vh;display:grid}.auth-story{color:#fff;background:linear-gradient(145deg,#08271cf5,#165c43ed),repeating-linear-gradient(45deg,#0000,#0000 18px,#ffffff08 19px);flex-direction:column;justify-content:space-between;padding:clamp(2rem,6vw,7rem);display:flex}.brand{font-weight:600;font-family:var(--font-display);align-items:center;gap:.75rem;display:flex}.brand-mark{background:var(--lime);width:2.15rem;height:2.15rem;color:var(--green-2);border-radius:.65rem;place-items:center;font-weight:600;display:grid}.auth-story h1{max-width:850px;margin-bottom:1.5rem;font-size:clamp(2.8rem,6vw,6.5rem);line-height:.96}.eyebrow{text-transform:uppercase;letter-spacing:.16em;color:var(--green);font-size:.73rem;font-weight:600}.auth-story .eyebrow{color:var(--lime)}.auth-story p{color:#d8e7df;max-width:640px;font-size:1.05rem;line-height:1.65}.auth-panel{place-items:center;padding:2rem;display:grid}.auth-card{width:min(420px,100%)}.auth-card h2{margin-bottom:.5rem;font-size:2.2rem}.auth-card>p{color:var(--muted);margin-bottom:2rem}.field{gap:.5rem;margin-bottom:1rem;display:grid}.field label{font-size:.82rem;font-weight:600}.field input,.field select,.field textarea{border:1px solid var(--line);background:var(--surface);width:100%;color:var(--ink);border-radius:.8rem;outline:none;padding:.85rem 1rem}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px #165c431f}.button{background:var(--green);color:#fff;border:0;border-radius:.8rem;justify-content:center;align-items:center;gap:.5rem;padding:.82rem 1.1rem;font-weight:600;display:inline-flex}.button:hover{background:var(--green-2)}.button.secondary{color:var(--ink);background:#e8ece8}.button.danger{background:var(--red)}.button.full{width:100%}.button:disabled{opacity:.55;cursor:not-allowed}.error{color:var(--red);font-size:.85rem}.app-shell{grid-template-columns:250px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--green-2);color:#fff;flex-direction:column;height:100vh;padding:1.3rem;display:flex;position:sticky;top:0}.sidebar .brand{margin-bottom:2rem;font-size:1.15rem}.nav{gap:.35rem;display:grid}.nav a{color:#c8d9d1;border-radius:.7rem;align-items:center;gap:.75rem;padding:.7rem .8rem;font-size:.9rem;font-weight:500;display:flex}.nav a:hover,.nav a.active{color:#fff;background:#ffffff1a}.sidebar-footer{border-top:1px solid #ffffff1f;margin-top:auto;padding-top:1rem}.main{min-width:0}.topbar{border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:10;background:#f4f0e7db;justify-content:space-between;align-items:center;height:72px;padding:0 2rem;display:flex;position:sticky;top:0}.content{max-width:1600px;margin:0 auto;padding:2rem}.page-head{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.75rem;display:flex}.page-head h1{margin-bottom:.25rem;font-size:clamp(2rem,4vw,3.3rem)}.page-head p{color:var(--muted)}.grid{gap:1rem;display:grid}.stats{grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:1rem}.two-col{grid-template-columns:1.4fr 1fr}.card{border:1px solid var(--line);box-shadow:var(--shadow);background:#fffdf8eb;border-radius:1rem;padding:1.2rem}.stat .label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;font-weight:600}.stat .value{font-family:var(--font-display);margin-top:.5rem;font-size:2rem;font-weight:600}.stat .hint{color:var(--muted);font-size:.78rem}.table-wrap{border:1px solid var(--line);background:var(--surface);border-radius:.9rem;overflow:auto}table{border-collapse:collapse;width:100%;min-width:760px}th,td{text-align:left;border-bottom:1px solid var(--line);padding:.85rem 1rem;font-size:.86rem}th{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);background:#f8f6f0;font-size:.72rem;font-weight:600}tr:last-child td{border-bottom:0}.badge{background:#e8ece8;border-radius:999px;align-items:center;gap:.35rem;padding:.3rem .55rem;font-size:.7rem;font-weight:600;display:inline-flex}.badge.good{color:#155637;background:#d9efdf}.badge.warn{color:#815500;background:#fff0c8}.badge.bad{color:#8e2d28;background:#f7d9d6}.toolbar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.toolbar input,.toolbar select{border:1px solid var(--line);background:var(--surface);border-radius:.65rem;padding:.65rem .8rem}.empty{text-align:center;color:var(--muted);padding:3rem}.progress{background:#e1e5df;border-radius:999px;height:.55rem;overflow:hidden}.progress>span{background:var(--green);height:100%;display:block}.sync-banner{background:#fff0c8;border-radius:.75rem;justify-content:space-between;gap:1rem;margin-bottom:1rem;padding:.65rem 1rem;font-size:.82rem;display:flex}.quick-grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:.75rem;display:grid}.worker-tile{border:1px solid var(--line);background:var(--surface);border-radius:.9rem;padding:1rem}.worker-tile h3{margin-bottom:.25rem}.worker-tile p{color:var(--muted);margin-bottom:.8rem;font-size:.8rem}.worker-actions{gap:.5rem;display:flex}.worker-actions .button{flex:1;padding:.62rem;font-size:.8rem}.modal-backdrop{z-index:50;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#08271c8c;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.review-panel{border:1px solid var(--line);background:var(--surface);border-radius:1rem;width:min(680px,100%);max-height:calc(100vh - 2rem);padding:1.25rem;overflow:auto;box-shadow:0 24px 80px #08271c47}.review-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:1rem;padding-bottom:1rem;display:flex}.review-head h2{margin-bottom:.3rem}.review-head p{color:var(--muted);margin-bottom:0}.icon-button{border:1px solid var(--line);width:2.5rem;height:2.5rem;color:var(--ink);background:#fff;border-radius:.7rem;place-items:center;display:grid}.review-summary{color:var(--muted);background:#f8f6f0;border-radius:.75rem;align-items:center;gap:.75rem;margin:1rem 0;padding:.8rem;font-size:.82rem;display:flex}.exception-list{gap:.8rem;display:grid}.exception-card{border:1px solid var(--line);background:#fff;border-radius:.85rem;padding:1rem}.exception-card>div>strong{text-transform:capitalize}.exception-card p{color:var(--muted);margin:.25rem 0 1rem;font-size:.82rem}.decision-actions{gap:.6rem;display:flex}.muted{color:var(--muted);font-size:.8rem}.inline-actions{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.table-link{color:var(--ink);text-align:left;background:0 0;border:0;padding:0;font-weight:600}.table-link:hover{color:var(--green)}.worker-pay-link{text-underline-offset:.2rem;font-weight:600;-webkit-text-decoration:underline #0000;text-decoration:underline #0000}.worker-pay-link:hover{color:var(--green);text-decoration-color:currentColor}.selected-row td{background:#ccf06a17}.payroll-policy{justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:1rem;display:flex}.payroll-policy>div{align-items:center;gap:.8rem;display:flex}.payroll-policy p{color:var(--muted);margin:.2rem 0 0;font-size:.82rem}.settings-icon{width:2.5rem;height:2.5rem;color:var(--green-2);background:var(--lime);border-radius:.75rem;flex:none;place-items:center;display:grid}.policy-control{flex:none}.money-input{border:1px solid var(--line);background:var(--surface);border-radius:.65rem;align-items:center;min-width:155px;display:flex;overflow:hidden}.money-input span{color:var(--muted);padding:0 .7rem;font-size:.75rem;font-weight:600}.money-input input{background:0 0;border:0;outline:0;width:100%;min-width:0;padding:.65rem .7rem}.percentage-input{width:150px}.cycle-form{grid-template-columns:1.4fr 1fr 1fr auto;align-items:end;gap:.8rem;margin-bottom:1rem;display:grid}.cycle-form .field{margin:0}.payroll-lines{margin-top:2rem}.payroll-section-head{align-items:center;margin-bottom:1rem}.payroll-section-head h2{margin-bottom:.2rem}.payroll-override{gap:.45rem;min-width:260px;display:grid}.payroll-override>input{border:1px solid var(--line);background:var(--surface);border-radius:.65rem;outline:none;padding:.65rem .7rem}.payroll-line-action{min-width:290px}.payroll-empty{justify-items:center;gap:.8rem;display:grid}.payroll-empty p{margin:0}.payroll-notice{color:#155637;background:#d9efdf}.payroll-error{color:#8e2d28;background:#f7d9d6}.detail-back{margin-bottom:1rem}.payroll-detail-head{align-items:center}.payroll-detail-head h1{margin-bottom:.25rem}.payroll-detail-meta{color:var(--muted);margin-bottom:0}.payroll-detail-stats{grid-template-columns:repeat(5,minmax(0,1fr));margin-bottom:1rem}.payroll-detail-stat .value{font-size:1.55rem}.payroll-detail-note{margin-bottom:1rem}.payroll-detail-table td{vertical-align:top}.payroll-detail-table .amount-positive{color:var(--green);font-weight:600}.payroll-detail-table .amount-negative{color:var(--red);font-weight:600}.day-context{gap:.18rem;display:grid}.day-context span{color:var(--muted);font-size:.76rem}.day-pay-components{gap:.15rem;min-width:140px;display:grid}.day-pay-components span{color:var(--muted);font-size:.74rem}.payroll-reconciliation{grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1rem;display:grid}.payroll-reconciliation>div{background:#f8f6f0;border-radius:.8rem;padding:1rem}.payroll-reconciliation span{color:var(--muted);margin-bottom:.3rem;font-size:.75rem;display:block}.worker-form-section{margin-bottom:1rem}.section-heading{justify-content:space-between;gap:1rem;margin-bottom:1rem;display:flex}.section-heading h2{margin-bottom:.25rem}.section-heading p{color:var(--muted);margin-bottom:0;font-size:.84rem}.worker-form-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;display:grid}.worker-form-grid .field{margin:0}.worker-form-grid .span-2{grid-column:span 2}.wage-grid{grid-template-columns:repeat(2,minmax(0,260px))}.allowance-list{gap:.65rem;margin-top:1rem;display:grid}.allowance-row{background:#f8f6f0;border-radius:.8rem;grid-template-columns:1.4fr 1fr 1fr auto;align-items:end;gap:.75rem;padding:.8rem;display:grid}.allowance-row .field{margin:0}.allowance-remove{margin-bottom:.02rem}.add-allowance{justify-self:start}.worker-form-actions{z-index:5;border:1px solid var(--line);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow);background:#fffdf8f0;border-radius:.9rem;justify-content:flex-end;gap:.75rem;margin-top:1rem;padding:.85rem;display:flex;position:sticky;bottom:1rem}.staff-payroll-profile{color:#fff;background:var(--green-2);justify-content:space-between;align-items:center;gap:2rem;margin-bottom:1rem;display:flex}.staff-payroll-profile h2{margin-bottom:.25rem}.staff-payroll-profile p{color:#b9cdc4;margin-bottom:0}.staff-payroll-profile>div:last-child{text-align:right}.staff-payroll-profile span{color:#b9cdc4;font-size:.75rem;display:block}.staff-payroll-profile strong{margin-top:.25rem;font-size:1.5rem;display:block}.password-field{gap:.5rem;display:flex}.password-field input{flex:1}.payroll-profile-toggle{cursor:pointer;align-items:flex-start;gap:.75rem;display:flex}.payroll-profile-toggle input{width:1.1rem;height:1.1rem;accent-color:var(--green);margin-top:.2rem}.payroll-profile-toggle span{gap:.25rem;display:grid}.payroll-profile-toggle small{color:var(--muted);line-height:1.5}.role-check{border:1px solid var(--line);text-transform:capitalize;background:#f8f6f0;border-radius:.65rem;align-items:center;gap:.4rem;padding:.45rem .65rem;font-size:.78rem;display:inline-flex}.role-check input{accent-color:var(--green)}.advance-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.7rem;margin:1rem 0;display:grid}.advance-summary-grid>div{background:#f8f6f0;border-radius:.75rem;align-content:start;gap:.35rem;padding:.8rem;display:grid}.advance-summary-grid span{color:var(--muted);font-size:.72rem}.case-note{border-left:3px solid var(--lime);background:#f8f6f0;margin-bottom:1rem;padding:.9rem}.case-note p{color:var(--muted);margin:.35rem 0 0;line-height:1.55}.dispute-panel{width:min(820px,100%)}.case-section{border-top:1px solid var(--line);padding:1rem 0}.case-section h3,.case-resolution h3{margin-bottom:.7rem}.case-entry{border:1px solid var(--line);border-radius:.7rem;margin-bottom:.6rem;padding:.75rem}.case-entry p{color:var(--muted);margin:.25rem 0}.case-entry span{color:var(--muted);font-size:.7rem}.case-resolution{background:#f8f6f0;border-radius:.8rem;margin-top:1rem;padding:1rem}.sla-overdue{color:var(--red);font-size:.8rem;font-weight:600}@media (max-width:1000px){.stats{grid-template-columns:repeat(2,1fr)}.two-col{grid-template-columns:1fr}.cycle-form{grid-template-columns:1fr 1fr}.payroll-detail-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.worker-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:760px){.auth-shell{grid-template-columns:1fr}.auth-story{min-height:36vh;padding:2rem}.auth-story h1{font-size:2.8rem}.app-shell{grid-template-columns:1fr}.sidebar{height:auto;position:static}.nav{grid-template-columns:repeat(4,1fr);overflow:auto}.nav a{flex-direction:column;gap:.3rem;font-size:.68rem}.sidebar-footer{display:none}.topbar{padding:0 1rem}.content{padding:1rem}.stats{grid-template-columns:1fr 1fr}.decision-actions{flex-direction:column}.payroll-policy,.payroll-policy>div{align-items:flex-start}.payroll-policy{flex-direction:column}.policy-control{flex-wrap:wrap;width:100%}.cycle-form{grid-template-columns:1fr}.payroll-detail-stats,.payroll-reconciliation{grid-template-columns:1fr 1fr}.worker-form-grid,.wage-grid,.allowance-row{grid-template-columns:1fr}.advance-summary-grid{grid-template-columns:1fr 1fr}.worker-form-grid .span-2{grid-column:auto}.allowance-remove{justify-self:end}}
