*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;-webkit-font-smoothing:antialiased;background:#f4f5f7}a{text-decoration:none}.react-resizable{position:relative;background-clip:padding-box}.react-resizable-handle{position:absolute;right:-5px;bottom:0;z-index:1;width:10px;height:100%;cursor:col-resize;touch-action:none}.pderp-list-card{background:#fff;border:1px solid #e8edf3;border-radius:14px;overflow:hidden;box-shadow:0 1px 3px #1018280a}.pderp-list-card .ant-table{background:transparent}.pderp-table .ant-table-thead>tr>th{background:#f8fafc;color:#475569;font-weight:600;font-size:12px;border-bottom:1px solid #e8edf3;padding:5px 12px}.pderp-table .ant-table-thead>tr>th:before{display:none!important}.pderp-table .ant-table-tbody>tr>td{padding:3px 12px;border-bottom:1px solid #f1f5f9;font-size:12.5px}.pderp-table .ant-avatar{vertical-align:middle}.pderp-table .ant-table-tbody>tr:last-child>td{border-bottom:none}.pderp-table:not(.pderp-edit) .ant-table-row{cursor:pointer}.pderp-table .ant-table-row:hover>td{background:#f5f8ff}.pderp-table.pderp-edit .ant-table-row{cursor:default}.pderp-table.pderp-edit .ant-table-row:hover>td{background:#fffdf5}.pderp-table .ant-pagination{padding:0 14px}.pderp-editbtn{display:inline-flex;align-items:center;gap:8px;height:32px;padding:0 12px;border:1px solid #d9dee8;border-radius:8px;color:#475569;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff}.pderp-editbtn:hover{border-color:#3b5bd6;color:#3b5bd6}.pderp-editbtn.on{border-color:#3b5bd6;color:#3b5bd6;background:#eff3ff}.pderp-drawer .ant-drawer-body{background:#fafbfc;padding:0}.pderp-form{background:#fff;border:1px solid #eef0f3;border-radius:12px;margin:16px;padding:18px 20px;box-shadow:0 1px 3px #0000000a}.pderp-form .ant-divider{color:#1e2d4f;font-weight:600}.pderp-form-2col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-gap:18px;align-items:start}.pderp-form-2col>.ant-divider,.pderp-form-2col>.ant-tabs,.pderp-form-2col>.pderp-col-full,.pderp-form-2col>.ant-form-item:has(textarea),.pderp-form-2col>.ant-form-item:has(.ant-upload-drag){grid-column:1 / -1}@media (max-width: 640px){.pderp-form-2col{grid-template-columns:1fr}}.pderp-drawer-footer{position:sticky;bottom:0;background:#fff;border-top:1px solid #eef0f3;padding:10px 16px;display:flex;justify-content:space-between;align-items:center}.pderp-smartbtn{border:1px solid #e2e8f0;border-radius:10px;padding:8px 14px;background:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.pderp-smartbtn:hover{border-color:#3b5bd6;box-shadow:0 2px 6px #00000014}.pderp-smartbtn .num{font-size:18px;font-weight:800;color:#1e2d4f}.pderp-pill{display:inline-block;padding:0 7px;border-radius:5px;font-size:11px;font-weight:600;color:#fff;line-height:17px;white-space:nowrap;vertical-align:middle}.pderp-pill.pending{background:#f59e0b}.pderp-pill.approved{background:#16a34a}.pderp-pill.refused{background:#e0566b}.pderp-pill.final{background:#0ea5b7}.pderp-pill.draft{background:#94a3b8}.pderp-pill.blue{background:#2563eb}.pderp-pill.green{background:#16a34a}.pderp-pill.purple{background:#7c3aed}.pderp-pill.gold{background:#d97706}.pderp-pill.slate{background:#64748b}.o_mw_seg .ant-segmented-item-selected{background:#1f9bb3}.o_mw_seg .ant-segmented-item-selected .ant-segmented-item-label{color:#fff;font-weight:600}.o_mw_seg .ant-segmented-item-label{font-weight:500}.o_bal_grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.o_bal_tile{background:#fff;border:1px solid #e8edf3;border-radius:12px;padding:12px 14px;box-shadow:0 1px 3px #1018280a}.o_bal_tile .t{font-size:12px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.03em}.o_bal_tile .n{font-size:1.7rem;font-weight:800;color:#1f9bb3;line-height:1.1;margin-top:2px}.o_bal_tile .s{font-size:11px;color:#94a3b8}.pderp-ptag{display:inline-flex;align-items:center;margin:2px 4px 2px 0}.pderp-ptag-x{margin-left:1px;cursor:pointer;color:#94a3b8;visibility:hidden;font-size:15px;line-height:1}.pderp-ptag:hover .pderp-ptag-x{visibility:visible}.o_att_home{max-width:720px;margin:0 auto}.o_att_clock{width:180px;height:180px;border-radius:50%;border:none;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#fff;font-size:1.25rem;cursor:pointer;box-shadow:0 6px 18px #0000002e;transition:transform .1s,box-shadow .15s,background .2s}.o_att_clock .anticon,.o_att_clock .o_att_clock_ic{font-size:2.6rem}.o_att_clock .o_att_clock_label{font-weight:600}.o_att_clock:hover{transform:translateY(-2px);box-shadow:0 10px 24px #00000038}.o_att_clock:active{transform:translateY(0)}.o_att_clock.o_in{background:#28a745}.o_att_clock.o_out{background:#dc3545}.o_att_clock:disabled{opacity:.6;cursor:default}.o_mw_section_label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;font-weight:700;margin:14px 2px 6px}.o_mw_tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.o_mw_tile{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:14px 6px;border:1px solid #e2e8f0;border-radius:12px;background:#fff;color:#334155;cursor:pointer;transition:transform .08s,box-shadow .15s,border-color .15s}.o_mw_tile:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #00000012;transform:translateY(-1px)}.o_mw_tile_ic{font-size:1.5rem;color:#5b7cfa}.o_mw_tile_approve .o_mw_tile_ic{color:#16a34a}.o_mw_tile_lbl{font-size:.8rem;font-weight:600}.o_mw_corner{position:absolute;top:6px;left:8px;width:16px;height:16px;line-height:16px;text-align:center;border-radius:50%;font-size:.6rem;color:#fff}.o_mw_corner_req{background:#5b7cfa}.o_mw_corner_app{background:#16a34a}.o_mw_badge{position:absolute;top:6px;right:8px;background:#dc3545;color:#fff;font-size:.7rem;font-weight:700;min-width:18px;height:18px;line-height:18px;border-radius:9px;padding:0 5px;text-align:center}.o_mw_tile.o_pa_doc_po{border-bottom:3px solid #2563eb}.o_mw_tile.o_pa_doc_voucher{border-bottom:3px solid #d97706}.o_mw_tile.o_pa_doc_so{border-bottom:3px solid #0d9488}.o_mw_tile.o_pa_doc_po .o_mw_tile_ic{color:#2563eb}.o_mw_tile.o_pa_doc_voucher .o_mw_tile_ic{color:#d97706}.o_mw_tile.o_pa_doc_so .o_mw_tile_ic{color:#0d9488}.o_mw_topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.o_mw_topbtn{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:4px 10px;font-size:13px;cursor:pointer;color:#334155;display:inline-flex;align-items:center;gap:5px}.o_mw_topbtn:hover{border-color:#cbd5e1}.o_att_balance_card{border:1px solid #dee2e6;border-radius:8px;padding:8px 14px;min-width:120px;text-align:center;background:#fff}.o_att_balance_card.o_clickable{cursor:pointer;transition:border-color .15s,box-shadow .15s}.o_att_balance_card.o_clickable:hover{border-color:#714b67;box-shadow:0 2px 6px #0000001a}.o_bal_type{font-size:.8rem;font-weight:600;color:#555}.o_bal_remaining{font-size:1.6rem;font-weight:700;color:#28a745;line-height:1.1}.o_att_home_row{padding:8px 4px;border-bottom:1px solid #f0f0f0}.o_att_home_thumb,.o_att_home_avatar{width:40px;height:40px;object-fit:cover}.o_att_cards{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}.o_att_card{width:110px;border:2px solid #dee2e6;border-radius:8px;padding:6px;text-align:center;background:#fff;cursor:pointer;transition:border-color .15s,box-shadow .15s}.o_att_card:hover{border-color:#adb5bd;box-shadow:0 2px 6px #00000014}.o_att_card.o_att_selected{border-color:#714b67;box-shadow:0 0 0 2px #714b6740}.o_att_card_imgwrap{width:100%;height:90px;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:6px;background:#f1f1f1}.o_att_card_img{max-width:100%;max-height:100%;object-fit:cover}.o_att_card_ph{font-size:2rem;color:#94a3b8}.o_att_card_label{margin-top:4px;font-size:.8rem;font-weight:500;word-break:break-word;line-height:1.2}.o_ci_loc{border-radius:8px;padding:8px 12px;margin-bottom:10px;font-size:13px}.o_ci_loc_ok{background:#ecfdf3;border:1px solid #abefc6;color:#067647}.o_loc_chip{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:9px;border:1px solid #cbd5e1;background:#fff;color:#334155;cursor:pointer;font-size:13px}.o_loc_chip:hover{border-color:#1f9bb3}.o_loc_chip.on{background:#1f9bb3;border-color:#1f9bb3;color:#fff}.o_att_filter{display:inline-flex;gap:6px;flex-wrap:wrap}.o_att_fbtn{border:1px solid #d9dee8;background:#fff;border-radius:8px;padding:4px 13px;cursor:pointer;font-weight:600;font-size:13px;color:#475569}.o_att_fbtn:hover{border-color:#cbd5e1}.o_att_fbtn.on.all{background:#1f9bb3;border-color:#1f9bb3;color:#fff}.o_att_fbtn.on.pending{background:#f59e0b;border-color:#f59e0b;color:#fff}.o_att_fbtn.on.approved{background:#16a34a;border-color:#16a34a;color:#fff}.o_att_fbtn.on.refused{background:#e0566b;border-color:#e0566b;color:#fff}.o_req{max-width:720px;margin:0 auto}.o_req_title{display:flex;align-items:center;gap:8px;font-size:20px;font-weight:700;color:#1e293b;margin:4px 2px 14px}.o_req_card{background:#fff;border:1px solid #e8edf3;border-radius:14px;padding:18px;box-shadow:0 1px 3px #1018280d}.o_req_label{font-weight:700;color:#334155;margin:16px 0 8px;font-size:14px}.o_req_label:first-child{margin-top:0}.o_req_grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.o_req_duration{background:#f8fafc;border:1px solid #eef2f6;border-radius:10px;padding:12px 14px;color:#475569;margin-top:16px;font-size:14px}.o_req_foot{display:flex;gap:10px;position:sticky;bottom:0;padding:14px 0 4px;margin-top:14px;background:linear-gradient(180deg,#f4f5f700,#f4f5f7 40%)}.o_btn_submit{flex:1;height:48px;border:none;border-radius:10px;background:#1f9bb3;color:#fff;font-size:16px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.o_btn_submit:hover{background:#1a8aa0}.o_btn_submit:disabled{background:#9fc8d2;cursor:default}.o_btn_discard{height:48px;border:1px solid #cbd5e1;border-radius:10px;background:#fff;color:#475569;padding:0 22px;font-size:15px;cursor:pointer}.o_btn_discard:hover{border-color:#94a3b8}.o_appr{max-width:760px;margin:0 auto}.o_appr_tabs{display:flex;border:1px solid #1f9bb3;border-radius:10px;overflow:hidden;margin-bottom:12px}.o_appr_tab{flex:1;text-align:center;padding:11px;cursor:pointer;font-weight:700;color:#1f9bb3;background:#fff;border:none;font-size:15px}.o_appr_tab.on{background:#1f9bb3;color:#fff}.o_appr_card{background:#fff;border:1px solid #e8edf3;border-radius:12px;margin-bottom:12px;overflow:hidden;box-shadow:0 1px 3px #1018280a}.o_appr_head{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid #f1f5f9}.o_appr_name{font-weight:700;color:#1e293b}.o_appr_sub{font-size:13px;color:#64748b}.o_appr_body{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;flex-wrap:wrap}.o_appr_meta{font-size:13px;color:#475569}.o_appr_meta .anticon{color:#94a3b8}.o_appr_btns{display:flex;gap:8px}.o_iconbtn{width:40px;height:40px;border:none;border-radius:9px;color:#fff;font-size:17px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.o_iconbtn.ok{background:#16a34a}.o_iconbtn.ok:hover{background:#15803d}.o_iconbtn.edit{background:#0ea5b7}.o_iconbtn.edit:hover{background:#0b8a99}.o_iconbtn.no{background:#e0566b}.o_iconbtn.no:hover{background:#c2415a}.o_pill{display:inline-block;padding:0 8px;border-radius:5px;font-size:11px;font-weight:600;color:#fff;line-height:18px}.o_pill.pending{background:#f59e0b}.o_pill.approved{background:#16a34a}.o_pill.refused{background:#e0566b}.o_appr_approver{display:inline-flex;align-items:center;gap:6px;color:#64748b;font-size:13px;margin-top:4px}.o_year_nav{display:inline-flex;align-items:center;border:1px solid #d9dee8;border-radius:8px;overflow:hidden}.o_year_nav button{border:none;background:#fff;padding:6px 12px;cursor:pointer;font-size:16px;color:#475569}.o_year_nav button:hover{background:#f1f5f9}.o_year_nav span{padding:6px 16px;font-weight:700;border-left:1px solid #eef2f6;border-right:1px solid #eef2f6}.o_to_card{background:#fff;border:1px solid #e8edf3;border-radius:12px;overflow:hidden;margin-bottom:14px;box-shadow:0 1px 3px #1018280a}.o_to_head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#f8fafc;border-bottom:1px solid #eef2f6}.o_to_name{font-weight:700;font-size:16px;color:#1e293b}.o_to_left{text-align:right;color:#16a34a;line-height:1}.o_to_left b{font-size:1.7rem;font-weight:800}.o_to_left small{display:block;color:#94a3b8;font-weight:600;font-size:11px}.o_to_stats{display:flex;border-bottom:1px solid #f1f5f9}.o_to_stat{flex:1;text-align:center;padding:14px 6px;border-right:1px solid #f1f5f9}.o_to_stat:last-child{border-right:none}.o_to_stat .n{font-size:1.4rem;font-weight:800;color:#1e293b}.o_to_stat .l{font-size:11px;color:#94a3b8;font-weight:600;letter-spacing:.04em}.o_to_stat.green .n{color:#16a34a}.o_to_stat.amber .n{color:#f59e0b}.o_to_app{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid #f3f4f6;font-size:13px;color:#475569}.o_to_app:last-child{border-bottom:none}.o_to_empty{padding:12px 16px;color:#94a3b8}.o_att_dash{max-width:980px;margin:0 auto}.o_dash_split{display:flex;gap:20px;align-items:flex-start;flex-wrap:wrap}.o_dash_nav{width:220px;flex:0 0 220px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000a}.o_dash_navitem{display:block;width:100%;text-align:left;border:none;background:transparent;border-bottom:1px solid #f1f5f9;padding:12px 16px;cursor:pointer;font-weight:700;font-size:12.5px;color:#475569;letter-spacing:.03em}.o_dash_navitem:last-child{border-bottom:0}.o_dash_navitem:hover{background:#f8fafc}.o_dash_navitem.on{background:#1f9bb3;color:#fff}.o_dash_pane{flex:1 1 320px;min-width:280px}@media (max-width: 620px){.o_dash_nav{width:100%;flex-basis:100%}}.o_dash_group_h{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;font-weight:700;margin:1.1rem 0 .4rem .25rem}.o_dash_list{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000a}.o_dash_item{display:flex;align-items:center;width:100%;gap:.75rem;background:transparent;border:0;border-bottom:1px solid #f1f5f9;padding:11px 14px;text-align:left;cursor:pointer;color:#1e293b;transition:background .08s}.o_dash_item:last-child{border-bottom:0}.o_dash_item:hover{background:#f8fafc}.o_dash_ic{width:22px;text-align:center;font-size:1.05rem;color:#64748b}.o_dash_lbl{flex:1 1 auto;font-size:.92rem}.o_dash_chev{color:#cbd5e1;font-size:.8rem}
