@import "https://fonts.googleapis.com/css2?family=Quicksand:wght@400;500;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg-primary:#fff0f9;--bg-secondary:#fff;--bg-tertiary:#fde7f3;--bg-glass:#ffffffe6;--text-primary:#1a1a1a;--text-secondary:#64748b;--text-inverse:#fff;--brand-primary:#db2777;--brand-secondary:#be185d;--brand-light:#fbcfe8;--brand-bg-transparent:#db27771a;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;--info:#3b82f6;--font-brand:"Quicksand", sans-serif;--font-ui:"Quicksand", sans-serif;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--glass-border:1px solid #db27771a;--glass-shadow:0 4px 16px 0 #db27770d;--glass-blur:blur(8px);--transition-fast:.15s ease-in-out;--transition-normal:.3s ease-in-out}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-ui);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;line-height:1.5;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-brand);letter-spacing:-.01em;font-weight:700}a{color:var(--brand-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--brand-secondary)}button{font-family:var(--font-ui);cursor:pointer;background:0 0;border:none;outline:none}.glass-panel{background:var(--bg-glass);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--glass-shadow)}.btn-primary{background:var(--brand-primary);color:var(--text-inverse);border-radius:var(--radius-md);transition:all var(--transition-fast);justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:1rem;font-weight:600;display:inline-flex}.btn-primary:active{background:var(--brand-secondary);transform:translateY(1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--brand-primary);border-radius:var(--radius-md);transition:all var(--transition-fast);justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:1rem;font-weight:600;display:inline-flex}.btn-secondary:active{background:var(--brand-light)}.input-field{background:var(--bg-secondary);width:100%;color:var(--text-primary);border-radius:var(--radius-md);font-size:1rem;font-family:var(--font-ui);transition:all var(--transition-fast);border:1px solid #e2e8f0;padding:12px 16px}.input-field:focus{border-color:var(--brand-primary);box-shadow:0 0 0 3px var(--brand-bg-transparent);outline:none}.input-field::placeholder{color:var(--text-secondary)}.heading-lg{font-size:2rem;font-family:var(--font-brand);color:var(--brand-primary)}.heading-md{font-size:1.25rem;font-family:var(--font-brand);color:#1a1a1a}.text-body{color:var(--text-primary);font-size:.95rem}.text-muted{color:var(--text-secondary);font-size:.85rem}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-col{flex-direction:column;display:flex}::-webkit-scrollbar-thumb:hover{background:var(--brand-primary)}:root{--nav-bg:#6b9dc2;--nav-text:#ffffffe0;--bg:#eef3f8;--surface:#fff;--border:#dde5ee;--border-light:#eef2f7;--text:#1c2b3a;--text-2:#4a607a;--text-3:#8a9cb0;--green:#34c759;--red:#ff3b30;--blue:#6b9dc2;--blue-light:#eaf0f7;--yellow:#f59e0b;--radius:12px;--radius-sm:8px;--shadow:0 1px 6px #00000012;--shadow-md:0 4px 16px #0000001a;--t:all .18s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Inter,system-ui,sans-serif}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select{font-family:inherit}.navbar{background:var(--nav-bg);z-index:100;align-items:center;gap:6px;height:52px;padding:0 20px;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #00000026}.navbar-brand{flex-shrink:0;align-items:center;gap:8px;margin-right:10px;display:flex}.brand-name{color:#fff;white-space:nowrap;font-size:14px;font-weight:700}.navbar-nav{flex:1;align-items:center;gap:2px;display:flex}.nav-tab{color:var(--nav-text);transition:var(--t);white-space:nowrap;border-radius:20px;padding:5px 14px;font-size:13px;font-weight:500}.nav-tab:hover{color:#fff;background:#ffffff26}.nav-tab.active{color:var(--blue);background:#fffffff2;font-weight:600}.navbar-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.btn-qr{color:#fff;transition:var(--t);background:#ffffff2e;border:1px solid #ffffff52;border-radius:20px;align-items:center;gap:5px;padding:5px 12px;font-size:12.5px;font-weight:500;display:flex}.btn-qr:hover{background:#ffffff47}.avatar-btn{color:#fff;cursor:pointer;background:#ffffff38;border:2px solid #ffffff73;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:12px;font-weight:700;display:flex}.content{box-sizing:border-box;width:100%;max-width:1400px;margin:0 auto;padding:20px}.page{width:100%;animation:.2s fadeUp;display:none}.page.active{width:100%;display:block}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.page-heading{color:var(--text);margin-bottom:4px;font-size:20px;font-weight:700}.page-sub{color:var(--text-3);margin-bottom:16px;font-size:12.5px}.page-header-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:14px;display:flex}.filter-bar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.time-filters{flex-wrap:wrap;gap:4px;display:flex}.tf-btn{color:var(--text-2);background:var(--surface);border:1px solid var(--border);transition:var(--t);white-space:nowrap;border-radius:20px;padding:6px 13px;font-size:12.5px;font-weight:500}.tf-btn:hover{border-color:var(--blue);color:var(--blue)}.tf-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}.custom-date-range{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-3);align-items:center;gap:6px;padding:4px 10px;font-size:12px;display:flex}.custom-date-range input{color:var(--text);background:0 0;border:none;outline:none;font-size:12.5px}.branch-select{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:var(--surface);cursor:pointer;appearance:none;transition:var(--t);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M5 6L0 0h10z' fill='%238A9CB0'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding:6px 28px 6px 10px;font-size:12.5px}.branch-select:focus{border-color:var(--blue);outline:none}.search-input{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:var(--surface);transition:var(--t);padding:7px 12px;font-size:13px}.search-input:focus{border-color:var(--blue);outline:none}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);margin-bottom:12px}.card-top{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:13px 17px;display:flex}.card-label{color:var(--text);font-size:13.5px;font-weight:600}.card-meta{color:var(--text-3);font-size:11.5px}.dash-stats{grid-template-columns:repeat(4,1fr);gap:12px;width:100%;margin-bottom:16px;display:grid}.stat-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transition:var(--t);align-items:center;gap:14px;padding:16px 18px;display:flex}.stat-box:hover{box-shadow:var(--shadow-md)}.stat-box.highlight-box{background:var(--nav-bg);border-color:var(--nav-bg)}.highlight-box .stat-val,.highlight-box .stat-lbl{color:#fff!important}.stat-icon{border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.green-bg{background:var(--green)}.red-bg{background:var(--red)}.blue-bg{background:#5b8fc7}.gold-bg{background:#e0943a}.stat-val{color:var(--text);font-size:22px;font-weight:700;line-height:1.1}.stat-lbl{color:var(--text-3);margin-top:2px;font-size:11.5px}.dash-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.live-dot-label{color:#ff3b30;letter-spacing:.3px;background:#fff0ef;border-radius:20px;padding:2px 8px;font-size:10px;font-weight:700;animation:2s infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.simple-list{flex-direction:column;gap:7px;padding:10px 16px;list-style:none;display:flex}.simple-list li{color:var(--text-2);border-bottom:1px solid var(--border-light);padding:4px 0;font-size:13px}.simple-list li:last-child{border-bottom:none}.sl-empty{font-style:italic;color:var(--text-3)!important}.sl-meta{color:var(--text-3);font-size:11px;display:block}.sl-warn{color:#d97706!important}.emp-list{flex-direction:column;gap:8px;width:100%;display:flex}.emp-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);transition:var(--t);align-items:center;gap:13px;padding:13px 17px;display:flex}.emp-row:hover{border-color:var(--blue);box-shadow:var(--shadow-md)}.emp-av{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:700;display:flex}.emp-info{flex:1}.emp-name{color:var(--text);font-size:14px;font-weight:600}.emp-meta{color:var(--text-3);margin-top:2px;font-size:11.5px}.emp-badges{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.badge{white-space:nowrap;border-radius:20px;padding:3px 9px;font-size:11px;font-weight:600}.badge-full{color:#28a745;background:#e5f5ec}.badge-part{color:#856404;background:#fef3cd}.badge-role{background:var(--blue-light);color:var(--blue)}.badge-branch{color:#7c5cbf;background:#f3efff}.emp-salary{text-align:right;margin-right:4px}.emp-rate{color:var(--text);font-size:14px;font-weight:700}.emp-rate-label{color:var(--text-3);font-size:11px}.emp-actions{gap:5px;display:flex}.table-wrap{overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:13px}.table th{text-align:left;border-bottom:1px solid var(--border);color:var(--text-3);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;background:#f7fafd;padding:10px 15px;font-size:11px;font-weight:600}.table td{border-bottom:1px solid var(--border-light);color:var(--text);vertical-align:middle;padding:10px 15px}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:#fafcff}.time-in{color:#28c840;font-weight:600}.time-out{color:#ff3b30;font-weight:600}.hours-pill{background:var(--blue-light);color:var(--blue);border-radius:20px;padding:2px 9px;font-size:11.5px;font-weight:600;display:inline-block}.salary-summary-bar{grid-template-columns:repeat(3,1fr);gap:12px;width:100%;margin-bottom:16px;display:grid}.ssb-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:14px 18px}.ssb-item.highlight{background:var(--nav-bg);border-color:var(--nav-bg)}.ssb-label{color:var(--text-3);margin-bottom:5px;font-size:11px;font-weight:500;display:block}.ssb-item.highlight .ssb-label{color:#ffffffbf}.ssb-val{color:var(--text);font-size:18px;font-weight:700}.ssb-item.highlight .ssb-val{color:#fff}.salary-list{flex-direction:column;gap:8px;display:flex}.sal-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transition:var(--t);overflow:hidden}.sal-row:hover{box-shadow:var(--shadow-md)}.sal-row-top{cursor:pointer;align-items:center;gap:14px;padding:14px 20px;display:flex}.sal-av{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:14px;font-weight:700;display:flex}.sal-info{flex:1}.sal-name{color:var(--text);font-size:15px;font-weight:700}.sal-meta{color:var(--text-3);margin-top:3px;font-size:12px}.sal-total{text-align:right}.sal-total-val{color:var(--blue);font-size:17px;font-weight:700}.sal-total-label{color:var(--text-3);font-size:10.5px}.sal-expand-icon{color:var(--text-3);transition:var(--t);font-size:11px}.sal-row.open .sal-expand-icon{transform:rotate(180deg)}.sal-detail{border-top:1px solid var(--border-light);padding:16px 20px;animation:.22s cubic-bezier(.16,1,.3,1) slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.sal-detail-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.sdg-title{color:var(--text-3);text-transform:uppercase;letter-spacing:.4px;margin-bottom:7px;font-size:10.5px;font-weight:700}.sdg-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:5px 0;font-size:12.5px;display:flex}.sdg-row:last-child{border-bottom:none}.sdg-label{color:var(--text-2)}.sdg-val{color:var(--text);font-weight:600}.sdg-val.green{color:#28c840}.sdg-val.auto{color:var(--blue)}.bonus-editor{border-top:1px dashed var(--border);grid-template-columns:1fr 1fr 1fr 1fr;gap:12px;margin-top:14px;padding-top:14px;display:grid}.be-item{flex-direction:column;gap:4px;display:flex}.be-label{color:var(--text-3);font-size:11px;font-weight:500}.be-select,.be-input{border:1px solid var(--border);color:var(--text);background:var(--surface);transition:var(--t);border-radius:6px;padding:6px 8px;font-family:inherit;font-size:12.5px}.be-select:focus,.be-input:focus{border-color:var(--blue);outline:none}.be-input[readonly]{color:var(--text-3);background:#f5f7fa}.sal-actions{justify-content:flex-end;gap:8px;margin-top:12px;display:flex}.offdays-auto{color:#3a7fc1;background:#e8f4fc;border-radius:6px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.att-month-picker{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);align-items:center;gap:4px;padding:5px 10px;font-size:13.5px;font-weight:600;display:inline-flex}.amp-arrow{cursor:pointer;color:var(--text-3);transition:var(--t);background:0 0;border:none;padding:0 4px;font-size:18px;line-height:1}.amp-arrow:hover{color:var(--blue)}.amp-label{text-align:center;min-width:100px}.att-av{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.att-branch-pill{color:#6366f1;white-space:nowrap;background:#eef2ff;border-radius:20px;padding:2px 10px;font-size:12px;font-weight:600;display:inline-block}.att-time{font-size:13.5px;font-weight:700}.att-time.att-in{color:#16a34a}.att-time.att-out{color:#e11d48}.att-chua-out{color:#d97706;background:#fef3c7;border-radius:20px;padding:2px 9px;font-size:12px;font-weight:700;display:inline-block}.att-hours-pill{color:#3a7fc1;background:#e8f4fc;border-radius:20px;padding:2px 9px;font-size:12px;font-weight:700;display:inline-block}.att-icon-btn{cursor:pointer;width:28px;height:28px;transition:var(--t);border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;margin-left:4px;font-size:13px;display:inline-flex}.att-edit-btn{color:#475569;border-color:var(--border);background:#f1f5f9}.att-edit-btn:hover{background:var(--blue-light);color:var(--blue);border-color:var(--blue)}.att-del-btn{color:var(--red);background:#fef0ef;border-color:#fddcdb;font-size:11px;font-weight:700}.att-del-btn:hover{background:var(--red);color:#fff}.settings-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.settings-card{padding:0;overflow:hidden}.sc-label{color:var(--text);border-bottom:1px solid var(--border-light);background:#fafcff;padding:13px 17px;font-size:13px;font-weight:600}.sf{flex-direction:column;gap:10px;padding:12px 17px;display:flex}.sf-row{justify-content:space-between;align-items:center;gap:10px;display:flex}.sf-row label{color:var(--text-2);flex:1;font-size:12.5px}.sf-row input,.sf-row select{border:1px solid var(--border);width:130px;color:var(--text);text-align:right;background:var(--surface);transition:var(--t);border-radius:6px;flex-shrink:0;padding:6px 8px;font-family:inherit;font-size:12.5px}.sf-row input:focus,.sf-row select:focus{border-color:var(--blue);outline:none}.info-row{border-top:1px solid var(--border-light);padding-top:10px}.info-text{color:var(--text-3);font-size:12px;font-style:italic}.setting-hint{color:#3a7fc1;background:#eaf0f7;border-radius:6px;padding:7px 10px;font-size:11.5px}.branch-list{flex-direction:column;gap:6px;display:flex}.branch-item{border:1px solid var(--border-light);color:var(--text);background:#f7fafd;border-radius:6px;justify-content:space-between;align-items:center;padding:7px 12px;font-size:13px;display:flex}.branch-item-del{color:var(--text-3);transition:var(--t);border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;display:flex}.branch-item-del:hover{color:var(--red);background:#fddcdb}.btn-primary{background:var(--nav-bg);color:#fff;border-radius:var(--radius-sm);transition:var(--t);align-items:center;gap:5px;padding:7px 16px;font-size:13px;font-weight:600;display:inline-flex}.btn-primary:hover{background:#5a8baf}.btn-primary.full{justify-content:center;width:100%;padding:11px;font-size:14px}.btn-outline{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-2);background:var(--surface);transition:var(--t);align-items:center;gap:5px;padding:7px 14px;font-size:13px;display:inline-flex}.btn-outline:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light)}.btn-sm{transition:var(--t);border-radius:6px;padding:4px 11px;font-size:12px;font-weight:500}.btn-edit-sm{color:var(--text-2);background:#eef2f7}.btn-edit-sm:hover{background:var(--blue-light);color:var(--blue)}.btn-del-sm{color:var(--red);background:#fef0ef}.btn-del-sm:hover{background:#fddcdb}.btn-pencil{color:var(--text-3);transition:var(--t);background:0 0;border-radius:6px;padding:4px 7px;font-size:14px}.btn-pencil:hover{background:var(--blue-light);color:var(--blue)}.link-btn{color:var(--text-3);text-align:center;transition:var(--t);background:0 0;margin-top:4px;font-size:12px;display:block}.link-btn:hover{color:var(--blue)}select{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:var(--surface);cursor:pointer;appearance:none;transition:var(--t);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M5 6L0 0h10z' fill='%238A9CB0'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;padding:7px 28px 7px 10px;font-size:12.5px}select:focus{border-color:var(--blue);outline:none}input[type=text],input[type=number],input[type=tel],input[type=date],input[type=time]{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:var(--surface);transition:var(--t);padding:7px 10px;font-size:13px}input:focus{border-color:var(--blue);outline:none;box-shadow:0 0 0 2px #6b9dc21f}input::placeholder{color:var(--text-3)}.overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:200;background:#0f1e326b;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.overlay.open{display:flex}.modal{background:var(--surface);border-radius:16px;width:400px;max-height:92vh;padding:24px;animation:.22s cubic-bezier(.34,1.56,.64,1) popIn;position:relative;overflow-y:auto;box-shadow:0 8px 40px #0000002e}.modal-lg{width:580px}@keyframes popIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.modal-x{width:26px;height:26px;color:var(--text-3);transition:var(--t);background:#f0f4f8;border-radius:50%;justify-content:center;align-items:center;font-size:12px;display:flex;position:absolute;top:13px;right:13px}.modal-x:hover{color:var(--red);background:#fddcdb}.modal-title{color:var(--text);margin-bottom:5px;font-size:17px;font-weight:700}.modal-desc{color:var(--text-3);margin-bottom:16px;font-size:12.5px}.modal-footer{justify-content:flex-end;gap:8px;margin-top:18px;display:flex}.form-grid{grid-template-columns:1fr 1fr;gap:10px;margin-top:12px;display:grid}.form-col{flex-direction:column;gap:4px;display:flex}.fl{color:var(--text-2);font-size:11.5px;font-weight:600}.form-section-title{color:var(--blue);text-transform:uppercase;letter-spacing:.4px;margin-top:14px;font-size:11.5px;font-weight:700}.form-col input,.form-col select{width:100%}.qr-step{flex-direction:column;gap:13px;display:none}.qr-step.active{display:flex}.qr-box{border:1px dashed var(--border);border-radius:var(--radius);background:#f7fafd;justify-content:center;padding:24px;display:flex}.qr-img{box-shadow:var(--shadow);background:#fff;border-radius:8px;padding:14px}.pin-input{border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;letter-spacing:3px;width:100%;transition:var(--t);padding:13px;font-size:18px;font-weight:600}.pin-input:focus{border-color:var(--blue);outline:none;box-shadow:0 0 0 3px #6b9dc226}.pin-btns{gap:8px;display:flex}.btn-checkin{border-radius:var(--radius-sm);background:var(--nav-bg);color:#fff;transition:var(--t);flex:1;padding:11px;font-size:13.5px;font-weight:600}.btn-checkin:hover{background:#5a8baf}.btn-checkout{border-radius:var(--radius-sm);color:var(--red);transition:var(--t);background:#fef0ef;border:1px solid #fddcdb;flex:1;padding:11px;font-size:13.5px;font-weight:600}.btn-checkout:hover{background:var(--red);color:#fff}.pin-msg{text-align:center;min-height:20px;transition:var(--t);border-radius:6px;padding:4px;font-size:12.5px;font-weight:600}.pin-msg.success{color:#1d8348;background:#e5f5ec}.pin-msg.error{color:var(--red);background:#fddcdb}.ps-header{text-align:center;border-bottom:1px solid var(--border);margin-bottom:14px;padding-bottom:14px}.ps-title{color:var(--text);font-size:18px;font-weight:700}.ps-period{color:var(--text-3);margin-top:3px;font-size:12px}.ps-emp-grid{border-radius:var(--radius-sm);background:#f7fafd;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px;padding:13px;display:grid}.pe-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.4px;font-size:10px}.pe-val{color:var(--text);font-size:13px;font-weight:600}.ps-table{border-collapse:collapse;width:100%;margin-bottom:13px;font-size:13px}.ps-table td{border-bottom:1px solid var(--border-light);padding:7px 10px}.ps-table tr:last-child td{border-bottom:none}.ps-table .pt-l{color:var(--text-2)}.ps-table .pt-r{text-align:right;font-weight:600}.ps-table .sec-head td{color:var(--text-3);text-transform:uppercase;letter-spacing:.4px;padding-top:12px;font-size:10px;font-weight:700}.ps-total{background:var(--nav-bg);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;margin-bottom:14px;padding:13px 16px;display:flex}.ps-total-label{color:#fffc;font-size:12.5px}.ps-total-val{color:#fff;font-size:20px;font-weight:700}.ps-footer{gap:8px;display:flex}.sal-action-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:14px;padding:10px 16px;display:flex}.sab-left{flex:1}.sab-right{gap:8px;display:flex}.sab-status{color:var(--text-3);font-size:12.5px}.sab-status.ok{color:#1d8348;font-weight:600}.sab-status.err{color:var(--red);font-weight:600}.sab-status.loading{color:var(--blue)}.empty{text-align:center;color:var(--text-3);padding:40px 20px;font-size:13px}.empty-icon{margin-bottom:10px;font-size:34px}.empty-title{color:var(--text-2);margin-bottom:4px;font-size:14px;font-weight:600}.toast{color:#fff;box-shadow:var(--shadow-md);z-index:999;opacity:0;pointer-events:none;background:#1c2b3a;border-radius:8px;padding:9px 16px;font-size:13px;font-weight:500;transition:all .28s cubic-bezier(.34,1.56,.64,1);position:fixed;bottom:22px;right:22px;transform:translateY(60px)}.toast.show{opacity:1;transform:translateY(0)}.toast.success{background:#1d8348}.toast.error{background:var(--red)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}@media (width<=960px){.dash-stats{grid-template-columns:repeat(2,1fr)}.dash-grid{grid-template-columns:1fr 1fr}.settings-grid,.salary-summary-bar{grid-template-columns:1fr}}@media (width<=768px){.ps-container{padding:10px}.payslip{margin-bottom:12px;padding:16px}.settings-grid{grid-template-columns:1fr}}.login-overlay{z-index:9999;color:#fff;background:linear-gradient(135deg,#1c2b3a 0%,#101923 100%);justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.login-card{-webkit-backdrop-filter:blur(16px);background:#ffffff08;border:1px solid #ffffff14;border-radius:24px;width:100%;max-width:400px;padding:40px 32px;animation:.5s cubic-bezier(.16,1,.3,1) forwards loginAppear;box-shadow:0 24px 64px #0006,inset 0 0 0 1px #ffffff0d}@keyframes loginAppear{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.login-header{text-align:center;margin-bottom:32px}.login-logo{background:linear-gradient(135deg, var(--blue) 0%, #517e9a 100%);border-radius:18px;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:16px;display:inline-flex;box-shadow:0 12px 24px #6b9dc24d}.login-title{letter-spacing:-.5px;margin-bottom:6px;font-size:24px;font-weight:800}.login-subtitle{color:#fff9;font-size:14px;font-weight:500}.login-form{flex-direction:column;gap:20px;display:flex}.login-input-group{text-align:left;flex-direction:column;gap:8px;display:flex}.login-input-group label{color:#fffc;text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.login-input-wrapper{align-items:center;display:flex;position:relative}.login-input-wrapper .input-icon{color:#fff6;position:absolute;left:16px}.login-input-wrapper input{width:100%;height:52px;color:#fff!important;background:#0003!important;border:1px solid #ffffff1a!important;border-radius:14px!important;padding:0 16px 0 46px!important;font-size:15px!important;transition:all .2s!important}.login-input-wrapper input::placeholder{color:#ffffff40!important}.login-input-wrapper input:focus{background:#0000004d!important;border-color:#6b9dc280!important;outline:none!important;box-shadow:0 0 0 4px #6b9dc226!important}.login-input-wrapper input[type=password]{letter-spacing:4px;font-family:monospace;font-size:20px!important}.login-input-wrapper input[type=password]::placeholder{letter-spacing:normal;font-family:Inter,system-ui,sans-serif;font-size:15px!important}.login-btn{color:#101923;background:#fff;border-radius:14px;justify-content:center;align-items:center;gap:10px;width:100%;height:52px;margin-top:8px;font-size:15px;font-weight:700;transition:all .2s;display:flex}.login-btn:hover{background:#eef2f7;transform:translateY(-1px);box-shadow:0 8px 16px #ffffff1a}.login-btn:active{transform:translateY(0)}.login-error{color:#ff6b6b;text-align:center;min-height:18px;font-size:13px;font-weight:500}@media (width<=700px){.dash-grid,.sal-detail-grid{grid-template-columns:1fr}.bonus-editor{grid-template-columns:1fr 1fr}.content{padding:14px 14px 70px}.modal{width:calc(100vw - 28px)}.form-grid{grid-template-columns:1fr}.navbar-nav{background:var(--surface);z-index:999;justify-content:space-around;gap:0;height:60px;padding:0;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 10px #0000000f}.nav-tab{color:var(--text-3);border-radius:0;flex:1;justify-content:center;align-items:center;padding:0;font-size:11px;display:flex}.nav-tab:hover{color:var(--blue);background:0 0}.nav-tab.active{color:var(--blue);border-top:2px solid var(--blue);background:0 0;font-weight:700}}
