.view-modal{max-width:860px}.salary-section{margin-bottom:1.8rem}.salary-section-title{font-size:1rem;font-weight:700;color:#1b2a4a;margin:0 0 .75rem;padding-bottom:.4rem;border-bottom:2px solid #e2e8f0}.salary-hint{font-size:10px;color:#64748b;font-weight:400;margin-left:6px;font-style:italic}.salary-esi-toggle{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:#1e293b;cursor:pointer}.salary-table{width:100%;border-collapse:collapse;font-size:13px}.salary-table th{background:#1b2a4a;color:#fff;padding:8px 12px;text-align:left;font-size:12px;letter-spacing:.3px}.salary-table td{padding:7px 12px;border-bottom:1px solid #f1f5f9;color:#1e293b;vertical-align:middle}.salary-table tr:hover td{background:#f8fafc}.salary-table-total td{background:#f0fdf4!important;font-weight:800;border-top:2px solid #16a34a;color:#15803d}.salary-table-readonly td{color:#475569;background:#fafafa}.salary-table-readonly .salary-table-total td{color:#1d4ed8;background:#eff6ff!important;border-color:#3b82f6}.salary-input{border:1.5px solid #e2e8f0;border-radius:6px;padding:5px 8px;font-size:13px;width:130px;text-align:right;transition:border .15s}.salary-input:focus{border-color:#3b82f6;outline:none}.deduction-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;letter-spacing:.3px}.deduction-badge.emp{background:#fef3c7;color:#92400e}.deduction-badge.er{background:#dbeafe;color:#1e40af}.salary-summary-section{margin-top:.5rem}.salary-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.salary-summary-card{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;padding:14px 16px;text-align:center}.salary-summary-card.takehome{background:#f0fdf4;border-color:#16a34a}.salary-summary-card.ctc{background:#eff6ff;border-color:#3b82f6}.salary-summary-card.deduction{background:#fff7ed;border-color:#f97316}.salary-summary-label{font-size:11px;color:#64748b;text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px}.salary-summary-value{font-size:1.2rem;font-weight:800;color:#1b2a4a}.salary-summary-value.highlight{color:#15803d;font-size:1.35rem}.sal-summary-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:1rem}.sal-card{border-radius:10px;padding:12px 16px;text-align:center;border:1.5px solid transparent}.sal-card.blue{background:#eff6ff;border-color:#bfdbfe}.sal-card.red{background:#fff7ed;border-color:#fed7aa}.sal-card.green{background:#f0fdf4;border-color:#bbf7d0}.sal-card.navy{background:#f0f4ff;border-color:#c7d2fe}.sal-card-label{font-size:10px;color:#64748b;text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px}.sal-card-value{font-size:1rem;font-weight:800;color:#1b2a4a}.sal-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.sal-detail-box{background:#fafafa;border:1px solid #e2e8f0;border-radius:8px;padding:1rem}.sal-detail-title{font-size:12px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.4px;margin-bottom:.75rem}.sal-detail-table{width:100%;border-collapse:collapse;font-size:13px}.sal-detail-table td{padding:5px 8px;border-bottom:1px solid #f1f5f9;color:#334155}.sal-detail-table .sal-amt{text-align:right;font-variant-numeric:tabular-nums}.sal-detail-table .sal-total-row td{background:#f0f7ff;font-weight:700;border-top:2px solid #cbd5e1}.sal-note{font-size:10px;color:#94a3b8;margin-left:6px}.sal-history-timeline{display:flex;flex-direction:column;gap:0}.sal-history-item{display:flex;gap:1rem;padding-bottom:1.5rem;border-left:2px solid #e2e8f0;margin-left:10px;padding-left:1.25rem;position:relative}.sal-history-item:last-child{border-left-color:transparent}.sal-history-dot{width:12px;height:12px;border-radius:50%;background:#3b82f6;border:2px solid #fff;box-shadow:0 0 0 2px #3b82f6;position:absolute;left:-7px;top:2px}.sal-history-body{flex:1;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:.75rem 1rem}.sal-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.sal-history-date{font-size:11px;color:#64748b;background:#e2e8f0;border-radius:20px;padding:2px 8px}.sal-history-reason{font-size:12px;color:#64748b;margin-bottom:.5rem}.sal-history-amounts{display:flex;flex-wrap:wrap;gap:1rem;font-size:12px;color:#475569}.sal-history-amounts strong{color:#1b2a4a}.sal-history-detail-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:.5rem}.sal-history-detail-table td,.sal-history-detail-table th{padding:4px 8px;border:1px solid #e2e8f0}.sal-history-detail-table th{text-align:left;font-weight:600;font-size:11px}.payroll-page{padding:0}.payroll-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.payroll-header-left{display:flex;flex-direction:column;gap:10px}.payroll-header-left h2{margin:0;font-size:1.4rem;color:#1b2a4a}.payroll-tabs{display:flex;gap:4px;background:#f1f5f9;border-radius:10px;padding:4px}.payroll-tab{background:none;border:none;padding:6px 18px;border-radius:8px;font-size:13px;font-weight:600;color:#64748b;cursor:pointer;transition:all .15s}.payroll-tab.active{background:#fff;color:#1b2a4a;box-shadow:0 1px 4px #0000001f}.payroll-gen-bar{display:flex;gap:10px;align-items:center;margin-top:4px}.payroll-month-picker{border:1.5px solid #e2e8f0;border-radius:8px;padding:8px 12px;font-size:13px;color:#1e293b;background:#fff}.payroll-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}.payroll-stat-card{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:16px 20px;text-align:center;box-shadow:0 1px 4px #0000000d}.ps-num{font-size:1.6rem;font-weight:800}.ps-label{font-size:11px;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.payroll-search{border:1.5px solid #e2e8f0;border-radius:8px;padding:8px 14px;font-size:13px;width:280px}.payroll-empty{text-align:center;padding:60px 20px;color:#94a3b8;font-size:15px}.prp-run-btn{font-size:.9rem;padding:.5rem 1.25rem}.prp-panel{background:#fff;border-radius:16px;width:min(1100px,96vw);max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 60px #00000040;overflow:hidden}.prp-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#1b2a4a,#2d4370);border-bottom:3px solid #f59e0b}.prp-header-left{display:flex;flex-direction:column;gap:.75rem}.prp-title{margin:0;font-size:1.2rem;color:#fff;font-weight:800;letter-spacing:.02em}.prp-controls{display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end}.prp-field{display:flex;flex-direction:column;gap:.25rem}.prp-label{font-size:.7rem;color:#94a3b8;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.prp-input{padding:.42rem .75rem;border:1.5px solid rgba(255,255,255,.25);border-radius:8px;font-size:.875rem;background:#ffffff1f;color:#fff;outline:none;transition:border-color .18s}.prp-input:focus{border-color:#f59e0b}.prp-input-sm{width:80px;text-align:center}.prp-header-right{display:flex;flex-direction:column;align-items:flex-end;gap:.75rem}.prp-summary-chips{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:flex-end}.prp-chip{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:.5rem 1rem;text-align:center;min-width:110px}.prp-chip-green{background:#16a34a33;border-color:#16a34a66}.prp-chip-label{font-size:.68rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;display:block}.prp-chip-val{font-size:1rem;font-weight:800;color:#fff;display:block;margin-top:2px}.prp-chip-green .prp-chip-val{color:#86efac}.prp-btn-row{display:flex;gap:.6rem}.prp-table-wrap{overflow:auto;flex:1}.prp-table{width:100%;border-collapse:collapse;font-size:.82rem}.prp-table thead tr{background:#f8fafc;border-bottom:2px solid #e2e8f0;position:sticky;top:0;z-index:1}.prp-table th{padding:.65rem .75rem;font-size:.72rem;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.04em;text-align:left;white-space:nowrap}.prp-num{text-align:right!important}.prp-table td{padding:.5rem .75rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.prp-table tbody tr:hover{background:#f8fafc}.prp-excluded{opacity:.38}.prp-emp-name{font-weight:700;color:#1e293b;font-size:.83rem}.prp-emp-id{font-size:.72rem;color:#94a3b8}.prp-desg{font-size:.78rem;color:#64748b}.prp-gross-val{font-weight:600;color:#1b2a4a}.prp-lop-tag{font-size:.68rem;color:#b45309;background:#fef3c7;border-radius:4px;padding:1px 5px;margin-top:2px;display:inline-block}.prp-net-val{font-weight:800;color:#16a34a}.prp-cell-input{width:80px;padding:.3rem .5rem;border:1.5px solid #e2e8f0;border-radius:6px;text-align:right;font-size:.82rem;color:#1e293b;transition:border-color .15s}.prp-cell-input:focus{border-color:#1b2a4a;outline:none}.prp-totals-row td{background:#1b2a4a;color:#fff;font-weight:700;padding:.6rem .75rem;font-size:.82rem}.prp-total-net{color:#86efac;font-size:.95rem}.payroll-run-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;margin-bottom:20px;overflow:hidden;box-shadow:0 2px 8px #0000000d}.payroll-run-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;background:#f8fafc;border-bottom:1px solid #e2e8f0;flex-wrap:wrap;gap:10px}.payroll-run-month{font-size:16px;font-weight:800;color:#1b2a4a}.payroll-slips-table{width:100%;border-collapse:collapse}.payroll-slips-table thead tr{background:#1b2a4a}.payroll-slips-table th{padding:10px 14px;color:#fff;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;text-align:left}.payroll-slips-table td{padding:10px 14px;font-size:13px;border-bottom:1px solid #f1f5f9}.payroll-slips-table tbody tr:hover{background:#f8fafc}.payroll-slips-table .btn-sm{padding:4px 10px;font-size:12px;border-radius:6px}.payroll-preview-modal{background:#fff;border-radius:14px;width:860px;max-height:90vh;display:flex;flex-direction:column;padding:20px;box-shadow:0 24px 60px #0000004d}.payroll-preview-scroll{overflow-y:auto;flex:1;border:1px solid #e2e8f0;border-radius:8px}.btn-outline{background:#fff;border:1.5px solid #e2e8f0;color:#374151;cursor:pointer;border-radius:6px}.btn-outline:hover{background:#f1f5f9}.wizard-layout{display:flex;gap:1.5rem;align-items:flex-start;min-height:calc(100vh - 80px)}.wizard-sidebar{width:220px;flex-shrink:0;background:#fff;border-radius:14px;padding:2rem 1.25rem;box-shadow:0 1px 4px #00000014;display:flex;flex-direction:column;gap:0;position:sticky;top:1.5rem}.wizard-step{display:flex;align-items:center;gap:.85rem;padding:.75rem 0;position:relative;cursor:default}.wizard-step:not(:last-child):after{content:"";position:absolute;left:16px;top:calc(50% + 16px);width:2px;height:32px;background:#e2e8f0}.wizard-step.done:not(:last-child):after{background:#f59e0b}.wizard-step-num{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;border:2px solid #e2e8f0;color:#94a3b8;background:#fff;flex-shrink:0;transition:all .2s;z-index:1}.wizard-step.active .wizard-step-num,.wizard-step.done .wizard-step-num{background:#f59e0b;border-color:#f59e0b;color:#fff}.wizard-step-label{font-size:.88rem;font-weight:600;color:#94a3b8}.wizard-step.active .wizard-step-label{color:#1e293b}.wizard-step.done .wizard-step-label{color:#64748b}.wizard-content{flex:1;background:#fff;border-radius:14px;box-shadow:0 1px 4px #00000014;display:flex;flex-direction:column;overflow:hidden}.wizard-body{flex:1;padding:1.75rem 2rem;overflow-y:auto}.wizard-title{font-size:1.2rem;font-weight:700;color:#1e293b;margin-bottom:1.5rem}.wiz-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem 1.25rem}.form-group select{border:1px solid #d1d5db;border-radius:7px;padding:.5rem .75rem;font-size:.875rem;color:#1e293b;outline:none;background:#fafafa;cursor:pointer;transition:border-color .15s,box-shadow .15s;font-family:inherit;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.form-group select:focus{border-color:#3d007a;box-shadow:0 0 0 3px #3d007a1f;background:#fff}.phone-input{display:flex;align-items:center;border:1px solid #d1d5db;border-radius:7px;background:#fafafa;overflow:hidden;transition:border-color .15s,box-shadow .15s}.phone-input:focus-within{border-color:#3d007a;box-shadow:0 0 0 3px #3d007a1f;background:#fff}.phone-flag{padding:.5rem .6rem;font-size:.82rem;font-weight:600;color:#374151;white-space:nowrap;border-right:1px solid #e2e8f0;background:#f1f5f9;flex-shrink:0}.phone-input input{border:none!important;outline:none!important;box-shadow:none!important;background:transparent!important;flex:1;padding:.5rem .75rem;font-size:.875rem;color:#1e293b}.address-section{border:1px solid #e2e8f0;border-radius:10px;margin-bottom:1.25rem;overflow:hidden}.address-section-header{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.25rem;background:#f8fafc;cursor:default}.address-title{font-size:.95rem;font-weight:700;color:#3d007a;margin:0}.address-title.perm{color:#1e293b}.addr-chevron{font-size:.9rem;color:#94a3b8}.addr-grid{padding:1rem 1.25rem 1.25rem}.addr-grid .form-group input{border:1px solid #d1d5db;border-radius:7px;padding:.5rem .75rem;font-size:.875rem;width:100%}.same-addr-checkbox{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-size:.875rem;color:#374151;cursor:pointer;border-top:1px solid #f1f5f9}.same-addr-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:#3d007a;cursor:pointer}.wizard-footer{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;border-top:1px solid #e2e8f0;background:#f8fafc;flex-shrink:0}.wizard-footer-right{display:flex;gap:.75rem;margin-left:auto}.btn-back{background:#f1f5f9;color:#374151;border:1px solid #d1d5db;display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.2rem;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;transition:background .15s}.btn-back:hover{background:#e2e8f0}.btn-success{background:#16a34a;color:#fff;display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.2rem;border-radius:8px;border:none;cursor:pointer;font-size:.875rem;font-weight:600;transition:background .15s}.btn-success:hover{background:#15803d}.emp-id{font-size:.8rem;font-weight:600;color:#f59e0b}.view-header-left{display:flex;align-items:center;gap:1rem}.view-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#3d007a,#2a0060);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:800;flex-shrink:0}.view-header-left h2{font-size:1.2rem;font-weight:700;margin-bottom:.25rem}.view-body{overflow-y:auto;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem}.view-section{border:1px solid #e2e8f0;border-radius:10px;padding:1rem 1.25rem}.view-section-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#3d007a;margin-bottom:.85rem}.view-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem 1.5rem}.view-field{display:flex;flex-direction:column;gap:.2rem}.view-field.full-width{grid-column:1 / -1}.view-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8}.view-value{font-size:.9rem;color:#1e293b;font-weight:500;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:.45rem .75rem;min-height:2rem}.view-field.highlight .view-value{background:#f0fdf4;border-color:#86efac;color:#16a34a;font-weight:700;font-size:1rem}.btn-icon.view:hover{background:#f5eeff;border-color:#d4aaff}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#160038,#200050);padding:1rem}.login-card{background:#fff;border-radius:16px;padding:2.5rem 2rem;width:100%;max-width:400px;box-shadow:0 20px 60px #00000040;display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}.login-logo-wrap{background:linear-gradient(135deg,#3d007a,#2a0060);border-radius:12px;padding:.6rem 1.2rem;margin-bottom:.25rem}.login-logo{height:48px;width:auto;object-fit:contain;filter:brightness(0) invert(1)}.login-title{font-size:1.4rem;font-weight:800;color:#1e293b}.login-subtitle{font-size:.9rem;color:#64748b;margin-top:-.5rem}.login-error{width:100%;background:#fef2f2;border:1px solid #fca5a5;color:#dc2626;border-radius:8px;padding:.65rem 1rem;font-size:.85rem;display:flex;align-items:center;gap:.5rem}.login-error-icon{font-size:1rem;flex-shrink:0}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem 1.25rem;border:1.5px solid #d1d5db;border-radius:10px;background:#fff;color:#374151;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s,box-shadow .15s;margin-top:.5rem}.btn-google:hover:not(:disabled){background:#f8fafc;box-shadow:0 2px 8px #0000001a}.btn-google:disabled{opacity:.6;cursor:not-allowed}.google-icon{width:20px;height:20px;flex-shrink:0}.login-footer{font-size:.75rem;color:#94a3b8;margin-top:.5rem}.login-spinner{display:inline-block;width:18px;height:18px;border:2px solid #cbd5e1;border-top-color:#f59e0b;border-radius:50%;animation:spin .7s linear infinite}.auth-loading{min-height:100vh;display:flex;align-items:center;justify-content:center}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:#f0f4f8;color:#1a202c;min-height:100vh}.app-header{background:linear-gradient(180deg,#160038,#1a0042);color:#fff;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;box-shadow:0 3px #f59e0b,0 4px 12px #0006;position:sticky;top:0;z-index:100;border-bottom:3px solid #f59e0b}.header-brand{display:flex;align-items:center;gap:.75rem}.header-logo{height:44px;width:auto;object-fit:contain;filter:brightness(0) invert(1)}.header-divider{width:1px;height:36px;background:#ffffff4d;margin:0 .25rem}.app-header h1{font-size:1.4rem;font-weight:700}.app-header p{font-size:.8rem;opacity:.8}.header-actions{display:flex;align-items:center;gap:.75rem}.header-user{font-size:.85rem;opacity:.9;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-main{max-width:1400px;margin:0 auto;padding:1.5rem}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:12px;padding:1.25rem 1.5rem;box-shadow:0 1px 4px #00000014;text-align:center;border-top:4px solid #e2e8f0;transition:transform .15s}.stat-card:hover{transform:translateY(-2px)}.stat-num{font-size:2rem;font-weight:800}.stat-num.total{color:#3d007a}.stat-num.active{color:#16a34a}.stat-num.inactive{color:#dc2626}.stat-label{font-size:.8rem;color:#6b7280;margin-top:.25rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.toolbar{display:flex;gap:1rem;align-items:center;margin-bottom:1rem}.search-box{flex:1;display:flex;align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:0 .75rem;box-shadow:0 1px 3px #0000000f}.search-box input{flex:1;border:none;outline:none;padding:.6rem .5rem;font-size:.9rem;background:transparent}.search-icon{color:#9ca3af;font-size:1rem}.clear-search{background:none;border:none;cursor:pointer;color:#9ca3af;font-size:1rem;padding:0 .25rem}.clear-search:hover{color:#374151}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.2rem;border-radius:8px;border:none;cursor:pointer;font-size:.875rem;font-weight:600;transition:background .15s,transform .1s}.btn:active{transform:scale(.97)}.btn-primary{background:#f59e0b;color:#fff}.btn-primary:hover{background:#d97706}.btn-secondary{background:#f1f5f9;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover{background:#e2e8f0}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover{background:#b91c1c}.table-wrapper{overflow-x:auto;border-radius:12px;box-shadow:0 1px 4px #00000014;-webkit-overflow-scrolling:touch}.table-wrapper::-webkit-scrollbar{height:5px}.table-wrapper::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.table-wrapper::-webkit-scrollbar-thumb{background:#c4b5fd;border-radius:4px}.table-wrapper::-webkit-scrollbar-thumb:hover{background:#3d007a}.emp-table{width:100%;border-collapse:collapse;background:#fff;font-size:.875rem}.emp-table thead tr{background:#160038;color:#fff}.emp-table th{padding:.85rem 1rem;text-align:left;font-weight:600;white-space:nowrap;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}.emp-table td{padding:.75rem 1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.emp-table tbody tr:hover{background:#f8fafc}.emp-table tbody tr:last-child td{border-bottom:none}.emp-name{font-weight:600;color:#1e293b}.emp-sub{font-size:.75rem;color:#94a3b8;margin-top:1px;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.salary-cell{font-weight:600;color:#16a34a}.badge{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.badge.active{background:#dcfce7;color:#15803d}.badge.inactive{background:#fee2e2;color:#b91c1c}.action-btns{display:flex;gap:.4rem}.btn-icon{background:none;border:1px solid transparent;border-radius:6px;padding:.3rem .45rem;cursor:pointer;font-size:1rem;transition:background .15s}.btn-icon.edit:hover{background:#f5eeff;border-color:#d4aaff}.btn-icon.delete:hover{background:#fee2e2;border-color:#fca5a5}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:500;padding:1rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-box{background:#fff;border-radius:12px;padding:28px 28px 24px;width:100%;box-shadow:0 24px 64px #00000059;z-index:501}.modal{background:#fff;border-radius:16px;width:100%;max-width:820px;max-height:92vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000040;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0;background:#f8fafc}.modal-header h2{font-size:1.15rem;font-weight:700;color:#1e293b}.close-btn{background:none;border:none;cursor:pointer;font-size:1.1rem;color:#64748b;padding:.3rem;border-radius:6px;transition:background .15s}.close-btn:hover{background:#fee2e2;color:#dc2626}form{display:flex;flex-direction:column;overflow:hidden;flex:1}.form-sections{overflow-y:auto;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem}fieldset{border:1px solid #e2e8f0;border-radius:10px;padding:1rem 1.25rem}legend{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#3d007a;padding:0 .5rem}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.85rem;margin-top:.75rem}.form-group{display:flex;flex-direction:column;gap:.3rem}.form-group.full-width{grid-column:1 / -1}.form-group label{font-size:.8rem;font-weight:600;color:#374151}.form-group input,.form-group textarea{border:1px solid #d1d5db;border-radius:7px;padding:.5rem .75rem;font-size:.875rem;color:#1e293b;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit;background:#fafafa}.form-group input:focus,.form-group textarea:focus{border-color:#3d007a;box-shadow:0 0 0 3px #3d007a1f;background:#fff}.form-group textarea{resize:vertical}.req{color:#dc2626}.err{font-size:.75rem;color:#dc2626}.total-box{border:1px solid #d1d5db;border-radius:7px;padding:.5rem .75rem;font-size:.875rem;font-weight:700;color:#16a34a;background:#f0fdf4}.salary-total label{color:#16a34a}.modal-footer{padding:1rem 1.5rem;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;gap:.75rem;background:#f8fafc;flex-shrink:0}.form-label{display:block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#475569;margin-bottom:.35rem}.form-input{width:100%;padding:.5rem .75rem;border:1.5px solid #d1d5db;border-radius:8px;font-size:.875rem;color:#1e293b;background:#fff;outline:none;transition:border-color .18s,box-shadow .18s;font-family:inherit;box-sizing:border-box}.form-input:focus{border-color:#1b2a4a;box-shadow:0 0 0 3px #1b2a4a1f}.revise-meta-bar{display:grid;grid-template-columns:1fr 2fr;gap:1rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1.5px solid #e2e8f0;border-radius:12px;padding:1rem 1.25rem;margin-bottom:1.25rem;box-shadow:0 1px 4px #1b2a4a12}.confirm-dialog{background:#fff;border-radius:16px;padding:2rem;max-width:400px;width:100%;text-align:center;box-shadow:0 20px 60px #00000040}.confirm-icon{font-size:3rem;margin-bottom:1rem}.confirm-dialog p{font-size:.95rem;color:#374151;margin-bottom:1.5rem;line-height:1.6}.confirm-actions{display:flex;justify-content:center;gap:1rem}.state-box{background:#fff;border-radius:12px;padding:3rem;text-align:center;color:#94a3b8;box-shadow:0 1px 4px #00000014}.state-box svg{margin-bottom:1rem;stroke:#cbd5e1}.state-box p{font-size:.9rem}.state-box strong{color:#3d007a}.spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#f59e0b;border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 900px){.app-header{padding:.75rem 1.25rem;flex-wrap:wrap;gap:.6rem}.header-user{max-width:160px;font-size:.78rem}.app-header h1{font-size:1.15rem}.app-header p{display:none}.app-nav{padding:0 1rem}.app-nav-tab{padding:.65rem .9rem;font-size:.82rem}.app-main{padding:1rem}.stats-row{grid-template-columns:repeat(3,1fr)}.view-grid{grid-template-columns:1fr}.wizard-layout{flex-direction:column;gap:1rem}.wizard-sidebar{width:100%;flex-direction:row;padding:.85rem 1.25rem;gap:0;position:static;justify-content:space-between;border-radius:12px}.wizard-step{flex:1;flex-direction:column;align-items:center;gap:.35rem;padding:0}.wizard-step:not(:last-child):after{top:16px;left:calc(50% + 16px);width:calc(100% - 32px);height:2px;position:absolute}.wizard-step-label{font-size:.75rem;text-align:center}.wizard-body{padding:1.25rem}.wiz-grid{grid-template-columns:repeat(2,1fr)}.wiz-grid>[style*="span 3"],.wiz-grid>[style*="span 4"]{grid-column:span 2!important}.md-layout{flex-direction:column;gap:.85rem}.md-sidebar{width:100%;flex-direction:row;flex-wrap:nowrap;overflow-x:auto;gap:.35rem;padding:.75rem 1rem;position:static;border-radius:12px;-webkit-overflow-scrolling:touch}.md-sidebar-title{display:none}.md-tab{white-space:nowrap;flex-shrink:0}.md-content{min-height:unset}}@media (max-width: 640px){.app-header{padding:.65rem 1rem;flex-direction:column;align-items:stretch;gap:.5rem}.header-brand{justify-content:flex-start}.header-logo{height:34px}.app-header h1{font-size:1.05rem}.header-actions{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;align-items:center}.header-user{grid-column:1 / -1;max-width:100%;font-size:.76rem;text-align:center;background:#ffffff26;border-radius:6px;padding:.25rem .5rem}.header-actions .btn{width:100%;text-align:center;font-size:.8rem;padding:.45rem .5rem}.app-nav{padding:0 .5rem}.app-nav-tab{padding:.6rem .75rem;font-size:.8rem}.app-main{padding:.75rem}.stats-row{grid-template-columns:1fr;gap:.5rem;margin-bottom:1rem}.toolbar{flex-direction:column;align-items:stretch;gap:.6rem}.wiz-grid{grid-template-columns:1fr}.wiz-grid>*{grid-column:span 1!important}.wizard-body{padding:1rem}.wizard-footer{padding:.85rem 1rem}.wizard-footer-right{gap:.5rem}.wizard-footer-right .btn,.wizard-footer .btn-back{font-size:.8rem;padding:.5rem .9rem}.wizard-step-label{display:none}.addr-grid{padding:.75rem}.md-content{padding:1rem;border-radius:10px}.md-header{flex-direction:column;align-items:stretch;gap:.6rem}.md-header .btn{width:100%;justify-content:center}.md-form-wrap{max-width:100%}.md-form-body{grid-template-columns:1fr}.md-form-footer{flex-direction:column-reverse}.md-form-footer .btn{width:100%;justify-content:center}.table-wrapper{border-radius:8px}.emp-table th,.emp-table td{padding:.6rem .75rem;font-size:.8rem}.modal-overlay{padding:.5rem;align-items:flex-end}.modal{max-height:96vh;border-radius:16px 16px 0 0;max-width:100%}.view-modal{max-width:100%}.form-grid,.view-grid{grid-template-columns:1fr}.login-card{padding:2rem 1.25rem}.confirm-dialog{padding:1.5rem 1.25rem}.confirm-actions{flex-direction:column}.confirm-actions .btn{width:100%;justify-content:center}}.app-nav{background:#fff;border-bottom:1px solid #e2e8f0;padding:0 2rem;display:flex;gap:0}.app-nav-tab{padding:.75rem 1.25rem;border:none;background:transparent;font-size:.875rem;font-weight:600;color:#64748b;cursor:pointer;border-bottom:3px solid transparent;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:.4rem}.app-nav-tab:hover{color:#f59e0b}.app-nav-tab.active{color:#f59e0b;border-bottom-color:#f59e0b}.md-layout{display:flex;gap:1.5rem;align-items:flex-start;min-height:calc(100vh - 130px)}.md-sidebar{width:210px;flex-shrink:0;background:#fff;border-radius:14px;padding:1.25rem 1rem;box-shadow:0 1px 4px #00000014;display:flex;flex-direction:column;gap:.25rem;position:sticky;top:1.5rem}.md-sidebar-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8;padding:0 .5rem;margin-bottom:.5rem}.portal-config-panel{max-width:680px}.portal-config-title{font-size:1.15rem;font-weight:700;color:#1e293b;margin:0 0 .35rem}.portal-config-desc{font-size:.85rem;color:#64748b;margin:0 0 1.5rem}.portal-config-list{display:flex;flex-direction:column;gap:0;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.portal-config-row{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:#fff;gap:1rem}.portal-config-row+.portal-config-row{border-top:1px solid #f1f5f9}.portal-config-info{display:flex;align-items:center;gap:.85rem;flex:1}.portal-config-icon{font-size:1.4rem}.portal-config-name{font-size:.9rem;font-weight:600;color:#1e293b}.portal-config-hint{font-size:.78rem;color:#64748b;margin-top:2px}.toggle-switch{position:relative;display:inline-block;width:48px;height:26px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background:#cbd5e1;border-radius:34px;transition:background .2s}.toggle-slider:before{content:"";position:absolute;height:20px;width:20px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-slider{background:#22c55e}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.toggle-switch input:disabled+.toggle-slider{opacity:.6;cursor:not-allowed}.md-tab{display:flex;align-items:center;gap:.6rem;padding:.6rem .75rem;border-radius:8px;border:none;background:transparent;font-size:.875rem;font-weight:500;color:#374151;cursor:pointer;text-align:left;transition:background .15s,color .15s}.md-tab:hover{background:#f1f5f9;color:#d97706}.md-tab.active{background:#faf5ff;color:#3d007a;font-weight:700}.md-tab-icon{font-size:1rem}.md-group-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;padding:.6rem .75rem .2rem;margin-top:.35rem}.md-content{flex:1;min-width:0;background:#fff;border-radius:14px;padding:1.5rem;box-shadow:0 1px 4px #00000014;min-height:400px;overflow:hidden}.md-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.25rem;gap:1rem}.md-title{font-size:1.15rem;font-weight:700;color:#1e293b;margin-bottom:.2rem}.md-subtitle{font-size:.8rem;color:#94a3b8}.md-toolbar{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.md-toolbar .search-box{flex:1}.md-add-btn{white-space:nowrap;flex-shrink:0}.md-form-wrap{max-width:760px}.md-form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.md-form-body{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.md-form-body .form-group.full-width{grid-column:1 / -1}.md-form-footer{display:flex;gap:.75rem;justify-content:flex-end}.state-box{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:#94a3b8;gap:.75rem;font-size:.9rem}.state-box.empty{color:#64748b}.spinner{width:28px;height:28px;border:3px solid #e2e8f0;border-top-color:#f59e0b;border-radius:50%;animation:spin .7s linear infinite}@media (max-width: 900px){.md-layout{flex-direction:column;gap:.85rem}.md-sidebar{width:100%;flex-direction:row;flex-wrap:nowrap;overflow-x:auto;gap:.35rem;padding:.75rem 1rem;position:static;border-radius:12px;-webkit-overflow-scrolling:touch}.md-sidebar-title,.md-group-label{display:none}.md-tab{white-space:nowrap;flex-shrink:0}.md-content{min-height:unset}}.md-content{padding:1rem;border-radius:10px}.md-add-btn{padding:.5rem .75rem;font-size:.8rem}.md-form-wrap{max-width:100%}.md-form-footer{flex-direction:column-reverse}.md-form-footer .btn{width:100%;justify-content:center}} .portal-access-box{margin-top:1.5rem;padding:1.25rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;grid-column:1 / -1}.portal-access-toggle{display:flex;align-items:center;gap:.75rem;font-weight:600;cursor:pointer;font-size:.95rem}.portal-credentials{margin-top:1rem;display:flex;flex-direction:column;gap:.6rem}.portal-cred-row{display:flex;align-items:center;gap:.75rem}.portal-cred-label{font-size:.8rem;color:#64748b;font-weight:600;min-width:80px}.portal-cred-value{font-family:monospace;font-size:.95rem;background:#fff;padding:.3rem .6rem;border-radius:6px;border:1px solid #d1fae5}.portal-cred-note{font-size:.75rem;color:#16a34a;margin-top:.25rem}.btn-regen{font-size:.75rem;padding:.2rem .55rem;border-radius:6px;border:1px solid #16a34a;background:#fff;color:#16a34a;cursor:pointer}.btn-regen:hover{background:#f0fdf4}.portal-modules-box{margin-top:1rem;padding:.85rem 1rem;background:#fff;border:1px solid #d1fae5;border-radius:8px}.portal-modules-label{font-size:.8rem;font-weight:600;color:#15803d;margin:0 0 .55rem}.portal-modules-grid{display:flex;flex-wrap:wrap;gap:.5rem 1.5rem}.portal-module-toggle{display:flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:500;cursor:pointer;color:#1e293b}.portal-module-toggle input{accent-color:#16a34a;width:15px;height:15px}.portal-modules-view{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.6rem}.mod-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:600;padding:.2rem .55rem;border-radius:20px}.mod-badge.on{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}.mod-badge.off{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca;text-decoration:line-through;opacity:.7}.login-tabs{display:flex;margin:1rem 0 .25rem;border-bottom:2px solid #e2e8f0}.login-tab{flex:1;padding:.65rem;border:none;background:transparent;font-weight:600;font-size:.85rem;color:#64748b;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .15s}.login-tab.active{color:#f59e0b;border-bottom-color:#f59e0b}.login-tab:hover:not(.active){color:#334155}.login-form{display:flex;flex-direction:column;gap:.85rem;margin-top:.75rem}.btn-checkin{background:#0891b2;color:#fff;border:none;border-radius:8px;padding:.45rem 1rem;font-weight:600;cursor:pointer;font-size:.85rem;transition:background .15s}.btn-checkin:hover{background:#0e7490}.checkin-modal{width:640px;max-width:95vw;max-height:80vh;display:flex;flex-direction:column}.checkin-list{overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;padding-right:.25rem}.checkin-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#f8fafc;border-radius:10px;gap:1rem}.checkin-info{display:flex;flex-direction:column;gap:.15rem}.checkin-name{font-weight:600;font-size:.95rem}.checkin-dept{font-size:.75rem;color:#64748b}.checkin-status{display:flex;align-items:center;gap:.5rem;flex-shrink:0;flex-wrap:wrap}.btn-sm{padding:.3rem .75rem;font-size:.8rem;border-radius:6px;border:none;cursor:pointer;font-weight:600}.btn-checkin-btn{background:#22c55e;color:#fff}.btn-checkin-btn:hover{background:#16a34a}.btn-checkout{background:#f59e0b;color:#fff}.btn-checkout:hover{background:#d97706}.badge{display:inline-block;padding:.2rem .55rem;border-radius:6px;font-size:.75rem;font-weight:600}.badge-in{background:#dcfce7;color:#15803d}.badge-out{background:#fef3c7;color:#92400e}.att-page{display:flex;flex-direction:column;gap:1.25rem}.att-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.att-title{margin:0;font-size:1.3rem}.att-controls{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.att-date-input{padding:.4rem .6rem;border:1px solid #d1d5db;border-radius:8px;font-size:.9rem}.att-search{padding:.4rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.9rem;width:200px}.att-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.att-stat{border-radius:14px;padding:1.1rem 1.25rem;display:flex;flex-direction:column;align-items:center;gap:.2rem;border:1.5px solid transparent;position:relative;overflow:hidden}.att-stat-present{background:linear-gradient(135deg,#dcfce7,#f0fdf4);border-color:#86efac}.att-stat-duty{background:linear-gradient(135deg,#fef9c3,#fffbeb);border-color:#fde68a}.att-stat-done{background:linear-gradient(135deg,#f5eeff,#faf5ff);border-color:#d4aaff}.stat-icon{font-size:1.2rem;margin-bottom:.1rem}.stat-num{font-size:2rem;font-weight:800;color:#1e293b;line-height:1}.att-stat-present .stat-num{color:#15803d}.att-stat-duty .stat-num{color:#92400e}.att-stat-done .stat-num{color:#2a0060}.stat-lbl{font-size:.72rem;color:#64748b;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.att-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.att-card{background:#fff;border-radius:14px;border:1.5px solid #e2e8f0;overflow:hidden;box-shadow:0 2px 8px #0000000f;transition:box-shadow .15s}.att-card:hover{box-shadow:0 6px 20px #0000001a}.att-card-duty{border-top:3px solid #f59e0b}.att-card-done{border-top:3px solid #22c55e}.att-card-header{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem .75rem;border-bottom:1px solid #f1f5f9;background:#f8fafc}.att-card-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#3d007a,#5200a0);color:#fff;font-weight:800;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.att-card-info{flex:1;min-width:0}.att-card-name{font-weight:700;font-size:.92rem;color:#1e293b;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.att-card-badge{font-size:.7rem;font-weight:700;border-radius:20px;padding:.22rem .7rem;white-space:nowrap}.badge-on-duty{background:#fef9c3;color:#92400e;border:1px solid #fde68a}.badge-done{background:#dcfce7;color:#15803d;border:1px solid #86efac}.att-card-sessions{padding:.65rem 1rem;display:flex;flex-direction:column;gap:.4rem}.att-no-sessions{font-size:.8rem;color:#94a3b8;font-style:italic}.att-session-row{display:flex;align-items:center;gap:.4rem;font-size:.8rem;padding:.3rem .5rem;border-radius:8px;background:#f8fafc;border:1px solid #e2e8f0}.att-session-row.session-ongoing{background:#fffbeb;border-color:#fde68a}.sess-num{font-size:.68rem;color:#94a3b8;min-width:58px;font-weight:600}.sess-in{color:#15803d;font-weight:700;font-family:monospace}.sess-arrow{color:#94a3b8}.sess-out{color:#b45309;font-weight:700;font-family:monospace}.sess-dur{margin-left:auto;color:#64748b;font-size:.72rem}.sess-live{margin-left:auto;color:#f59e0b;font-weight:700;font-size:.72rem;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.att-card-footer{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;border-top:1px solid #f1f5f9;background:#f8fafc}.att-total-label{font-size:.72rem;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.att-total-val{font-size:.92rem;font-weight:800;color:#1e293b}.self-portal{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem;padding:1rem 0}.self-profile-card{background:linear-gradient(135deg,#160038,#1a0042);color:#fff;border-radius:16px;padding:1.5rem 1.75rem;display:flex;align-items:center;gap:1.25rem;border-bottom:3px solid #f59e0b}.self-avatar{width:64px;height:64px;border-radius:50%;background:#ffffff40;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:700;flex-shrink:0;border:2px solid rgba(255,255,255,.4)}.self-card-body{display:flex;flex-direction:column;gap:.55rem}.self-name{margin:0;font-size:1.25rem;font-weight:700;letter-spacing:.01em}.self-card-chips{display:flex;flex-wrap:wrap;gap:.45rem}.self-card-chip{display:inline-flex;align-items:center;gap:.3rem;background:#ffffff2e;border:1px solid rgba(255,255,255,.3);border-radius:20px;padding:.22rem .65rem;font-size:.76rem;font-weight:500;color:#fff;white-space:nowrap}.self-meta{margin:.15rem 0 0;font-size:.85rem;opacity:.85}.self-today-card{background:#fff;border-radius:16px;padding:1.5rem;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000f}.self-today-card h3{margin:0 0 1rem;display:flex;align-items:center;gap:.75rem;font-size:1rem}.self-date{font-weight:400;color:#64748b;font-size:.85rem}.self-today-info{display:flex;flex-direction:column;gap:.6rem}.self-time-row{display:flex;align-items:center;gap:.75rem}.self-time-label{font-size:.8rem;font-weight:600;color:#64748b;min-width:80px}.self-time-value{font-size:.95rem;font-weight:600}.self-done-msg{margin:.5rem 0 0;color:#15803d;font-size:.9rem;font-weight:600}.self-checkin-prompt{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1rem 0}.self-checkin-prompt p{color:#64748b;margin:0}.self-checkin-btn,.self-checkout-btn{padding:.65rem 2rem;font-size:1rem;border-radius:10px;font-weight:700}.self-ci-bar{display:flex;align-items:stretch;gap:.65rem;flex-wrap:wrap;margin-bottom:.25rem}.self-ci-chip{flex:1;min-width:120px;display:flex;align-items:center;gap:.7rem;background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;padding:.75rem 1rem;box-shadow:0 1px 4px #0000000d}.self-ci-icon-wrap{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.self-ci-green{background:#dcfce7;color:#16a34a}.self-ci-orange{background:#ffedd5;color:#ea580c}.self-ci-info{display:flex;flex-direction:column}.self-ci-label{font-size:.7rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em}.self-ci-time{font-size:.98rem;font-weight:700;color:#1e293b;margin-top:.1rem}.self-stop-btn{flex:1;min-width:150px;display:flex;align-items:center;justify-content:center;gap:.4rem;background:#ef4444;color:#fff;border:none;border-radius:14px;padding:.75rem 1rem;font-size:.95rem;font-weight:700;cursor:pointer;transition:background .15s}.self-stop-btn:hover{background:#dc2626}.self-stop-sq{font-size:1.1rem;line-height:1}.self-stop-clock{font-size:.88rem;opacity:.85}.self-stop-timer{font-family:Courier New,monospace;font-size:1rem;letter-spacing:.06em}.self-checkin-action-btn{flex:1;min-width:130px;display:flex;align-items:center;justify-content:center;gap:.45rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:14px;padding:.75rem 1rem;font-size:.92rem;font-weight:700;cursor:pointer;transition:opacity .15s}.self-checkin-action-btn:hover{opacity:.88}.self-sessions-toggle-btn{width:100%;display:flex;align-items:center;justify-content:space-between;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;padding:.5rem .9rem;font-size:.8rem;font-weight:600;color:#475569;cursor:pointer;margin-top:.75rem;transition:background .15s}.self-sessions-toggle-btn:hover{background:#f1f5f9}.self-toggle-total{background:#f5eeff;color:#2a0060;padding:.18rem .55rem;border-radius:20px;font-size:.76rem;font-weight:700}.self-history{background:#fff;border-radius:16px;padding:1.5rem;border:1px solid #e2e8f0}.self-history h3{margin:0 0 1rem;font-size:1rem}.self-tab-nav{display:flex;gap:.65rem;background:transparent;padding:0}.self-tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;padding:.9rem .5rem .75rem;border:1.5px solid #e2e8f0;background:#fff;border-radius:14px;font-size:.78rem;font-weight:600;color:#94a3b8;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000000a;position:relative;overflow:hidden}.self-tab-btn .stab-icon{font-size:1.4rem;line-height:1;transition:transform .2s}.self-tab-btn .stab-label{font-size:.75rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.self-tab-btn:hover{border-color:#f59e0b;color:#160038;background:#fffbeb;transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b33}.self-tab-btn:hover .stab-icon{transform:scale(1.15)}.self-tab-active{background:linear-gradient(135deg,#f59e0b,#d97706)!important;border-color:transparent!important;color:#fff!important;box-shadow:0 6px 20px #f59e0b66!important;transform:translateY(-2px)}.self-tab-active .stab-label{color:#fff}.self-tab-active:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:36px;height:3px;background:#ffffff80;border-radius:3px 3px 0 0}.sp-profile-sections{display:flex;flex-direction:column;gap:1rem}.sp-section{background:#fff;border-radius:14px;padding:1.25rem 1.5rem;border:1px solid #e2e8f0;box-shadow:0 1px 4px #0000000a}.sp-section-title{margin:0 0 1rem;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#160038;border-bottom:2px solid #f59e0b;padding-bottom:.5rem}.sp-sal-summary-cards{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.2rem}.sp-sal-card{flex:1;min-width:140px;border-radius:10px;padding:.9rem 1rem;text-align:center}.sp-sal-card-gross{background:#eff6ff;border:1px solid #bfdbfe}.sp-sal-card-take{background:#f0fdf4;border:1px solid #86efac}.sp-sal-card-ctc{background:#eef2ff;border:1px solid #a5b4fc}.sp-sal-card-val{font-size:1.15rem;font-weight:700;color:#1e293b}.sp-sal-card-gross .sp-sal-card-val{color:#1d4ed8}.sp-sal-card-take .sp-sal-card-val{color:#15803d}.sp-sal-card-ctc .sp-sal-card-val{color:#4338ca}.sp-sal-card-lbl{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin-top:.2rem}.sp-sal-tables{display:flex;gap:1.2rem;flex-wrap:wrap;margin-bottom:.8rem}.sp-sal-table-wrap{flex:1;min-width:240px}.sp-sal-table-title{font-size:.75rem;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem}.sp-sal-table{width:100%;border-collapse:collapse;font-size:.82rem}.sp-sal-table th{background:#1b2a4a;color:#fff;padding:.4rem .6rem;text-align:left;font-size:.75rem}.sp-sal-table td{padding:.38rem .6rem;border-bottom:1px solid #f1f5f9;color:#374151}.sp-sal-table td:last-child{text-align:right;font-variant-numeric:tabular-nums}.sp-sal-table th:last-child{text-align:right}.sp-sal-total-row td{background:#f8fafc;font-weight:700;color:#1e293b;border-top:2px solid #e2e8f0}.sp-sal-note{font-size:.75rem;color:#64748b;margin-top:.4rem}.sp-info-grid{display:flex;flex-direction:column;gap:0}.sp-info-row{display:flex;align-items:baseline;gap:.5rem;padding:.45rem 0;border-bottom:1px solid #f1f5f9}.sp-info-row:last-child{border-bottom:none}.sp-info-label{min-width:150px;font-size:.78rem;font-weight:600;color:#94a3b8;flex-shrink:0}.sp-info-value{font-size:.88rem;font-weight:500;color:#1e293b;word-break:break-word}.sp-security-card{background:#fff;border-radius:14px;padding:1.75rem 1.5rem;border:1px solid #e2e8f0;box-shadow:0 1px 4px #0000000a;max-width:440px}.sp-security-title{margin:0 0 .3rem;font-size:1.05rem;font-weight:700;color:#1e293b}.sp-security-sub{margin:0 0 1.5rem;font-size:.83rem;color:#64748b}.sp-pw-form{display:flex;flex-direction:column;gap:1.1rem}.sp-pw-field{display:flex;flex-direction:column;gap:.35rem}.sp-pw-field label{font-size:.8rem;font-weight:600;color:#475569}.sp-pw-input-wrap{position:relative;display:flex;align-items:center}.sp-pw-input-wrap input{width:100%;padding:.62rem 2.5rem .62rem .85rem;border:1.5px solid #e2e8f0;border-radius:9px;font-size:.9rem;outline:none;transition:border-color .15s;box-sizing:border-box}.sp-pw-input-wrap input:focus{border-color:#f59e0b}.sp-pw-eye{position:absolute;right:.65rem;background:none;border:none;cursor:pointer;font-size:1rem;line-height:1;padding:0;color:#94a3b8}.sp-pw-submit-btn{margin-top:.5rem;padding:.7rem 1.5rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:10px;font-size:.9rem;font-weight:700;cursor:pointer;transition:opacity .15s;align-self:flex-start}.sp-pw-submit-btn:hover{opacity:.88}.sp-pw-submit-btn:disabled{opacity:.6;cursor:not-allowed}.self-month-section{background:#fff;border-radius:16px;padding:1.25rem 1.5rem;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000d}.self-month-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.self-month-title{margin:0;font-size:1.05rem;font-weight:700;color:#1e293b}.btn-view-calendar{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:10px;padding:.45rem 1rem;font-size:.82rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-view-calendar:hover{opacity:.88}.self-month-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.85rem}.self-mstat{border-radius:12px;padding:1rem .75rem;display:flex;flex-direction:column;align-items:center;gap:.2rem;border:1.5px solid transparent}.self-mstat-work{background:linear-gradient(135deg,#faf5ff,#f5eeff);border-color:#d4aaff}.self-mstat-present{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#86efac}.self-mstat-absent{background:linear-gradient(135deg,#fff7ed,#fed7aa);border-color:#fdba74}.self-mstat-num{font-size:2.2rem;font-weight:800;line-height:1}.self-mstat-work .self-mstat-num{color:#2a0060}.self-mstat-present .self-mstat-num{color:#15803d}.self-mstat-absent .self-mstat-num{color:#c2410c}.self-mstat-lbl{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b}.loading-msg{text-align:center;color:#94a3b8;padding:2rem 0}.portal-section{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px}.portal-cred-view{display:flex;flex-direction:column;gap:.6rem}.portal-cred-input{padding:.3rem .6rem;border:1px solid #16a34a;border-radius:6px;font-size:.9rem;font-family:monospace;width:180px}.btn-icon{background:none;border:none;cursor:pointer;font-size:1rem;padding:.1rem .25rem;line-height:1}.att-mgmt-modal{width:960px;max-width:96vw;max-height:90vh;display:flex;flex-direction:column;background:#fff;border-radius:18px;overflow:hidden;padding:0;box-shadow:0 20px 60px #0000002e}.att-mgmt-modal .modal-header{background:linear-gradient(135deg,#1a0042,#3d007a);padding:1.15rem 1.6rem;border-bottom:none}.att-mgmt-modal .modal-header h2{color:#fff;font-size:1.35rem;margin:0}.att-mgmt-modal .btn-close{background:#ffffff2e;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:8px;width:34px;height:34px;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.att-mgmt-modal .btn-close:hover{background:#ffffff52}.att-mgmt-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding:.85rem 1.25rem;border-bottom:1px solid #e2e8f0;background:#f8fafc}.att-mgmt-stats{display:flex;gap:.5rem;margin-left:auto;flex-wrap:wrap}.att-mini-stat{padding:.3rem .8rem;border-radius:20px;font-size:.78rem;font-weight:700;display:flex;align-items:center;gap:.3rem;border:1.5px solid transparent}.att-mini-stat.present{background:#dcfce7;color:#15803d;border-color:#86efac}.att-mini-stat.duty{background:#fef9c3;color:#92400e;border-color:#fde68a}.att-mini-stat.absent{background:#fee2e2;color:#b91c1c;border-color:#fca5a5}.att-mgmt-table-wrap{overflow:auto;flex:1;background:#fff}.att-mgmt-table{width:100%;border-collapse:collapse;font-size:.88rem}.att-mgmt-table th{background:#0f172a;color:#94a3b8;padding:.7rem 1rem;text-align:left;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;position:sticky;top:0;z-index:1}.att-mgmt-table td{padding:.65rem 1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.att-mgmt-table tr.row-present{background:#fff}.att-mgmt-table tr.row-absent{background:#fafafa}.att-mgmt-table tr:hover td{background:#faf5ff}.att-emp-name-btn{background:none;border:none;color:#3d007a;font-weight:600;font-size:.88rem;cursor:pointer;padding:0;text-align:left;display:block}.att-emp-name-btn:hover{text-decoration:underline}.att-emp-dept{display:block;font-size:.73rem;color:#94a3b8;margin-top:.1rem}.att-time-input{padding:.25rem .4rem;border:1px solid #5200a0;border-radius:6px;font-size:.85rem;width:110px}.time-val{font-weight:600;color:#0f172a;font-family:monospace}.time-empty{color:#cbd5e1}.dur-val{font-size:.8rem;color:#475569}.att-actions{display:flex;gap:.35rem;align-items:center;flex-wrap:wrap}.btn-edit-att{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.btn-edit-att:hover{background:#e2e8f0}.btn-cal-att{background:#faf5ff;color:#3d007a;border:1px solid #eedeff}.btn-cal-att:hover{background:#f5eeff}.badge-absent{background:#fee2e2;color:#b91c1c}.att-cal-modal{width:960px;max-width:98vw;max-height:93vh;display:flex;flex-direction:column;background:#fff;color:#1e293b;border-radius:20px;overflow:hidden;padding:0;box-shadow:0 20px 60px #0000002e}.att-cal-modal .modal-header{background:linear-gradient(135deg,#1a0042,#3d007a);padding:1.25rem 1.75rem;border-bottom:none}.att-cal-modal .modal-header h2{color:#fff;font-size:1.4rem;margin:0}.att-cal-modal .btn-close{background:#ffffff2e;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:8px;width:34px;height:34px;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.att-cal-modal .btn-close:hover{background:#ffffff52}.att-cal-subtitle{margin:.25rem 0 0;font-size:.85rem;color:#ffffffbf}.att-cal-nav{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:.6rem 1.25rem .5rem;background:#f8fafc;border-bottom:1px solid #e2e8f0}.btn-cal-nav{background:#fff;border:1.5px solid #cbd5e1;border-radius:10px;width:38px;height:38px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#1e293b;font-weight:700;transition:all .15s;box-shadow:0 1px 3px #00000014}.btn-cal-nav:hover{background:#3d007a;color:#fff;border-color:#3d007a}.att-cal-month{font-size:1.3rem;font-weight:800;min-width:200px;text-align:center;color:#1e293b;letter-spacing:.01em}.att-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;padding:.4rem .75rem;overflow:visible;flex:1;background:#f8fafc}.att-cal-day-header{text-align:center;font-size:.68rem;font-weight:800;color:#64748b;padding:.25rem 0;text-transform:uppercase;letter-spacing:.08em}.att-cal-day-header:first-child,.att-cal-day-header:last-child{color:#ef4444}.att-cal-cell{border-radius:7px;padding:.28rem .3rem;height:62px;min-height:62px;max-height:62px;background:#fff;border:1.5px solid #e2e8f0;display:flex;flex-direction:column;gap:.1rem;position:relative;overflow:visible;transition:box-shadow .15s;cursor:default}.att-cal-cell:not(.empty):hover{box-shadow:0 4px 16px #00000021;z-index:10}.att-cal-cell.empty{background:transparent;border-color:transparent}.att-cal-cell.has-record{background:#f0fdf4;border-color:#4ade80;border-left:4px solid #16a34a}.att-cal-cell.is-today{background:#faf5ff;border-color:#96c;border-left:4px solid #3d007a;box-shadow:0 0 0 2px #3d007a33}.att-cal-cell.is-weekend{background:#fff7ed;border-color:#fdba74;border-left:4px solid #f97316}.att-cal-cell.is-weekend.has-record{background:#fef3c7;border-color:#fbbf24;border-left:4px solid #d97706}.att-cal-cell.is-future{background:#f8fafc;opacity:.5}.att-cal-cell.is-absent{background:#f1f5f9;border-color:#cbd5e1}.att-cal-date{font-size:.75rem;font-weight:700;color:#334155}.is-today .att-cal-date{background:#3d007a;color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:.68rem;box-shadow:0 2px 6px #3d007a66}.is-weekend .att-cal-date{color:#c2410c}.att-cal-times{display:flex;flex-direction:column;gap:.08rem;margin-top:.1rem}.att-cal-in{font-size:.6rem;color:#15803d;font-weight:600;background:#dcfce7;border-radius:3px;padding:.02rem .25rem;display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.att-cal-dur{font-size:.58rem;color:#64748b;margin-top:.05rem;font-weight:500}.att-cal-absent{font-size:.85rem;color:#cbd5e1;line-height:1;margin-top:.15rem}.cal-status-badge{display:inline-block;font-size:.58rem;font-weight:700;border-radius:4px;padding:.08rem .3rem;margin-top:.1rem;letter-spacing:.03em;text-transform:uppercase;width:fit-content}.cal-status-present{background:#dcfce7;color:#15803d}.cal-status-absent{background:#f1f5f9;color:#94a3b8}.cal-status-holiday{background:#fff7ed;color:#c2410c}.att-cal-tooltip{display:none;position:absolute;bottom:calc(100% + 8px);top:auto;left:50%;transform:translate(-50%);background:#1e293b;color:#f1f5f9;border-radius:10px;padding:.65rem .85rem;min-width:190px;max-width:240px;z-index:200;box-shadow:0 8px 24px #00000047;font-size:.72rem;pointer-events:none;white-space:nowrap}.att-cal-tooltip:before{content:"";position:absolute;bottom:-5px;top:auto;left:50%;transform:translate(-50%);border-width:5px 5px 0;border-style:solid;border-color:#1e293b transparent transparent}.att-cal-grid>.att-cal-cell:nth-child(-n+21) .att-cal-tooltip{bottom:auto;top:calc(100% + 8px)}.att-cal-grid>.att-cal-cell:nth-child(-n+21) .att-cal-tooltip:before{bottom:auto;top:-5px;border-width:0 5px 5px;border-color:transparent transparent #1e293b}.att-cal-cell:not(.empty):hover .att-cal-tooltip{display:block}.att-cal-tooltip-date{font-size:.65rem;color:#94a3b8;margin-bottom:.4rem;font-weight:600}.att-cal-tooltip-row{display:flex;align-items:center;gap:.35rem;margin-bottom:.25rem}.tip-session{color:#94a3b8;font-size:.65rem;min-width:56px}.tip-in{color:#4ade80;font-weight:700}.tip-out{color:#fbbf24;font-weight:700}.tip-ongoing{color:#96c;font-style:italic}.tip-dur{color:#94a3b8;font-size:.65rem;margin-left:auto}.att-cal-tooltip-total{border-top:1px solid rgba(255,255,255,.1);margin-top:.3rem;padding-top:.3rem;color:#e2e8f0;font-size:.7rem}.tip-no-rec{color:#64748b;font-style:italic}.att-cal-legend{display:flex;gap:1.5rem;padding:.75rem 1.5rem;font-size:.8rem;color:#475569;border-top:1px solid #e2e8f0;background:#fff;margin-top:0}.legend-item{display:flex;align-items:center;gap:.45rem;font-weight:500}.legend-dot{width:12px;height:12px;border-radius:4px}.legend-dot.present{background:#4ade80;border-left:3px solid #16a34a}.legend-dot.absent{background:#f1f5f9;border:1.5px solid #cbd5e1}.legend-dot.weekend{background:#fdba74;border-left:3px solid #f97316}.yearly-att{display:flex;flex-direction:column;gap:1.5rem;padding:.25rem 0}.yearly-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.yearly-title{margin:0;font-size:1.35rem;font-weight:800;color:#1e293b}.yearly-year-nav{display:flex;align-items:center;gap:.75rem;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;padding:.35rem .75rem;box-shadow:0 1px 4px #0000000f}.yearly-year{font-size:1.2rem;font-weight:800;color:#1e293b;min-width:52px;text-align:center}.btn-yr-nav{background:none;border:none;cursor:pointer;font-size:1.3rem;font-weight:700;color:#3d007a;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .15s}.btn-yr-nav:hover{background:#faf5ff}.btn-yr-nav:disabled{color:#cbd5e1;cursor:default}.yr-month-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.85rem}.yr-month-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;padding:1rem 1rem .75rem;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;gap:.4rem;box-shadow:0 1px 4px #0000000d;position:relative;overflow:hidden}.yr-month-card:hover:not(.yr-month-future){box-shadow:0 4px 16px #3d007a1f;border-color:#d4aaff;transform:translateY(-2px)}.yr-month-card.yr-month-has-data{border-color:#86efac;background:#f0fdf4}.yr-month-card.yr-month-selected{border-color:#f59e0b;background:#fffbeb;box-shadow:0 4px 16px #f59e0b33}.yr-month-card.yr-month-current{border-color:#96c}.yr-month-card.yr-month-future{opacity:.45;cursor:default}.yr-month-name{font-size:1rem;font-weight:800;color:#1e293b}.yr-month-card.yr-month-selected .yr-month-name{color:#f59e0b}.yr-month-card.yr-month-has-data .yr-month-name{color:#15803d}.yr-month-stats{display:flex;gap:.35rem;flex-wrap:wrap}.yr-stat-pill{font-size:.68rem;font-weight:700;border-radius:20px;padding:.12rem .5rem}.yr-pill-days{background:#dcfce7;color:#15803d}.yr-pill-emps{background:#f5eeff;color:#2a0060}.yr-month-future-lbl,.yr-month-empty-lbl{font-size:.72rem;color:#94a3b8;font-style:italic}.yr-month-bar-wrap{width:100%;height:4px;background:#e2e8f0;border-radius:2px;overflow:hidden;margin-top:.25rem}.yr-month-bar{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:2px;transition:width .4s ease}.yr-month-card.yr-month-selected .yr-month-bar{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.yr-month-detail{background:#fff;border:1.5px solid #e2e8f0;border-radius:16px;overflow:hidden;box-shadow:0 4px 16px #00000012}.yr-detail-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:linear-gradient(135deg,#1a0042,#3d007a)}.yr-detail-title{margin:0;font-size:1.05rem;font-weight:700;color:#fff}.btn-yr-close{background:#ffffff2e;border:none;color:#fff;border-radius:8px;width:30px;height:30px;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.btn-yr-close:hover{background:#ffffff52}.yr-emp-table{width:100%;border-collapse:collapse;font-size:.87rem}.yr-emp-table th{background:#0f172a;color:#94a3b8;padding:.65rem 1rem;text-align:left;font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}.yr-emp-table td{padding:.65rem 1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.yr-emp-table tr:last-child td{border-bottom:none}.yr-emp-table tr:hover td{background:#f8fafc}.yr-row-absent td{background:#fafafa}.yr-emp-cell{display:flex;align-items:center;gap:.6rem}.yr-emp-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#3d007a,#5200a0);color:#fff;font-weight:800;font-size:.85rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.yr-emp-name{font-weight:600;color:#1e293b}.yr-dept,.yr-wdays{color:#64748b;font-size:.82rem}.yr-total-hrs{font-weight:600;color:#1e293b;font-size:.82rem}.yr-present-badge{font-size:.75rem;font-weight:700;border-radius:20px;padding:.2rem .65rem}.badge-present-days{background:#dcfce7;color:#15803d}.badge-absent-days{background:#fee2e2;color:#b91c1c}.yr-pct-wrap{display:flex;align-items:center;gap:.5rem}.yr-pct-bar-bg{flex:1;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.yr-pct-bar{height:100%;border-radius:4px;transition:width .4s ease}.pct-good{background:linear-gradient(90deg,#22c55e,#16a34a)}.pct-ok{background:linear-gradient(90deg,#f59e0b,#d97706)}.pct-low{background:linear-gradient(90deg,#ef4444,#b91c1c)}.yr-pct-num{font-size:.75rem;font-weight:700;color:#475569;min-width:32px}.btn-yr-cal{background:#faf5ff;color:#3d007a;border:1px solid #eedeff;border-radius:8px;padding:.3rem .55rem;cursor:pointer;font-size:.85rem;transition:background .15s}.btn-yr-cal:hover{background:#f5eeff}.sessions-summary{display:flex;flex-wrap:wrap;gap:.35rem}.session-chip{display:inline-flex;align-items:center;gap:.2rem;background:#f1f5f9;border-radius:20px;padding:.15rem .5rem;font-size:.75rem;white-space:nowrap}.chip-in{color:#15803d;font-weight:600}.chip-arrow{color:#94a3b8}.chip-out{color:#b45309;font-weight:600}.chip-ongoing{color:#3d007a;font-weight:600;font-style:italic}.session-edit-row td{background:#f8fafc;padding:0!important}.session-editor{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.5rem;border-top:2px solid #e2e8f0}.session-editor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.session-edit-row-inner{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.4rem .5rem;background:#fff;border-radius:8px;border:1px solid #e2e8f0}.session-num{font-size:.75rem;font-weight:700;color:#64748b;min-width:2rem}.session-edit-label{font-size:.75rem;color:#64748b;font-weight:600}.session-editor-footer{display:flex;align-items:center;gap:.75rem;padding-top:.35rem;border-top:1px solid #e2e8f0;margin-top:.25rem}.self-sessions{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.self-session-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.5rem .75rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.self-session-num{font-size:.75rem;font-weight:700;color:#64748b;min-width:65px}.self-dur{font-size:.78rem;color:#64748b;margin-left:.35rem}.badge-ongoing{background:#faf5ff;color:#3d007a;border-radius:6px;padding:.2rem .5rem;font-size:.75rem;font-weight:600}.self-total-row{display:flex;align-items:center;gap:.75rem;padding:.4rem .75rem}.self-total-dur{color:#200050;font-size:1rem}.self-action-row{display:flex;gap:1rem;justify-content:center;margin-top:.5rem}.inv-subnav{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid #e2e8f0;padding-bottom:0}.inv-subnav-btn{padding:.55rem 1.2rem;border:none;background:transparent;font-size:.9rem;font-weight:600;color:#64748b;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;border-radius:6px 6px 0 0;transition:color .15s,border-color .15s}.inv-subnav-btn:hover{color:#3d007a}.inv-subnav-btn.active{color:#3d007a;border-bottom-color:#3d007a;background:#faf5ff}.inv-page{padding:0}.inv-page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.25rem}.inv-form-wrap{background:#fff;border-radius:14px;padding:1.75rem 2rem;box-shadow:0 1px 4px #00000014;max-width:1100px}.inv-section{border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1.25rem;background:#fafbff}.inv-section-title{font-size:1rem;font-weight:700;color:#1e293b;margin:0 0 1rem}.inv-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.25rem}.inv-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem 1.25rem}.inv-preview-modal{background:#fff;border-radius:16px;box-shadow:0 8px 40px #0000002e;display:flex;flex-direction:column;max-height:92vh;width:min(860px,96vw);overflow:hidden}.inv-preview-actions{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0;flex-shrink:0;background:#f8fafc}.inv-preview-scroll{overflow-y:auto;padding:1.5rem;background:#e2e8f0;display:flex;justify-content:center}@media (max-width: 900px){.inv-grid-3{grid-template-columns:1fr 1fr}.inv-form-wrap{padding:1.25rem}.inv-section{padding:1rem}}@media (max-width: 640px){.inv-grid-2,.inv-grid-3{grid-template-columns:1fr}.inv-preview-scroll{padding:.5rem}}.ts-wrap{padding:1.5rem;max-width:1200px;margin:0 auto}.ts-list-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap}.ts-list-header h2{margin:0;font-size:1.35rem;color:#1e293b;flex-shrink:0}.ts-list-header .btn-primary{margin-left:auto;flex-shrink:0}.ts-filters{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.ts-filters select,.ts-filters input[type=month]{padding:.45rem .75rem;border:1px solid #cbd5e1;border-radius:7px;font-size:.88rem;background:#fff;color:#1e293b}.ts-table-wrap{overflow-x:auto}.ts-list-table{width:100%;border-collapse:collapse;font-size:.875rem}.ts-list-table th{background:#1b2a4a;color:#fff;padding:.65rem .9rem;text-align:left;white-space:nowrap}.ts-list-table td{padding:.6rem .9rem;border-bottom:1px solid #e2e8f0;white-space:nowrap}.ts-list-table tbody tr:hover{background:#f8faff}.ts-status{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.78rem;font-weight:600}.ts-status-draft{background:#f1f5f9;color:#475569}.ts-status-final{background:#dcfce7;color:#15803d;font-weight:700}.ts-status-submitted{background:#dbeafe;color:#1d4ed8}.ts-status-approved{background:#dcfce7;color:#15803d}.ts-status-rejected{background:#fee2e2;color:#b91c1c}.ts-actions{display:flex;gap:.4rem}.ts-empty{text-align:center;padding:3rem 1rem;color:#94a3b8;font-size:.95rem}.ts-form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.ts-form-header h2{margin:0;font-size:1.3rem;color:#1e293b}.ts-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;background:#f8faff;border:1px solid #e2e8f0;border-radius:10px;padding:1.1rem 1.25rem;margin-bottom:1.5rem}.ts-field{display:flex;flex-direction:column;gap:.35rem}.ts-field label{font-size:.8rem;font-weight:600;color:#475569}.ts-field input,.ts-field select{padding:.5rem .75rem;border:1px solid #cbd5e1;border-radius:7px;font-size:.9rem;background:#fff;color:#1e293b}.ts-field input:disabled{background:#f1f5f9;color:#94a3b8;cursor:not-allowed}.ts-grid-wrap{overflow-x:auto;margin-bottom:0}.ts-grid{width:100%;border-collapse:collapse;font-size:.875rem}.ts-grid th{background:#1b2a4a;color:#fff;padding:.6rem .75rem;text-align:center;white-space:nowrap}.ts-grid td{border-bottom:1px solid #e2e8f0;padding:.3rem .5rem;text-align:center}.ts-grid tfoot td{font-weight:700;background:#f1f5f9;padding:.5rem .75rem;border-top:2px solid #cbd5e1}.ts-grid tfoot td:first-child{text-align:left}.ts-doc{background:#fff;border:1px solid #c0c0c0;padding:1.5rem 2rem;margin-bottom:1.5rem;font-family:Arial,sans-serif}.ts-doc-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.ts-doc-logo-col{display:flex;flex-direction:column;gap:.5rem}.ts-doc-logo-bg{background:#1b2a4a;padding:.5rem .75rem;border-radius:4px;display:inline-block;width:fit-content}.ts-doc-logo-img{height:48px;display:block}.ts-doc-company-info{font-size:.78rem;color:#333;line-height:1.5}.ts-doc-pay-hint{background:#ff8c00;color:#fff;font-size:.75rem;font-weight:600;padding:.5rem .75rem;border-radius:4px;text-align:center;max-width:200px;line-height:1.4}.ts-doc-pay-arrow{font-size:1.2rem;text-align:center;margin-top:.25rem}.ts-doc-title{text-align:center;font-size:1.05rem;font-weight:700;letter-spacing:1px;margin:.75rem 0;text-transform:uppercase;border-top:1px solid #999;border-bottom:1px solid #999;padding:.4rem 0}.ts-doc-meta-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.5rem}.ts-doc-meta-left,.ts-doc-meta-right{display:flex;align-items:center;gap:.5rem}.ts-doc-client-row{display:flex;gap:2rem;margin-bottom:.75rem}.ts-doc-client-field{display:flex;align-items:center;gap:.5rem;flex:1}.ts-doc-label{font-size:.85rem;font-weight:600;white-space:nowrap;color:#111}.ts-doc-yellow-field{background:#ff0!important;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1.5px solid #888;padding:.3rem .6rem;font-size:.9rem;font-weight:700;color:#111;border-radius:0;min-width:160px;flex:1;box-shadow:none;outline:none}.ts-doc-yellow-field:focus{background:#ff0!important;border-color:#555}.ts-doc-yellow-field:disabled{background:#fffaaa!important;cursor:not-allowed}.ts-doc-yellow-field[type=month]::-webkit-calendar-picker-indicator{opacity:.5;cursor:pointer}.emp-payslip-section{padding:1.2rem 1rem 2rem;max-width:960px;margin:0 auto}.eps-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.eps-header-left{flex:1;min-width:0}.eps-title{font-size:1.1rem;font-weight:800;color:#1b2a4a;margin:0 0 2px}.eps-sub{font-size:.78rem;color:#64748b;margin:0}.eps-count-chip{background:#1b2a4a;color:#fff;font-size:.75rem;font-weight:700;padding:5px 14px;border-radius:20px;white-space:nowrap}.eps-loading{text-align:center;color:#94a3b8;padding:3rem 0;font-size:.9rem}.eps-empty{text-align:center;padding:3rem 1rem}.eps-empty-icon{font-size:3rem;margin-bottom:.75rem}.eps-empty-title{font-size:1rem;font-weight:700;color:#374151;margin-bottom:.35rem}.eps-empty-sub{font-size:.8rem;color:#94a3b8;max-width:320px;margin:0 auto;line-height:1.6}.eps-list{display:flex;flex-direction:column;gap:.85rem}.eps-card{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem 1.2rem;box-shadow:0 2px 10px #1b2a4a12;transition:box-shadow .18s}.eps-card:hover{box-shadow:0 4px 18px #1b2a4a21}.eps-card-left{min-width:130px}.eps-month{font-size:.98rem;font-weight:800;color:#1b2a4a}.eps-paid-on{font-size:.72rem;color:#16a34a;font-weight:600;margin-top:3px}.eps-card-chips{display:flex;gap:.65rem;flex:1;flex-wrap:wrap}.eps-chip{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:.4rem .75rem;min-width:110px}.eps-chip-lbl{font-size:.66rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}.eps-chip-val{font-size:.88rem;font-weight:700;color:#1b2a4a}.eps-chip-gross{color:#1b2a4a}.eps-chip-ded{color:#dc2626}.eps-chip-net{color:#16a34a;font-size:1rem}.eps-chip-net-wrap{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#bbf7d0}.eps-card-actions{display:flex;gap:.5rem;flex-shrink:0}.eps-btn{border:none;border-radius:7px;padding:7px 14px;font-size:.78rem;font-weight:700;cursor:pointer;transition:opacity .15s,background .15s;white-space:nowrap}.eps-btn:disabled{opacity:.55;cursor:not-allowed}.eps-btn-preview{background:#f1f5f9;color:#1b2a4a}.eps-btn-preview:hover:not(:disabled){background:#e2e8f0}.eps-btn-dl{background:linear-gradient(135deg,#1b2a4a,#2d4370);color:#fff}.eps-btn-dl:hover:not(:disabled){opacity:.88}.eps-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f1f3db8;z-index:1200;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;overflow-y:auto}.eps-preview-modal{background:#fff;border-radius:14px;width:860px;max-width:100%;box-shadow:0 8px 48px #00000052;overflow:hidden}.eps-preview-bar{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.2rem;background:#1b2a4a;gap:1rem}.eps-preview-title{font-size:.9rem;font-weight:800;color:#fff}.eps-preview-close{background:#ffffff1f;border:none;color:#fff;border-radius:6px;width:32px;height:32px;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.eps-preview-close:hover{background:#ffffff38}.eps-preview-body{padding:1rem;overflow-x:auto}.report-bar{display:flex;align-items:center;justify-content:space-between;padding:.55rem .9rem;background:#f8fafc;border-bottom:1px solid #e2e8f0}.report-bar-label{font-size:.8rem;font-weight:600;color:#64748b}.report-bar-btns{display:flex;gap:6px;align-items:center}.rpt-btn{display:inline-flex;align-items:center;gap:5px;border:none;border-radius:6px;padding:5px 12px;font-size:.76rem;font-weight:700;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap}.rpt-btn:hover{opacity:.85;transform:translateY(-1px)}.rpt-btn:active{transform:translateY(0)}.rpt-xl{background:#16a34a;color:#fff}.rpt-pdf{background:#dc2626;color:#fff}.ts-doc-name-select{min-width:220px}.ts-default-bar{display:flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,#1b2a4a,#2d4370);border-radius:10px;padding:.65rem 1.1rem;margin-bottom:.6rem;box-shadow:0 2px 8px #1b2a4a2e;flex-wrap:wrap}.ts-default-bar span{color:#e2e8f0;font-size:.82rem;font-weight:600;letter-spacing:.01em;white-space:nowrap}.ts-default-bar span:before{content:"⏱ ";font-size:.95rem}.ts-default-input{width:72px;padding:.36rem .55rem;border:2px solid #fcd34d;border-radius:6px;background:#fff;font-size:.85rem;font-weight:700;color:#1b2a4a;text-align:center;outline:none;transition:border-color .18s,box-shadow .18s}.ts-default-input:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #fcd34d59}.ts-default-input::-webkit-inner-spin-button,.ts-default-input::-webkit-outer-spin-button{opacity:1}.ts-default-btn{padding:.38rem 1rem;background:linear-gradient(135deg,#f59e0b,#fcd34d);color:#1b2a4a;border:none;border-radius:6px;font-size:.8rem;font-weight:700;cursor:pointer;letter-spacing:.02em;white-space:nowrap;box-shadow:0 2px 6px #f59e0b59;transition:background .18s,box-shadow .18s,transform .12s}.ts-default-btn:hover{background:linear-gradient(135deg,#d97706,#f59e0b);box-shadow:0 4px 12px #f59e0b73;transform:translateY(-1px)}.ts-default-btn:active{transform:translateY(0);box-shadow:0 1px 4px #f59e0b4d}.ts-doc-grid{width:100%;border-collapse:collapse;font-size:.82rem;margin-bottom:0}.ts-doc-grid th{background:#000;color:#fff;padding:.4rem .6rem;text-align:center;border:1px solid #555;font-size:.8rem}.ts-doc-grid td{border:1px solid #aaa;padding:.2rem .4rem;text-align:center}.ts-workday{background:#fff}.ts-weekend{background:#ffd966}.ts-weekend td{font-weight:700;color:#7a4f00;font-style:italic}.ts-weekend input{background:#ffd966;border-color:#bba000}.ts-doc-totals-row td{background:#d9d9d9;font-weight:700;border:1px solid #999;padding:.4rem .6rem}.ts-doc-totals-label{text-align:left!important;font-size:.8rem;line-height:1.3}.ts-doc-cert{font-size:.78rem;font-style:italic;color:#333;margin:.75rem 0;border-top:1px solid #ccc;padding-top:.5rem}.ts-doc-sig-row{display:flex;gap:3rem;margin-top:1rem}.ts-doc-sig-block{flex:1}.ts-doc-sig-name{background:#ff0;border-bottom:2px solid #333;min-height:28px;padding:.25rem .5rem;font-weight:700;font-size:.88rem;color:#111;margin-bottom:.25rem}.ts-doc-sig-label{font-size:.75rem;color:#444}.ts-cell-center{text-align:center}.ts-date{font-size:.82rem;white-space:nowrap}.ts-day{font-size:.82rem;white-space:nowrap;font-weight:600;text-align:left;padding-left:.5rem}.ts-total-cell{font-weight:700;color:#1b2a4a}.ts-hour-input{width:70px;padding:.3rem .4rem;border:1px solid #cbd5e1;border-radius:5px;text-align:center;font-size:.88rem}.ts-hour-input:focus{outline:none;border-color:#3b82f6}.ts-remarks-input{width:100%;min-width:200px;padding:.3rem .5rem;border:1px solid #cbd5e1;border-radius:5px;font-size:.85rem}.ts-remarks-input:focus{outline:none;border-color:#3b82f6}.ts-form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:.5rem}
