:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f4f7f6;color:#17201d;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}body.modal-scroll-locked{overflow:hidden}button,input,select,textarea{font:inherit}button{border:0;cursor:pointer}.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:#eef2f1}.login-panel{width:min(420px,100%);background:#fff;border:1px solid #dfe7e3;border-radius:8px;padding:28px;box-shadow:0 18px 50px #14201d1f}.login-panel h1{margin-bottom:22px}.login-mark{width:48px;height:48px;display:grid;place-items:center;margin-bottom:18px;border-radius:8px;color:#fff;background:#19735d}.app-shell{display:grid;grid-template-columns:272px minmax(0,1fr);min-height:100vh}.sidebar{background:#172722;color:#f4fbf7;padding:22px 16px}.brand{display:flex;gap:12px;align-items:center;padding:4px 8px 22px}.brand strong,.brand span{display:block}.brand span{color:#adc2bb;font-size:13px;margin-top:2px}nav{display:grid;gap:4px}nav button{width:100%;min-height:48px;display:grid;grid-template-columns:22px minmax(0,1fr) auto;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;background:transparent;color:#d7e4df;text-align:left}nav button small{color:#91aaa1;font-size:11px}nav button.active,nav button:hover{background:#2b463e;color:#fff}.content{padding:26px;display:grid;gap:22px;align-content:start}.topbar{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,360px) auto auto;gap:14px;align-items:end;padding-bottom:18px;border-bottom:1px solid #dce6e2}.lock-warning{display:flex;align-items:start;gap:12px;padding:14px 16px;color:#533c07;background:#fff7df;border:1px solid #f1d59a;border-radius:8px}.lock-warning strong,.lock-warning span{display:block}.lock-warning span{margin-top:3px;color:#71520c;font-size:13px}.eyebrow{color:#5f706a;margin:0 0 6px;font-size:13px;text-transform:uppercase;letter-spacing:0}.status-line{margin:8px 0 0;color:#536660}h1,h2{margin:0;line-height:1.15}h1{font-size:30px}h2{font-size:18px}.period-select{display:grid;gap:6px;color:#4d5e58;font-size:13px}.icon-button{width:42px;height:42px;border-radius:8px;display:grid;place-items:center;background:#fff;color:#20342f;border:1px solid #dfe7e3}.metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.metric,.panel,.table-section{background:#fff;border:1px solid #dfe7e3;border-radius:8px;box-shadow:0 1px 2px #14201d0d}.metric{min-height:108px;display:grid;align-content:space-between;gap:10px;padding:16px;color:#40534d}.metric strong{color:#17201d;font-size:21px;overflow-wrap:anywhere}.dashboard-grid,.page-grid,.review-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px;align-items:start}.review-grid{grid-template-columns:minmax(0,1fr)}.full-page{display:grid;gap:16px}.panel,.table-section{padding:18px}.panel-title,.section-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.panel-title{justify-content:flex-start}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.form-grid.single-column{grid-template-columns:1fr}.compact-form-grid{margin-top:12px}.checkbox-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:14px}.checkbox-grid .checkbox-line{min-height:48px;padding:10px 12px;border:1px solid #d9e4df;border-radius:8px;background:#fbfdfc}label{display:grid;gap:6px;color:#4d5e58;font-size:13px}.label-text{display:inline-flex;align-items:center;gap:4px}.required-star{color:#b42318;font-weight:800}.field-hint{color:#667872;font-size:12px}.workflow-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:14px 0 18px}.workflow-step{display:grid;grid-template-columns:34px 1fr;gap:10px;align-items:start;padding:14px;border:1px solid #d9e4df;border-radius:8px;background:#fff}.workflow-step>b{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;background:#e8f3ef;color:#137761}.workflow-step strong,.workflow-step span{display:block}.workflow-step span{margin-top:4px;color:#667872;font-size:.88rem;line-height:1.4}input,select,textarea{min-height:40px;border:1px solid #cbd8d3;border-radius:6px;padding:8px 10px;color:#17201d;background:#fff}textarea{min-height:72px;resize:vertical}.form-section-title{margin:16px 0 10px;color:#233631;font-size:13px;font-weight:700}.panel-title+.form-section-title{margin-top:0}.wide-field{margin-top:12px}.primary,.actions button,.quick-actions button,.mini-button{min-height:40px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:#19735d;color:#fff;padding:0 14px;margin-top:16px}.primary.inline{margin-top:0}.actions button:disabled,.primary:disabled{background:#9aaba5;cursor:not-allowed}.mini-button{min-height:32px;margin-top:0;padding:0 10px;background:#edf5f2;color:#1f473e}.row-actions{display:inline-flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:8px}.batch-row{align-items:flex-start;width:100%;border:0;border-bottom:1px solid #edf2f0;background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer;transition:background .15s ease,border-color .15s ease}.batch-row:hover,.batch-row:focus-visible{background:#f3faf7;outline:none}.batch-row-main{min-width:0}.batch-row-main strong{display:flex;align-items:center;flex-wrap:wrap;gap:8px;font-size:18px}.batch-row-main .status-badge{margin-top:0}.payment-batch-list{gap:0}.batch-action-button{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 12px;border:1px solid transparent;border-radius:8px;background:#edf5f2;color:#1f473e;font-weight:700;cursor:pointer}.batch-action-button:hover{filter:brightness(.98)}.batch-action-button.approve,.batch-action-button.pay,.batch-action-button.report{background:#e8f3ef;color:#154f42}.batch-action-button.delete{background:#fff1f0;color:#9b2c22}.payment-batch-drawer .payment-report-card{margin-top:0;border-radius:8px;box-shadow:none}.payment-group-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.payment-group-tabs button{min-height:48px;padding:8px 12px;border:1px solid #d6e4df;border-radius:8px;background:#fff;color:#20332f;font-weight:800;text-align:left;cursor:pointer}.payment-group-tabs button.active{border-color:#19735d;background:#eaf6f1;color:#0d5f4b}.payment-group-tabs span{display:block;margin-top:2px;color:#667872;font-size:12px;font-weight:600}.payment-sticky-save{position:sticky;bottom:0;z-index:8;display:flex;align-items:center;justify-content:flex-end;gap:12px;margin:0 -20px -20px;padding:14px 20px;border-top:1px solid #dfe7e3;background:#fffffff5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.payment-sticky-save span{margin-right:auto;color:#60746d;font-weight:800}.note-input{width:min(190px,32vw)}.split-title{justify-content:space-between;align-items:start}.split-title span{display:block;margin-top:4px;color:#667872;font-size:13px}.employee-tools{grid-column:1 / -1}.employee-photo-panel{display:grid;grid-template-columns:96px minmax(0,1fr);gap:14px;align-items:center;padding:14px;border:1px solid #dbe7e2;border-radius:8px;background:#f8faf9}.employee-photo-preview{width:96px;aspect-ratio:1;display:grid;place-items:center;overflow:hidden;border:1px dashed #b9cbc4;border-radius:8px;background:#eef6f3;color:#19735d;text-align:center;font-size:12px;word-break:break-word;padding:8px}.employee-photo-actions{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.file-action{min-height:40px;display:inline-flex;align-items:center;justify-content:center;padding:0 14px;border:1px solid #cbd8d3;border-radius:8px;background:#fff;color:#1f473e;font-weight:700;cursor:pointer}.file-action input{display:none}.search-field{min-height:40px;display:grid;grid-template-columns:18px minmax(0,1fr);align-items:center;gap:8px;padding:0 10px;border:1px solid #cbd8d3;border-radius:8px;background:#fff}.search-field input{min-height:34px;border:0;padding:0}.search-field input:focus{outline:0}.full-search{margin-bottom:14px}.profile-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px}.profile-summary div,.document-item{padding:12px;border:1px solid #e5ece9;border-radius:8px;background:#f8faf9}.profile-summary span,.document-item span,.document-item small{display:block;margin-top:4px;color:#667872;font-size:12px}.document-form{margin-top:18px;padding-top:18px;border-top:1px solid #e5ece9}.document-list{display:grid;gap:10px;margin-top:14px}.bank-name-field{gap:8px}.bank-name-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center}.record-browser{display:grid;gap:16px}.record-toolbar{display:flex;align-items:start;justify-content:space-between;gap:16px;padding:18px;background:#fff;border:1px solid #dfe7e3;border-radius:8px;box-shadow:0 1px 2px #14201d0d}.record-toolbar p{margin:6px 0 0;color:#667872}.record-actions{display:flex;align-items:center;justify-content:end;flex-wrap:wrap;gap:10px}.browser-search{width:min(320px,42vw)}.record-filter-bar{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:10px;padding:14px 16px;background:#fff;border:1px solid #dfe7e3;border-radius:8px}.record-filter-bar label{font-size:12px}.smart-table-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid #dfe7e3;border-radius:8px;background:#fff}.smart-table-bar>div:first-child{display:flex;align-items:center;gap:8px;color:#60746d}.smart-table-bar strong{color:#17201d}.smart-table-bar b{padding:4px 8px;border-radius:999px;background:#e8f5ef;color:#12664f;font-size:12px}.smart-table-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:10px}.smart-table-actions label{display:inline-flex;align-items:center;gap:8px;color:#60746d;font-size:13px}.smart-table-actions select{min-height:34px;padding:4px 28px 4px 10px}.column-menu-wrap{position:relative}.column-menu{position:absolute;top:calc(100% + 8px);right:0;z-index:20;min-width:210px;display:grid;gap:8px;padding:12px;border:1px solid #dfe7e3;border-radius:8px;background:#fff;box-shadow:0 14px 35px #14201d29}.column-menu label{display:flex;align-items:center;gap:8px;color:#20342f}.smart-table-section{padding:0;overflow:hidden}.smart-pagination{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:12px 14px;border-top:1px solid #e5ece9;color:#60746d}.smart-pagination .mini-button:disabled{opacity:.45;cursor:not-allowed}.record-group-stack{display:grid;gap:16px}.record-group{display:grid;gap:10px}.record-group-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 2px}.record-group-head h3{margin:0;font-size:18px}.record-group-head span{color:#667872;font-size:13px}.segmented-control{display:inline-flex;gap:2px;padding:3px;border:1px solid #dfe7e3;border-radius:8px;background:#f6faf8}.segmented-control button{width:34px;height:34px;display:grid;place-items:center;border-radius:6px;color:#536660;background:transparent}.segmented-control button.active,.segmented-control button:hover{color:#17201d;background:#fff;box-shadow:0 1px 2px #14201d14}.record-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.record-card{display:grid;gap:12px;min-height:178px;padding:16px;background:#fff;border:1px solid #dfe7e3;border-radius:8px;box-shadow:0 1px 2px #14201d0d;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.record-card.is-clickable{cursor:pointer}.record-card.is-clickable:hover,.record-card.is-clickable:focus-visible{border-color:#b8d2c9;box-shadow:0 10px 24px #14201d1a;transform:translateY(-1px)}.record-card.is-clickable:focus-visible{outline:2px solid #16745c;outline-offset:3px}.record-card-head{display:flex;justify-content:space-between;align-items:center;gap:10px}.record-card-head>span:first-child{color:#536660;font-size:13px;font-weight:700}.record-card h3{margin:0;color:#17201d;font-size:18px;line-height:1.2}.record-meta{display:grid;gap:5px;color:#667872;font-size:13px}.record-card .mini-button{justify-self:start;margin-top:auto}.record-card-actions,.row-inline-actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.record-card-actions{margin-top:auto}.record-card-actions .mini-button{margin-top:0}.mass-edit-shell{display:grid;gap:14px}.mass-edit-topbar{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}.mass-edit-topbar label{display:inline-grid;gap:4px;color:#536660;font-size:12px;font-weight:700}.mass-edit-topbar select,.mass-edit-table input,.mass-edit-table select{min-height:34px;width:100%;min-width:120px;padding:0 9px;border:1px solid #d8e3df;border-radius:8px;background:#fff}.mass-edit-steps{display:flex;gap:6px;flex-wrap:wrap}.mass-edit-steps span{min-height:30px;display:inline-flex;align-items:center;padding:0 10px;border:1px solid #dfe7e3;border-radius:999px;color:#536660;background:#f8faf9;font-size:12px;font-weight:800}.mass-edit-steps span.active{border-color:#0d7b5f;color:#075f49;background:#e6f5ef}.mass-field-groups{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.mass-field-group{display:grid;gap:10px;padding:12px;border:1px solid #dfe7e3;border-radius:8px;background:#fbfdfc}.mass-field-group h3{margin:0;font-size:15px}.mass-field-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.mass-field-options label{display:flex;align-items:center;gap:8px;min-height:32px;color:#263d36;font-size:13px;font-weight:700}.mass-edit-table-wrap{max-height:calc(100vh - 250px);overflow:auto;border:1px solid #dfe7e3;border-radius:8px}.mass-edit-table{width:100%;border-collapse:collapse;font-size:13px}.mass-edit-table th,.mass-edit-table td{min-width:130px;padding:8px;border-bottom:1px solid #edf2f0;text-align:left}.mass-edit-table th{position:sticky;top:0;z-index:1;color:#40534d;background:#f8faf9}.mass-edit-table th:first-child,.mass-edit-table td:first-child{min-width:96px}.mass-edit-table th:nth-child(2),.mass-edit-table td:nth-child(2){min-width:180px}.status-badge{display:inline-flex;align-items:center;min-height:28px;padding:0 9px;border-radius:999px;background:#eef3f1;color:#40534d;font-size:12px;font-weight:700;text-transform:capitalize}.status-active,.status-approved,.status-paid,.status-current{background:#e5f5ee;color:#12664f}.status-review,.status-calculating,.status-requested{background:#fff2d8;color:#7a4b00}.status-locked{background:#e5e9e8;color:#17201d}.status-cancelled,.status-resigned,.status-suspended{background:#fee8e6;color:#9b2c22}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;justify-items:end;background:#17201d47;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);cursor:pointer;overscroll-behavior:contain}.confirm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;display:grid;place-items:center;padding:20px;background:#17201d5c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.confirm-dialog{width:min(430px,100%);display:grid;gap:18px;padding:20px;border:1px solid #dfe7e3;border-radius:10px;background:#fff;box-shadow:0 24px 70px #14201d3d}.confirm-dialog h3{margin:0;color:#172722;font-size:20px}.confirm-dialog p{margin:8px 0 0;color:#60746d}.confirm-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.record-drawer{width:min(760px,100%);height:100vh;display:grid;grid-template-rows:auto minmax(0,1fr) auto;background:#fff;box-shadow:-20px 0 60px #14201d2e;cursor:default;overflow:hidden;overscroll-behavior:contain}.drawer-wide{width:min(920px,100%)}.drawer-side{width:min(410px,100%)}.drawer-side-wide{width:min(980px,calc(100vw - 32px))}.drawer-full{width:min(1320px,calc(100vw - 24px))}.drawer-header-stack{background:#fff;border-bottom:1px solid #e5ece9}.drawer-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:20px;border-bottom:0;background:#fff}.drawer-header p{margin:6px 0 0;color:#667872}.drawer-body{overflow:auto;padding:20px;background:#fbfdfc}.drawer-body form{display:grid;gap:12px}.side-editor-form{min-height:100%;align-content:start}.side-editor-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,360px);gap:18px;align-items:start}.side-editor-events{position:sticky;top:0;display:grid;gap:12px;max-height:calc(100vh - 176px);overflow:auto;padding:16px;border:1px solid #e0e8e5;border-radius:10px;background:#fff}.side-editor-section{display:grid;gap:12px;padding:14px 0;border-bottom:1px solid #e5ece9}.side-editor-section:first-child{padding-top:0}.compact-field-grid{display:grid;gap:8px}.compact-field-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.compact-field-grid.three{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.compact-field-grid.four{grid-template-columns:repeat(auto-fit,minmax(132px,1fr))}.side-editor-section label,.compact-field-grid label{min-width:0}.side-editor-section input,.side-editor-section select{width:100%;min-width:0;min-height:38px;padding:8px 10px}.side-editor-section input:disabled,.side-editor-section select:disabled,.manual-cell-input:disabled{border-color:#d9e1de;background:#eef2f0;color:#7d8d88;cursor:not-allowed}.editor-mode-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;padding:0;background:transparent;border-bottom:0}.editor-mode-tabs-header{margin-top:8px}.editor-mode-tabs button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:38px;padding:8px;border:1px solid #d8e3df;border-radius:8px;background:#fff;color:#40534d;font-weight:700}.editor-mode-tabs button.active{border-color:#067a52;background:#087b5f;color:#fff}.editor-active-panel{padding-bottom:18px}.readonly-field span{display:flex;align-items:center;min-width:0;min-height:38px;padding:8px 10px;border:1px solid #d8e3df;border-radius:8px;background:#f4f7f6;font-weight:800;overflow-wrap:anywhere}.wage-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(118px,1fr));gap:8px;padding:10px;border:1px solid #dce8e4;border-radius:10px;background:#f7fbf9}.wage-summary div{min-width:0;padding:8px 10px;border-radius:8px;background:#fff}.wage-summary span,.wage-summary strong{display:block}.wage-summary span{color:#647772;font-size:12px;font-weight:700}.wage-summary strong{margin-top:2px;color:#10251f;font-size:14px;overflow-wrap:anywhere}.readonly-field .positive{color:#07834f}.readonly-field .negative{color:#bd2b25}.preview-strip{padding:10px 12px;border:1px solid #cfe2dc;border-radius:8px;background:#edf8f4;color:#21423a;font-size:13px;font-weight:700;overflow-wrap:anywhere}.document-file-row{display:flex;align-items:center;min-height:34px;margin-top:8px;padding:7px 9px;border:1px solid #e5ece9;border-radius:8px;background:#f8faf9;color:#40534d;font-size:12px;overflow-wrap:anywhere}.side-editor-actions{padding:14px 0}.drawer-footer{padding:14px 20px;border-top:1px solid #e5ece9;background:#fff;box-shadow:0 -12px 30px #14201d0f}.drawer-footer-actions{display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap}.drawer-header-slot{padding:0 20px 12px;border-bottom:0;background:#fff}.event-list-head{display:flex;justify-content:space-between;gap:12px;color:#172722}.event-list-head span{color:#667872;font-size:13px}.event-list-controls{display:grid;grid-template-columns:1fr 1fr;gap:8px}.event-list-controls select{min-width:0;min-height:36px;padding:7px 9px;border:1px solid #d8e3df;border-radius:8px;background:#fff}.event-list{display:grid;gap:8px}.event-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;padding:10px;border:1px solid #e5ece9;border-radius:8px;background:#fff}.event-row-clickable{cursor:pointer;grid-template-columns:minmax(0,1fr) auto}.event-row strong,.event-row span{display:block}.event-row span{margin-top:2px;color:#667872;font-size:12px}.event-row .positive{color:#07834f}.event-row .negative{color:#bd2b25}.event-row.active{border-color:#16745c;background:#f0faf5}.event-row-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:6px;padding-top:8px;border-top:1px solid #edf2f0}.icon-button.danger{color:#bd2b25}.event-action{display:inline-flex;align-items:center;gap:5px;min-height:32px;padding:0 10px;border:1px solid #d7e2de;border-radius:8px;background:#fff;color:#24443b;font-weight:800;cursor:pointer}.event-action.edit{border-color:#bcded2;background:#eff8f4;color:#0f765c}.event-action.delete{border-color:#f0c4c1;background:#fff1f0;color:#bd2b25}.event-action:disabled{opacity:.55;cursor:not-allowed}.required-label{display:inline-flex;align-items:center;gap:3px}.required-label b{color:#bd2b25;font-weight:900}.ghost-button.compact{min-height:38px;padding:0 12px}@media (max-width: 760px){.compact-field-grid.two,.compact-field-grid.three,.compact-field-grid.four{grid-template-columns:1fr}.editor-mode-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}.drawer-side-wide{width:100%}.side-editor-layout{grid-template-columns:1fr}.side-editor-events{position:static;max-height:none}.drawer-footer-actions{display:grid;grid-template-columns:1fr 1fr}}.compact-empty{margin:0;padding:8px 0}.drawer-notice{display:grid;gap:4px;padding:12px 14px;border:1px solid #d7e5df;border-radius:8px;color:#26443b;background:#f2faf6}.drawer-notice strong,.drawer-notice span{display:block}.drawer-notice span{color:#536660;font-size:13px}.drawer-notice-error{border-color:#f0b9b4;color:#8a2118;background:#fff1f0}.drawer-notice-error span{color:#9b2c22}.drawer-notice-warning{border-color:#f1d59a;color:#7a4d00;background:#fff8e8}.drawer-notice-warning span{color:#815c15}.print-drawer{width:min(980px,100%)}.print-backdrop{background:#17201d6b}.payslip-print-actions{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin:16px 0 10px;padding:10px 12px;border:1px solid #dfe7e3;border-radius:8px;background:#fff}.payslip-print-actions span{color:#60746d;font-size:13px;margin-right:auto}.payment-report-card{margin-top:16px;font-size:14px}.report-title-box{width:min(480px,100%);margin:0 auto 18px;padding:12px;border:1px solid #40534d;text-align:center}.report-title-box h2{margin:0 0 6px;font-size:17px}.report-title-box p{margin:0;color:#536660;font-size:14px}.payment-report-meta{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:12px}.payment-report-meta div{padding:8px 10px;border:1px solid #e5ece9;border-radius:8px;background:#f8faf9}.payment-report-meta span,.payment-report-meta strong{display:block}.payment-report-meta span{color:#60746d;font-size:11px}.payment-report-meta strong{font-size:15px}.payment-report-table th,.payment-report-table td{padding:9px 12px;font-size:14px;line-height:1.35}.payment-report-table th:last-child,.payment-report-table td:last-child{text-align:right}.payment-report-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:12px 0 14px}.payment-report-tabs button{min-height:58px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border:1px solid #dce8e4;border-radius:8px;background:#fff;color:#1f312d;cursor:pointer;text-align:left}.payment-report-tabs button.active{border-color:#19735d;background:#edf8f4}.payment-report-tabs strong{font-size:15px}.payment-report-tabs span{color:#60746d;font-size:13px;font-weight:800;white-space:nowrap}.payment-report-section{margin-top:14px;page-break-inside:avoid;break-inside:avoid}.payment-report-section.inactive{display:none}.payment-report-group-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:8px;padding:8px 12px;border:1px solid #dfe7e3;border-radius:8px;background:#f3faf7}.payment-report-group-head h3{margin:0;font-size:15px}.payment-report-group-head span{color:#60746d;font-size:14px;font-weight:800}.employee-detail-link{display:grid;gap:2px;padding:0;border:0;background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer}.employee-detail-link:hover strong{color:#12664f;text-decoration:underline}.copy-cell{display:inline-flex;align-items:center;justify-content:flex-end;gap:6px}.copy-cell.amount{width:100%}.copy-button{width:28px;min-height:28px;padding:0;border:1px solid #d8e5e0;border-radius:8px;background:#f7fbf9;color:#31534b;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.copy-button:hover{background:#eaf6f1;border-color:#b7d4c9}.danger-inline{color:#9b2c22;background:#fff1f0}.payslip-paper{display:grid;gap:18px;min-height:1120px;padding:38px;color:#17201d;background:#fff;border:1px solid #dfe7e3;border-radius:8px;box-shadow:0 8px 28px #14201d14}.payslip-a5{width:210mm;min-height:148mm;max-width:100%;gap:3mm;margin:0 auto 18px;padding:6mm;font-size:11px}.payslip-a5+.payslip-a5{page-break-before:always}.payslip-head{display:grid;grid-template-columns:minmax(0,1fr) 150px;gap:18px;align-items:start;padding-bottom:18px;border-bottom:2px solid #172722}.payslip-head h2{margin-top:4px;font-size:28px}.payslip-head span{display:block;margin-top:8px;color:#536660}.payslip-head.compact{grid-template-columns:minmax(0,1fr) 58mm;gap:7mm;padding-bottom:3mm;border-bottom-width:1.5px}.payslip-head.compact h2{margin:1mm 0 0;font-size:29px;line-height:1.05}.payslip-head.compact span{margin-top:2.2mm;font-size:13px}.payslip-head.compact .eyebrow{font-size:15.5px;letter-spacing:0}.payslip-doc{display:grid;gap:2.3mm;align-content:start;padding:3.2mm 3.8mm;border:1px solid #dfe7e3;text-align:right}.payslip-doc strong{font-size:14px;overflow-wrap:anywhere}.payslip-doc span{margin:0;color:#60746d;font-size:12.2px}.qr-box{min-height:150px;display:grid;place-items:center;padding:14px;border:2px solid #172722;border-radius:8px;color:#172722;font-size:12px;font-weight:800;text-align:center;overflow-wrap:anywhere;background:linear-gradient(90deg,rgba(23,39,34,.08) 50%,transparent 0) 0 0 / 16px 16px,linear-gradient(rgba(23,39,34,.08) 50%,transparent 0) 0 0 / 16px 16px,#fff}.payslip-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.payslip-grid div{min-height:74px;padding:12px;border:1px solid #e5ece9;border-radius:8px;background:#f8faf9}.payslip-info-table,.payslip-time-table,.payslip-ledger{width:100%;border:1px solid #dfe7e3;border-collapse:separate;border-spacing:0;overflow:hidden}.payslip-info-table th,.payslip-info-table td,.payslip-time-table th,.payslip-time-table td,.payslip-ledger th,.payslip-ledger td{padding:2.2mm 2.4mm;border-bottom:1px solid #edf2f0;white-space:normal;font-weight:560}.payslip-info-table tr:last-child th,.payslip-info-table tr:last-child td,.payslip-time-table tr:last-child td,.payslip-ledger tr:last-child td{border-bottom:0}.payslip-info-table th,.payslip-time-table th,.payslip-ledger th{color:#60746d;font-size:11.2px;font-weight:700;background:#f8faf9}.payslip-info-table td,.payslip-time-table td,.payslip-ledger td{font-size:12px}.payslip-info-table th{width:22mm;text-align:left}.payslip-time-table th,.payslip-time-table td{text-align:center}.payslip-summary-value{display:inline-flex;gap:.8mm;align-items:center;justify-content:center;flex-wrap:wrap}.payslip-positive{color:#07814f;font-weight:800}.payslip-negative{color:#c92525;font-weight:800}.payslip-ledger th:nth-child(3),.payslip-ledger td:nth-child(3),.payslip-ledger th:last-child,.payslip-ledger td:last-child{text-align:right;white-space:nowrap}.payslip-money-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) 42mm;gap:3mm;align-items:start}.payslip-money-table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid #dfe7e3;overflow:hidden}.payslip-money-table th,.payslip-money-table td{padding:1.55mm 1.65mm;border-bottom:1px solid #edf2f0;font-size:10.4px;line-height:1.28;white-space:normal;overflow-wrap:anywhere;vertical-align:top;font-weight:500}.payslip-money-table thead tr:first-child th{color:#fff;font-size:12px;font-weight:700;text-align:left}.payslip-money-table.earning thead tr:first-child th{background:#07814f}.payslip-money-table.deduction thead tr:first-child th{background:#c92525}.payslip-money-table thead tr:nth-child(2) th{color:#40534d;font-weight:700;background:#f8faf9}.payslip-money-table th:last-child,.payslip-money-table td:last-child{text-align:right;white-space:nowrap}.payslip-money-table th:first-child,.payslip-money-table td:first-child{width:74%}.payslip-money-table th:nth-child(2),.payslip-money-table td:nth-child(2){width:26%}.payslip-item-cell,.payslip-row-detail{display:grid;gap:.45mm}.payslip-item-cell>strong{color:#17201d;font-size:10.8px;font-weight:650;line-height:1.18}.payslip-row-detail span{display:block;color:#40534d;font-size:8px;font-weight:450;line-height:1.22;overflow-wrap:anywhere}.payslip-money-table tfoot td{border-bottom:0;font-weight:700}.payslip-money-table.earning tfoot td{color:#07814f;background:#edf8f2}.payslip-money-table.deduction tfoot td{color:#c92525;background:#fff1f1}.payslip-net-panel{display:grid;gap:2mm;align-self:start}.payslip-tax-mini{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));border:1px solid #dfe7e3}.payslip-tax-mini div{display:grid;gap:1mm;padding:1.4mm;border-right:1px solid #edf2f0;border-bottom:1px solid #edf2f0}.payslip-tax-mini div:nth-child(2n){border-right:0}.payslip-tax-mini div:nth-last-child(-n+2){border-bottom:0}.payslip-tax-mini span,.payslip-note-box span{color:#60746d;font-size:8.1px;font-weight:500}.payslip-tax-mini strong{font-size:8.9px;font-weight:650}.payslip-net-box{display:grid;gap:1.3mm;padding:5mm 3mm;border:1.5px solid #1d5fc4;color:#1d5fc4;text-align:center}.payslip-net-box span{font-size:13px;font-weight:700}.payslip-net-box small{color:#40534d;font-size:10px;font-weight:550}.payslip-net-box strong{font-size:30px;font-weight:700;line-height:1.05;letter-spacing:0}.payslip-net-box b{color:#40534d;font-size:9px;font-weight:650}.payslip-note-box{display:grid;gap:1mm;padding:2.4mm;border:1px solid #dfe7e3}.payslip-note-box strong{color:#1d5fc4;font-size:10px}.payslip-note-box b{color:#1d5fc4;font-size:9.5px}.payslip-grid strong,.payslip-grid span{display:block}.payslip-grid span{margin-top:5px;color:#536660;overflow-wrap:anywhere}.payslip-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.payslip-columns>div{padding:16px;border:1px solid #e5ece9;border-radius:8px}.payslip-columns h3{margin:0 0 14px;font-size:16px}.payslip-events{display:grid;gap:8px;margin-top:18px;padding:14px;border:1px solid #e5ece9;border-radius:8px}.payslip-events h3{margin:0 0 6px;font-size:16px}.payslip-total{padding:16px;border:1px solid #dfe7e3;border-radius:8px;background:#f8faf9}.signature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-top:auto;padding-top:70px}.signature-grid div{padding-top:12px;border-top:1px solid #172722;color:#40534d;text-align:center}.drawer-actions{position:sticky;bottom:-20px;z-index:5;display:flex;justify-content:end;gap:10px;margin:18px -20px -20px;padding:14px 20px;border-top:1px solid #e5ece9;background:#fffffffa;box-shadow:0 -12px 28px #14201d14}.drawer-actions .danger-button{margin-right:auto}.drawer-actions.static-actions{position:static;justify-content:start;padding-top:16px;border-top:0;margin:18px 0 0;box-shadow:none}.drawer-body .drawer-actions.static-actions{position:sticky;bottom:-20px;justify-content:flex-end;margin:18px -20px -20px;padding:14px 20px;border-top:1px solid #e5ece9;box-shadow:0 -12px 28px #14201d14}.ghost-button{min-height:40px;display:inline-flex;align-items:center;justify-content:center;padding:0 14px;border:1px solid #cbd8d3;border-radius:8px;background:#fff;color:#233631}.ghost-button.compact{min-height:36px;padding:0 12px}.danger-button{min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;border:1px solid #f0b4ad;border-radius:8px;background:#fff1f0;color:#b42318;font-weight:800}.danger-button:disabled{color:#a7aaa8;border-color:#d8dfdc;background:#f4f6f5}.danger-zone{display:grid;gap:12px;margin-top:18px;padding:14px;border:1px solid #f0b4ad;border-radius:8px;background:#fff8f7}.danger-zone strong,.danger-zone span{display:block}.danger-zone span{margin-top:4px;color:#7a514c;font-size:13px}.ghost-button:disabled{color:#9aaba5;background:#f2f5f4;cursor:not-allowed}.toggle-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:12px}.manual-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.manual-entry-form{align-content:start}.manual-workspace{gap:16px}.manual-heading span{display:block;margin-top:6px;color:#5b6f68}.manual-table-shell{border:1px solid #dfe7e3;border-radius:8px;background:#fff;overflow:hidden}.manual-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-bottom:1px solid #e5ece9}.manual-controls{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.manual-controls select{min-height:38px;padding:0 10px;border:1px solid #d7e2de;border-radius:8px;background:#fff;color:#40534d;font-weight:700}.sortable-header{display:inline-flex;align-items:center;gap:6px;width:100%;padding:0;border:0;background:transparent;color:inherit;font:inherit;font-weight:800;text-align:left;cursor:pointer}.sortable-header b{color:#7a8e87;font-size:12px}.sortable-header.active{color:#0f765c}.category-manager{display:grid;gap:10px;padding:12px;border:1px solid #dfe9e5;border-radius:8px;background:#f8fbfa}.category-create-row{display:grid;grid-template-columns:minmax(0,1fr) 120px auto;gap:8px}.category-create-row input,.category-create-row select{min-height:38px;padding:0 10px;border:1px solid #d7e2de;border-radius:8px;background:#fff}.category-chip-list{display:flex;flex-wrap:wrap;gap:6px}.category-chip{min-height:30px;padding:0 10px;border:1px solid #cfe1db;border-radius:999px;background:#fff;color:#31564c;font-weight:700}.attendance-grid-wrap{overflow:auto;max-height:62vh;border-top:1px solid #e5ece9;background:#fff}.attendance-grid-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0;background:#fff;color:#14241f}.attendance-grid-table th,.attendance-grid-table td{border-right:1px solid #e6eeeb;border-bottom:1px solid #e6eeeb;padding:6px;text-align:center}.attendance-grid-table thead th{position:sticky;top:0;z-index:2;background:#f4f8f6;color:#516761;font-size:12px;font-weight:800}.attendance-employee-head,.attendance-employee-cell{position:sticky;left:0;z-index:3;min-width:230px;max-width:230px;background:#f8fbfa;color:#172722;text-align:left!important}.attendance-employee-cell strong,.attendance-employee-cell span,.attendance-employee-cell small{display:block}.attendance-employee-cell span,.attendance-employee-cell small{color:#667872;font-weight:500}.attendance-cell{display:inline-grid;place-items:center;gap:1px;width:56px;min-height:38px;border:1px solid transparent;border-radius:8px;color:#14342c;font-weight:800;cursor:pointer;box-shadow:inset 0 -1px #0000000a}.attendance-cell small{color:inherit;font-size:10px;font-weight:800;opacity:.78;line-height:1}.attendance-cell.work{border-color:#cfe5dc;background:#edf8f3;color:#0f765c}.attendance-cell.late{border-color:#efd895;background:#fff7dd;color:#8a5f00}.attendance-cell.absence{border-color:#efc0bd;background:#fff0ef;color:#b52722}.attendance-cell.leave{border-color:#efc0bd;background:#fff4f2;color:#b52722}.attendance-cell.leave-paid{border-color:#bdd8ef;background:#edf7ff;color:#1f6091}.attendance-cell.ot{border-color:#9fd9c4;background:#e5f8ef;color:#08764e}.attendance-cell.holiday{border-color:#b8dfd3;background:linear-gradient(180deg,#f4fbf8,#dff4ed);color:#0c6f57}.holiday-day-head{background:#e9f6f1!important}.day-head-button{width:100%;min-height:26px;border:0;background:transparent;color:inherit;font:inherit;font-weight:900;cursor:pointer}.day-head-button:hover{color:#08765c;text-decoration:underline}.holiday-picker{display:grid;gap:12px;grid-column:1 / -1;padding:14px;border:1px solid #dfeae6;border-radius:8px;background:#f8fbfa}.holiday-list,.department-list{display:grid;gap:10px}.holiday-row,.department-row{display:grid;grid-template-columns:minmax(110px,auto) minmax(160px,1fr) auto auto auto;align-items:center;gap:10px;padding:10px;border:1px solid #dfeae6;border-radius:8px;background:#fff}.holiday-row input[type=text],.holiday-row input:not([type]){min-width:0}.checkbox-row{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;font-weight:700}.inline-field-action{align-self:end}.department-row{grid-template-columns:minmax(160px,1fr) auto auto auto auto}.department-meta{display:grid;gap:2px}.department-meta span{color:#667872;font-size:13px}.visually-hidden{display:none!important}.settings-page{gap:0}.settings-layout{display:grid;grid-template-columns:260px minmax(0,1fr);gap:18px;align-items:start}.settings-nav-panel{position:sticky;top:18px;display:grid;gap:8px;padding:14px;border:1px solid #dfe7e3;border-radius:8px;background:#fff;box-shadow:0 10px 28px #122d250f}.settings-nav-head{padding:8px 8px 12px;border-bottom:1px solid #edf2f0}.settings-nav-head h2{margin:0;font-size:24px}.settings-nav-panel button{display:grid;gap:3px;padding:12px;border:1px solid transparent;border-radius:8px;background:transparent;color:#253f37;text-align:left;cursor:pointer}.settings-nav-panel button strong{font-size:15px}.settings-nav-panel button span{color:#6b7b76;font-size:12px}.settings-nav-panel button.active,.settings-nav-panel button:hover{border-color:#cce3db;background:#edf8f3;color:#08765c}.settings-content-panel{display:grid;gap:18px;min-width:0}.settings-key-grid,.template-toggle-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.settings-key-grid div{display:grid;gap:4px;padding:14px;border:1px solid #e5ece9;border-radius:8px;background:#f8fbfa}.settings-key-grid span,.template-settings-head span{color:#667872;font-size:13px}.template-settings-list{display:grid;gap:14px}.template-settings-card{display:grid;gap:14px;padding:16px;border:1px solid #dfe7e3;border-radius:8px;background:#fff}.template-settings-head{display:flex;justify-content:space-between;gap:16px;align-items:start;padding-bottom:10px;border-bottom:1px solid #edf2f0}.template-settings-head div{display:grid;gap:3px}.template-settings-head strong{font-size:18px}.settings-table-wrap{overflow:auto;border:1px solid #dfe7e3;border-radius:8px}.settings-table-wrap table{min-width:860px;border:0}.settings-table-wrap th{background:#f5f8f6}.workflow-details{border:1px solid #dfe7e3;border-radius:8px;background:#fff}.workflow-details summary{cursor:pointer;padding:12px 16px;color:#172722;font-weight:800}.workflow-details .workflow-strip{padding:0 16px 16px}.drawer-tabs{position:sticky;top:0;z-index:2;display:flex;gap:8px;flex-wrap:wrap;padding:0 0 14px;margin-bottom:18px;background:#fff;border-bottom:1px solid #edf2f0}.drawer-tabs button{min-height:40px;padding:0 14px;border:1px solid #d7e2de;border-radius:8px;background:#f8fbfa;color:#40534d;font-weight:700}.drawer-tabs button.active,.drawer-tabs button:hover{border-color:#16745c;background:#e8f5ef;color:#0f5b47}.tab-section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px}.tab-section-head h3{margin:0 0 4px;color:#17201d;font-size:18px}.tab-section-head p{margin:0;color:#667872}.employee-contract-tab,.contract-list{display:grid;gap:14px}.contract-highlight{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto auto;align-items:center;gap:14px;padding:16px;border:1px solid #cfe3dc;border-radius:8px;background:#f3fbf7}.contract-highlight span,.contract-row small{display:block;color:#667872;font-size:12px}.contract-highlight strong{display:block;margin:3px 0;color:#17201d;font-size:17px}.contract-highlight small{color:#536660}.contract-row{align-items:center}.recurring-pay-section{display:grid;gap:12px;margin-top:18px}.recurring-pay-list{display:grid;gap:10px}.recurring-pay-row{display:grid;grid-template-columns:minmax(180px,1.2fr) 120px 140px 150px 140px minmax(140px,1fr) minmax(160px,1fr) 44px;gap:10px;align-items:end;padding:12px;border:1px solid #e1e9e6;border-radius:8px;background:#fbfdfc}.recurring-pay-row label{min-width:0}.recurring-remove{margin-bottom:0}.inline-field-action{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center}.inline-field-action .ghost-button{min-height:44px;white-space:nowrap}.contract-preview{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:14px;padding:12px 14px;border:1px solid #d7e9e2;border-radius:8px;background:#f3fbf7;color:#40534d}.contract-preview strong{color:#0f5b47}.contract-preview span{padding:6px 9px;border-radius:8px;background:#fff;font-weight:700}.contract-template-settings{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.contract-template-card{display:grid;gap:12px;padding:14px;border:1px solid #e1e9e6;border-radius:8px;background:#fbfdfc}.contract-template-card>strong{color:#172722;font-size:17px}.segmented-tabs{display:inline-flex;gap:4px;padding:4px;border:1px solid #dfe7e3;border-radius:8px;background:#f6f9f8}.segmented-tabs button{min-height:34px;padding:0 12px;border:0;border-radius:6px;background:transparent;color:#536660;font-weight:700}.segmented-tabs button.active{background:#fff;color:#137761;box-shadow:0 1px 4px #17272214}.table-search{max-width:280px;min-height:38px;display:flex;align-items:center;gap:8px;padding:0 10px;border:1px solid #d7e2de;border-radius:8px;background:#fff}.table-search input{min-height:34px;padding:0;border:0}.manual-table-wrap{overflow:auto}.manual-input-table th,.manual-input-table td{padding:10px 12px;vertical-align:middle}.manual-input-table th{position:sticky;top:0;z-index:1}.employee-cell{min-width:190px}.employee-cell-button{display:block;width:100%;padding:0;border:0;background:transparent;color:inherit;text-align:left;cursor:pointer}.employee-cell-button strong{transition:color .16s ease}.employee-cell-button:hover strong,.employee-cell-button:focus-visible strong{color:#087b5f}.employee-cell-button:focus-visible{outline:2px solid #0b8f6a;outline-offset:3px;border-radius:6px}.employee-cell span{display:block;margin-top:2px;color:#667872;font-size:13px}.manual-input-table tbody tr:hover{background:#f7fbf9}.manual-cell-input{width:92px;min-height:34px;padding:6px 8px;border:1px solid #d7e2de;border-radius:7px;background:#fff;font-size:14px}.manual-cell-input::placeholder{color:#8a9a95}.readonly-table .readonly-metric{display:inline-grid;gap:2px;min-width:78px;cursor:help}.readonly-table .readonly-metric small{color:#667872;font-size:12px;font-weight:700}.readonly-table .readonly-metric.positive,.readonly-table .positive{color:#07834f}.readonly-table .readonly-metric.negative,.readonly-table .negative{color:#bd2b25}.group-row td{background:#f3f8f6;color:#245045;font-weight:800}.mini-chip,.document-pill{display:inline-flex;align-items:center;gap:4px;margin-top:4px;padding:3px 7px;border-radius:999px;background:#edf5f2;color:#1f6d5b;font-size:12px;font-weight:700}.document-pill{margin-top:0}.manual-summary-bar{display:flex;flex-wrap:wrap;gap:16px;align-items:center;padding:12px 14px;border-top:1px solid #e5ece9;background:#f8faf9;color:#536660}.manual-summary-bar b{color:#172722}.drawer-tab-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.drawer-mini-form{padding:14px;border:1px solid #e5ece9;border-radius:8px;background:#fff}.drawer-mini-form .primary{margin-top:12px}.manual-tables{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.table-note{padding:12px 14px;color:#5b6f68;background:#f8faf9;border-bottom:1px solid #e5ece9;font-size:13px}.checkbox-line{min-height:40px;display:flex;align-items:center;gap:8px;padding:9px 10px;border:1px solid #dfe7e3;border-radius:8px;background:#f8faf9;color:#233631}.checkbox-line input{width:16px;min-height:16px}.quick-actions{display:flex;flex-wrap:wrap;gap:10px}.quick-actions button{margin-top:0;background:#edf5f2;color:#1f473e}.review-band{display:flex;justify-content:space-between;gap:16px;align-items:end;padding:16px;background:#fff;border:1px solid #dfe7e3;border-radius:8px}.actions{display:flex;gap:10px;flex-wrap:wrap}.table-wrap{overflow:auto;border:1px solid #e5ece9;border-radius:8px}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:12px 14px;border-bottom:1px solid #e8efec;white-space:nowrap}tr:last-child td{border-bottom:0}th{color:#586b64;font-size:13px;font-weight:700;background:#f8faf9}td{color:#233631}tbody tr{transition:background .14s ease}tbody tr:hover{background:#f8fbfa}.payroll-line-row{cursor:pointer}.payroll-line-row:hover{background:#eef8f4}.payroll-review-table{min-width:1420px}.payroll-review-table th,.payroll-review-table td{vertical-align:middle}.payroll-review-table th{font-size:12px}.payroll-review-table td{font-size:13px}.payroll-review-table .money-cell{text-align:right;font-variant-numeric:tabular-nums}.payroll-review-table .positive{color:#067a4f}.payroll-review-table .negative{color:#9b2c22}.payroll-review-table .net{color:#067a4f;font-weight:800}.selected-row{background:#edf7f3}td strong,.subtext{display:block}.subtext{margin-top:2px;color:#667872;font-size:12px}.money-input{width:106px;min-height:34px;padding:6px 8px}.status-track{display:grid;gap:12px}.status-track div{display:flex;align-items:center;gap:10px;color:#61756e}.status-track span{width:12px;height:12px;border-radius:999px;background:#c9d8d3}.status-track .current{color:#17201d}.status-track .current span{background:#19735d}.rows-list,.summary-list{display:grid;gap:10px}.row-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid #edf2f0}.row-item:last-child{border-bottom:0}.row-item span{display:block;margin-top:2px;color:#667872;font-size:12px}.setting-toggle-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;padding:10px 0;border-bottom:1px solid #edf2f0}.setting-toggle-row small{display:block;margin-top:2px;color:#667872}.setting-toggle-row input{width:18px;min-height:18px}.option-row{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(90px,.6fr) auto auto;gap:8px;align-items:center}.data-transfer-panel{gap:14px}.import-export-actions,.import-preview-stats{display:flex;flex-wrap:wrap;gap:8px}.import-mode-field{display:grid;gap:6px;max-width:320px;color:#40534d;font-size:13px;font-weight:700}.import-mode-field select{min-height:40px;padding:0 12px;border:1px solid #d8e3df;border-radius:8px;background:#fff}.file-drop-zone{display:grid;gap:6px;padding:18px;border:1px dashed #b9cbc5;border-radius:10px;background:#f7fbf9;cursor:pointer}.file-drop-zone input{max-width:100%}.file-drop-zone span{color:#667872;font-size:13px}.import-preview-box{display:grid;gap:12px;padding:12px;border:1px solid #e0e8e5;border-radius:10px;background:#fff}.import-preview-stats span{padding:8px 10px;border:1px solid #e0e8e5;border-radius:8px;background:#f8faf9;color:#40534d}.import-preview-stats .positive{color:#07834f}.import-preview-stats .negative{color:#bd2b25}.import-preview-list{display:grid;gap:8px;max-height:280px;overflow:auto}.import-preview-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(120px,auto);gap:12px;align-items:center;padding:10px;border:1px solid #e0e8e5;border-radius:8px}.import-preview-row span{display:block;color:#667872;font-size:13px}.import-preview-row b{color:#07834f;text-align:right}.import-preview-row.has-error{border-color:#f2b8b5;background:#fff4f3}.import-preview-row.has-error b{color:#bd2b25}.import-preview-table-wrap{max-height:360px;overflow:auto;border:1px solid #e0e8e5;border-radius:8px}.import-preview-table{width:100%;border-collapse:collapse;font-size:13px}.import-preview-table th,.import-preview-table td{padding:9px 10px;border-bottom:1px solid #edf2f0;text-align:left;white-space:nowrap}.import-preview-table th{position:sticky;top:0;z-index:1;color:#40534d;background:#f8faf9}.import-preview-table tr.has-error td{color:#9b2c22;background:#fff4f3}.mini-button.danger{color:#9b2c22;background:#fee8e6}.summary-list{grid-template-columns:1fr auto;margin:0}.summary-list dt{color:#5b6f68}.summary-list dd{margin:0;font-weight:700}.detail-panel{display:grid;gap:16px;background:#fff;border:1px solid #dfe7e3;border-radius:8px;padding:18px;box-shadow:0 1px 2px #14201d0d}.payroll-line-drawer .detail-panel{min-height:100%;border:0;border-radius:0;box-shadow:none;overflow:auto}.payroll-line-drawer .detail-header{position:sticky;top:0;z-index:2;margin:-18px -18px 0;padding:18px;background:#fff}.detail-header{display:flex;justify-content:space-between;gap:16px;align-items:start;padding-bottom:14px;border-bottom:1px solid #edf2f0}.detail-header span{display:block;margin-top:4px;color:#667872}.detail-header>strong{color:#19735d;background:#edf7f3;padding:6px 10px;border-radius:999px;font-size:12px}.detail-block{display:grid;gap:10px}.detail-block h3{margin:0;font-size:14px;color:#233631}.source-breakdown{gap:10px}.payroll-detail-tabs{margin-bottom:2px}.accounting-tab{display:grid;gap:10px}.summary-heading{display:flex;justify-content:space-between;align-items:flex-end;gap:12px}.summary-heading.compact{margin-top:4px}.summary-heading span{display:block;margin-top:3px;color:#667872;font-size:12px}.summary-tools{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.payroll-summary-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.summary-card{display:grid;gap:5px;min-height:82px;padding:12px;border:1px solid #dfe7e3;border-radius:8px;background:#fff}.summary-card span{color:#60746d;font-size:12px;font-weight:700}.summary-card strong{color:#172722;font-size:22px;line-height:1.1}.summary-card.positive strong,.summary-card.net strong{color:#067a4f}.summary-card.negative strong{color:#9b2c22}.summary-card.net{border-color:#b9ddd0;background:#eef8f4}.wage-detail-panel{display:grid;gap:10px;padding:12px;border:1px solid #dfe7e3;border-radius:8px;background:#fbfdfc}.wage-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.wage-detail-grid div{display:grid;gap:4px;padding:10px;border:1px solid #edf2f0;border-radius:8px;background:#fff}.wage-detail-grid span{color:#60746d;font-size:12px;font-weight:700}.wage-detail-grid strong{color:#172722;font-size:16px}.accounting-summary{overflow:hidden;border:1px solid #dfe7e3;border-radius:8px;background:#fff}.accounting-summary table{width:100%;border-collapse:collapse}.accounting-summary th,.accounting-summary td{padding:10px 12px;border-bottom:1px solid #edf2f0;text-align:right}.accounting-summary th:first-child,.accounting-summary td:first-child{text-align:left}.accounting-summary th:nth-child(2),.accounting-summary td:nth-child(2){text-align:left}.accounting-summary th{color:#60746d;font-size:12px;background:#f8faf9}.accounting-summary td{color:#172722;font-size:13px;font-weight:600}.accounting-summary td:nth-child(2){color:#60746d;font-weight:500}.accounting-summary td:last-child{white-space:nowrap;font-size:15px;font-weight:800}.accounting-summary tfoot td{border-bottom:0;background:#eef8f4;color:#172722}.accounting-summary .positive,.accounting-summary .net{color:#067a4f}.accounting-summary .negative{color:#9b2c22}.accounting-summary .neutral{color:#60746d}.accounting-summary .subtotal{color:#172722}.source-row{display:flex;justify-content:space-between;gap:12px;padding:11px 12px;border:1px solid #e5ece9;border-radius:8px;background:#f8faf9}.source-title-line{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.source-title-line em{padding:3px 7px;border-radius:999px;background:#e7f3ee;color:#12664f;font-size:10px;font-style:normal;font-weight:700}.source-row span{display:block;margin-top:3px;color:#667872;font-size:12px}.source-toggle{display:inline-flex;align-items:center;width:fit-content;margin-top:7px;padding:3px 8px;border:1px solid #d8e4df;border-radius:999px;background:#eef6f2;color:#12664f;font:inherit;font-size:11px;font-weight:600;cursor:pointer}.source-toggle:hover{border-color:#9fc8bb;background:#e1f0ea}.source-row b{color:#12664f;white-space:nowrap}.source-row b.positive,.payroll-source-list b.positive,.line-item-row b.positive,.money-rows dd.positive{color:#067a4f}.source-row b.negative{color:#9b2c22}.line-status-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.payroll-source-group{display:grid;gap:6px}.payroll-source-group.open .source-row{border-color:#c7ded6;background:#f4faf7}.payroll-source-table,.line-item-list{display:grid;gap:6px;margin:0;padding:0}.payroll-source-table-row,.line-item-row{display:grid;grid-template-columns:minmax(140px,1.4fr) minmax(90px,.8fr) minmax(140px,1.2fr) minmax(90px,auto);align-items:flex-start;gap:12px;padding:7px 9px;border-left:3px solid #dfe7e3;background:#fbfcfb;color:#405650;font-size:12px}.payroll-source-table-row>span,.line-item-row span{display:grid;gap:2px;min-width:0}.payroll-source-table-row span strong{color:#172722;font-size:12px;font-weight:650;line-height:1.25}.payroll-source-table-row span,.payroll-source-table-row span small{color:#667872;font-size:11px;line-height:1.35}.payroll-source-table-row b,.line-item-row b{color:#12664f;font-size:12px;font-weight:700;white-space:nowrap}.payroll-source-table-row b.negative,.line-item-row b.negative,.detail-total strong.negative{color:#9b2c22}.line-item-list h4{margin:8px 0 2px;color:#60746d;font-size:13px}.payment-input-stack{display:grid;gap:6px;min-width:190px}.row-fill-actions,.payment-fill-toolbar{display:flex;flex-wrap:wrap;gap:6px}.row-fill-actions .mini-button{min-height:30px;padding:0 9px;font-size:12px}.money-rows{display:grid;grid-template-columns:1fr auto;gap:8px 16px;margin:0}.money-rows dt,.detail-total span{color:#60746d}.money-rows dd{margin:0;font-weight:650}.money-rows dd.negative{color:#9b2c22}.detail-pairs{display:grid;grid-template-columns:120px minmax(0,1fr);gap:8px 16px;margin:0}.detail-pairs dt{color:#60746d}.detail-pairs dd{margin:0;font-weight:700}.detail-total{display:grid;gap:8px;padding-top:14px;border-top:1px solid #edf2f0}.detail-total div{display:flex;justify-content:space-between;gap:16px}.detail-total div:last-child strong{color:#19735d;font-size:18px}.empty,.empty-state p{color:#667872}.empty-state{display:grid;justify-items:center;gap:10px;padding:56px 20px;background:#fff;border:1px solid #dfe7e3;border-radius:8px;text-align:center}.empty-state.compact{padding:36px 18px}@media (max-width: 1060px){.app-shell{grid-template-columns:1fr}.sidebar{position:static}nav{grid-template-columns:repeat(2,minmax(0,1fr))}.topbar,.metrics,.dashboard-grid,.page-grid,.record-card-grid,.record-filter-bar,.workflow-strip,.contract-highlight,.contract-template-settings,.recurring-pay-row,.drawer-tab-grid,.manual-grid,.manual-tables,.review-grid,.settings-layout,.settings-key-grid,.template-toggle-grid{grid-template-columns:1fr}.settings-nav-panel{position:static}.record-toolbar,.tab-section-head,.contract-row,.manual-toolbar{display:grid}.payslip-grid,.payslip-columns,.payslip-head{grid-template-columns:1fr}.qr-box{min-height:96px}.browser-search{width:100%}}@media (max-width: 560px){.content{padding:18px}.form-grid,.checkbox-grid,nav{grid-template-columns:1fr}.record-actions{justify-content:stretch}.record-actions .primary,.search-field{width:100%}h1{font-size:26px}.payslip-paper{min-height:auto;padding:22px}}@media print{@page{size:A5 landscape;margin:0}@page payment-report-a4{size:A4 portrait;margin:10mm}html,body{width:210mm;min-height:148mm;height:auto;margin:0;background:#fff}body *{visibility:hidden}.app-shell{display:block!important;width:210mm!important;height:auto!important;min-height:0!important;margin:0!important;padding:0!important;overflow:visible!important;background:#fff!important}.app-shell>.sidebar,.app-shell>.content>:not(.print-backdrop){display:none!important}body.payment-report-printing .app-shell>.content>.full-page:has(.print-backdrop){display:block!important;width:auto!important;height:auto!important;min-height:0!important;margin:0!important;padding:0!important;overflow:visible!important;background:#fff!important}body.payment-report-printing .app-shell>.content>.full-page:has(.print-backdrop)>:not(.print-backdrop){display:none!important}.app-shell>.content{display:block!important;width:210mm!important;height:auto!important;margin:0!important;padding:0!important;overflow:visible!important;visibility:visible!important;background:#fff!important}.payslip-paper,.payslip-paper *,.print-backdrop,.print-backdrop *,.payment-report-card,.payment-report-card *{visibility:visible}.no-print{display:none!important}.print-backdrop{position:static!important;z-index:9999!important;display:block!important;width:210mm!important;height:auto!important;padding:0!important;margin:0!important;overflow:visible!important;background:#fff!important;box-shadow:none!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;cursor:default!important}.print-drawer{position:static!important;display:block!important;width:210mm!important;height:auto!important;min-height:0!important;padding:0!important;margin:0!important;overflow:visible!important;background:#fff!important;box-shadow:none!important}.print-drawer>:not(.drawer-body){display:none!important}.print-drawer .drawer-body{position:static!important;display:block!important;width:210mm!important;height:auto!important;min-height:0!important;padding:0!important;margin:0!important;overflow:visible!important;background:#fff!important}.payslip-paper,.payslip-a5{position:relative;display:grid;gap:2.5mm;page-break-after:always;page-break-inside:avoid;break-after:page;break-inside:avoid;width:210mm;min-height:0;height:148mm;max-height:148mm;margin:0;padding:4.5mm 5mm;box-sizing:border-box;overflow:hidden;border:0;border-radius:0;box-shadow:none}.payslip-paper:last-child,.payslip-a5:last-child{page-break-after:auto;break-after:auto}.payslip-head.compact{grid-template-columns:minmax(0,1fr) 60mm;gap:7mm;padding-bottom:2.6mm}.payslip-head.compact h2{font-size:28px}.payslip-head.compact span{font-size:12.4px}.payslip-head.compact .eyebrow{font-size:15px}.payslip-doc{gap:2.2mm;padding:3mm 3.5mm}.payslip-doc strong{font-size:13.6px}.payslip-doc span{font-size:11.8px}.payslip-info-table th,.payslip-info-table td,.payslip-time-table th,.payslip-time-table td{padding:1.7mm 1.9mm;font-size:10.6px;line-height:1.25}.payslip-time-table td{font-size:11.1px}.payslip-money-layout{grid-template-columns:minmax(0,1fr) minmax(0,1fr) 43mm;gap:2.8mm}.payslip-money-table th,.payslip-money-table td{padding:1.25mm 1.4mm;font-size:9.6px;line-height:1.22}.payslip-money-table thead tr:first-child th{font-size:10.8px}.payslip-item-cell>strong{font-size:9.8px}.payslip-net-box{gap:1.15mm;padding:4.2mm 2.5mm}.payslip-net-box span{font-size:12.4px}.payslip-net-box small{font-size:9.6px}.payslip-net-box strong{font-size:28px}.payment-report-card{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;padding:0;border:0;box-shadow:none}body.payment-report-printing,body.payment-report-printing html{width:210mm;min-height:297mm}body.payment-report-printing .print-backdrop{width:auto!important;min-height:297mm!important}body.payment-report-printing .print-drawer{width:auto!important;min-height:0!important}body.payment-report-printing .payment-report-card{position:static!important;inset:auto!important;page:payment-report-a4;display:block!important;width:auto!important;min-height:0!important;padding:0!important;border:0!important;box-shadow:none!important;font-size:11px!important}body.payment-report-printing .report-title-box{width:130mm!important;margin-bottom:5mm!important;padding:4mm!important}body.payment-report-printing .report-title-box h2{font-size:16px!important}body.payment-report-printing .report-title-box p{font-size:12px!important}body.payment-report-printing .payment-report-meta{gap:3mm!important;margin-bottom:5mm!important}body.payment-report-printing .payment-report-meta div{padding:3mm!important}body.payment-report-printing .payment-report-meta strong{font-size:13px!important}body.payment-report-printing .payment-report-meta div,body.payment-report-printing .payment-report-group-head,body.payment-report-printing .payment-report-table th,body.payment-report-printing .payment-report-table td{border-color:#d8e3df!important}body.payment-report-printing .payment-report-section{page-break-inside:avoid;break-inside:avoid}body.payment-report-printing .payment-report-section.active{display:block!important}body.payment-report-printing .payment-report-section.inactive{display:none!important}body.payment-report-printing .payment-report-table th,body.payment-report-printing .payment-report-table td{padding:3mm 3.5mm!important;font-size:11px!important}}
