*{margin:0;padding:0;font-family:Inter,sans-serif}.container-login{width:100%;height:100vh;background-color:#fff;display:flex;justify-content:center;align-items:center;font-family:Inter,sans-serif;min-width:400px}.wrapper-login{width:100%;height:50%;display:flex;justify-content:center;align-items:center;gap:2%}.wrapper-login hr{width:1px;height:60%;background-color:#004a73;border:none;margin:0 20px}.left-login{width:20%;height:50%;display:flex;flex-direction:column;gap:16px}.left-login img{width:100%;object-fit:cover}.left-login h4{font-size:22px;color:#004a73;font-weight:500;line-height:1.3}.right-login{width:20%;height:50%;gap:14px;display:flex;flex-direction:column}.right-login .title-login h1{font-size:26px;color:#004a73;font-weight:600;line-height:1.3}.input-login{display:flex;flex-direction:column;gap:16px}.input-login input{width:300px!important;height:45px;border:1px solid #004a73;border-radius:6px;padding:10px 14px;font-size:15px;font-weight:400}.button-login button{width:300px;height:45px;font-size:16px;font-weight:600;background-color:#004a73;color:#fff;border-radius:6px}.forgot-password{margin-top:6px}.forgot-password a{margin-top:6px;font-size:14px}@media(max-width:1024px){.container-login{width:100%;height:100vh;background-color:#fff;display:flex;justify-content:center;align-items:center;font-family:Inter,sans-serif}.wrapper-login{width:100%;height:50%;display:flex;justify-content:center;align-items:center;gap:2%}.wrapper-login hr{width:1px;height:60%;background-color:#004a73;border:none;margin:0 20px}.left-login{width:30%;height:50%;display:flex;flex-direction:column;gap:16px}.left-login img{width:100%;object-fit:cover}.left-login h4{font-size:18px;color:#004a73;font-weight:400;line-height:1.3}.right-login{width:20%;height:50%;gap:8px;display:flex;flex-direction:column}.right-login .title-login h1{font-size:20px;color:#004a73;font-weight:500;line-height:1.3}.input-login{display:flex;flex-direction:column;gap:16px}.input-login input{width:250px!important;height:40px;border:1px solid #004a73;border-radius:6px;padding:10px 14px;font-size:12px;font-weight:400}.button-login button{width:300px;height:40px;font-size:12px;font-weight:500;background-color:#004a73;color:#fff;border-radius:6px}.forgot-password{margin-top:6px}.forgot-password a{margin-top:6px;font-size:12px}}@media(max-width:728px){.container-login{width:100%;height:100vh;background-color:#fff;display:flex;justify-content:center;align-items:center;font-family:Inter,sans-serif}.wrapper-login{width:90%;height:90%;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:2%}.wrapper-login hr{width:80%;height:1px;background-color:#004a73;border:none;margin:0 20px}.left-login{width:100%;height:50%;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:16px}.left-login img{width:50%;object-fit:cover}.left-login h4{font-size:18px;color:#004a73;font-weight:400;line-height:1.3}.right-login{width:100%;height:100%;gap:8px;display:flex;flex-direction:column;justify-content:flex-start;align-items:center}.right-login .title-login h1{font-size:20px;color:#004a73;font-weight:500;line-height:1.3}.input-login{display:flex;flex-direction:column;gap:16px}.input-login input{width:100%!important;height:40px;border:1px solid #004a73;border-radius:6px;padding:10px 14px;font-size:12px;font-weight:400}.button-login button{width:300px;height:40px;font-size:12px;font-weight:500;background-color:#004a73;color:#fff;border-radius:6px}.forgot-password{margin-top:6px}.forgot-password a{margin-top:6px;font-size:12px}}@media(max-width:425px){.wrapper-login{gap:22px;padding:0 16px}.left-login,.right-login{width:100%}.left-login img{width:70%}.left-login h4{font-size:17px}.right-login .title-login h1{font-size:20px}.input-login input{width:100%!important;max-width:300px;height:46px;font-size:14px}.button-login button{width:100%;max-width:300px;height:46px;font-size:15px}.forgot-password a{font-size:13px}}.input-container{display:flex;flex-direction:column;gap:6px}.input-label{font-size:14px;font-weight:500;color:#333}.required{color:red}.input-field{border:1px solid #ccc;border-radius:6px;padding:8px 12px;font-size:14px;outline:none;transition:all .2s ease;width:100%;box-sizing:border-box}.input-field:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff33}.input-field:disabled{background-color:#f5f5f5;cursor:not-allowed}.input-error{border-color:red}.input-error-text{font-size:12px;color:red;margin-top:2px}.container-forgot{display:flex;align-items:center;justify-content:center;height:100vh;background:#f7f8fa}.wrapper-forgot{display:flex;align-items:center;justify-content:center;background:#fff;border-radius:20px;box-shadow:0 4px 10px #0000001a;padding:40px 60px}.left-forgot{display:flex;flex-direction:column;align-items:center;justify-content:center}.left-forgot img{width:120px;object-fit:contain}.left-forgot h4{color:#004a73;margin-top:10px}.divider{width:1px;height:300px;background-color:#ddd;margin:0 40px}.right-forgot{position:relative;display:flex;flex-direction:column;align-items:center}.back-btn{position:absolute;top:0;right:0;background:none;border:none;color:#004a73;font-weight:600;cursor:pointer;font-size:14px;transition:.3s}.back-btn:hover{color:#f6b500}.card-forgot{background-color:#fff;border-radius:16px;padding:40px 50px;text-align:center;min-width:350px}.title-forgot h1{color:#1a2b5f;margin-bottom:10px}.title-forgot p{color:#666;margin-bottom:25px;font-size:14px}.form-forgot{display:flex;flex-direction:column;align-items:center;gap:15px}.button-forgot button{width:300px;height:45px;background-color:#004a73;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600}.button-forgot button:hover{background-color:#f6b500;color:#004a73;transition:.3s}.success-forgot{text-align:center;color:#004a73}.container-app{width:100%;height:100vh;display:flex;font-family:Inter,sans-serif}.left-bar{width:15%;transition:transform .4s ease,opacity .4s ease;transform:translate(0)}.main-bar{flex:1;width:100%;background-color:transparent;padding:16px}.loading-logo-screen{position:fixed;inset:0;background:linear-gradient(135deg,#fff,#f6f9fc);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999}.loading-logo{width:140px;height:auto;margin-bottom:24px;animation:logoPulse 1.8s ease-in-out infinite}.loader-dots{display:flex;gap:8px}.loader-dots:before,.loader-dots:after,.loader-dots{content:""}.loader-dots:before,.loader-dots:after{width:10px;height:10px;background:#0b5ed7;border-radius:50%;animation:dots 1.4s infinite ease-in-out both}.loader-dots:after{animation-delay:-.7s}@keyframes logoPulse{0%{transform:scale(1);opacity:.85}50%{transform:scale(1.05);opacity:1}to{transform:scale(1);opacity:.85}}@keyframes dots{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.leftbar-desktop{display:block}@media(max-width:1080px){.container-app{flex-direction:column;height:auto}.leftbar-desktop{display:none}}.container-leftbar{width:100%;height:100%;box-shadow:0 4px 10px #0000001f;background:#fff;display:flex;flex-direction:column;overflow:hidden}.top-leftbar{width:80%;height:5%;padding:10px 12px;display:flex;justify-content:center;align-items:center;gap:5%;border-bottom:1px solid rgba(16,24,40,.1)}.top-leftbar h1{margin:0;font-size:20px;font-weight:500;color:#0f172a;line-height:1.2}.menu-leftbar{display:flex;flex-direction:column;gap:6px;padding:12px;overflow-y:auto}.menu-leftbar span{display:flex;align-items:center;gap:10px;font-size:14px;color:#0f172ae6;padding:10px 12px;border-radius:10px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s ease,color .2s ease}.menu-leftbar span:hover{background-color:#0f172a0f}.menu-leftbar span.active-menu{background-color:#1976d21f;color:#1976d2;font-weight:700}.submenu{margin-left:12px;display:flex;flex-direction:column;gap:4px;padding-left:8px;border-left:2px solid rgba(16,24,40,.08)}.submenu span{font-size:13px;padding:8px 10px;border-radius:8px;color:#0f172ac7}.submenu span:hover{background-color:#0f172a0f}.submenu span.active-menu{background-color:#1976d21a;color:#1976d2;font-weight:700}@media(max-width:1080px){.top-leftbar{display:none}.top-leftbar h1{font-size:16px}.menu-leftbar{padding:10px}}@media(max-width:768px){.container-leftbar{box-shadow:none;border-right:1px solid rgba(16,24,40,.08)}.top-leftbar{padding:12px 10px}.menu-leftbar span{padding:10px;font-size:13.5px}.submenu{margin-left:10px}}@media(max-width:480px){.top-leftbar h1{font-size:15px}.menu-leftbar{padding:8px}.menu-leftbar span{font-size:13px;border-radius:12px}}.users-container{font-family:Poppins,sans-serif;color:#111827eb;background:#fff;min-height:100%;box-sizing:border-box;min-width:400px}.users-wrap{width:98%;display:flex;flex-direction:column;gap:5px}.users-topbar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:4px}.users-title h2{margin:0;font-size:18px;font-weight:800;letter-spacing:.2px}.users-title p{margin:6px 0 0;font-size:12.5px;color:#1118279e}.users-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.users-filters{display:grid;grid-template-columns:1fr 220px 120px;gap:12px;align-items:center}.users-role-select{height:42px;width:100%;padding:0 12px;border-radius:999px;border:1px solid rgba(16,24,40,.12);background:#fff;outline:none;font-size:14px}.users-role-select:focus{border-color:#4068928c;box-shadow:0 0 0 4px #40689224}.users-history{max-height:56vh;overflow:auto}.users-table{width:100%;border-collapse:collapse;min-width:780px}.users-table thead th{position:sticky;top:0;background:#fff;z-index:0;border-bottom:1px solid rgba(16,24,40,.1);text-align:left;padding:12px 14px;font-size:12px;letter-spacing:.25px;text-transform:uppercase;color:#111827b3}.users-table tbody td{padding:10px 14px;border-bottom:1px solid rgba(16,24,40,.08);font-size:13px;color:#111827db;vertical-align:middle}.users-table tbody tr:hover{background:#4068920f}.users-email{font-weight:800;color:#111827eb}.users-badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.2px;border:1px solid rgba(16,24,40,.1);background:#94a3b81f}.users-badge.role{background:#4068921f;border-color:#40689233;color:#1e40aff2}.users-badge.active{background:#22c55e1f;border-color:#22c55e33;color:#15803df2}.users-badge.inactive{background:#e74c3c1a;border-color:#e74c3c33;color:#b91c1cf2}.user-error{margin-top:10px;padding:10px 12px;border-radius:12px;border:1px solid rgba(231,76,60,.25);background:#e74c3c14;color:#b91c1cf2;font-weight:700;font-size:13px}@media(max-width:760px){.users-topbar{flex-direction:column;align-items:stretch}.users-actions{justify-content:flex-start}.users-filters{grid-template-columns:1fr}.users-role-select{border-radius:14px}.detail-grid{grid-template-columns:1fr}}.pwd-rules{margin-top:10px;padding:10px 12px;border-radius:12px;border:1px solid rgba(16,24,40,.1);background:#94a3b81a;font-size:12.5px}.pwd-rules-title{font-weight:900;margin-bottom:6px;color:#111827c7}.pwd-rule{display:flex;align-items:center;gap:8px;margin:4px 0;color:#111827b3;font-weight:700}.pwd-rule.ok{color:#15803df2}.pwd-dot{width:9px;height:9px;border-radius:999px;background:#e74c3c8c}.pwd-rule.ok .pwd-dot{background:#22c55ed9}.modal-reusable-overlay{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:9999;padding:16px}.modal-reusable-modal{background:#fff;border-radius:18px;border:1px solid rgba(16,24,40,.12);box-shadow:0 20px 60px #0f172a2e;overflow:hidden;max-width:96vw}.modal-reusable-header{display:flex;justify-content:space-between;align-items:start;gap:12px;padding:16px 18px;background:linear-gradient(180deg,#fff,#f7f9fc);border-bottom:1px solid rgba(16,24,40,.08)}.modal-reusable-header h3{margin:0;font-size:18px;font-weight:900;color:#111827eb}.modal-reusable-header p{margin:6px 0 0;font-size:12.5px;color:#1118279e}.modal-reusable-x{border:0;background:#4068921a;color:#406892;width:36px;height:36px;border-radius:12px;cursor:pointer;font-weight:900}.modal-reusable-error{margin:14px 18px 0;padding:10px 12px;border-radius:12px;background:#ef44441a;color:#b91c1cf2;border:1px solid rgba(239,68,68,.22);font-size:13px}.modal-reusable-form{padding:16px 18px 18px}.modal-reusable-actions{padding:0 18px 18px;display:flex;justify-content:flex-end;gap:10px}.modal-reusable-btn{height:42px;padding:0 14px;border-radius:999px;cursor:pointer;font-weight:900;border:1px solid rgba(16,24,40,.12);background:#fff;color:#111827eb}.modal-reusable-btn.ghost{background:#94a3b81a}.modal-reusable-btn.primary{border:0;background:linear-gradient(135deg,#406892,#2f567b);color:#fff;box-shadow:0 10px 22px #6895c58c}.m-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.m-grid-1{grid-template-columns:1fr}.m-full{grid-column:1 / -1}.m-field{display:grid;gap:6px}.m-label{font-size:12px;font-weight:800;color:#111827b3}.m-input,.m-select,.m-textarea{height:42px;padding:0 12px;border-radius:12px;border:1px solid rgba(16,24,40,.12);outline:none;background:#fff;color:#111827eb;transition:.15s ease;display:flex;justify-content:flex-start;align-items:center}.m-textarea{height:auto;padding:10px 12px;resize:vertical;min-height:110px}.m-input:focus,.m-select:focus,.m-textarea:focus{border-color:#4068928c;box-shadow:0 0 0 4px #4068922e}.m-help{font-size:12px;color:#1118279e}.m-file{height:auto;padding:10px 12px}.roles-container{font-family:Poppins,sans-serif;color:#111827eb;background:#fff;min-height:100%;box-sizing:border-box;min-width:400px}.roles-wrap{width:98%;display:flex;flex-direction:column;gap:5px}.roles-topbar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:4px}.roles-title h2{margin:0;font-size:18px;font-weight:800;letter-spacing:.2px}.roles-title p{margin:6px 0 0;font-size:12.5px;color:#1118279e}.roles-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.roles-filters{display:grid;grid-template-columns:1fr 260px;gap:12px;align-items:center}.roles-info{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.roles-mini{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;font-size:12px;font-weight:800;border:1px solid rgba(16,24,40,.1);background:#94a3b81a;color:#111827c7}.roles-history{max-height:56vh;overflow:auto}.roles-table{width:100%;border-collapse:collapse;min-width:820px}.roles-table thead th{position:sticky;top:0;background:#fff;z-index:0;border-bottom:1px solid rgba(16,24,40,.1);text-align:left;padding:12px 14px;font-size:12px;letter-spacing:.25px;text-transform:uppercase;color:#111827b3}.roles-table tbody td{padding:10px 14px;border-bottom:1px solid rgba(16,24,40,.08);font-size:13px;color:#111827db;vertical-align:middle}.roles-table tbody tr:hover{background:#4068920f}.roles-role{font-weight:900;color:#111827eb}.roles-access{color:#111827b3}.roles-badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.2px;border:1px solid rgba(16,24,40,.1);background:#94a3b81f}.roles-badge.users{background:#4068921f;border-color:#40689233;color:#1e40aff2}.roles-badge.access{background:#22c55e1a;border-color:#22c55e33;color:#15803df2}.roles-badge.empty{background:#e74c3c14;border-color:#e74c3c2e;color:#b91c1ceb}.modal-content input,.modal-content select{width:100%;height:44px;padding:0 12px;border-radius:12px;border:1px solid rgba(16,24,40,.12);outline:none;font-size:14px;background:#fff}.modal-content input:focus,.modal-content select:focus{border-color:#4068928c;box-shadow:0 0 0 4px #40689224}.modal-actions button:first-child{background:#4068921f;border-color:#40689240}.detail-box{width:min(420px,96vw);max-height:min(80vh,760px);overflow:auto;background:#fff;border-radius:14px;padding:12px;border:1px solid rgba(16,24,40,.1);box-shadow:0 20px 50px #0f172a38}.roles-section{margin-top:12px;padding-top:10px;border-top:1px solid rgba(16,24,40,.08)}.section-title{font-size:12px;font-weight:900;color:#111827d9;margin-bottom:8px}.menu-access{display:grid;grid-template-columns:1fr 1fr;gap:10px 12px}.menu-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid rgba(16,24,40,.1);background:#94a3b80f;cursor:pointer;-webkit-user-select:none;user-select:none}.menu-item input{width:16px;height:16px}.menu-item span{font-size:13px;font-weight:800;color:#111827d1}.users-list{display:flex;flex-direction:column;gap:8px}.user-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid rgba(16,24,40,.1);background:#fff}.user-meta{display:flex;flex-direction:column;gap:2px}.user-name{font-size:13px;font-weight:900;color:#111827eb}.user-email{font-size:12px;color:#1118279e;font-weight:700}.btn-remove{border:0;width:38px;height:38px;border-radius:12px;cursor:pointer;background:#e74c3c1a;border:1px solid rgba(231,76,60,.18)}.empty-mini{padding:10px 12px;border-radius:12px;border:1px dashed rgba(16,24,40,.14);background:#94a3b80f;color:#1118279e;font-size:13px;font-weight:700}.add-user{margin-top:10px}.add-user input{width:100%;height:44px;padding:0 12px;border-radius:12px;border:1px solid rgba(16,24,40,.12);outline:none;font-size:14px;background:#fff;margin-top:8px}.add-user input:focus{border-color:#4068928c;box-shadow:0 0 0 4px #40689224}@media(max-width:760px){.roles-topbar{flex-direction:column;align-items:stretch}.roles-actions{justify-content:flex-start}.roles-filters{grid-template-columns:1fr}.roles-info{justify-content:flex-start}.detail-grid,.menu-access{grid-template-columns:1fr}}.container-employee{width:100%;min-height:90vh;box-sizing:border-box;font-family:Poppins,sans-serif;color:#111827eb}.employee-container{width:100%;height:100%;display:flex;flex-direction:column;gap:12px}.employee-header{display:grid;grid-template-columns:1fr 180px 180px auto auto auto;gap:10px;align-items:center}.employee-header input{height:42px;border-radius:999px;border:1px solid rgba(16,24,40,.12);padding:0 14px;outline:none;background:#fff;font-size:14px}.employee-header input:focus{border-color:#4068928c;box-shadow:0 0 0 4px #40689224}.employee-header select{height:42px;border-radius:999px;border:1px solid rgba(16,24,40,.12);padding:0 14px;outline:none;background:#fff;font-size:14px;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg fill='none' stroke='%23666' stroke-width='2' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 9l6 6 6-6'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:16px}.employee-header select:focus{border-color:#4068928c;box-shadow:0 0 0 4px #40689224}.employee-header button{height:42px;padding:0 16px;border:none;border-radius:999px;cursor:pointer;font-weight:700;font-size:13px;letter-spacing:.15px;background:#406892;color:#fff;box-shadow:0 10px 22px #4068922e;transition:.2s ease}.employee-header button:hover{transform:translateY(-1px);opacity:.95}.employee-header button:nth-of-type(2){background:#0f172a;box-shadow:0 10px 22px #0f172a2e}.employee-header button:nth-of-type(3){background:#e74c3c;box-shadow:0 10px 22px #e74c3c29}.employee-table{width:100%;border-collapse:collapse;min-width:860px}.employee-table thead th{position:sticky;top:0;background:#fff;z-index:0;text-align:left;padding:12px 14px;font-size:12px;letter-spacing:.25px;text-transform:uppercase;color:#111827b3;border-bottom:1px solid rgba(16,24,40,.1)}.employee-table tbody td{padding:10px 14px;border-bottom:1px solid rgba(16,24,40,.08);font-size:13px;color:#111827db;vertical-align:middle;cursor:pointer}.employee-table tbody tr:hover{background:#4068920f}.pagination{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:6px;flex-wrap:wrap}.pagination button{height:40px;padding:0 14px;border-radius:999px;border:1px solid rgba(16,24,40,.12);background:#fff;cursor:pointer;font-weight:700;color:#111827db}.pagination button:disabled{opacity:.5;cursor:not-allowed}.modal-content-karyawan{background:#fff;border-radius:16px;padding:16px;width:min(760px,96vw);max-height:86vh;overflow:auto;border:1px solid rgba(16,24,40,.1);box-shadow:0 20px 50px #0f172a38}.modal-content-karyawan h3{margin:0 0 12px;font-size:16px;font-weight:800}.modal-content-karyawan p{margin:8px 0;color:#111827d1;font-size:13.5px}.modal-content-karyawan hr{border:0;border-top:1px solid rgba(16,24,40,.1);margin:12px 0}.modal-actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}.modal-actions button{border-radius:12px;padding:10px 14px;border:1px solid rgba(16,24,40,.12);background:#fff;cursor:pointer;font-weight:700}@media(max-width:1080px){.employee-header{grid-template-columns:1fr 1fr}.employee-header button{width:100%}}@media(max-width:760px){.employee-header{grid-template-columns:1fr}.employee-table{min-width:720px}}.modal-add-employee{position:fixed;inset:0;background:#02061773;display:flex;justify-content:center;align-items:center;z-index:9999;padding:14px}.modal-content-karyawan{width:min(560px,96vw);max-height:86vh;overflow:auto;background:#fff;border-radius:16px;padding:16px;border:1px solid rgba(16,24,40,.1);box-shadow:0 20px 50px #0f172a38}.modal-content-karyawan h3{margin:0 0 12px;font-size:16px;font-weight:800;color:#111827eb}.user-error{padding:10px 12px;border-radius:12px;border:1px solid rgba(231,76,60,.22);background:#e74c3c1a;color:#b91c1cf2;font-size:13px;font-weight:700}.add-employee-form{display:flex;flex-direction:column;gap:10px}.add-employee-form label{font-size:12px;font-weight:800;letter-spacing:.2px;color:#111827b3;margin-top:4px}.add-employee-form input,.add-employee-form select{height:42px;width:100%;box-sizing:border-box;border-radius:12px;border:1px solid rgba(16,24,40,.12);background:#fff;padding:0 12px;font-size:14px;color:#111827e0;outline:none}.add-employee-form input:focus,.add-employee-form select:focus{border-color:#4068928c;box-shadow:0 0 0 4px #40689224}.add-employee-form select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg fill='none' stroke='%23666' stroke-width='2' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 9l6 6 6-6'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:38px}.add-employee-form input[type=date]{padding-right:12px}.modal-actions{margin-top:10px;display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}.modal-actions button[type=button]{height:44px;padding:0 16px;border-radius:12px;border:1px solid rgba(16,24,40,.12);background:#fff;color:#111827db;font-weight:800;cursor:pointer;transition:.2s ease}.modal-actions button[type=button]:hover{background:#4068920f}.add-employee-form input:disabled,.add-employee-form select:disabled,.modal-actions button:disabled{opacity:.65;cursor:not-allowed}@media(max-width:520px){.modal-content-karyawan{width:min(520px,96vw);padding:12px;border-radius:16px}.modal-actions{grid-template-columns:1fr}.modal-actions button[type=button]{width:100%}}.user-picker{position:relative}.user-clear-btn{position:absolute;top:50%;right:10px;transform:translateY(-50%);border:0;background:#0f172a14;width:30px;height:30px;border-radius:10px;cursor:pointer}.user-dropdown{position:absolute;left:0;right:0;top:calc(100% + 8px);background:#fff;border:1px solid rgba(16,24,40,.12);border-radius:12px;box-shadow:0 16px 30px #0f172a1f;overflow:hidden;z-index:50;max-height:280px;overflow-y:auto}.user-option{width:100%;text-align:left;padding:10px 12px;border:0;background:transparent;cursor:pointer}.user-option:hover{background:#4068920f}.user-option-name{font-weight:700;font-size:13px;color:#111827eb}.user-option-sub{margin-top:2px;font-size:12px;color:#11182799}.user-empty{padding:12px;font-size:13px;color:#11182799}.sk-wrap{margin-top:10px;display:flex;flex-direction:column;gap:10px}.sk-row{display:flex;flex-direction:column;gap:6px}.sk{position:relative;overflow:hidden;background:#94a3b82e;border:1px solid rgba(16,24,40,.08);border-radius:12px}.sk:after{content:"";position:absolute;inset:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);animation:sk-shimmer 1.2s infinite}.sk-label{height:12px;width:32%;border-radius:8px;border:0;background:#94a3b838}.sk-input{height:42px;width:100%}.sk-textarea{height:70px;width:100%}.sk-actions{display:grid;grid-template-columns:1fr auto;gap:10px;margin-top:6px}.sk-btn{height:44px;border-radius:12px}.sk-btn.small{width:92px}.sk-dropdown{margin-top:8px;border-radius:12px;overflow:hidden;border:1px solid rgba(16,24,40,.1)}.sk-option{padding:10px 12px;border-bottom:1px solid rgba(16,24,40,.06);background:#fff}.sk-option:last-child{border-bottom:none}.sk-option .sk-line{height:12px;border-radius:8px;margin:6px 0;background:#94a3b82e;position:relative;overflow:hidden}.sk-option .sk-line:after{content:"";position:absolute;inset:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.7),transparent);animation:sk-shimmer 1.2s infinite}.sk-option .sk-line.w-60{width:60%}.sk-option .sk-line.w-40{width:40%}.modal-detail-employee__overlay{position:fixed;inset:0;background:#02061773;display:flex;justify-content:center;align-items:center;z-index:9999;padding:14px}.modal-detail-employee__panel{background:#fff;border-radius:16px;padding:16px;width:min(860px,96vw);max-height:86vh;overflow:auto;border:1px solid rgba(16,24,40,.1);box-shadow:0 20px 50px #0f172a38}.modal-detail-employee__head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.modal-detail-employee__title{margin:0;font-size:16px;font-weight:800;color:#111827eb}.modal-detail-employee__close{height:36px;width:36px;border-radius:10px;border:1px solid rgba(16,24,40,.12);background:#fff;cursor:pointer;font-weight:900}.modal-detail-employee__divider{border:0;border-top:1px solid rgba(16,24,40,.1);margin:12px 0}.modal-detail-employee__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.modal-detail-employee__item{border:1px solid rgba(16,24,40,.08);border-radius:12px;padding:10px 12px;background:#fff}.modal-detail-employee__label{display:block;font-size:11px;letter-spacing:.3px;text-transform:uppercase;color:#1118278c;margin-bottom:4px}.modal-detail-employee__value{display:block;font-size:13.5px;color:#111827e0;font-weight:700}.modal-detail-employee__toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px;align-items:center}.modal-detail-employee__pkwt{display:flex;align-items:center}.modal-detail-employee__action{border:none;border-radius:999px;height:40px;padding:0 14px;cursor:pointer;font-weight:800;font-size:13px;color:#fff;transition:.2s ease}.modal-detail-employee__action:hover{transform:translateY(-1px);opacity:.95}.modal-detail-employee__action--warning{background:#f59e0b;box-shadow:0 10px 22px #f59e0b29}.modal-detail-employee__action--success{background:#16a34a;box-shadow:0 10px 22px #16a34a29}.modal-detail-employee__action--danger{background:#e11d48;box-shadow:0 10px 22px #e11d4829}.modal-detail-employee__section{margin-top:4px}.modal-detail-employee__sectionTitle{margin:0 0 10px;font-size:14px;font-weight:900;color:#111827eb}.modal-detail-employee__muted{color:#111827a6;font-size:13px}.modal-detail-employee__badgeRow{display:flex;align-items:center;gap:10px;margin-bottom:10px}.modal-detail-employee__badge{display:inline-flex;align-items:center;height:30px;padding:0 12px;border-radius:999px;border:1px solid rgba(16,24,40,.1);background:#40689214;color:#111827d9;font-weight:800;font-size:12px}.modal-detail-employee__tableWrap{width:100%;overflow:auto;border:1px solid rgba(16,24,40,.08);border-radius:12px}.modal-detail-employee__table{width:100%;border-collapse:collapse;min-width:860px}.modal-detail-employee__table th{text-align:left;padding:10px 12px;font-size:12px;color:#111827b3;background:#fff;border-bottom:1px solid rgba(16,24,40,.1)}.modal-detail-employee__table td{padding:10px 12px;font-size:13px;border-bottom:1px solid rgba(16,24,40,.08);color:#111827db}.modal-detail-employee__terminationBox{margin-top:10px;padding:12px;border-radius:12px;border:1px solid rgba(225,29,72,.18);background:#e11d480f}.modal-detail-employee__kpiHead{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:10px}.modal-detail-employee__kpiActions{display:flex;gap:8px;flex-wrap:wrap}.modal-detail-employee__kpiGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.modal-detail-employee__kpiItem{border:1px solid rgba(16,24,40,.08);border-radius:12px;padding:10px 12px;background:#fff;display:flex;align-items:center;justify-content:space-between;gap:10px}.modal-detail-employee__kpiItem label{font-size:12px;color:#111827bf;font-weight:800}.modal-detail-employee__kpiItem span{font-weight:900;color:#111827eb}.modal-detail-employee__kpiItem input{width:92px;height:36px;border-radius:10px;border:1px solid rgba(16,24,40,.12);padding:0 10px;outline:none;text-align:right;font-weight:800}.modal-detail-employee__kpiItem input:focus{border-color:#4068928c;box-shadow:0 0 0 4px #40689224}.modal-detail-employee__kpiTotal{margin-top:10px;padding:10px 12px;border-radius:12px;border:1px solid rgba(16,24,40,.1);background:#0f172a08;font-weight:900}.modal-detail-employee__footer{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.modal-detail-employee__miniBtn{border-radius:12px;padding:10px 14px;border:1px solid rgba(16,24,40,.12);background:#fff;cursor:pointer;font-weight:800}.modal-detail-employee__miniBtn--dark{background:#0f172a;color:#fff;border:none;box-shadow:0 10px 22px #0f172a2e}.modal-detail-employee__miniBtn--save{background:#16a34a;color:#fff;border:none;box-shadow:0 10px 22px #16a34a29}.modal-detail-employee__miniBtn--edit{background:#4068921a;border-color:#40689240}@media(max-width:820px){.modal-detail-employee__grid,.modal-detail-employee__kpiGrid{grid-template-columns:1fr}.modal-detail-employee__table{min-width:760px}.modal-detail-employee__footer{justify-content:stretch}.modal-detail-employee__miniBtn{width:100%}}.total-info-reimburse-hrd{margin-top:4px;font-size:14px;color:#555;background:#eef5ff;padding:5px 10px;border-radius:6px;font-weight:500}.actions-reimburse-hrd{display:flex;gap:10px}.actions-reimburse-hrd select,.actions-reimburse-hrd button{padding:6px 10px;border-radius:6px;border:1px solid #ccc;font-size:13px}.actions-reimburse-hrd button{background:#406892;color:#fff;border:none;cursor:pointer}.actions-reimburse-hrd button:hover{background:linear-gradient(90deg,#1565c0,#1976d2)}.modal-actions-reimburse-hrd button{border:none;border-radius:6px;padding:8px 14px;cursor:pointer}.modal-actions-reimburse-hrd button:first-child{background:#1976d2;color:#fff}.modal-actions-reimburse-hrd button:last-child{background:#ccc}.modal-actions-reimburse-hrd{display:flex;justify-content:space-between;margin-top:10px}.modal-actions-reimburse-hrd button:first-child{background:linear-gradient(90deg,#2196f3,#42a5f5);color:#fff;border:none;border-radius:6px;padding:8px 14px;cursor:pointer}.modal-actions-reimburse-hrd button:first-child:hover{background:linear-gradient(90deg,#1976d2,#2196f3)}.reimburse-table-hrd thead th{background-color:#f5f5f5!important;color:#333!important;font-weight:600;border-bottom:1px solid #ddd}.actions-payroll-hrd{display:flex;align-items:center;gap:10px}.actions-payroll-hrd button{background-color:#406892;color:#fff;border:none;padding:8px 14px;border-radius:6px;cursor:pointer;font-size:12px;transition:.3s}.actions-payroll-hrd button:hover{background-color:#0d47a1}.actions-payroll-hrd select{padding:6px 10px;border-radius:5px;border:1px solid #ccc}.payroll-table-hrd{width:100%;border-collapse:collapse;background-color:#fff;box-shadow:0 2px 5px #0000001a;border-radius:8px;overflow:hidden}.payroll-table-hrd tr:hover{background-color:#f9f9f9}.modal-payroll-hrd{position:fixed;inset:0;display:flex;justify-content:center;align-items:center}.modal-content-payroll{background:#fff;padding:25px;border-radius:8px;width:450px;animation:fadeIn .3s ease}.actions-payroll-hrd input{padding:6px 10px;border:1px solid #ccc;border-radius:6px}.payroll-table-hrd th{background-color:#f5f5f5;color:#0f0f0f}.payroll-table-hrd td b{color:#1976d2}.modal-actions-payroll{display:flex;justify-content:space-between;margin-top:10px}.modal-actions-payroll button:first-child{background-color:#1976d2;color:#fff}.modal-actions-payroll button:last-child{background-color:#ccc}.title-section{display:flex;flex-direction:column;align-items:flex-start}.total-info-hrd{margin-top:5px;font-size:14px;color:#000;padding:6px 10px;border-radius:6px;font-weight:500;box-shadow:0 1px 3px #00000014}.total-info-hrd strong{color:#1976d2}.table-wrapper-payroll-hrd{width:100%;overflow-x:auto;overflow-y:auto;max-height:450px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.table-wrapper-payroll-hrd::-webkit-scrollbar{height:8px;width:8px}.table-wrapper-payroll-hrd::-webkit-scrollbar-thumb{background:#b0bec5;border-radius:4px}.table-wrapper-payroll-hrd::-webkit-scrollbar-thumb:hover{background:#90a4ae}.table-wrapper-payroll-hrd::-webkit-scrollbar-track{background:#f5f5f5;border-radius:4px}.add-btn-payroll-hrd{background:#48f321;color:#fff;border:none;border-radius:6px;padding:8px 14px;cursor:pointer;font-weight:600;transition:.2s}.add-btn-payroll-hrd:hover{background:#1976d2}.slip-modal{position:relative;max-width:400px;text-align:left}.close-btn{position:absolute;top:8px;right:8px;background:transparent;border:none;font-size:18px;cursor:pointer}.modal-actions-payroll{margin-top:15px;display:flex;justify-content:space-between}.modal-actions-payroll button{padding:6px 12px;border:none;border-radius:6px;cursor:pointer}.modal-actions-payroll button:first-child{background:#007bff;color:#fff}.modal-actions-payroll button:last-child{background:#dc3545;color:#fff}.action-buttons{display:flex;justify-content:space-between;gap:15px;margin:20px 0}.action-buttons button{flex:1;padding:12px;background:#005eff;color:#fff;border:none;border-radius:8px;cursor:pointer}.action-buttons button:hover{background:#0041b8}.payroll-modal-wrapper{position:fixed;top:0;left:0;width:100vw;height:100vh;background:transparent;display:flex;justify-content:center;align-items:center;z-index:9999}.payroll-modal-content{background:#fff;padding:20px 25px;width:360px;border-radius:12px;animation:payrollFadeIn .25s ease;box-shadow:0 0 5px #cfcfcf2e;text-align:center}.payroll-modal-content h3{margin-bottom:18px;font-size:18px;font-weight:600;color:#1e1e1e}.payroll-modal-content .action-buttons{display:flex;flex-direction:column;gap:12px}.payroll-modal-content .action-buttons button{padding:10px;border:none;border-radius:8px;background:#1a73e8;color:#fff;cursor:pointer;transition:.2s ease;font-size:14px}.payroll-modal-content .action-buttons button:hover{background:#0d47a1}.payroll-modal-content .modal-actions-payroll{margin-top:18px;display:flex;justify-content:center}.payroll-modal-content .modal-actions-payroll button{padding:8px 16px;background:#ccc;border-radius:8px;border:none;cursor:pointer}@keyframes payrollFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.payroll-edit-modal-wrapper{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#131c2659;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;justify-content:center;align-items:center;z-index:9999;animation:fadeIn .25s ease}.payroll-edit-modal-content{width:430px;background:#fff;padding:25px 28px 30px;border-radius:14px;position:relative;box-shadow:0 10px 28px #0000002e;animation:slideUp .25s ease;max-height:82vh;overflow-y:auto}.payroll-edit-modal-content h3{font-size:20px;font-weight:600;color:#1d1d1d;margin:0 0 20px;text-align:left}.payroll-edit-modal-close{position:absolute;top:12px;right:14px;background:#e3e3e3;border:none;width:30px;height:30px;border-radius:50%;font-size:16px;cursor:pointer;font-weight:600;display:flex;align-items:center;justify-content:center;transition:.2s}.payroll-edit-modal-close:hover{background:#d0d0d0}.payroll-edit-modal-content label{font-size:13px;font-weight:600;color:#333;margin-bottom:4px;display:block}.payroll-edit-modal-content input,.payroll-edit-modal-content select{width:100%;padding:10px 12px;border-radius:8px;border:1px solid #cfcfcf;font-size:14px;margin-bottom:15px;transition:border-color .25s,box-shadow .25s;background:#fafafa}.payroll-edit-modal-content input:focus,.payroll-edit-modal-content select:focus{border-color:#1976d2;box-shadow:0 0 0 3px #1976d233;outline:none}.payroll-edit-modal-content .modal-actions{display:flex;justify-content:space-between;margin-top:10px}.payroll-edit-modal-content .modal-actions button{width:48%;padding:10px 0;border-radius:8px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:.25s}.payroll-edit-modal-content .modal-actions button:first-child{background:#1976d2;color:#fff}.payroll-edit-modal-content .modal-actions button:first-child:hover{background:#0d47a1}.payroll-edit-modal-content .modal-actions button:last-child{background:#e0e0e0;color:#333}.payroll-edit-modal-content .modal-actions button:last-child:hover{background:#c7c7c7}@keyframes slideUp{0%{transform:translateY(25px);opacity:0}to{transform:translateY(0);opacity:1}}.payroll-edit-modal-content::-webkit-scrollbar{width:7px}.payroll-edit-modal-content::-webkit-scrollbar-thumb{background:#b8b8b8;border-radius:10px}.payroll-edit-modal-content::-webkit-scrollbar-thumb:hover{background:#9e9e9e}.container-report{font-family:Poppins,sans-serif;height:100%;color:#333}.report-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;margin-bottom:25px;gap:10px}.title-section h2{font-size:22px;font-weight:500;color:#000;margin:0}.subtitle{font-size:14px;color:#555;margin-top:3px}.actions-report{display:flex;align-items:center;gap:10px}.actions-report select,.actions-report button{padding:8px 14px;border-radius:6px;font-size:14px;border:1px solid #d0d0d0;outline:none;transition:all .25s ease}.actions-report select:hover{border-color:#1976d2}.actions-report button{color:#fff;border:none;cursor:pointer;background-color:#406892;font-weight:500;box-shadow:0 2px 5px #1976d24d}.actions-report button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #1976d266}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-bottom:30px}.card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 6px #00000014;text-align:center;transition:all .25s ease}.card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #0000001f}.card h4{font-size:15px;font-weight:600;color:#1976d2;margin-bottom:5px}.card p{font-size:16px;font-weight:700;color:#333;margin:0}.card.total{background:linear-gradient(90deg,#1976d2,#42a5f5);color:#fff;box-shadow:0 3px 8px #1976d266}.card.total h4,.card.total p{color:#fff}.charts-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:25px;margin-bottom:30px}.chart-box{background:#fff;border-radius:12px;padding:18px;box-shadow:0 3px 8px #00000014;transition:all .3s ease}.chart-box:hover{transform:translateY(-3px);box-shadow:0 5px 12px #0000001f}.chart-box h3{font-size:16px;font-weight:600;margin-bottom:12px;color:#333}.table-wrapper{overflow-x:auto;border-radius:10px;background:#fff;box-shadow:0 2px 6px #00000014}.report-table{width:100%;border-collapse:collapse;min-width:700px}.report-table th,.report-table td{padding:12px 16px;border-bottom:1px solid #eee;text-align:left}.report-table th{background:linear-gradient(90deg,#1976d2,#42a5f5);color:#fff;font-weight:600;font-size:14px;text-transform:uppercase}.report-table td{font-size:14px}.report-table tr:hover{background-color:#f9f9f9}@media(max-width:768px){.charts-container{grid-template-columns:1fr}.summary-cards{grid-template-columns:1fr 1fr}.title-section h2{font-size:18px}.actions-report button,.actions-report select{font-size:13px;padding:7px 10px}}.table-wrapper::-webkit-scrollbar{height:8px}.hrd-report-header .title-section h2{color:#000!important}.hrd-report-header .subtitle{color:#5a8ab0!important}.btn-report{padding:8px 14px;border:none;border-radius:6px;cursor:pointer;color:#fff;background-color:#406892;transition:.25s ease;font-weight:500;box-shadow:0 2px 5px #4068924d}.btn-report:hover{background-color:#345675;transform:translateY(-2px)}.card-hrd{border-top:4px solid #406892;background:#fff;transition:.3s ease}.card-hrd h4{color:#406892!important}.card-hrd:hover{transform:translateY(-4px);box-shadow:0 4px 10px #40689233}.card-hrd-total{background:#406892!important;color:#fff!important;box-shadow:0 4px 10px #40689266}.card-hrd-total h4,.card-hrd-total p{color:#fff!important}.chart-box-hrd{border-left:4px solid #406892}.chart-box-hrd h3{color:#406892!important}.report-table-hrd thead th{background-color:#406892!important;color:#fff!important;font-weight:600;font-size:14px}.report-table-hrd tbody tr:hover{background:#eef3f8!important}.report-table-hrd td{font-size:14px;padding:12px 16px;border-bottom:1px solid #eee}.hrd-report-header select{border:1px solid #b9c7d9;padding:8px 12px;border-radius:6px;transition:.3s}.hrd-report-header select:focus{border-color:#406892}.gradient-removed{background:none!important}.container-profile{display:flex;justify-content:center;align-items:center;height:85vh;font-family:Poppins,sans-serif}.profile-card{background:#fff;padding:30px;border-radius:14px;box-shadow:0 4px 15px #0000001a;text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:center;width:350px;position:relative;transition:.3s}.profile-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000026}.profile-info h2{color:#1976d2;margin:10px 0 5px}.profile-info p{color:#555;margin:0 0 10px;font-size:14px}.role-badge{background:#1976d2;color:#fff;padding:5px 12px;border-radius:8px;font-size:13px;font-weight:500}.profile-actions{margin-top:20px;display:flex;flex-direction:column;gap:8px}.profile-actions button{border:none;border-radius:6px;padding:8px 14px;cursor:pointer;font-size:13px;font-weight:600;transition:.2s}.edit-btn{background:#1976d2;color:#fff}.password-btn{background:#fbc02d;color:#333}.save-btn{background:#43a047;color:#fff}.cancel-btn{background:#e53935;color:#fff}.profile-actions button:hover{opacity:.9}.name-input{font-size:18px;font-weight:600;color:#1976d2;border:1px solid #ccc;border-radius:6px;padding:6px 10px;text-align:center;outline:none}.modal{position:fixed;inset:0;background:#00000073;display:flex;justify-content:center;align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .3s ease;z-index:1000}.modal-content{background:#fffffff7;border-radius:14px;width:360px;padding:25px 58px;box-shadow:0 8px 25px #00000026;text-align:left;animation:popIn .3s ease;transition:all .25s ease;font-family:Poppins,sans-serif}.modal-content h3{color:#1565c0;font-size:18px;font-weight:700;margin-bottom:18px;text-align:center;border-bottom:2px solid #e3f2fd;padding-bottom:10px}.modal-content label{display:block;font-size:13px;margin-bottom:5px;color:#444;font-weight:500}.modal-content input{width:100%;padding:9px 12px;margin-bottom:14px;border:1px solid #ccc;border-radius:8px;font-size:13px;outline:none;transition:all .2s ease}.modal-content input:focus{border-color:#1976d2;box-shadow:0 0 0 2px #1976d226}.modal-actions{display:flex;justify-content:space-between;margin-top:10px;gap:10px}.modal-actions button{flex:1;border:none;border-radius:8px;padding:10px 14px;cursor:pointer;font-size:13px;font-weight:600;transition:all .25s ease}.modal-actions button:first-child{background:linear-gradient(90deg,#1976d2,#42a5f5);color:#fff;box-shadow:0 3px 6px #1976d24d}.modal-actions button:first-child:hover{background:linear-gradient(90deg,#1565c0,#2196f3);transform:translateY(-2px)}.modal-actions button:last-child{background:#e0e0e0;color:#333}.modal-actions button:last-child:hover{background:#d5d5d5}@keyframes popIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.pd-wrap{--primary: #406892;--primary-2: #406892;--bg: #ffffff;--surface: #ffffff;--surface-2: #f2f4f8;--stroke: rgba(16, 24, 40, .1);--stroke-2: rgba(16, 24, 40, .16);--text: rgba(17, 24, 39, .92);--muted: rgba(17, 24, 39, .62);--shadow: 0 14px 32px rgba(15, 23, 42, .08);--shadow-soft: 0 10px 18px rgba(15, 23, 42, .06);--radius-lg: 18px;--radius-md: 14px;--radius-sm: 12px;background:var(--bg);color:var(--text);min-height:100%;box-sizing:border-box;margin:0;padding:0;min-width:400px}.pd-topbar{position:sticky;top:0;z-index:10;padding:16px;border-radius:var(--radius-lg);border:1px solid var(--stroke);background:#ffffffd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-soft);display:flex;gap:14px;align-items:center;justify-content:space-between}.pd-title h3{margin:0;font-size:18px;font-weight:800;letter-spacing:.2px}.pd-title p{margin:6px 0 0;font-size:12.5px;color:var(--muted)}.pd-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.pd-search{width:min(360px,48vw);height:42px;padding:0 14px;border-radius:999px;border:1px solid var(--stroke);background:#fff;color:var(--text);outline:none;transition:.18s ease}.pd-search::placeholder{color:#11182773}.pd-search:focus{border-color:#4068928c;box-shadow:0 0 0 4px #4068922e}.pd-select{height:42px;padding:0 12px;border-radius:999px;border:1px solid var(--stroke);background:#fff;color:var(--text);outline:none;cursor:pointer;transition:.18s ease;min-width:170px}.pd-select:focus{border-color:#4068928c;box-shadow:0 0 0 4px #4068922e}.pd-select option{background:#fff;color:#111827}.pd-create{height:42px;padding:0 14px;border:0;border-radius:999px;cursor:pointer;color:#fff;font-weight:800;letter-spacing:.2px;background:linear-gradient(135deg,var(--primary),var(--primary-2));box-shadow:0 10px 22px #40689238;transition:.18s ease;white-space:nowrap}.pd-create:hover{transform:translateY(-1px);box-shadow:0 14px 26px #40689247}.pd-create:active{transform:translateY(0)}.pd-content{margin-top:14px}.pd-empty{margin-top:16px;padding:18px;border-radius:var(--radius-lg);border:1px dashed rgba(16,24,40,.22);background:#ffffffbf;color:var(--muted)}.pd-kanban{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(160px,340px);gap:14px;align-items:start;padding-bottom:10px;overflow-x:auto;overscroll-behavior-x:contain;scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:rgba(17,24,39,.22) transparent}.pd-kanban::-webkit-scrollbar{height:10px}.pd-kanban::-webkit-scrollbar-track{background:transparent}.pd-kanban::-webkit-scrollbar-thumb{background:#1118272e;border-radius:999px}.pd-kanban::-webkit-scrollbar-thumb:hover{background:#11182747}.pd-col{scroll-snap-align:start;border-radius:var(--radius-lg);border:1px solid var(--stroke);background:#ffffffd9;box-shadow:var(--shadow-soft);overflow:hidden;--col-accent: #94a3b8}.pd-col:hover{border-color:#40689240}.pd-col:nth-child(1){--col-accent: #94a3b8}.pd-col:nth-child(2){--col-accent: #f59e0b}.pd-col:nth-child(3){--col-accent: #3b82f6}.pd-col:nth-child(4){--col-accent: #22c55e}.pd-col:nth-child(5){--col-accent: #a78bfa}.pd-col-header{padding:14px 14px 12px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid rgba(16,24,40,.08);background:linear-gradient(180deg,#fff,#f7f9fc);position:relative}.pd-col-header:before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--col-accent)}.pd-col-header h4{margin:0;padding-left:8px;font-size:13px;font-weight:900;letter-spacing:.25px;text-transform:uppercase;color:#111827e0}.pd-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:24px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:900;color:#111827e0;background:#94a3b82e;border:1px solid rgba(16,24,40,.1)}.pd-col-body{padding:12px;max-height:calc(100vh - 190px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(17,24,39,.18) transparent}.pd-col-body::-webkit-scrollbar{width:10px}.pd-col-body::-webkit-scrollbar-track{background:transparent}.pd-col-body::-webkit-scrollbar-thumb{background:#11182724;border-radius:999px}.pd-col-body::-webkit-scrollbar-thumb:hover{background:#11182738}.pd-empty-col{padding:14px;border-radius:var(--radius-md);border:1px dashed rgba(16,24,40,.22);color:#1118278c;text-align:center;font-size:13px;background:#94a3b814}.pd-task-card{border-radius:var(--radius-md);border:1px solid rgba(16,24,40,.1);background:#fff;box-shadow:0 8px 16px #0f172a0f;padding:12px;margin-bottom:10px;transition:.16s ease;position:relative}.pd-task-card:before{content:"";position:absolute;left:0;top:10px;bottom:10px;width:4px;border-radius:999px;background:var(--col-accent);opacity:.9}.pd-task-card:hover{transform:translateY(-2px);border-color:#4068924d;box-shadow:0 14px 24px #0f172a1a}.pd-task-title{font-size:14px;font-weight:900;color:#111827eb;line-height:1.25;margin-bottom:6px;padding-left:10px}.pd-task-desc{font-size:13px;color:#111827a8;line-height:1.35;margin-bottom:10px;padding-left:10px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.pd-task-meta{display:flex;justify-content:space-between;gap:10px;font-size:12px;color:#11182794;padding-left:10px}.pd-task-card.is-saving{opacity:.65;pointer-events:none;position:relative}.pd-saving-badge{margin-top:10px;display:inline-flex;align-self:flex-start;font-size:12px;padding:6px 10px;border-radius:999px;background:#4068921f;border:1px solid rgba(64,104,146,.25);color:#406892;font-weight:700}@media(max-width:1080px){.pd-topbar{flex-direction:column;align-items:stretch}.pd-actions{justify-content:flex-start}.pd-search{width:100%;min-width:0}.pd-select{min-width:0;flex:1}.pd-create{width:100%}.pd-kanban{grid-auto-columns:minmax(260px,1fr)}}@media(max-width:520px){.pd-wrap{padding:14px}.pd-col-body{max-height:none}.pd-kanban{grid-auto-flow:row;overflow-x:visible;scroll-snap-type:none;grid-auto-columns:minmax(140px,340px)}}.pd-col-body{min-height:120px}.pd-empty-col{pointer-events:auto}.pd-progress{margin-top:10px}.pd-progress-top{display:flex;justify-content:space-between;font-size:12px;opacity:.8;margin-bottom:6px}.pd-progress-bar{height:8px;border-radius:999px;background:#0000001a;overflow:hidden}.pd-progress-fill{height:100%;border-radius:999px;background:#2e7dff;transition:width .2s ease}.sk{position:relative;overflow:hidden;border-radius:10px;background:#0f172a14}.sk:after{content:"";position:absolute;inset:0;transform:translate(-100%);background:linear-gradient(90deg,#fff0,#ffffff8c,#fff0);animation:sk-shimmer 1.1s infinite}.sk-pill{height:22px;border-radius:999px}.sk-bar{height:8px;border-radius:999px}.w-100{width:100%}.w-240{width:240px}.pd-topbar-skeleton,.pd-kanban-skeleton{pointer-events:none}.pd-task-skeleton{border-color:#10182814}.pd-task-skeleton:before{opacity:.35}.ct-overlay{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:9999;padding:16px}.ct-modal{width:min(880px,100%);background:#fff;border-radius:18px;border:1px solid rgba(16,24,40,.12);box-shadow:0 20px 60px #0f172a2e;overflow:hidden}.ct-header{display:flex;justify-content:space-between;align-items:start;gap:12px;padding:16px 18px;background:linear-gradient(180deg,#fff,#f7f9fc);border-bottom:1px solid rgba(16,24,40,.08)}.ct-header h3{margin:0;font-size:18px;font-weight:900;color:#111827eb}.ct-header p{margin:6px 0 0;font-size:12.5px;color:#1118279e}.ct-x{border:0;background:#4068921a;color:#406892;width:36px;height:36px;border-radius:12px;cursor:pointer;font-weight:900}.ct-error{margin:14px 18px 0;padding:10px 12px;border-radius:12px;background:#ef44441a;color:#b91c1cf2;border:1px solid rgba(239,68,68,.22);font-size:13px}.ct-form{padding:16px 18px 18px}.ct-field{display:grid;gap:6px}.ct-field span{font-size:12px;font-weight:800;color:#111827b3}.ct-field input,.ct-field select,.ct-field textarea{height:42px;padding:0 12px;border-radius:12px;border:1px solid rgba(16,24,40,.12);outline:none;background:#fff;color:#111827eb;transition:.15s ease}.ct-field textarea{height:auto;padding:10px 12px;resize:vertical;min-height:110px}.ct-file{font-size:12px;color:#1118279e}.ct-actions{margin-top:14px;display:flex;justify-content:flex-end;gap:10px}.ct-btn{height:42px;padding:0 14px;border-radius:999px;cursor:pointer;font-weight:900;border:1px solid rgba(16,24,40,.12);background:#fff;color:#111827eb}.ct-btn.ghost{background:#94a3b81a}.ct-btn.primary{border:0;background:linear-gradient(135deg,#406892,#2f567b);color:#fff;box-shadow:0 10px 22px #6895c5}.et-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;padding:18px;z-index:9999}.et-modal{width:min(920px,100%);background:#fff;border-radius:18px;border:1px solid rgba(0,0,0,.08);box-shadow:0 24px 70px #00000040;overflow:hidden}.et-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:16px 18px;background:linear-gradient(180deg,#4068921a,#40689208);border-bottom:1px solid rgba(0,0,0,.08)}.et-header h3{margin:0;font-size:18px}.et-header p{margin:6px 0 0;color:#6b7280;font-size:13px}.et-x{border:1px solid rgba(0,0,0,.08);background:#fff;width:36px;height:36px;border-radius:12px;cursor:pointer}.et-error{margin:14px 18px 0;padding:10px 12px;border-radius:12px;background:#ef44441a;color:#b91c1c;border:1px solid rgba(239,68,68,.2);font-size:13px}.et-form{padding:16px 18px 18px}.et-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.et-field span{font-size:12px;color:#4b5563;font-weight:700}.et-field input,.et-field select,.et-field textarea{border:1px solid rgba(0,0,0,.1);border-radius:12px;padding:10px 12px;outline:none;background:#fff}.et-field input:focus,.et-field select:focus,.et-field textarea:focus{border-color:#4068928c;box-shadow:0 0 0 4px #40689226}.et-file{display:block;margin-top:6px;color:#6b7280;font-size:12px}.et-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:14px}.et-actions-right{display:flex;gap:10px}.et-btn{height:40px;padding:0 14px;border-radius:999px;border:1px solid rgba(0,0,0,.1);background:#fff;cursor:pointer;font-weight:800}.et-btn.primary{border:0;background:#406892;color:#fff}.et-btn.primary:hover{filter:brightness(1.05)}.et-btn.ghost{background:#40689214;color:#406892;border-color:#40689233}.et-btn.danger{background:#ef44441a;color:#b91c1c;border-color:#ef444440}@media(max-width:760px){.et-grid{grid-template-columns:1fr}.et-actions{flex-direction:column;align-items:stretch}.et-actions-right,.et-btn{width:100%}}.att-topbar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:4px}.att-title h2{margin:0;font-size:18px;font-weight:800;letter-spacing:.2px}.att-title p{margin:6px 0 0;font-size:12.5px;color:#1118279e}.att-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}@media(max-width:760px){.att-topbar{flex-direction:column;align-items:stretch}.att-actions{justify-content:flex-start}.att-filters{grid-template-columns:1fr}.att-date-input{border-radius:14px}}@media(max-width:520px){.attendance-container{padding:8px}.att-title h2{font-size:16px}.att-title p{font-size:12px}.att-history-head{flex-direction:column;align-items:flex-start}.camera-box{padding:12px}}.departments-container{font-family:Poppins,sans-serif;color:#111827eb;background:#fff;min-height:100%;box-sizing:border-box;min-width:400px}.departments-wrap{width:98%;display:flex;flex-direction:column;gap:5px}.departments-topbar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:4px}.departments-title h2{margin:0;font-size:18px;font-weight:800;letter-spacing:.2px}.departments-title p{margin:6px 0 0;font-size:12.5px;color:#1118279e}.departments-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.departments-filters{display:grid;grid-template-columns:1fr 120px;gap:12px;align-items:center}.departments-history{max-height:56vh;overflow:auto}.departments-table{width:100%;border-collapse:collapse;min-width:740px}.departments-table thead th{position:sticky;top:0;background:#fff;z-index:0;border-bottom:1px solid rgba(16,24,40,.1);text-align:left;padding:12px 14px;font-size:12px;letter-spacing:.25px;text-transform:uppercase;color:#111827b3}.departments-table tbody td{padding:10px 14px;border-bottom:1px solid rgba(16,24,40,.08);font-size:13px;color:#111827db;vertical-align:middle}.departments-table tbody tr:hover{background:#4068920f}.departments-name{font-weight:800;color:#111827eb}.departments-badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.2px;border:1px solid rgba(16,24,40,.1);background:#94a3b81f}.departments-badge.active{background:#22c55e1f;border-color:#22c55e33;color:#15803df2}.departments-badge.inactive{background:#e74c3c1a;border-color:#e74c3c33;color:#b91c1cf2}.dept-error{margin-top:10px;padding:10px 12px;border-radius:12px;border:1px solid rgba(231,76,60,.25);background:#e74c3c14;color:#b91c1cf2;font-weight:700;font-size:13px}@media(max-width:760px){.departments-topbar{flex-direction:column;align-items:stretch}.departments-actions{justify-content:flex-start}.departments-filters,.detail-grid{grid-template-columns:1fr}}.positions-container{font-family:Poppins,sans-serif;color:#111827eb;background:#fff;min-height:100%;box-sizing:border-box;min-width:400px}.positions-wrap{width:98%;display:flex;flex-direction:column;gap:5px}.positions-topbar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:4px}.positions-title h2{margin:0;font-size:18px;font-weight:800;letter-spacing:.2px}.positions-title p{margin:6px 0 0;font-size:12.5px;color:#1118279e}.positions-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.positions-filters{display:grid;grid-template-columns:1fr 120px;gap:12px;align-items:center}.positions-history{max-height:56vh;overflow:auto}.positions-table{width:100%;border-collapse:collapse;min-width:740px}.positions-table thead th{position:sticky;top:0;background:#fff;z-index:0;border-bottom:1px solid rgba(16,24,40,.1);text-align:left;padding:12px 14px;font-size:12px;letter-spacing:.25px;text-transform:uppercase;color:#111827b3}.positions-table tbody td{padding:10px 14px;border-bottom:1px solid rgba(16,24,40,.08);font-size:13px;color:#111827db;vertical-align:middle}.positions-table tbody tr:hover{background:#4068920f}.positions-name{font-weight:800;color:#111827eb}.positions-badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.2px;border:1px solid rgba(16,24,40,.1);background:#94a3b81f}.positions-badge.active{background:#22c55e1f;border-color:#22c55e33;color:#15803df2}.positions-badge.inactive{background:#e74c3c1a;border-color:#e74c3c33;color:#b91c1cf2}.modal{position:fixed;inset:0;background:#02061773;display:flex;justify-content:center;align-items:center;z-index:200;padding:18px}.modal-content{width:min(520px,100%);background:#fff;border-radius:16px;padding:14px;border:1px solid rgba(16,24,40,.1);box-shadow:0 20px 50px #0f172a38}.modal-content h3{margin:0 0 10px;font-size:16px;font-weight:900}.modal-content label{display:block;font-size:12px;margin:10px 0 6px;color:#111827ad;font-weight:700}.modal-content input{width:100%;height:44px;padding:0 12px;border-radius:12px;border:1px solid rgba(16,24,40,.12);outline:none;font-size:14px;background:#fff}.modal-content input:focus{border-color:#4068928c;box-shadow:0 0 0 4px #40689224}.modal-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}.modal-actions button{height:44px;border-radius:12px;border:1px solid rgba(16,24,40,.12);font-weight:800;cursor:pointer;background:#fff}.modal-actions button[type=submit]{background:#4068921f;border-color:#40689240}.pos-error{margin-top:10px;padding:10px 12px;border-radius:12px;border:1px solid rgba(231,76,60,.25);background:#e74c3c14;color:#b91c1cf2;font-weight:700;font-size:13px}.sk-row td{padding-top:12px;padding-bottom:12px}.detail-head h3{margin:0;font-size:15px;font-weight:900}.detail-value{font-size:13px;font-weight:800;color:#111827e6}.detail-actions{margin-top:6px}@media(max-width:760px){.positions-topbar{flex-direction:column;align-items:stretch}.positions-actions{justify-content:flex-start}.positions-filters,.detail-grid{grid-template-columns:1fr}}.form-container{max-width:600px;margin:50px auto;background:#fff;padding:30px 40px;border-radius:12px;box-shadow:0 5px 20px #0000001a;font-family:Poppins,sans-serif}.form-container h2{text-align:center;margin-bottom:10px;color:#007bff}.form-container p{text-align:center;font-size:14px;margin-bottom:25px;color:#555}.job-form{display:flex;flex-direction:column;gap:15px}.job-form label{font-weight:600;font-size:14px;color:#333}.job-form input[type=text],.job-form input[type=email],.job-form input[type=file]{padding:10px;border-radius:8px;border:1px solid #ccc;font-size:14px;outline:none;transition:.2s}.job-form input:focus{border-color:#007bff}.job-form button{background-color:#007bff;border:none;color:#fff;padding:10px;border-radius:8px;font-size:15px;cursor:pointer;transition:.3s}.job-form button:hover{background-color:#0056b3}.container-leftbar-staff{width:100%;height:100%;box-shadow:0 4px 10px #0000001f;background:#fff;display:flex;flex-direction:column;overflow:hidden}.top-leftbar-staff{width:80%;height:5%;padding:10px 12px;display:flex;justify-content:center;align-items:center;gap:5%;border-bottom:1px solid rgba(16,24,40,.1)}.top-leftbar-staff h1{margin:0;font-size:20px;font-weight:500;color:#0f172a;line-height:1.2}.menu-leftbar-staff{display:flex;flex-direction:column;gap:6px;padding:12px;overflow-y:auto}.menu-leftbar-staff span{display:flex;align-items:center;gap:10px;font-size:14px;color:#0f172ae6;padding:10px 12px;border-radius:10px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s ease,color .2s ease}.menu-leftbar-staff span:hover{background-color:#0f172a0f}.menu-leftbar-staff span.active-menu{background-color:#1976d21f;color:#1976d2;font-weight:700}.submenu-staff{margin-left:12px;display:flex;flex-direction:column;gap:4px;padding-left:8px;border-left:2px solid rgba(16,24,40,.08)}.submenu-staff span{font-size:13px;padding:8px 10px;border-radius:8px;color:#0f172ac7}.submenu-staff span:hover{background-color:#0f172a0f}.submenu-staff span.active-menu{background-color:#1976d21a;color:#1976d2;font-weight:700}.dash-card-head h2{margin:0;font-size:15px;color:#000}.dash-card-head p{margin:4px 0 0;font-size:11.5px;color:#0000009e}.dash-event,.dash-next-info{display:flex;flex-direction:column;align-items:center;gap:10px}.dash-event img,.dash-next-info img{width:54px;height:54px;border-radius:12px;object-fit:cover;border:1px solid rgba(16,24,40,.1)}.skeleton{animation:pulse 1.4s ease-in-out infinite}.skeleton-img{width:64px;height:64px;border-radius:12px;background:#e5e7eb}.skeleton-line{height:14px;background:#e5e7eb;border-radius:8px;margin-top:6px}.skeleton-line.title{width:160px;height:16px}.skeleton-line.subtitle{width:120px}.skeleton-line.small{width:60px;height:12px;margin-bottom:6px}@keyframes pulse{0%{opacity:1}50%{opacity:.45}to{opacity:1}}.actions-reimburse-user{display:flex;gap:10px}.actions-reimburse-user select,.actions-reimburse-user button{padding:6px 10px;border-radius:6px;border:1px solid #ccc;font-size:13px}.actions-reimburse-user button{background:#406892;color:#fff;border:none;cursor:pointer}.actions-reimburse-user button:hover{background:linear-gradient(90deg,#1565c0,#1976d2)}.reimburse-table-staff thead th{background-color:#f5f5f5!important;color:#333!important;font-weight:600;border-bottom:1px solid #ddd}.payroll-table-staff{width:100%;border-collapse:collapse;background-color:#ffffffc5;box-shadow:0 2px 5px #0000001a;border-radius:8px;overflow:hidden}.payroll-table-staff th,.payroll-table-staff td{padding:10px;border-bottom:1px solid #eee;text-align:left}.payroll-table-staff th{background-color:#f1f1f1;font-weight:600}.payroll-table-staff tr:hover{background-color:#f9f9f9}.payroll-table-staff th{background:linear-gradient(90deg,#d21919,#f54242);color:#fff}.payroll-table-staff td b{color:#1976d2}.payroll-table-staff thead th{background-color:#f5f5f5!important;color:#333!important;font-weight:600}.payroll-table-staff{width:100%;border-collapse:collapse;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 1px 4px #00000014}.payroll-table-staff thead th{background:#f5f5f5!important;color:#333!important;font-weight:600;padding:12px 10px;font-size:13px;border-bottom:1px solid #e0e0e0}.payroll-table-staff tbody td{padding:10px 12px;font-size:12px;color:#333;border-bottom:1px solid #f1f1f1}.payroll-table-staff tbody tr:hover{background:#fafafa}.payroll-table-staff tbody td b{color:#1976d2;font-weight:600}.modal-content{background:#fff;padding:22px 26px;border-radius:12px;width:430px;animation:fadeIn .25s ease;box-shadow:0 6px 18px #00000026;border:1px solid #e8e8e8}.modal-content h3{background:#f5f5f5!important;padding:12px 14px;border-radius:8px;font-size:16px;margin:0 0 15px;color:#333;border:1px solid #e0e0e0}.modal-content p{font-size:13px;margin:3px 0}.modal-actions{display:flex;justify-content:space-between;margin-top:12px}.modal-actions button{flex:1;margin:0 4px;padding:9px;border-radius:8px;font-weight:600;border:none;cursor:pointer;transition:.2s ease}.modal-actions button:first-child{background:#e0e0e0;color:#333}.modal-actions button:first-child:hover{background:#d5d5d5}.modal-actions .btn-export{background:#2ecc71;color:#fff}.modal-actions .btn-export:hover{background:#27ae60}.att-topbar-staff{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:4px}.att-title-staff h2{margin:0;font-size:18px;font-weight:800;letter-spacing:.2px}.att-title-staff p{margin:6px 0 0;font-size:12.5px;color:#1118279e}.att-actions-staff{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}@media(max-width:760px){.att-topbar-staff{flex-direction:column;align-items:stretch}.att-actions-staff{justify-content:flex-start}.att-filters{grid-template-columns:1fr}.att-date-input{border-radius:14px}}@media(max-width:520px){.attendance-container{padding:8px}.att-title-staff h2{font-size:16px}.att-title-staff p{font-size:12px}.att-history-staff{flex-direction:column;align-items:flex-start}.camera-box{padding:12px}}.detail-staff{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;position:sticky;top:0;background:#fff;padding-bottom:8px;z-index:2;border-bottom:1px solid rgba(16,24,40,.08)}.detail-staff h3{margin:0;font-size:15px;font-weight:800}@media(max-width:420px){.detail-box{max-height:90vh;padding:10px}.detail-staff h3{font-size:14px}}.top-mainbar{width:100%;height:60px;display:flex;align-items:center;justify-content:space-between}.left-placeholder{width:32px;height:32px}.profile-container{position:relative;display:flex;align-items:center}.profile-dropdown{position:absolute;top:60px;right:0;background:#fff;border-radius:10px;box-shadow:0 6px 20px #0000001a;padding:12px;width:180px;animation:fadeIn .2s ease;z-index:999}.profile-dropdown hr{border:none;height:1px;background:#eee;margin:8px 0}.profile-name{font-weight:600;font-size:15px;color:#333}.profile-role{font-size:13px;color:#666}.dropdown-item{width:100%;text-align:left;background:none;border:none;padding:8px 0;font-size:14px;cursor:pointer;color:#333;border-radius:6px;transition:background .2s}.dropdown-item:hover{background:#f5f5f5}.dropdown-item.logout{color:#e53935;font-weight:600}.dropdown-item.logout:hover{background:#fdecea}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.leftbar-mobile-wrapper{display:none}@media(max-width:1080px){.leftbar-mobile-wrapper{display:block;overflow:hidden;max-height:0;opacity:0;transform:translateY(-8px);transition:max-height .35s ease,opacity .25s ease,transform .25s ease;margin-top:8px;border-radius:12px;background:#fff;box-shadow:0 6px 20px #00000014}.leftbar-mobile-wrapper.open{max-height:70vh;opacity:1;transform:translateY(0)}}.dash-container{font-family:Poppins,sans-serif;color:#111827eb;width:100%;height:85vh;box-sizing:border-box;display:flex;flex-direction:column;background:transparent}.dash-top{width:100%;height:30%;display:grid;grid-template-columns:1fr 1fr;align-items:stretch}.dash-bottom{width:100%;flex:1;height:70%;display:flex}.dash-card{width:100%;height:100%;display:flex;flex-direction:column;gap:10px;box-sizing:border-box}.clickable{cursor:pointer}.clickable:hover{background:#4068920a;border-radius:12px}.clickable-text{cursor:pointer}.dash-card-head h2{margin:0;font-size:15px;font-weight:800;letter-spacing:.2px}.dash-card-head p{margin:4px 0 0;font-size:11.5px;color:#1118279e}.dash-happening{display:grid;grid-template-columns:1fr 2px 1fr;gap:12px;align-items:center}.dash-event,.dash-next-info{display:flex;align-items:center;gap:10px}.dash-event img,.dash-next-info img{width:54px;height:54px;border-radius:12px;object-fit:cover;border:1px solid rgba(16,24,40,.1);background:#f3f4f6}.dash-event-info h3,.dash-next-info h3{margin:0;font-size:12.5px;font-weight:800}.dash-event-info p,.dash-next-info p{margin:2px 0 0;font-size:11.5px;color:#1118279e}.dash-divider{width:2px;height:48px;background:#1018281a;border-radius:999px}.dash-next-label{margin:0 0 6px;font-size:11.5px;font-weight:700;color:#1118279e}.dash-scroll{overflow:auto;padding-right:6px;max-height:160px}.dash-request{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:9px 11px;border-radius:12px;border:1px solid rgba(16,24,40,.08);background:#fff;cursor:pointer;transition:.2s ease;margin-bottom:10px}.dash-request:hover{transform:translateY(-1px);background:#4068920d;border-color:#4068922e}.dash-request-info strong{font-weight:800}.dash-request-reason{font-size:11.5px;color:#1118279e;margin-top:2px}.dash-request-status{font-size:11.5px;font-weight:800;border-radius:999px;padding:6px 10px;border:1px solid rgba(16,24,40,.1);background:#94a3b81f;white-space:nowrap}.dash-request.approved .dash-request-status{background:#22c55e1f;border-color:#22c55e33;color:#15803df2}.dash-request.pending .dash-request-status{background:#f39c121f;border-color:#f39c1233;color:#b45309f2}.dash-request.rejected .dash-request-status{background:#e74c3c1a;border-color:#e74c3c33;color:#b91c1cf2}.dash-modal{position:fixed;inset:0;background:#02061773;display:flex;justify-content:center;align-items:center;z-index:9999;padding:14px}.dash-modal-box{width:min(560px,96vw);max-height:85vh;overflow:auto;background:#fff;border-radius:16px;padding:14px;border:1px solid rgba(16,24,40,.1);box-shadow:0 20px 50px #0f172a38}.dash-modal-box.calendar{width:min(560px,96vw)}.dash-modal-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid rgba(16,24,40,.08)}.dash-modal-head h3{margin:0;font-size:14px;font-weight:800}.dash-modal-head button{border:0;background:#0f172a0f;width:34px;height:34px;border-radius:10px;cursor:pointer}.dash-legend{margin-top:12px;display:flex;justify-content:space-evenly;gap:10px;background:#f5f7fa;border-radius:10px;padding:10px;font-size:12px;color:#111827b8}.calendar-dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:6px}.holiday-dot{background-color:#ff5c5c;box-shadow:0 0 6px #ff5c5cb3}.birthday-dot{background-color:#f1c40f;box-shadow:0 0 6px #f1c40fb3}.dash-bday{margin-top:14px;background:#fff;border:1px solid rgba(16,24,40,.1);border-radius:14px;padding:12px}.dash-bday h4{margin:0 0 10px;font-size:13px;font-weight:800}.dash-bday ul{list-style:none;padding:0;margin:0}.dash-bday li{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px dashed rgba(16,24,40,.1)}.dash-bday li:last-child{border-bottom:none}.dash-bday li img{width:36px;height:36px;border-radius:12px;object-fit:cover;border:1px solid rgba(16,24,40,.1)}.post-wrap{width:100%;height:100%;display:flex;flex-direction:column;gap:12px}.post-compose{display:grid;grid-template-columns:1fr 130px;gap:10px;align-items:start}.post-compose textarea{width:95%;min-height:62px;resize:none;border-radius:14px;border:1px solid rgba(16,24,40,.12);padding:10px 12px;font-size:12.5px;outline:none;font-family:Poppins,sans-serif;background:#fff}.post-compose textarea:focus{border-color:#4068928c;box-shadow:0 0 0 4px #40689224}.post-list{flex:1;overflow-y:auto;padding-right:6px;border-top:1px solid rgba(16,24,40,.08);padding-top:12px}.post-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid rgba(16,24,40,.08)}.post-avatar{width:40px;height:40px;border-radius:14px;object-fit:cover;border:1px solid rgba(16,24,40,.1);background:#f3f4f6}.post-body{flex:1;display:flex;flex-direction:column}.post-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.post-author{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.post-name{font-weight:800;font-size:12.5px}.post-time{font-size:11.5px;color:#11182794}.post-menu{display:flex;gap:8px}.post-mini{border:0;width:20px;height:20px;border-radius:10px;cursor:pointer;transition:.15s ease;background-color:transparent}.post-mini:hover{background:#40689224}.post-mini.danger:hover{background:#e74c3c24}.post-message{margin:0;font-size:12.5px;color:#111827db;white-space:pre-line}.post-meta{display:flex;gap:12px;font-size:11.5px;color:#1118279e;margin-top:4px}.post-edit{display:flex;flex-direction:column;gap:10px}.post-edit textarea{width:97%;resize:vertical;min-height:72px;border-radius:14px;border:1px solid rgba(16,24,40,.12);padding:10px 12px;outline:none;font-size:12.5px;font-family:Poppins,sans-serif;background:#fff}.post-edit textarea:focus{border-color:#4068928c;box-shadow:0 0 0 4px #40689224}.post-edit-actions{display:flex;gap:10px;flex-wrap:wrap}.empty-text{margin:0;padding:14px 0;font-size:12px;color:#11182799}.dash-scroll::-webkit-scrollbar,.post-list::-webkit-scrollbar,.dash-modal-box::-webkit-scrollbar{width:6px}.dash-scroll::-webkit-scrollbar-thumb,.post-list::-webkit-scrollbar-thumb,.dash-modal-box::-webkit-scrollbar-thumb{background-color:#9696964d;border-radius:10px}.react-calendar{width:100%;border:1px solid rgba(16,24,40,.08);border-radius:14px;background:#fff;box-shadow:0 10px 22px #0f172a0d;padding:10px;font-family:Poppins,sans-serif;color:#111827e6}.react-calendar__navigation{display:flex;gap:8px;margin-bottom:10px}.react-calendar__navigation button{background:#0f172a0f;border:1px solid rgba(16,24,40,.1);border-radius:12px;color:#111827db;padding:8px 10px;cursor:pointer;transition:.2s ease;font-weight:700}.react-calendar__navigation button:hover{background:#4068921f;border-color:#4068922e}.react-calendar__month-view__weekdays{text-transform:uppercase;font-size:11px;color:#1118278c}.react-calendar__tile{height:44px;border-radius:12px;transition:.2s ease}.react-calendar__tile:hover{background:#40689214;transform:translateY(-1px)}.react-calendar__tile--now{background:#4068921f;border:1px solid rgba(64,104,146,.4);font-weight:800;color:#406892f2}.react-calendar__tile--active{background:#406892!important;color:#fff!important;font-weight:800}@media(max-width:980px){.dash-top{grid-template-columns:1fr}.dash-bottom{min-height:520px}}@media(max-width:760px){.dash-happening{grid-template-columns:1fr}.dash-divider{display:none}.post-compose{grid-template-columns:1fr}.dash-scroll{max-height:220px}}@media(max-width:520px){.dash-container{padding:10px}.dash-modal{align-items:flex-end;padding:6px}.dash-modal-box{width:100%;border-radius:16px}.post-item{gap:10px}.post-avatar{width:38px;height:38px;border-radius:12px}.post-mini{width:30px;height:30px;border-radius:10px}}.dash-scroll.compact{max-height:150px}.leave-mini{width:100%;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:8px 10px;border-radius:12px;border:1px solid rgba(16,24,40,.08);background:#fff;cursor:pointer;transition:.15s ease;margin-bottom:8px;text-align:left}.leave-mini:hover{transform:translateY(-1px);background:#4068920d;border-color:#4068922e}.leave-mini-left{flex:1;min-width:0}.leave-mini-name{font-size:12px;font-weight:800;line-height:1.2}.leave-mini-sub{margin-top:2px;font-size:11px;color:#1118279e}.leave-mini-note{margin-top:4px;font-size:11px;color:#111827b3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leave-mini-badge{font-size:11px;font-weight:800;border-radius:999px;padding:5px 9px;border:1px solid rgba(16,24,40,.1);background:#94a3b81f;white-space:nowrap}.leave-mini-badge.approved{background:#22c55e1f;border-color:#22c55e33;color:#15803df2}.leave-mini-badge.requested{background:#f39c121f;border-color:#f39c1233;color:#b45309f2}.leave-mini-badge.rejected{background:#e74c3c1a;border-color:#e74c3c33;color:#b91c1cf2}.leave-mini-badge.cancelled{background:#6366f11a;border-color:#6366f133;color:#4338caf2}.leave-modal .modal-sub{margin:6px 0 0;font-size:12px;color:#11182799}.leave-detail{display:flex;flex-direction:column;gap:14px}.leave-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.leave-kv{border:1px solid rgba(16,24,40,.08);border-radius:14px;padding:10px;background:#fff}.leave-kv span{display:block;font-size:11px;color:#1118278c;margin-bottom:4px}.leave-kv strong{font-size:12.5px;color:#111827e6}.leave-actions{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;border-top:1px solid rgba(16,24,40,.08);padding-top:12px}.leave-select label{display:block;font-size:11px;color:#11182799;margin-bottom:6px;font-weight:700}.leave-select select{height:40px;border-radius:12px;border:1px solid rgba(16,24,40,.12);padding:0 12px;outline:none;font-family:Poppins,sans-serif;font-size:12px}.leave-btns{display:flex;gap:10px;align-items:center}.btn-soft{height:40px;padding:0 12px;border-radius:12px;border:1px solid rgba(16,24,40,.12);background:#0f172a0a;cursor:pointer;font-weight:800}.btn-primary{height:40px;padding:0 14px;border-radius:12px;border:0;background:#406892;color:#fff;cursor:pointer;font-weight:800}.btn-primary:disabled,.btn-soft:disabled{opacity:.6;cursor:not-allowed}@media(max-width:520px){.leave-detail-grid{grid-template-columns:1fr}}.leave-modal-tools{display:flex;gap:10px;align-items:center;margin-bottom:12px}.leave-search{flex:1;height:40px;border-radius:12px;border:1px solid rgba(16,24,40,.12);padding:0 12px;outline:none;font-size:12.5px;font-family:Poppins,sans-serif}.leave-search:focus{border-color:#4068928c;box-shadow:0 0 0 4px #4068921f}.leave-modal-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:12px}.leave-modal-list{max-height:55vh;overflow:auto;padding-right:6px;border-right:1px solid rgba(16,24,40,.08)}.leave-mini.in-modal{width:100%;text-align:left;background:#fff;border:1px solid rgba(16,24,40,.1);border-radius:14px;padding:10px 12px;margin-bottom:10px;cursor:pointer;transition:.15s ease}.leave-mini.in-modal:hover{background:#4068920d;border-color:#4068922e;transform:translateY(-1px)}.leave-mini.in-modal.active{border-color:#4068928c;box-shadow:0 0 0 4px #4068921a}.leave-modal-detail{padding-left:2px}.modal-sub{margin:4px 0 0;font-size:12px;color:#1118279e}@media(max-width:760px){.leave-modal-grid{grid-template-columns:1fr}.leave-modal-list{border-right:none;border-bottom:1px solid rgba(16,24,40,.08);padding-bottom:10px;max-height:35vh}}.dash-modal-box.leave-apply{width:min(640px,92vw);max-height:86vh;overflow:auto;padding:16px;border-radius:16px}.leave-apply .dash-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding-bottom:12px;border-bottom:1px solid rgba(15,23,42,.08);margin-bottom:12px}.leave-apply .dash-modal-head h3{margin:0;font-size:18px;font-weight:800;color:#0f172a}.leave-apply .dash-modal-head .modal-sub{margin:4px 0 0;font-size:12px;color:#0f172a99;line-height:1.35}.leave-apply .dash-modal-head button{width:36px;height:36px;border-radius:10px;border:1px solid rgba(15,23,42,.12);background:#ffffffe6;cursor:pointer;color:#0f172ab3;transition:.15s ease}.leave-apply .dash-modal-head button:hover{background:#0f172a0a;transform:translateY(-1px)}.apply-error{margin:10px 0 0;padding:10px 12px;border-radius:12px;background:#ef444414;border:1px solid rgba(239,68,68,.18);color:#b91c1c;font-size:13px}.leave-apply-form{display:grid;gap:12px;margin-top:12px}.leave-apply-form label{display:grid;gap:8px;font-size:13px;font-weight:700;color:#0f172ad9}.leave-apply-form select,.leave-apply-form input[type=date],.leave-apply-form textarea{width:100%;border:1px solid rgba(15,23,42,.14);background:#fff;border-radius:12px;padding:10px 12px;font-size:13px;color:#0f172a;outline:none;transition:.15s ease}.leave-apply-form textarea{resize:vertical;min-height:88px;line-height:1.35}.leave-apply-form textarea::placeholder{color:#0f172a73}.leave-apply-form select:focus,.leave-apply-form input[type=date]:focus,.leave-apply-form textarea:focus{border-color:#4068928c;box-shadow:0 0 0 4px #40689224}.apply-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.apply-actions{display:flex;justify-content:flex-end;align-items:center;gap:10px;margin-top:4px;padding-top:10px;border-top:1px solid rgba(15,23,42,.08)}.leave-apply .btn-soft{padding:10px 14px;border-radius:12px;border:1px solid rgba(15,23,42,.14);background:#0f172a08;cursor:pointer;font-weight:700;color:#0f172acc;transition:.15s ease}.leave-apply .btn-soft:hover{background:#0f172a0f;transform:translateY(-1px)}.leave-apply .btn-primary{padding:10px 14px;border-radius:12px;border:0;cursor:pointer;font-weight:800;color:#fff;background:#406892;transition:.15s ease}.leave-apply .btn-primary:hover{filter:brightness(1.03);transform:translateY(-1px)}.leave-apply .btn-primary:disabled,.leave-apply .btn-soft:disabled{opacity:.65;cursor:not-allowed;transform:none}@media(max-width:520px){.apply-row{grid-template-columns:1fr}.dash-modal-box.leave-apply{padding:14px}.apply-actions{flex-direction:column-reverse;align-items:stretch}.leave-apply .btn-soft,.leave-apply .btn-primary{width:100%}}.leave-mini.skeleton{pointer-events:none;cursor:default;opacity:.9}.sk-line,.sk-badge{background:#0f172a14;border-radius:10px;position:relative;overflow:hidden}.sk-line:after,.sk-badge:after{content:"";position:absolute;inset:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);animation:sk-shimmer 1.15s infinite}.sk-name{height:12px;width:55%;margin-bottom:8px}.sk-sub{height:10px;width:80%;margin-bottom:8px}.sk-note{height:10px;width:65%}.sk-badge{height:22px;width:90px;border-radius:999px}.container-reimburse{font-family:Poppins,sans-serif}.reimburse-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:20px}.title-section h2{font-size:22px;font-weight:500;color:#1e1e1e}.total-info{margin-top:4px;font-size:14px;color:#555;background:#eef5ff;padding:5px 10px;border-radius:6px;font-weight:500}.actions-reimburse-head{display:flex;gap:10px}.actions-reimburse-head select,.actions-reimburse-head button{padding:6px 10px;border-radius:6px;border:1px solid #ccc;font-size:13px}.actions-reimburse-head button{background:#406892;color:#fff;border:none;cursor:pointer}.actions-reimburse-head button:hover{background:linear-gradient(90deg,#1565c0,#1976d2)}.table-wrapper{width:100%;overflow-x:auto;overflow-y:auto;max-height:450px;border-radius:8px}.reimburse-table{width:100%;border-collapse:collapse;background:#fff}.reimburse-table th,.reimburse-table td{padding:10px;border-bottom:1px solid #eee;font-size:13px;text-align:left}.reimburse-table th{background:linear-gradient(90deg,#1976d2,#42a5f5);color:#fff;position:sticky;top:0}.status-badge{padding:5px 10px;border-radius:5px;font-size:11px;font-weight:600;text-transform:uppercase}.status-badge.pending{background:#fff3cd;color:#856404}.status-badge.approved{background:#c8e6c9;color:#256029}.status-badge.rejected{background:#ffcdd2;color:#b71c1c}.status-badge.paid{background:#bbdefb;color:#0d47a1}.view-detail,.approve-btn,.reject-btn,.paid-btn{padding:4px 8px;border:none;border-radius:5px;margin-right:4px;cursor:pointer;font-size:11px;transition:all .3s ease}.view-detail{background:#0288d1;color:#fff}.view-detail:hover{background:#0277bd}.approve-btn{background:#43a047;color:#fff}.approve-btn:hover{background:#2e7d32}.reject-btn{background:#e53935;color:#fff}.reject-btn:hover{background:#b71c1c}.paid-btn{background:#ffb300;color:#000}.paid-btn:hover{background:#f9a825}.modal{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center}.modal-content{background:#fff;padding:20px;border-radius:8px;width:350px;animation:fadeIn .25s ease;height:600px;overflow:scroll}.modal-content h3{color:#1976d2;margin-bottom:10px}.modal-content input,.modal-content select,.modal-content textarea{width:100%;margin-bottom:8px;padding:6px 8px;border-radius:5px;border:1px solid #ccc;font-size:13px}.modal-actions button{border:none;border-radius:6px;padding:8px 14px;cursor:pointer}.modal-actions button:first-child{background:#1976d2;color:#fff}.modal-actions button:last-child{background:#ccc}.proof-image{max-width:100%;height:auto;border-radius:6px;margin-top:8px;box-shadow:0 2px 8px #00000026}.preview-section{background:#f8f9fc;padding:8px;border-radius:6px;margin-bottom:10px;text-align:center;border:1px solid #ddd}#reimburse-detail{background:#fff;color:#333;padding:20px;border-radius:10px;width:420px;line-height:1.6;box-shadow:0 2px 8px #0000001a}#reimburse-detail h3{text-align:center;color:#1976d2;margin-bottom:15px;text-transform:uppercase}.modal-actions button:first-child{background:linear-gradient(90deg,#2196f3,#42a5f5);color:#fff;border:none;border-radius:6px;padding:8px 14px;cursor:pointer}.modal-actions button:first-child:hover{background:linear-gradient(90deg,#1976d2,#2196f3)}.proof-thumbnail{width:120px;height:auto;border-radius:6px;cursor:pointer;box-shadow:0 2px 5px #0003;transition:transform .2s ease,box-shadow .2s ease}.proof-thumbnail:hover{transform:scale(1.05);box-shadow:0 4px 10px #0000004d}.image-zoom-modal{position:fixed;inset:0;background:#000000d9;display:flex;justify-content:center;align-items:center;z-index:9999}.image-zoom-modal img{max-width:90%;max-height:85vh;border-radius:8px;box-shadow:0 2px 15px #fff3;object-fit:contain}.close-zoom{position:absolute;top:20px;right:30px;color:#fff;font-size:28px;cursor:pointer;transition:.2s}.close-zoom:hover{color:#ffb300}.reimburse-table-head thead th{background-color:#f5f5f5!important;color:#333!important;font-weight:600;border-bottom:1px solid #ddd}.container-payroll{height:700px;font-family:Poppins,sans-serif}.payroll-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.payroll-header h2{font-size:16px;font-weight:600;color:#333}.actions{display:flex;align-items:center;gap:10px}.title-section button{background-color:#1976d2;color:#fff;border:none;padding:8px 14px;border-radius:6px;cursor:pointer;font-size:12px;transition:.3s}.title-section button:hover{background-color:#0d47a1}.actions select{padding:6px 10px;border-radius:5px;border:1px solid #ccc}.payroll-table{width:100%;border-collapse:collapse;background-color:#fff;box-shadow:0 2px 5px #0000001a;border-radius:8px;overflow:hidden}.payroll-table th,.payroll-table td{padding:10px;border-bottom:1px solid #eee;text-align:left}.payroll-table th{background-color:#f31b1b;font-weight:600}.payroll-table tr:hover{background-color:#f9f9f9}.status-badge{padding:5px 10px;border-radius:5px;font-size:10px;font-weight:600;text-transform:uppercase}.status-badge.paid{background-color:#c8e6c9;color:#256029}.status-badge.unpaid{background-color:#ffcdd2;color:#b71c1c}.view-slip{background-color:#43a047;color:#fff;border:none;padding:5px 10px;border-radius:4px;cursor:pointer}.view-slip:hover{background-color:#2e7d32}.modal{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center}.modal-content-payroll{background:#fff;padding:25px;border-radius:8px;width:450px;box-shadow:0 5px 15px #0003;animation:fadeIn .3s ease}.modal-content-payroll h3{margin-bottom:10px;color:#1976d2}.modal-content-payroll p{font-size:12px}.modal-content hr{margin:10px 0;border:.5px solid #ddd}.modal-content-payroll button{margin-top:15px;background-color:#1976d2;color:#fff;border:none;padding:8px 14px;border-radius:6px;cursor:pointer;width:100%}.modal-content-payroll button:hover{background-color:#0d47a1}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.actions input{padding:6px 10px;border:1px solid #ccc;border-radius:6px}.payroll-table th{background:linear-gradient(90deg,#1976d2,#42a5f5);color:#fff}.payroll-table td b{color:#1976d2}@keyframes popIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.clickable{color:#1976d2;cursor:pointer}.send-bank{background-color:#00897b}.send-email{background-color:#ffb300;color:#000}.send-bank:hover{background-color:#00695c}.send-email:hover{background-color:#ff9800}.modal-content-payroll input,.modal-content-payroll select{width:100%;margin-bottom:8px;padding:6px 8px;border:1px solid #ccc;border-radius:6px}.modal-actions{display:flex;justify-content:space-between;margin-top:10px}.modal-actions button:first-child{background-color:#1976d2;color:#fff}.modal-actions button:last-child{background-color:#ccc}.send-bank,.send-email{border:none;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer;transition:all .25s ease;box-shadow:0 2px 5px #0000001a;display:inline-flex;align-items:center;gap:6px;letter-spacing:.3px}.send-bank{background:linear-gradient(90deg,#009688,#26a69a);color:#fff}.send-bank:hover{background:linear-gradient(90deg,#00796b,#00897b);transform:translateY(-2px);box-shadow:0 4px 8px #0096884d}.send-email{background:linear-gradient(90deg,#f9a825,#ffb300);color:#212121}.send-email:hover{background:linear-gradient(90deg,#f57f17,#f9a825);transform:translateY(-2px);box-shadow:0 4px 8px #ffb3004d}td button{margin-right:5px}.send-bank:active,.send-email:active{transform:scale(.97);box-shadow:none}.title-section{display:flex;flex-direction:row;align-items:flex-start;gap:10px}.title-section h2{font-size:22px;font-weight:500;color:#1e1e1e;margin:0}.total-info{margin-top:5px;font-size:14px;color:#555;background:#eef5ff;padding:6px 10px;border-radius:6px;font-weight:500;box-shadow:0 1px 3px #00000014}.total-info strong{color:#1976d2}.payroll-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:10px}.table-wrapper{width:100%;overflow-x:auto;overflow-y:auto;max-height:450px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.table-wrapper::-webkit-scrollbar{height:8px;width:8px}.table-wrapper::-webkit-scrollbar-thumb{background:#b0bec5;border-radius:4px}.table-wrapper::-webkit-scrollbar-thumb:hover{background:#90a4ae}.table-wrapper::-webkit-scrollbar-track{background:#f5f5f5;border-radius:4px}.add-btn{background:#2196f3;color:#fff;border:none;border-radius:6px;padding:8px 14px;cursor:pointer;font-weight:600;transition:.2s}.add-btn:hover{background:#1976d2}.modal-content{background:#fff;color:#333;border-radius:10px;padding:20px;max-width:400px;margin:auto;box-shadow:0 4px 10px #0003}.modal-actions{display:flex;justify-content:space-between;margin-top:20px}.btn-export{background-color:#2ecc71;color:#fff;border:none;padding:8px 12px;border-radius:6px;cursor:pointer;font-weight:500}.btn-export:hover{background-color:#27ae60}.payroll-table-head thead th{background-color:#f5f5f5!important;color:#333!important;font-weight:600}.performance-container-head{width:100%;height:85vh;display:flex;flex-direction:column}.pm-content-head{flex:1;overflow-y:auto;width:100%}.ph-tree-canvas-card{margin-top:10px;border-radius:var(--radius-lg);border:1px solid var(--stroke);background:#ffffffd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-soft);overflow:hidden}.ph-tree-canvas-head{padding:14px 14px 12px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid rgba(16,24,40,.08);background:linear-gradient(180deg,#fff,#f7f9fc)}.ph-tree-canvas-title{font-weight:900;letter-spacing:.2px}.ph-tree-canvas-sub{margin-top:4px;font-size:12px;color:var(--muted)}.ph-tree-canvas-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.ph-tree-canvas{padding:18px;display:grid;grid-template-rows:auto 46px auto;justify-items:center;gap:14px;background:radial-gradient(circle at 1px 1px,rgba(64,104,146,.12) 1px,transparent 0) 0 0 / 18px 18px,linear-gradient(180deg,#ffffffd9,#f5f7fcd9)}.ph-tree-canvas.is-collapsed .ph-canvas-connector,.ph-tree-canvas.is-collapsed .ph-canvas-staff{display:none}.ph-canvas-person{width:min(520px,100%);text-align:left;border-radius:var(--radius-lg);border:1px solid rgba(16,24,40,.1);background:#fff;box-shadow:0 10px 18px #0f172a0f;padding:12px 14px;cursor:pointer;transition:.16s ease;position:relative}.ph-canvas-person:hover{transform:translateY(-2px);border-color:#4068924d;box-shadow:0 14px 24px #0f172a1a}.ph-canvas-person.is-active{border-color:#4068928c;box-shadow:0 0 0 4px #40689224}.ph-canvas-head:before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:4px;border-radius:999px;background:var(--primary)}.ph-canvas-person-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.ph-canvas-name{font-size:14px;font-weight:900;color:#111827eb}.ph-canvas-role{margin-top:4px;font-size:13px;color:#111827a8;font-weight:700}.ph-badge-pill{font-size:11px;padding:6px 10px;border-radius:999px;font-weight:900;letter-spacing:.2px;white-space:nowrap;background:#4068921f;border:1px solid rgba(64,104,146,.25);color:var(--primary)}.ph-badge-pill.soft{background:#94a3b829;border:1px solid rgba(16,24,40,.1);color:#111827b8}.ph-canvas-connector{width:100%;height:26px;position:relative}.ph-canvas-connector:before{content:"";position:absolute;top:0;left:50%;width:2px;height:18px;transform:translate(-50%);background:#40689240;border-radius:999px}.ph-canvas-connector:after{content:"";position:absolute;top:18px;left:10%;right:10%;height:2px;background:#40689240;border-radius:999px}.ph-canvas-staff{width:100%;display:flex;gap:12px}.ph-canvas-staff-card{position:relative}.ph-canvas-staff-card:before{content:"";position:absolute;top:-32px;left:50%;width:2px;height:32px;transform:translate(-50%);background:#20497540}@media(max-width:1080px){.ph-canvas-staff{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:520px){.ph-tree-canvas{padding:12px}.ph-canvas-staff{grid-template-columns:1fr}.ph-canvas-connector:after{left:20%;right:20%}}.ph-topbar{margin-top:14px;position:sticky;top:0;z-index:10;padding:16px;border-radius:var(--radius-lg);border:1px solid var(--stroke);background:#ffffffd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-soft);display:flex;gap:14px;align-items:center;justify-content:space-between}.ph-title h3{margin:0;font-size:18px;font-weight:900;letter-spacing:.2px}.ph-title p{margin:6px 0 0;font-size:12.5px;color:var(--muted)}.ph-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.ph-search{width:min(360px,48vw);height:42px;padding:0 14px;border-radius:999px;border:1px solid var(--stroke);background:#fff;color:var(--text);outline:none;transition:.18s ease}.ph-search::placeholder{color:#11182773}.ph-search:focus{border-color:#4068928c;box-shadow:0 0 0 4px #4068922e}.ph-select{height:42px;padding:0 12px;border-radius:999px;border:1px solid var(--stroke);background:#fff;color:var(--text);outline:none;cursor:pointer;transition:.18s ease;min-width:180px}.ph-select:focus{border-color:#4068928c;box-shadow:0 0 0 4px #4068922e}.ph-kanban-wrap{margin-top:14px}.ph-kanban{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(160px,340px);gap:14px;align-items:start;padding-bottom:10px;overflow-x:auto;overscroll-behavior-x:contain;scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:rgba(17,24,39,.22) transparent}.ph-kanban::-webkit-scrollbar{height:10px}.ph-kanban::-webkit-scrollbar-track{background:transparent}.ph-kanban::-webkit-scrollbar-thumb{background:#1118272e;border-radius:999px}.ph-kanban::-webkit-scrollbar-thumb:hover{background:#11182747}.ph-col{scroll-snap-align:start;border-radius:var(--radius-lg);border:1px solid var(--stroke);background:#ffffffd9;box-shadow:var(--shadow-soft);overflow:hidden;--col-accent: #94a3b8}.ph-col:nth-child(1){--col-accent: #94a3b8}.ph-col:nth-child(2){--col-accent: #f59e0b}.ph-col:nth-child(3){--col-accent: #3b82f6}.ph-col:nth-child(4){--col-accent: #22c55e}.ph-col:nth-child(5){--col-accent: #a78bfa}.ph-col-header{padding:14px 14px 12px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid rgba(16,24,40,.08);background:linear-gradient(180deg,#fff,#f7f9fc);position:relative}.ph-col-header:before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--col-accent)}.ph-col-header h4{margin:0;padding-left:8px;font-size:13px;font-weight:900;letter-spacing:.25px;text-transform:uppercase;color:#111827e0}.ph-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:24px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:900;color:#111827e0;background:#94a3b82e;border:1px solid rgba(16,24,40,.1)}.ph-col-body{padding:12px;max-height:calc(100vh - 220px);overflow-y:auto;min-height:120px}.ph-task-card{border-radius:var(--radius-md);border:1px solid rgba(16,24,40,.1);background:#fff;box-shadow:0 8px 16px #0f172a0f;padding:12px;margin-bottom:10px;transition:.16s ease;position:relative}.ph-task-card:before{content:"";position:absolute;left:0;top:10px;bottom:10px;width:4px;border-radius:999px;background:var(--col-accent);opacity:.9}.ph-task-card:hover{transform:translateY(-2px);border-color:#4068924d;box-shadow:0 14px 24px #0f172a1a}.ph-task-card.is-saving{opacity:.65;pointer-events:none}.ph-task-title{font-size:14px;font-weight:900;color:#111827eb;line-height:1.25;margin-bottom:6px;padding-left:10px}.ph-task-desc{font-size:13px;color:#111827a8;line-height:1.35;margin-bottom:10px;padding-left:10px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.ph-task-meta{display:flex;justify-content:space-between;gap:10px;font-size:12px;color:#11182794;padding-left:10px}.ph-saving-badge{margin-top:10px;display:inline-flex;align-self:flex-start;font-size:12px;padding:6px 10px;border-radius:999px;background:#4068921f;border:1px solid rgba(64,104,146,.25);color:var(--primary);font-weight:700}.ph-progress{margin-top:10px}.ph-progress-top{display:flex;justify-content:space-between;font-size:12px;opacity:.8;margin-bottom:6px}.ph-progress-bar{height:8px;border-radius:999px;background:#0000001a;overflow:hidden}.ph-progress-fill{height:100%;border-radius:999px;background:#2e7dff;transition:width .2s ease}@media(max-width:1080px){.ph-topbar{flex-direction:column;align-items:stretch}.ph-actions{justify-content:flex-start}.ph-search{width:100%;min-width:0}.ph-select{min-width:0;flex:1}.ph-kanban{grid-auto-columns:minmax(260px,1fr)}}@media(max-width:520px){.ph-kanban{grid-auto-flow:row;overflow-x:visible;scroll-snap-type:none;grid-auto-columns:minmax(140px,340px)}.ph-col-body{max-height:none}}.ct-overlay{position:fixed;inset:0;background:#0f172a80;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:16px;z-index:999}.ct-modal{width:min(860px,100%);background:#ffffffeb;border:1px solid rgba(16,24,40,.12);border-radius:18px;box-shadow:0 18px 44px #0f172a38;overflow:hidden}.ct-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 16px 12px;border-bottom:1px solid rgba(16,24,40,.1);background:linear-gradient(180deg,#fff,#f7f9fc)}.ct-header h3{margin:0;font-size:18px;font-weight:900;letter-spacing:.2px;color:#111827eb}.ct-header p{margin:6px 0 0;font-size:12.5px;font-weight:700;color:#1118279e}.ct-x{width:36px;height:36px;border-radius:999px;border:1px solid rgba(16,24,40,.12);background:#fff;cursor:pointer;font-weight:900;color:#111827bf;transition:.18s ease}.ct-x:hover{border-color:#40689259;box-shadow:0 0 0 4px #40689224}.ct-error{margin:12px 16px 0;padding:10px 12px;border-radius:14px;border:1px solid rgba(239,68,68,.3);background:#ef444414;color:#991b1bf2;font-size:13px;font-weight:800}.ct-form{padding:14px 16px 16px}.ct-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.ct-field{display:flex;flex-direction:column;gap:6px}.ct-field span{font-size:12px;font-weight:900;color:#111827bf;letter-spacing:.2px}.ct-field input,.ct-field select,.ct-field textarea{width:100%;height:42px;padding:0 12px;border-radius:12px;border:1px solid rgba(16,24,40,.14);background:#fff;color:#111827eb;outline:none;transition:.18s ease;font-weight:700}.ct-field textarea{height:auto;padding:10px 12px;resize:vertical;min-height:110px;line-height:1.35;font-weight:700}.ct-field input:focus,.ct-field select:focus,.ct-field textarea:focus{border-color:#4068928c;box-shadow:0 0 0 4px #4068922e}.ct-field input[type=file]{padding:8px 10px;height:auto}.ct-file{margin-top:6px;display:inline-flex;font-size:12px;font-weight:800;color:#111827a6}.ct-field-full{grid-column:1 / -1}.ct-actions{margin-top:14px;display:flex;align-items:center;justify-content:flex-end;gap:10px;border-top:1px solid rgba(16,24,40,.1);padding-top:12px}.ct-btn{height:42px;padding:0 16px;border-radius:999px;border:1px solid rgba(16,24,40,.14);background:#fff;cursor:pointer;font-weight:900;transition:.18s ease}.ct-btn.ghost:hover{border-color:#40689259;box-shadow:0 0 0 4px #40689224}.ct-btn.primary{background:#406892;border-color:#40689299;color:#fff}.ct-btn.primary:hover{background:#2f547a;box-shadow:0 10px 18px #0f172a1f}.ct-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:720px){.ct-grid{grid-template-columns:1fr}}.et-overlay{position:fixed;inset:0;background:#0f172a80;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:16px;z-index:999}.et-modal{width:min(860px,100%);background:#ffffffeb;border:1px solid rgba(16,24,40,.12);border-radius:18px;box-shadow:0 18px 44px #0f172a38;overflow:hidden}.et-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 16px 12px;border-bottom:1px solid rgba(16,24,40,.1);background:linear-gradient(180deg,#fff,#f7f9fc)}.et-header h3{margin:0;font-size:18px;font-weight:900;letter-spacing:.2px;color:#111827eb}.et-header p{margin:6px 0 0;font-size:12.5px;font-weight:700;color:#1118279e}.et-x{width:36px;height:36px;border-radius:999px;border:1px solid rgba(16,24,40,.12);background:#fff;cursor:pointer;font-weight:900;color:#111827bf;transition:.18s ease}.et-x:hover{border-color:#40689259;box-shadow:0 0 0 4px #40689224}.et-error{margin:12px 16px 0;padding:10px 12px;border-radius:14px;border:1px solid rgba(239,68,68,.3);background:#ef444414;color:#991b1bf2;font-size:13px;font-weight:800}.et-form{padding:14px 16px 16px}.et-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.et-field{display:flex;flex-direction:column;gap:6px}.et-field span{font-size:12px;font-weight:900;color:#111827bf;letter-spacing:.2px}.et-field input,.et-field select,.et-field textarea{width:100%;height:42px;padding:0 12px;border-radius:12px;border:1px solid rgba(16,24,40,.14);background:#fff;color:#111827eb;outline:none;transition:.18s ease;font-weight:700}.et-field textarea{height:auto;padding:10px 12px;resize:vertical;min-height:110px;line-height:1.35;font-weight:700}.et-field input:focus,.et-field select:focus,.et-field textarea:focus{border-color:#4068928c;box-shadow:0 0 0 4px #4068922e}.et-field input[type=file]{padding:8px 10px;height:auto}.et-file{margin-top:6px;display:inline-flex;font-size:12px;font-weight:800;color:#111827a6}.et-field-full{grid-column:1 / -1}.et-actions{margin-top:14px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-top:1px solid rgba(16,24,40,.1);padding-top:12px}.et-actions-right{display:flex;gap:10px;justify-content:flex-end}.et-btn{height:42px;padding:0 16px;border-radius:999px;border:1px solid rgba(16,24,40,.14);background:#fff;cursor:pointer;font-weight:900;transition:.18s ease}.et-btn.ghost:hover{border-color:#40689259;box-shadow:0 0 0 4px #40689224}.et-btn.primary{background:#406892;border-color:#40689299;color:#fff}.et-btn.primary:hover{background:#2f547a;box-shadow:0 10px 18px #0f172a1f}.et-btn.danger{background:#ef44441a;border-color:#ef444447;color:#991b1bf2}.et-btn.danger:hover{background:#ef444424;box-shadow:0 10px 18px #0f172a1a}.et-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:720px){.et-grid{grid-template-columns:1fr}.et-actions{flex-direction:column;align-items:stretch}.et-actions-right{justify-content:stretch}.et-btn{width:100%}}.sk{position:relative;overflow:hidden;background:#94a3b838;border-radius:12px}.sk:after{content:"";position:absolute;inset:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);animation:sk-shimmer 1.2s infinite}.sk-line{height:12px;border-radius:999px}.sk-pill{height:26px;border-radius:999px}.sk-input,.sk-select,.sk-btn{height:42px;border-radius:999px}.sk-bar{height:8px;border-radius:999px;background:#94a3b838;position:relative;overflow:hidden}.sk-bar:after{content:"";position:absolute;inset:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);animation:sk-shimmer 1.2s infinite}.w-36{width:36px}.w-40{width:40px}.w-60{width:60px}.w-70{width:70px}.w-90{width:90px}.w-110{width:110px}.w-120{width:120px}.w-130{width:130px}.w-140{width:140px}.w-160{width:160px}.w-170{width:170px}.w-180{width:180px}.w-190{width:190px}.w-200{width:200px}.w-260{width:260px}.ph-topbar-skeleton .ph-actions{gap:10px}.ph-task-skeleton{pointer-events:none}.sk-card{border:1px solid rgba(16,24,40,.08)}.ph-wrap{--primary: #406892;--primary-2: #2f547a;--bg: #ffffff;--stroke: rgba(16, 24, 40, .1);--text: rgba(17, 24, 39, .92);--muted: rgba(17, 24, 39, .62);--shadow-soft: 0 10px 18px rgba(15, 23, 42, .06);--radius-lg: 18px;--radius-md: 14px;background:var(--bg);color:var(--text);min-height:100%;box-sizing:border-box}.ph-mini-btn{height:34px;padding:0 12px;border-radius:999px;border:1px solid var(--stroke);background:#fff;color:var(--text);font-weight:800;cursor:pointer;transition:.18s ease}.ph-mini-btn:hover{border-color:#40689259;box-shadow:0 0 0 4px #4068921f}.ph-empty-col{padding:14px;border-radius:var(--radius-md);border:1px dashed rgba(16,24,40,.22);color:#1118278c;text-align:center;font-size:13px;background:#94a3b814}.ph-create-btn{height:42px;padding:0 14px;border-radius:999px;border:1px solid rgba(64,104,146,.6);background:#406892;color:#fff;font-weight:900;cursor:pointer;transition:.18s ease;white-space:nowrap}.ph-create-btn:hover{background:#2f547a;box-shadow:0 10px 18px #0f172a1f}.course-container{font-family:Poppins,sans-serif;color:#222;min-height:100vh}.course-header-user{display:flex;flex-direction:column;gap:8px;margin-bottom:40px}.course-header-user h2{color:#202265;font-size:2rem;font-weight:700;letter-spacing:.5px}.course-header-user p{color:#666;font-size:1rem;font-weight:400}.promotion-progress{background:#fff;border-radius:14px;padding:25px 30px;box-shadow:0 6px 20px #0000000d;margin-bottom:40px;border-left:5px solid #2b2b6b}.promotion-progress p{margin:6px 0;color:#333;font-size:.95rem}.progress-bar{width:100%;height:12px;background:#e8ebf7;border-radius:8px;overflow:hidden;margin-top:10px;margin-bottom:10px}.progress-fill{height:100%;border-radius:8px;background:linear-gradient(90deg,#2b2b6b,#4043b8);transition:width 1s ease}.progress-info{font-size:.9rem;color:#666;font-style:italic}.recommended-section-user{margin-top:20px}.completed-section h3,.recommended-section-user h3{margin-bottom:20px;font-size:1.4rem;color:#202265;font-weight:600;position:relative}.completed-section h3:after,.recommended-section-user h3:after{content:"";display:block;width:50px;height:3px;background:#2b2b6b;margin-top:6px;border-radius:10px}.course-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:25px}.course-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 8px 25px #0000000d;transition:all .3s ease;position:relative;overflow:hidden}.course-card:before{content:"";position:absolute;top:0;left:0;height:5px;width:0%;background:linear-gradient(90deg,#2b2b6b,#4043b8);transition:width .4s ease}.course-card:hover:before{width:100%}.course-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #2b2b6b1a}.course-card.completed{border-left:5px solid #4caf50;background:#f8fff8}.course-card h4{font-size:1.1rem;font-weight:600;color:#2b2b6b;margin-bottom:6px}.course-card .category{color:#777;font-size:.9rem;margin-bottom:6px}.course-card .date{color:#444;font-size:.9rem;margin-bottom:10px}.course-card p{margin:2px 0}.enroll-btn,.certificate-btn{border:none;border-radius:10px;padding:9px 14px;cursor:pointer;font-size:.92rem;font-weight:500;transition:.3s}.enroll-btn{background:linear-gradient(90deg,#2b2b6b,#4043b8);color:#fff}.enroll-btn:hover{background:linear-gradient(90deg,#3134ae,#5658e5)}.certificate-btn{background:linear-gradient(90deg,#4caf50,#66bb6a);color:#fff}.certificate-btn:hover{background:linear-gradient(90deg,#3fa243,#5fc060)}.no-data{color:#777;font-style:italic;text-align:center;margin-top:15px}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-course{background:#fff;border-radius:14px;padding:35px;max-width:640px;width:90%;box-shadow:0 8px 25px #00000026;position:relative;animation:slideUp .4s ease}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-course h2{color:#2b2b6b;font-weight:600}.modal-course h4{margin-top:15px;color:#4043b8;font-weight:600}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:25px}.modal-actions button{border:none;padding:10px 16px;border-radius:8px;cursor:pointer;font-weight:500}.modal-actions .complete-btn{background:#4caf50;color:#fff}.modal-actions .complete-btn:hover{background:#3d9441}.modal-actions button:first-child{background:#eee}.modal-actions button:first-child:hover{background:#ddd}@media(max-width:768px){.course-container{padding:20px}.course-header-user h2{font-size:1.5rem}.course-card{padding:18px}}.join-btn{background:linear-gradient(90deg,#2b2b6b,#4043b8);color:#fff;border:none;border-radius:8px;padding:10px 18px;cursor:pointer;font-size:.95rem;font-weight:500;transition:.3s}.join-btn:hover{background:linear-gradient(90deg,#3538a0,#5658e5);transform:translateY(-1px)}.attendance-container{font-family:Poppins,sans-serif;color:#111827eb;background:#fff;min-height:100%;box-sizing:border-box;min-width:400px}.att-wrap{width:98%;display:flex;flex-direction:column;gap:5px}.att-topbar-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:4px}.att-title-head h2{margin:0;font-size:18px;font-weight:800;letter-spacing:.2px}.att-title-head p{margin:6px 0 0;font-size:12.5px;color:#1118279e}.att-actions-head{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.att-filters{display:grid;grid-template-columns:1fr 180px 120px;gap:12px;align-items:center}.att-date-input{height:42px;width:90%;padding:0 12px;border-radius:999px;border:1px solid rgba(16,24,40,.12);background:#fff;outline:none;font-size:14px}.att-date-input:focus{border-color:#4068928c;box-shadow:0 0 0 4px #40689224}.attendance-history{max-height:56vh;overflow:auto}.table-wrap{width:100%;overflow:auto}.att-table{width:100%;border-collapse:collapse;min-width:860px}.att-table thead th{position:sticky;top:0;background:#fff;z-index:0;border-bottom:1px solid rgba(16,24,40,.1);text-align:left;padding:12px 14px;font-size:12px;letter-spacing:.25px;text-transform:uppercase;color:#111827b3}.att-table tbody td{padding:6px 8px;border-bottom:1px solid rgba(16,24,40,.08);font-size:13px;color:#111827db;vertical-align:middle}.att-table tbody tr:hover{background:#4068920f}.att-name{font-weight:700;color:#111827eb}.att-loc,.att-reason{color:#111827a8}.small-photo{width:44px;height:44px;object-fit:cover;border-radius:10px;border:1px solid rgba(16,24,40,.1);background:#f3f4f6}.att-badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.2px;border:1px solid rgba(16,24,40,.1);background:#94a3b81f}.att-badge.in{background:#22c55e1f;border-color:#22c55e33;color:#15803df2}.att-badge.out{background:#e74c3c1a;border-color:#e74c3c33;color:#b91c1cf2}.empty-text{padding:18px;text-align:center;color:#1118279e}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin:14px 0 6px;flex-wrap:wrap}.page-info{font-size:13px;color:#111827b3}.camera-modal{position:fixed;inset:0;background:#02061773;display:flex;justify-content:center;align-items:center;z-index:200;padding:18px}.camera-box{width:min(520px,100%);background:#fff;border-radius:16px;padding:14px;border:1px solid rgba(16,24,40,.1);box-shadow:0 20px 50px #0f172a38}.camera-preview{position:relative;width:100%;border-radius:14px;overflow:hidden;background:#000}.camera-preview video{width:100%;height:auto;display:block}.location-overlay{position:absolute;left:12px;right:12px;bottom:12px;background:#0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.14)}.loc-main{font-size:13px;font-weight:700;line-height:1.3}.coord-text{margin-top:6px;font-size:12px;opacity:.9}.camera-hint{margin-top:10px;font-size:12px;color:#1118279e;text-align:center}@media(max-width:1080px){.att-wrap{width:100%}}@media(max-width:760px){.att-topbar-head{flex-direction:column;align-items:stretch}.att-actions-head{justify-content:flex-start}.att-filters{grid-template-columns:1fr}.att-date-input{border-radius:14px}}@media(max-width:520px){.attendance-container{padding:8px}.att-title-head h2{font-size:16px}.att-title-head p{font-size:12px}.att-history-head{flex-direction:column;align-items:flex-start}.camera-box{padding:12px}}.sk-row td{padding-top:10px;padding-bottom:10px}.sk{display:inline-block;border-radius:10px;background:#94a3b833;position:relative;overflow:hidden}.sk:after{content:"";position:absolute;inset:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);animation:sk-shimmer 1.15s infinite}@keyframes sk-shimmer{to{transform:translate(100%)}}.sk-text{height:12px;border-radius:8px}.sk-pill{height:24px;border-radius:999px}.sk-avatar{width:44px;height:44px;border-radius:10px}.w-40{width:40%}.w-55{width:55%}.w-60{width:60%}.w-70{width:70%}.w-80{width:80%}.w-90{width:90%}.detail-modal{position:fixed;inset:0;background:#02061773;display:flex;justify-content:center;align-items:center;z-index:210;padding:14px}.detail-box{width:min(360px,96vw);max-height:min(78vh,720px);overflow:auto;background:#fff;border-radius:14px;padding:12px;border:1px solid rgba(16,24,40,.1);box-shadow:0 20px 50px #0f172a38}.detail-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;position:sticky;top:0;background:#fff;padding-bottom:8px;z-index:2;border-bottom:1px solid rgba(16,24,40,.08)}.detail-head h3{margin:0;font-size:15px;font-weight:800}.detail-close{border:0;background:#0f172a0f;width:34px;height:34px;border-radius:10px;cursor:pointer}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 12px}.detail-span{grid-column:1 / -1}.detail-label{font-size:11.5px;color:#1118279e;margin-bottom:3px}.detail-value{font-size:13px;font-weight:700;color:#111827e6}.detail-photo{margin-top:10px;border-radius:12px;overflow:hidden;border:1px solid rgba(16,24,40,.1);background:#f3f4f6}.detail-photo img{width:100%;height:auto;display:block}.detail-reason{margin-top:10px}.reason-input{width:100%;resize:vertical;padding:10px 12px;border-radius:12px;border:1px solid rgba(16,24,40,.12);outline:none;font-size:13px;font-family:Poppins,sans-serif}.reason-input:focus{border-color:#4068928c;box-shadow:0 0 0 4px #40689224}@media(max-width:640px){.detail-modal{padding:2px;align-items:flex-end}.detail-box{width:min(360px,76vw);max-height:min(108vh,520px);border-radius:16px;padding:2px}.detail-grid{grid-template-columns:1fr}.detail-photo img{max-height:36vh;object-fit:cover}}@media(max-width:420px){.detail-box{max-height:90vh;padding:10px}.detail-head h3{font-size:14px}}
