.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:6px 12px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;text-decoration:none;transition:background .15s}.btn-primary:hover{background:var(--color-primary-hover)}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:6px 12px;background:#fff;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;text-decoration:none;transition:all .15s}.btn-secondary:hover{background:var(--color-bg-tertiary)}.btn-secondary:disabled{opacity:.7;cursor:not-allowed}.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;background:var(--color-danger);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-danger:hover{background:var(--color-danger-dark)}.btn-danger:disabled{opacity:.7;cursor:not-allowed}.btn-danger-outline{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:6px 12px;background:#fff;color:var(--color-danger);border:1px solid var(--color-danger);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s}.btn-danger-outline:hover{background:var(--color-danger-light)}.btn-danger-outline:disabled{opacity:.7;cursor:not-allowed}.btn-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:var(--color-bg-tertiary);border-radius:4px;cursor:pointer;transition:all .15s ease;color:var(--color-text-tertiary);flex-shrink:0}.btn-icon:hover{background:var(--color-border);color:var(--color-text-primary)}.btn-icon.warning{color:var(--color-warning)}.btn-icon.warning:hover{background:var(--color-warning-light)}.btn-icon.success{color:var(--color-success)}.btn-icon.success:hover{background:var(--color-success-light)}.btn-icon.danger{color:var(--color-danger)}.btn-icon.danger:hover{background:var(--color-danger-light)}.btn-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:var(--color-bg-tertiary);border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-tertiary);transition:background .15s}.btn-close:hover{background:var(--color-border);color:var(--color-text-primary)}.btn-pagination{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border);border-radius:4px;background:#fff;cursor:pointer;font-size:11px;transition:all .1s}.btn-pagination:hover:not(:disabled){background:var(--color-bg-tertiary)}.btn-pagination:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000;padding:0}.modal{background:#fff;border-radius:16px 16px 0 0;padding:20px;padding-bottom:calc(20px + env(safe-area-inset-bottom));width:100%;max-width:100%;max-height:90vh;max-height:90dvh;overflow-x:hidden;overflow-y:auto;animation:slideUp .25s ease-out;box-sizing:border-box}.modal-body{overflow-x:hidden;width:100%;box-sizing:border-box}.modal input,.modal select,.modal textarea{max-width:100%;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}@keyframes slideUp{0%{transform:translateY(100%);opacity:.5}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--color-border)}.modal-header h2{margin:0;font-size:18px;color:var(--color-text-primary)}.modal-header .header-actions{display:flex;gap:8px;align-items:center}.modal-footer{display:flex;flex-direction:column-reverse;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--color-border)}.modal-footer button,.modal-footer .btn-primary,.modal-footer .btn-secondary,.modal-footer .btn-danger{width:100%;justify-content:center;padding:12px 16px;min-height:44px}.confirm-modal{text-align:center}.confirm-modal h2{margin:0 0 8px}.confirm-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.confirm-icon-danger{background:#fef2f2;color:#dc2626}.confirm-icon-warning{background:#fffbeb;color:#d97706}.confirm-icon-primary,.confirm-icon-info{background:#eff6ff;color:#2563eb}.confirm-icon-success{background:#f0fdf4;color:#16a34a}.confirm-icon.warning{background:var(--color-warning-light);color:var(--color-warning)}.confirm-icon.danger{background:var(--color-danger-light);color:var(--color-danger)}.confirm-icon.info,.confirm-icon.seed-icon{background:var(--color-primary-light);color:var(--color-primary)}.confirm-icon.success{background:var(--color-success-light);color:var(--color-success)}.confirm-icon:not(.warning):not(.danger):not(.info):not(.success):not(.seed-icon):not([class*=confirm-icon-]){background:var(--color-warning-light);color:var(--color-warning)}.confirm-message{font-size:15px;color:var(--color-text-secondary);margin:0 0 20px;line-height:1.6}.confirm-message strong{color:var(--color-text-primary)}.confirm-reason{text-align:left;margin-bottom:20px}.confirm-reason label{display:block;font-size:14px;font-weight:600;color:var(--color-text-primary);margin-bottom:8px}.confirm-reason textarea{width:100%;padding:14px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:16px;resize:vertical;min-height:100px;transition:border-color .15s,box-shadow .15s}.confirm-reason textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.confirm-actions{display:flex;flex-direction:column-reverse;gap:10px}.confirm-actions button{width:100%;padding:12px 16px;min-height:44px;justify-content:center}.detail-content{background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:16px}.detail-row{display:flex;flex-direction:column;gap:4px;padding:12px 0;border-bottom:1px solid var(--color-border)}.detail-row:last-child{border-bottom:none}.detail-row label{font-size:12px;color:var(--color-text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.03em}.detail-row span{font-size:15px;color:var(--color-text-primary);font-weight:500}.success-view{text-align:center}.success-icon{width:56px;height:56px;background:var(--color-success);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.seed-preview{text-align:left;background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:16px;margin-bottom:16px}.seed-preview ul{margin:0;padding-left:20px;font-size:14px;color:var(--color-text-secondary)}.seed-preview li{margin-bottom:6px}.modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:var(--color-bg-tertiary);border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-tertiary);transition:background .15s;flex-shrink:0}.modal-close:hover{background:var(--color-border);color:var(--color-text-primary)}@media(min-width:640px){.modal-overlay{align-items:center;padding:24px}.modal{border-radius:12px;padding:24px;max-width:480px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal.wide{max-width:600px}.modal.narrow{max-width:400px}.confirm-modal{max-width:420px}.detail-modal{max-width:500px}.modal-header{padding-bottom:0;border-bottom:none}.modal-header h2{font-size:16px}.modal-footer{flex-direction:row;justify-content:flex-end}.modal-footer button,.modal-footer .btn-primary,.modal-footer .btn-secondary,.modal-footer .btn-danger{width:auto;padding:8px 16px;min-height:auto}.confirm-icon{width:56px;height:56px}.confirm-message{font-size:14px}.confirm-reason textarea{font-size:14px;padding:12px;min-height:80px}.confirm-actions{flex-direction:row;justify-content:center}.confirm-actions button{width:auto;padding:8px 16px;min-height:auto}.detail-row{flex-direction:row;justify-content:space-between;align-items:center;gap:16px;padding:8px 0}.modal-close{width:28px;height:28px}}.toast-notification{position:fixed;top:20px;right:20px;min-width:280px;max-width:400px;padding:12px 16px;border-radius:var(--radius-md);background:#fff;box-shadow:var(--shadow-md),0 0 0 1px #0000001a;display:flex;align-items:center;gap:12px;z-index:9999;transform:translate(100%);opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1)}.toast-notification.visible{transform:translate(0);opacity:1}.toast-notification.success{border-left:4px solid var(--color-success)}.toast-notification.error{border-left:4px solid var(--color-danger)}.toast-notification.info{border-left:4px solid var(--color-primary)}.toast-notification.warning{border-left:4px solid var(--color-warning)}.toast-content{display:flex;align-items:center;gap:8px;flex:1}.toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.toast-notification.success .toast-icon{color:var(--color-success)}.toast-notification.error .toast-icon{color:var(--color-danger)}.toast-notification.info .toast-icon{color:var(--color-primary)}.toast-notification.warning .toast-icon{color:var(--color-warning)}.toast-message{font-size:13px;font-weight:500;color:var(--color-text-primary);line-height:1.4}.toast-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:var(--color-text-muted);border-radius:4px;cursor:pointer;transition:all .15s ease}.toast-close:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}@media(max-width:640px){.toast-notification{right:12px;left:12px;min-width:auto;max-width:none}}.table-container{overflow:auto;max-height:calc(100vh - 260px);min-height:200px;position:relative;width:100%;max-width:100%;box-sizing:border-box}.data-table{width:100%;min-width:800px;border-collapse:collapse;table-layout:fixed;border-spacing:0}.data-table tbody{transition:opacity .15s ease-out}.data-table tbody.loading{opacity:.6}.data-table th{padding:8px 10px;text-align:left;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--color-text-tertiary);background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:1;white-space:nowrap;height:32px;line-height:1.2;vertical-align:middle}.data-table td{padding:8px 10px;border-bottom:1px solid var(--color-border);font-size:12px;color:var(--color-text-secondary);height:44px;line-height:1.3;vertical-align:middle;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;box-sizing:border-box}.data-table tr:hover:not(.skeleton-row){background:var(--color-bg-tertiary)}.data-table .font-mono{font-family:monospace;font-size:11px}.data-table .font-medium{font-weight:500;color:var(--color-text-primary)}.data-table .actions-cell{display:flex;gap:4px;align-items:center;justify-content:flex-start;padding:8px 10px}.data-table .inactive-row{opacity:.6}.skeleton-row .skeleton{display:inline-block;width:60%;height:12px;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:skeleton-pulse 1.2s ease-in-out infinite;border-radius:3px}.skeleton-row .skeleton.wide{width:80%}.skeleton-row .skeleton.badge{width:50px;height:16px}.skeleton-row .skeleton.link{width:60px;height:16px}.skeleton-row .skeleton.actions{width:80px;height:20px}.pagination{display:flex;justify-content:center;align-items:center;gap:8px;padding:6px 8px;border-top:1px solid var(--color-border);height:32px}.page-info{font-size:11px;color:var(--color-text-tertiary);min-width:40px;text-align:center}.total-info{font-size:10px;color:var(--color-text-muted)}@media(max-width:768px){.data-table{min-width:0!important;width:100%!important;display:block!important;table-layout:auto!important}.data-table tbody,.data-table tr{display:block!important;width:100%!important}.data-table td{display:flex!important;overflow:visible!important;text-overflow:clip!important;white-space:normal!important;height:auto!important}}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:8px;font-size:.9375rem;font-weight:500;color:var(--color-text-secondary)}.form-group input,.form-group select,.form-group textarea{width:100%;max-width:100%;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;box-sizing:border-box;min-height:44px;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-group input,.form-group textarea{padding:12px 14px}.form-group select{padding:12px var(--select-padding-end) 12px 14px}.form-group textarea{resize:vertical;min-height:100px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.form-group input.uppercase-input{text-transform:uppercase}.form-group .disabled-input{background:var(--color-bg-tertiary)!important;color:var(--color-text-muted)!important;cursor:not-allowed!important}.form-hint{display:block;margin-top:6px;font-size:12px;color:var(--color-text-muted);font-style:italic}.form-actions{display:flex;flex-direction:column-reverse;gap:10px;margin-top:20px}.form-actions button{width:100%;min-height:44px;justify-content:center}.form-error{background:var(--color-danger-light);color:var(--color-danger-dark);padding:12px 14px;border-radius:var(--radius-md);margin-bottom:16px;font-size:.9375rem}.checkbox-group{margin:16px 0}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.9375rem;color:var(--color-text-secondary);min-height:44px}.checkbox-label input{width:20px;height:20px}.filters{display:flex;flex-direction:column;gap:10px;padding:12px;border-bottom:1px solid var(--color-border)}.search-input{flex:1;padding:12px 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;min-width:100%;min-height:44px}.search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.filter-select,.filter-select.wide{min-width:100%;width:100%;min-height:44px}.toggle-filter{display:flex;align-items:center;gap:10px;font-size:.9375rem;color:var(--color-text-secondary);cursor:pointer;min-height:44px}.toggle-filter input{width:20px;height:20px}@media(min-width:640px){.form-group{margin-bottom:12px}.form-group label{margin-bottom:4px;font-size:12px}.form-group input,.form-group select,.form-group textarea{font-size:13px;min-height:auto}.form-group input,.form-group textarea{padding:7px 10px}.form-group select{padding:7px var(--select-padding-end) 7px 10px}.form-group textarea{min-height:60px}.form-hint{font-size:11px}.form-row{grid-template-columns:1fr 1fr;gap:10px}.form-actions{flex-direction:row;justify-content:flex-end;gap:8px;margin-top:16px}.form-actions button{width:auto;min-height:auto}.form-error{padding:8px 10px;margin-bottom:12px;font-size:13px}.checkbox-label{font-size:13px;min-height:auto}.checkbox-label input{width:16px;height:16px}.filters{flex-direction:row;gap:8px;padding:10px 12px;flex-wrap:wrap}.search-input{padding:6px 10px;font-size:13px;min-width:200px;min-height:auto}.filter-select,.filter-select.wide{min-width:200px;width:auto;min-height:auto}.toggle-filter{font-size:13px;min-height:auto}.toggle-filter input{width:16px;height:16px}}.status-badge{display:inline-block;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:500;line-height:1.2;white-space:nowrap}.status-active{background:#dcfce7;color:#166534}.status-pending{background:#fef3c7;color:#92400e}.status-deactivated,.status-inactive{background:#fee2e2;color:#991b1b}.role-badge{display:inline-block;padding:2px 6px;background:#e0e7ff;color:#3730a3;border-radius:3px;font-size:10px;font-weight:500;line-height:1.2;white-space:nowrap}.role-badge.super-admin{background:#fae8ff;color:#86198f}.role-badge.hr-manager{background:#dbeafe;color:#1e40af}.role-badge.viewer{background:#f1f5f9;color:#475569}.leave-type-badge{display:inline-block;padding:2px 6px;background:#e0e7ff;color:#3730a3;border-radius:3px;font-size:10px;font-weight:600}.leave-type-badge.large{font-size:12px;padding:4px 10px}.admin-page{padding:12px;width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.page-header{display:flex;flex-direction:column;gap:12px;align-items:flex-start;margin-bottom:16px}.page-header h1{margin:0;font-size:1.25rem;color:var(--color-text-primary)}.page-header .subtitle{margin:4px 0 0;color:var(--color-text-tertiary);font-size:.875rem}.section-title{display:flex;align-items:center;gap:10px}.page-header .header-actions{display:flex;gap:10px;width:100%}.page-header .header-actions button,.page-header .header-actions a{flex:1;justify-content:center;min-height:44px}.card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden;width:100%;max-width:100%;box-sizing:border-box}.error-state,.empty-state{min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;text-align:center;color:var(--color-text-tertiary)}.error-state{color:var(--color-danger)}.error-state svg,.empty-state svg{margin-bottom:8px;opacity:.5}.empty-state span{display:block;font-size:.8125rem;color:var(--color-text-muted);margin-bottom:12px}.error-state p,.empty-state p{font-size:.875rem;margin:0}.empty-actions{display:flex;flex-direction:column;gap:10px;margin-top:12px;width:100%;max-width:280px}.empty-actions button{width:100%;min-height:44px}.info-box{background:var(--color-bg-tertiary);padding:14px 16px;border-radius:var(--radius-md);text-align:left;margin:16px 0}.info-box p{margin:6px 0;font-size:.875rem;color:var(--color-text-secondary)}.url-copy{display:flex;flex-direction:column;gap:10px}.url-copy input{flex:1;padding:12px 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.8125rem;background:var(--color-bg-tertiary);font-family:monospace;min-height:44px}.url-copy button{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 16px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s;min-height:44px}.url-copy button:hover{background:var(--color-primary-hover)}.hint{margin-top:8px;font-size:.8125rem;color:var(--color-text-muted)}.loading-modal{background:#fff;border-radius:var(--radius-lg);padding:32px;display:flex;flex-direction:column;align-items:center;gap:16px;font-size:1rem;color:var(--color-text-secondary)}@media(min-width:640px){.admin-page{padding:16px}.page-header{flex-direction:row;justify-content:space-between;align-items:center;gap:16px;margin-bottom:12px}.page-header h1{font-size:18px}.page-header .subtitle{margin:2px 0 0;font-size:12px}.page-header .header-actions{width:auto;gap:8px}.page-header .header-actions button,.page-header .header-actions a{flex:none;min-height:auto}.card{border-radius:var(--radius-md)}.error-state,.empty-state{min-height:180px;padding:20px 16px}.empty-state span{font-size:11px}.error-state p,.empty-state p{font-size:12px}.empty-actions{flex-direction:row;gap:8px;width:auto;max-width:none}.empty-actions button{width:auto;min-height:auto}.info-box{padding:10px 12px;margin:12px 0}.info-box p{font-size:12px;margin:4px 0}.url-copy{flex-direction:row;gap:0}.url-copy input{padding:7px 10px;border-right:none;border-radius:var(--radius-md) 0 0 var(--radius-md);font-size:11px;min-height:auto}.url-copy button{padding:7px 12px;border-radius:0 var(--radius-md) var(--radius-md) 0;font-size:12px;min-height:auto}.hint{font-size:11px;margin-top:6px}.loading-modal{padding:24px;font-size:14px;gap:12px}}.employee-cell{display:flex;flex-direction:column;gap:2px}.employee-id{font-size:10px;color:var(--color-text-muted);font-family:monospace}.carry-over{color:var(--color-success)}.used{color:var(--color-text-secondary)}.pending{color:var(--color-warning)}.available{font-weight:600;color:var(--color-primary)}.available.zero{color:var(--color-danger)}.radio-group{display:flex;gap:8px}.radio-option{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-weight:500;color:var(--color-text-secondary);background:var(--color-bg-primary);transition:all .15s ease}.radio-option:hover{border-color:var(--color-primary);background:var(--color-bg-tertiary)}.radio-option.selected{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary);font-weight:600}.radio-option input[type=radio]{position:absolute;opacity:0;pointer-events:none}.adjust-info{background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:12px;margin-bottom:16px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.info-row label{font-size:12px;color:var(--color-text-tertiary)}.info-row span{font-size:13px;font-weight:500;color:var(--color-text-primary)}.info-row .highlight{color:var(--color-primary);font-weight:600}.adjustment-input{display:flex;align-items:center;gap:8px}.adjust-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s}.adjust-btn.minus{background:var(--color-danger-light);color:var(--color-danger)}.adjust-btn.minus:hover{background:var(--color-danger);color:#fff}.adjust-btn.plus{background:var(--color-success-light);color:var(--color-success)}.adjust-btn.plus:hover{background:var(--color-success);color:#fff}.days-input{flex:1;text-align:center;font-size:18px!important;font-weight:600;padding:8px!important}.balance-summary{background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:16px;margin-bottom:16px}.summary-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.summary-header h3{margin:0;font-size:16px;color:var(--color-text-primary)}.summary-stats{display:flex;gap:16px;flex-wrap:wrap}.stat{display:flex;flex-direction:column;gap:2px}.stat label{font-size:10px;color:var(--color-text-tertiary);text-transform:uppercase}.stat span{font-size:18px;font-weight:600;color:var(--color-text-primary)}.stat span.positive{color:var(--color-success)}.stat span.negative{color:var(--color-text-secondary)}.stat span.warning{color:var(--color-warning)}.stat.highlight span{color:var(--color-primary)}.transactions-section{margin-top:16px}.transactions-section h4{display:flex;align-items:center;gap:6px;margin:0 0 12px;font-size:14px;color:var(--color-text-primary)}.transactions-list{max-height:300px;overflow-y:auto}.transaction-item{padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:8px;font-size:12px}.tx-type{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.tx-badge{font-size:10px;font-weight:600;padding:2px 6px;border-radius:3px;background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.type-initial .tx-badge{background:#dbeafe;color:#1e40af}.type-hold .tx-badge{background:#fef3c7;color:#92400e}.type-deduct .tx-badge{background:#fee2e2;color:#991b1b}.type-release .tx-badge,.type-refund .tx-badge{background:#dcfce7;color:#166534}.type-carryover .tx-badge{background:#e0e7ff;color:#3730a3}.type-adjustment .tx-badge{background:#fae8ff;color:#86198f}.type-reset .tx-badge{background:#f1f5f9;color:#475569}.tx-date{font-size:10px;color:var(--color-text-muted)}.tx-details{display:flex;justify-content:space-between;align-items:center}.tx-days{font-weight:600}.tx-days.positive{color:var(--color-success)}.tx-days.negative{color:var(--color-danger)}.tx-balance{font-size:10px;color:var(--color-text-muted)}.tx-description{margin:6px 0 0;padding:6px;background:var(--color-bg-tertiary);border-radius:4px;font-size:11px;color:var(--color-text-secondary)}.no-transactions{text-align:center;color:var(--color-text-muted);font-size:12px;padding:20px}.reset-icon{background:var(--color-primary-light);color:var(--color-primary)}.year-select{width:100%;padding:8px 12px;font-size:14px;margin-bottom:16px}.reset-info{text-align:left;background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:12px;margin-bottom:16px}.reset-info p{margin:0 0 8px;font-size:12px;color:var(--color-text-secondary)}.reset-info ul{margin:0;padding-left:16px;font-size:11px;color:var(--color-text-tertiary)}.reset-info li{margin-bottom:4px}.btn-icon.adjust{color:var(--color-primary)}.btn-icon.adjust:hover{background:var(--color-primary-light)}.expand-controls{display:flex;align-items:center;gap:8px;margin-left:auto}.expand-controls .btn-text{background:none;border:none;color:var(--color-primary);font-size:12px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:all .15s}.expand-controls .btn-text:hover{background:var(--color-primary-light)}.expand-controls .divider{color:var(--color-border);font-size:12px}.expandable-table .employee-row{cursor:pointer;transition:background .15s}.expandable-table .employee-row:hover{background:var(--color-bg-tertiary)}.expandable-table .employee-row.expanded{background:var(--color-primary-light);border-bottom:none}.expandable-table .employee-row.expanded:hover{background:var(--color-primary-light)}.expand-cell{text-align:center;color:var(--color-text-tertiary);transition:transform .2s}.employee-row.expanded .expand-cell svg{color:var(--color-primary)}.types-count{font-size:12px;color:var(--color-text-secondary);background:var(--color-bg-tertiary);padding:3px 8px;border-radius:var(--radius-sm)}.total-available{font-weight:600;color:var(--color-primary)}.total-available.zero{color:var(--color-danger)}.details-row{background:var(--color-bg-secondary)}.details-row>td{padding:0!important;border-top:none}.balance-details{padding:12px 16px 16px 48px;background:linear-gradient(to bottom,var(--color-primary-light) 0%,var(--color-bg-secondary) 8px);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.nested-table{width:100%;border-collapse:collapse;font-size:13px;background:var(--color-bg-primary);border-radius:var(--radius-md);overflow:hidden;box-shadow:0 1px 3px #00000014}.nested-table thead{background:var(--color-bg-tertiary)}.nested-table th{padding:10px 12px;text-align:left;font-size:11px;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--color-border)}.nested-table td{padding:10px 12px;border-bottom:1px solid var(--color-border-light)}.nested-table tbody tr:last-child td{border-bottom:none}.nested-table tbody tr:hover{background:var(--color-bg-tertiary)}.nested-table .actions-cell{display:flex;gap:4px}@media(max-width:640px){.summary-stats{gap:12px}}.admin-layout{display:flex;min-height:100vh;background:var(--color-bg-primary, #f8fafc)}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:60px;background:#fff;border-bottom:1px solid var(--color-border, #e2e8f0);padding:0 16px;align-items:center;gap:16px;z-index:90}.menu-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;color:var(--color-text-primary, #0f172a);cursor:pointer;border-radius:8px}.menu-toggle:hover{background:var(--color-bg-tertiary, #f1f5f9)}.mobile-logo{font-weight:700;font-size:18px;color:var(--color-text-primary, #0f172a)}.mobile-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:95}.sidebar{width:260px;background:#fff;border-right:1px solid var(--color-border, #e2e8f0);display:flex;flex-direction:column;transition:width .2s ease;position:fixed;left:0;top:0;bottom:0;z-index:100;overflow:visible}.sidebar.collapsed{width:72px}.sidebar-header{padding:20px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--color-border, #e2e8f0);min-height:72px;position:relative}.sidebar.collapsed .sidebar-header{padding-left:0;padding-right:0;justify-content:center}.logo{display:flex;align-items:center;gap:12px;overflow:hidden}.logo-text{font-weight:700;font-size:18px;color:var(--color-text-primary, #0f172a);white-space:nowrap}.collapse-btn{position:absolute;right:-12px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#fff;border:1px solid var(--color-border, #e2e8f0);border-radius:50%;color:var(--color-text-secondary, #475569);cursor:pointer;flex-shrink:0;z-index:10;box-shadow:0 2px 4px #0000000d;padding:0;transition:all .2s ease}.collapse-btn:hover{background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-primary, #3b82f6);border-color:var(--color-primary-light, #eff6ff)}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 14px;color:var(--color-text-secondary, #475569);text-decoration:none;border-radius:10px;margin-bottom:4px;transition:all .15s ease;font-size:14px;font-weight:500;width:100%;border:none;background:transparent;cursor:pointer;text-align:left}.sidebar.collapsed .nav-item{padding:12px 0;justify-content:center}.nav-item:hover{background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-primary, #0f172a)}.nav-item.active{background:var(--color-primary-light, #eff6ff);color:var(--color-primary, #3b82f6)}.nav-icon{display:flex;align-items:center;justify-content:center;width:24px;flex-shrink:0}.nav-label{white-space:nowrap;overflow:hidden;flex:1}.nav-group{margin-bottom:4px}.nav-parent{position:relative}.nav-chevron{transition:transform .2s ease;flex-shrink:0;opacity:.6}.nav-parent:hover .nav-chevron{opacity:1}.nav-parent.expanded .nav-chevron{transform:rotate(180deg)}.nav-children{overflow:hidden;margin-top:2px;padding-left:16px;border-left:2px solid var(--color-border, #e2e8f0);margin-left:26px}.nav-child{display:block;padding:8px 12px;color:var(--color-text-secondary, #475569);text-decoration:none;border-radius:6px;margin-bottom:2px;font-size:13px;font-weight:500;transition:all .15s ease;position:relative}.nav-child:hover{background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-primary, #0f172a)}.nav-child.active{background:var(--color-primary-light, #eff6ff);color:var(--color-primary, #3b82f6);font-weight:600}.nav-child.active:before{content:"";position:absolute;left:-18px;top:50%;transform:translateY(-50%);width:2px;height:16px;background:var(--color-primary, #3b82f6);border-radius:1px}.sidebar-footer{padding:16px;border-top:1px solid var(--color-border, #e2e8f0)}.sidebar-footer .settings-item{margin-bottom:12px}.user-section{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding:8px;background:var(--color-bg-tertiary, #f1f5f9);border-radius:10px}.sidebar.collapsed .user-section{justify-content:center}.user-avatar{width:40px;height:40px;background:linear-gradient(135deg,#111827,#374151);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:16px;flex-shrink:0}.sidebar-footer .user-info{overflow:hidden;flex:1}.user-name{color:var(--color-text-primary, #0f172a);font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{color:var(--color-text-tertiary, #64748b);font-size:12px}.sidebar-footer .logout-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;background:var(--color-danger-light, #fee2e2);border:none;border-radius:8px;color:var(--color-danger, #ef4444);cursor:pointer;font-size:14px;font-weight:500;transition:all .15s ease}.sidebar.collapsed .logout-btn{padding:10px 0;justify-content:center}.sidebar-footer .logout-btn:hover{background:#fecaca}.sidebar-footer .build-version{margin-top:12px;padding:8px;text-align:center;font-size:11px;color:var(--color-text-tertiary, #94a3b8);border-radius:6px;background:var(--color-bg-secondary, #f8fafc);cursor:default}.sidebar.collapsed .build-version{font-size:10px;padding:6px 4px}.sidebar-footer .switch-context-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;background:var(--color-primary-light, #eff6ff);border:none;border-radius:8px;color:var(--color-primary, #3b82f6);cursor:pointer;font-size:14px;font-weight:500;transition:all .15s ease;margin-bottom:8px}.sidebar.collapsed .switch-context-btn{padding:10px 0;justify-content:center}.sidebar-footer .switch-context-btn:hover{background:var(--color-primary, #3b82f6);color:#fff}.admin-layout .main-content{flex:1;margin-left:260px;transition:margin-left .2s ease;min-height:100vh;max-width:100%;overflow-x:hidden}.sidebar.collapsed+.main-content,.admin-layout:has(.sidebar.collapsed) .main-content{margin-left:72px}@media(max-width:1024px){.sidebar{width:72px}.sidebar .nav-label,.sidebar .nav-chevron,.sidebar .nav-children,.sidebar-footer .user-info,.sidebar .logo-text,.sidebar-footer .logout-btn span,.sidebar-footer .switch-context-btn span{display:none}.admin-layout .main-content{margin-left:72px}.desktop-only{display:none}.user-section{justify-content:center;padding:8px}}@media(max-width:768px){.mobile-header{display:flex}.mobile-overlay{display:block}.sidebar{width:280px;transform:translate(-100%);transition:transform .2s ease;box-shadow:var(--shadow-lg)}.sidebar.mobile-open{transform:translate(0)}.sidebar .nav-label,.sidebar .nav-chevron,.sidebar .nav-children,.sidebar-footer .user-info,.sidebar .logo-text,.sidebar-footer .logout-btn span,.sidebar-footer .switch-context-btn span{display:block}.admin-layout .main-content{margin-left:0;padding-top:60px;width:100%;max-width:100vw;box-sizing:border-box}.user-section{justify-content:flex-start}}.dashboard-overview{padding:16px;max-width:1200px;margin:0 auto}.dashboard-overview .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.dashboard-overview .page-header h1{margin:0;font-size:18px;font-weight:600;color:var(--color-text-primary, #0f172a)}.dashboard-overview .subtitle{margin:2px 0 0;color:var(--color-text-tertiary, #64748b);font-size:12px}.dashboard-overview .header-actions{display:flex;gap:6px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:#fff;border-radius:8px;padding:10px 12px;display:flex;align-items:center;gap:10px;border:1px solid var(--color-border, #e2e8f0);text-decoration:none;transition:border-color .15s}.stat-card:hover{border-color:var(--color-primary, #3b82f6)}.stat-icon{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-content{min-width:0}.stat-value{font-size:18px;font-weight:700;color:var(--color-text-primary, #0f172a);line-height:1}.stat-value .skeleton{display:inline-block;width:28px;height:18px;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:skeleton-pulse 1.2s ease-in-out infinite;border-radius:4px}.stat-title{font-size:11px;color:var(--color-text-tertiary, #64748b);margin-top:1px}.dashboard-overview .section{margin-bottom:12px}.dashboard-overview .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.dashboard-overview .section-header h2{font-size:13px;font-weight:600;color:var(--color-text-primary, #0f172a);margin:0}.view-all{font-size:11px;color:var(--color-primary, #3b82f6);text-decoration:none}.view-all:hover{text-decoration:underline}.actions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}@media(max-width:768px){.actions-grid{grid-template-columns:repeat(2,1fr)}}.dashboard-overview .action-card{background:#fff;border-radius:8px;padding:10px 12px;display:flex;flex-direction:column;gap:6px;border:1px solid var(--color-border, #e2e8f0);text-decoration:none;transition:border-color .15s}.dashboard-overview .action-card:hover{border-color:var(--color-primary, #3b82f6)}.dashboard-overview .action-icon{width:28px;height:28px;background:var(--color-bg-tertiary, #f1f5f9);border-radius:6px;display:flex;align-items:center;justify-content:center}.action-content{flex:1}.action-title{font-size:12px;font-weight:600;color:var(--color-text-primary, #0f172a)}.action-description{font-size:10px;color:var(--color-text-tertiary, #64748b);margin-top:1px}.action-arrow{display:none}.dashboard-overview .card{background:#fff;border-radius:8px;border:1px solid var(--color-border, #e2e8f0)}.empty-activity{padding:20px 12px;text-align:center}.empty-activity svg{margin-bottom:6px;opacity:.4;color:var(--color-text-muted, #94a3b8)}.empty-activity p{font-size:12px;font-weight:500;color:var(--color-text-secondary, #475569);margin:0}.empty-activity span{font-size:11px;color:var(--color-text-muted, #94a3b8)}@media(max-width:480px){.dashboard-overview{padding:12px}.dashboard-overview .page-header{flex-direction:column;align-items:stretch;gap:6px}.dashboard-overview .header-actions{justify-content:stretch}.dashboard-overview .btn-primary{justify-content:center;width:100%}.action-description{display:none}}.employee-management{padding:12px}.employee-management .filters{display:flex;flex-direction:column;gap:8px;padding:10px 12px;border-bottom:1px solid var(--color-border, #e2e8f0)}.employee-management .search-input{flex:1;padding:10px 12px;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;font-size:1rem;min-height:44px}.employee-management .search-input:focus{outline:none;border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 2px var(--color-primary-light, #eff6ff)}.employee-management .filter-select{padding:10px var(--select-padding-end) 10px 12px;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;font-size:1rem;min-width:100%;min-height:44px;background:#fff}.employee-management .table-container{overflow:auto;height:calc(100vh - 280px);min-height:300px;position:relative}.employee-management .data-table th:nth-child(1){width:90px}.employee-management .data-table th:nth-child(2){width:120px}.employee-management .data-table th:nth-child(3){width:160px}.employee-management .data-table th:nth-child(4){width:90px}.employee-management .data-table th:nth-child(5){width:70px}.employee-management .data-table th:nth-child(6){width:100px}.employee-management .data-table th:nth-child(7){width:100px}.employee-management .data-table th:nth-child(8){width:80px}.employee-management .data-table td:nth-child(5),.employee-management .data-table td:nth-child(6),.employee-management .data-table td:nth-child(7),.employee-management .data-table td:nth-child(8){text-overflow:clip;overflow:visible}.activation-link-cell{vertical-align:middle}.no-link{color:var(--color-text-muted, #94a3b8);font-size:11px}.btn-copy-link-inline{display:inline-flex;align-items:center;gap:4px;padding:6px 8px;border:1px solid var(--color-border, #e2e8f0);border-radius:4px;background:#fff;cursor:pointer;font-size:11px;color:var(--color-text-tertiary, #64748b);transition:all .15s ease;white-space:nowrap}.btn-copy-link-inline:hover{background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-secondary, #475569)}.btn-copy-link-inline.valid{color:var(--color-success, #22c55e);border-color:var(--color-success-light, #86efac)}.btn-copy-link-inline.valid:hover{background:var(--color-success-light, #dcfce7)}.btn-copy-link-inline.expired{color:var(--color-warning, #f59e0b);border-color:var(--color-warning-light, #fde68a)}.btn-copy-link-inline.expired:hover{background:var(--color-warning-light, #fef3c7)}.link-status-text{font-weight:500;font-size:10px}.edit-form-content{padding:0}.disabled-input{background:var(--color-bg-tertiary, #f8fafc)!important;color:var(--color-text-muted, #94a3b8)!important;cursor:not-allowed!important}.form-hint{display:block;margin-top:4px;font-size:12px;color:var(--color-text-muted, #94a3b8);font-style:italic}.edit-form-content .form-group{margin-bottom:16px}.edit-form-content .form-group label{display:block;margin-bottom:8px;font-size:.9375rem;font-weight:500;color:var(--color-text-secondary, #374151)}.edit-form-content .form-group input,.edit-form-content .form-group select{width:100%;padding:12px 14px;border:1px solid var(--color-border, #d1d5db);border-radius:8px;font-size:1rem;box-sizing:border-box;min-height:44px}.edit-form-content .form-group input:focus,.edit-form-content .form-group select:focus{outline:none;border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 2px var(--color-primary-light, #eff6ff)}.edit-form-content .form-actions{display:flex;flex-direction:column-reverse;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--color-border, #e2e8f0)}.edit-form-content .form-actions button{width:100%;min-height:44px;justify-content:center}@media(min-width:640px){.employee-detail-modal{max-width:600px}.edit-form-content .form-group label{font-size:13px;margin-bottom:6px}.edit-form-content .form-group input,.edit-form-content .form-group select{padding:8px 12px;font-size:14px;min-height:auto}.edit-form-content .form-actions{flex-direction:row;justify-content:flex-end}.edit-form-content .form-actions button{width:auto;min-height:auto}}.activation-link-content{display:flex;flex-direction:column;gap:16px}.activation-link-content h3{margin:0;font-size:14px;font-weight:600;color:var(--color-text-primary, #1e293b)}.info-section{background:var(--color-bg-tertiary, #f8fafc);border-radius:8px;padding:12px}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:8px}.info-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.info-item label{font-size:12px;color:var(--color-text-tertiary, #64748b);font-weight:500}.info-item span{font-size:13px;color:var(--color-text-primary, #0f172a);font-weight:500}.status-section{padding:0}.status-card{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;border:1px solid}.status-card.valid{background:var(--color-success-light, #dcfce7);border-color:var(--color-success, #22c55e)}.status-card.expired{background:var(--color-warning-light, #fef3c7);border-color:var(--color-warning, #f59e0b)}.status-card .status-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:#fff}.status-card.valid .status-icon{color:var(--color-success, #22c55e)}.status-card.expired .status-icon{color:var(--color-warning, #f59e0b)}.status-card .status-info{flex:1}.status-card .status-title{font-size:14px;font-weight:600;margin-bottom:2px}.status-card.valid .status-title{color:var(--color-success-dark, #15803d)}.status-card.expired .status-title{color:var(--color-warning-dark, #d97706)}.status-card .status-description{font-size:12px;color:var(--color-text-secondary, #475569)}.link-section{padding:0}.url-display{display:flex;gap:8px}.url-input{flex:1;padding:8px 12px;border:1px solid var(--color-border, #d1d5db);border-radius:6px;font-size:12px;font-family:monospace;background:var(--color-bg-tertiary, #f9fafb);color:var(--color-text-secondary, #475569)}.btn-copy{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;background:var(--color-primary, #3b82f6);color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:background .15s}.btn-copy:hover{background:var(--color-primary-hover, #2563eb)}.expiration-section{padding:0}.expiration-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px}.expiration-item{display:flex;flex-direction:column;gap:4px}.expiration-item label{font-size:11px;color:var(--color-text-tertiary, #64748b);font-weight:500}.expiration-item span{font-size:12px;color:var(--color-text-primary, #0f172a);font-weight:500}.time-remaining{font-weight:600}.time-remaining.valid{color:var(--color-success, #22c55e)}.time-remaining.expired{color:var(--color-warning, #f59e0b)}.actions-section{padding:0}.action-buttons{display:flex;gap:8px;margin-bottom:12px}.expired-notice{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--color-warning-light, #fef3c7);border:1px solid var(--color-warning, #f59e0b);border-radius:6px;color:var(--color-warning-dark, #d97706);font-size:12px}@media(min-width:641px){.employee-management{padding:16px}.employee-management .filters{flex-direction:row}.employee-management .search-input{padding:6px 10px;border-radius:6px;font-size:13px;min-height:auto}.employee-management .filter-select{min-width:140px;padding:6px var(--select-padding-end) 6px 10px;font-size:13px;min-height:auto}.employee-management .table-container{height:calc(100vh - 220px)}.activation-link-modal{max-width:600px}}.admin-user-management{padding:16px}.admin-user-management .filters{display:flex;gap:8px;padding:10px 12px;border-bottom:1px solid var(--color-border, #e2e8f0)}.admin-user-management .search-input{flex:1;padding:6px 10px;border:1px solid var(--color-border, #e2e8f0);border-radius:6px;font-size:13px}.admin-user-management .search-input:focus{outline:none;border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 2px var(--color-primary-light, #eff6ff)}.admin-user-management .filter-select{padding:6px var(--select-padding-end) 6px 10px;border:1px solid var(--color-border, #e2e8f0);border-radius:6px;font-size:13px;min-width:130px;background:#fff}.admin-user-management .table-container{overflow:auto;height:calc(100vh - 220px);min-height:300px;position:relative}.admin-user-management .data-table th:nth-child(1){width:150px}.admin-user-management .data-table th:nth-child(2){width:200px}.admin-user-management .data-table th:nth-child(3){width:110px}.admin-user-management .data-table th:nth-child(4){width:120px}.admin-user-management .data-table th:nth-child(5){width:100px}.admin-user-management .data-table th:nth-child(6){width:100px}.role-super-admin{background:#fce7f3;color:#9d174d}.role-hr-manager{background:#e0e7ff;color:#3730a3}.role-viewer{background:#f1f5f9;color:#475569}.admin-user-management .edit-form-content .form-group{margin-bottom:16px}.admin-user-management .disabled-input{background:var(--color-bg-tertiary, #f8fafc)!important;color:var(--color-text-muted, #94a3b8)!important;cursor:not-allowed!important}.admin-user-management .form-hint{display:block;margin-top:4px;font-size:11px;color:var(--color-text-muted, #94a3b8);font-style:italic}@media(max-width:640px){.admin-user-management{padding:12px}.admin-user-management .filters{flex-direction:column}.admin-user-management .filter-select{min-width:100%}.admin-user-management .table-container{height:calc(100vh - 280px)}}.leave-request-management{display:flex;flex-direction:column;gap:12px;padding:12px;width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.leave-request-management .page-header{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:8px;margin-bottom:0;padding:0}.leave-request-management .page-header>div:first-child{flex:1;min-width:0}.leave-request-management .page-header h1{font-size:1.125rem;margin:0;white-space:nowrap}.leave-request-management .page-header .subtitle{display:none}.leave-request-management .header-actions{flex-shrink:0;width:auto!important}.leave-request-management .header-actions button{padding:6px 10px;font-size:13px;min-height:36px;white-space:nowrap}.leave-request-management .filters{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:10px;border-radius:8px;background:var(--color-bg-tertiary, #f8fafc)}.leave-request-management .filters .select-container.inline.filter-select{width:100%!important;display:flex!important}.leave-request-management .filters .filter-select .ui-select{width:100%!important;min-width:0!important;max-width:100%!important;min-height:32px;height:32px;font-size:12px;padding:4px 28px 4px 8px;box-sizing:border-box}.leave-request-management .card{display:flex;flex-direction:column;gap:0;border-radius:8px;overflow:hidden}.leave-request-management .table-container{overflow:auto;min-height:150px;position:relative}@media(max-width:768px){.leave-request-management .table-container{height:auto;max-height:calc(100vh - 200px);overflow-y:auto;overflow-x:hidden;padding:6px}.leave-request-management .data-table thead{display:none}.leave-request-management .data-table,.leave-request-management .data-table tbody{display:block;width:100%}.leave-request-management .data-table tr{display:flex;flex-direction:column;background:#fff;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;margin-bottom:8px;padding:10px 12px;box-shadow:0 1px 2px #0000000a}.leave-request-management .data-table tr:hover{background:#fff}.leave-request-management .data-table td{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:none;height:auto!important;white-space:normal!important;text-overflow:clip!important;overflow:visible!important;box-sizing:border-box;font-size:13px;color:var(--color-text-primary, #0f172a)}.leave-request-management .data-table td:before{content:attr(data-label);font-weight:500;font-size:11px;color:var(--color-text-tertiary, #64748b);flex-shrink:0}.leave-request-management .data-table td[data-label="Request #"] .cell-value{font-family:monospace;font-size:12px;font-weight:600;color:var(--color-text-primary)}.leave-request-management .data-table td[data-label=Employee]{padding:8px 0;border-bottom:1px solid var(--color-border-light, #f1f5f9)}.leave-request-management .data-table td .employee-info{display:flex;flex-direction:row;align-items:center;gap:6px;flex-wrap:wrap}.leave-request-management .data-table td .employee-name{font-size:13px;font-weight:600;color:var(--color-text-primary, #0f172a)}.leave-request-management .data-table td .employee-id{font-size:11px;color:var(--color-text-tertiary, #64748b)}.leave-request-management .data-table td .dates-cell{font-size:12px;gap:4px}.leave-request-management .data-table td.days-cell .cell-value{font-weight:700;font-size:15px;color:var(--color-primary, #3b82f6)}.leave-request-management .data-table td[data-label=Actions]{padding-top:10px;border-top:1px solid var(--color-border-light, #f1f5f9);margin-top:4px}.leave-request-management .data-table td[data-label=Actions]:before{display:none}.leave-request-management .data-table td .actions-cell{width:100%;justify-content:flex-start;gap:8px;flex-wrap:wrap}.leave-request-management .data-table .actions-cell .btn-icon{width:40px;height:40px;min-width:40px;min-height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-tertiary, #f8fafc);border:1px solid var(--color-border, #e2e8f0)}.leave-request-management .data-table .actions-cell .btn-icon svg{width:18px;height:18px}.leave-request-management .data-table .actions-cell .btn-icon.success{background:var(--color-success-light, #dcfce7);border-color:var(--color-success, #22c55e);color:var(--color-success, #22c55e)}.leave-request-management .data-table .actions-cell .btn-icon.danger{background:var(--color-danger-light, #fee2e2);border-color:var(--color-danger, #ef4444);color:var(--color-danger, #ef4444)}.leave-request-management .data-table .actions-cell .btn-icon.warning{background:var(--color-warning-light, #fef3c7);border-color:var(--color-warning, #f59e0b);color:var(--color-warning, #f59e0b)}.leave-request-management .data-table tr:has(.empty-cell){border:none;box-shadow:none;background:transparent;padding:20px 12px}.leave-request-management .data-table .empty-cell{display:block;text-align:center}.leave-request-management .data-table .empty-cell:before{display:none}.leave-request-management .data-table tr.skeleton-row td{justify-content:flex-end}.leave-request-management .data-table tr.skeleton-row td:before{display:none}.leave-request-management .pagination{padding:8px;gap:6px;height:auto}.leave-request-management .pagination .btn-icon{width:32px;height:32px;min-width:32px;min-height:32px}}.leave-type-badge{display:inline-block;padding:4px 8px;background:var(--color-bg-secondary, #f1f5f9);color:var(--color-text-secondary, #475569);border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.dates-cell{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-secondary, #475569)}.date-separator{color:var(--color-text-tertiary, #94a3b8)}.days-cell{font-weight:500;color:var(--color-text-primary, #0f172a)}.status-badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.status-badge.pending{background:#fff7ed;color:#c2410c;border:1px solid #ffedd5}.status-badge.approved{background:#f0fdf4;color:#15803d;border:1px solid #dcfce7}.status-badge.rejected{background:#fef2f2;color:#b91c1c;border:1px solid #fee2e2}.status-badge.cancelled{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.actions-cell{display:flex;gap:6px;align-items:center}.btn-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--color-text-tertiary, #64748b);cursor:pointer;transition:all .2s}.btn-icon:hover{background:var(--color-bg-secondary, #f1f5f9);color:var(--color-text-primary, #0f172a);border-color:var(--color-border, #e2e8f0)}.btn-icon.success:hover{background:#f0fdf4;color:#15803d;border-color:#dcfce7}.btn-icon.danger:hover{background:#fef2f2;color:#b91c1c;border-color:#fee2e2}.btn-icon.warning:hover{background:#fff7ed;color:#c2410c;border-color:#ffedd5}.leave-request-management .data-table th:nth-child(1){width:110px}.leave-request-management .data-table th:nth-child(2){width:150px}.leave-request-management .data-table th:nth-child(3){width:80px}.leave-request-management .data-table th:nth-child(4){width:180px}.leave-request-management .data-table th:nth-child(5){width:60px}.leave-request-management .data-table th:nth-child(6){width:90px}.leave-request-management .data-table th:nth-child(7){width:120px}.leave-request-management .data-table td:nth-child(6),.leave-request-management .data-table td:nth-child(7){text-overflow:clip;overflow:visible}.employee-info{display:flex;flex-direction:column;gap:2px}.employee-name{font-weight:500;color:var(--color-text-primary, #0f172a)}.employee-id{font-size:11px;color:var(--color-text-tertiary, #64748b)}.leave-type-badge{display:inline-block;padding:2px 6px;background:var(--color-primary-light, #eff6ff);color:var(--color-primary, #3b82f6);font-size:11px;font-weight:600;border-radius:4px;font-family:monospace}.dates-cell{display:flex;align-items:center;gap:4px;font-size:12px}.date-separator{color:var(--color-text-muted, #94a3b8)}.days-cell{font-weight:600;color:var(--color-text-primary, #0f172a)}.status-badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.status-badge.large{padding:6px 12px;font-size:13px}.status-pending{background:var(--color-warning-light, #fef3c7);color:var(--color-warning-dark, #d97706)}.status-approved{background:var(--color-success-light, #dcfce7);color:var(--color-success-dark, #15803d)}.status-rejected{background:var(--color-danger-light, #fee2e2);color:var(--color-danger, #ef4444)}.status-cancelled{background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-tertiary, #64748b)}.btn-icon.success{color:var(--color-success, #22c55e)}.btn-icon.success:hover{background:var(--color-success-light, #dcfce7)}.btn-icon.danger{color:var(--color-danger, #ef4444)}.btn-icon.danger:hover{background:var(--color-danger-light, #fee2e2)}.btn-icon.warning{color:var(--color-warning, #f59e0b)}.btn-icon.warning:hover{background:var(--color-warning-light, #fef3c7)}.btn-success{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--color-success, #22c55e);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.btn-success:hover{background:var(--color-success-dark, #16a34a)}.btn-danger{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--color-danger, #ef4444);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.btn-danger:hover{background:#dc2626}.btn-warning{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--color-warning, #f59e0b);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.btn-warning:hover{background:var(--color-warning-dark, #d97706)}.form-row{display:grid;grid-template-columns:1fr;gap:12px}@media(min-width:640px){.modal.modal-lg{max-width:700px}.modal.modal-sm{max-width:450px}.form-row{grid-template-columns:1fr 1fr}}.detail-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:20px}.detail-section{background:var(--color-bg-tertiary, #f8fafc);border-radius:8px;padding:12px}.detail-section.full-width{grid-column:1 / -1}.detail-section h3{display:flex;align-items:center;gap:6px;margin:0 0 10px;font-size:12px;font-weight:600;color:var(--color-text-tertiary, #64748b);text-transform:uppercase}.detail-content{display:flex;flex-direction:column;gap:4px}.detail-main{font-size:14px;font-weight:500;color:var(--color-text-primary, #0f172a);display:flex;align-items:center;gap:8px}.detail-sub{font-size:12px;color:var(--color-text-secondary, #475569)}.detail-dates{font-size:13px;color:var(--color-text-primary, #0f172a);font-weight:500}.detail-days{font-size:14px;font-weight:600;color:var(--color-primary, #3b82f6)}.detail-actions{display:flex;flex-direction:column;gap:10px;padding-top:16px;border-top:1px solid var(--color-border, #e2e8f0);margin-top:16px}.detail-actions button{width:100%;min-height:44px;justify-content:center}.action-history{margin-top:20px}.action-history h3{display:flex;align-items:center;gap:6px;margin:0 0 12px;font-size:13px;font-weight:600;color:var(--color-text-primary, #0f172a)}.timeline{display:flex;flex-direction:column;gap:12px}.timeline-item{display:flex;gap:12px}.timeline-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--color-bg-tertiary, #f1f5f9);flex-shrink:0}.timeline-icon.submitted{background:var(--color-primary-light, #eff6ff);color:var(--color-primary, #3b82f6)}.timeline-icon.approved{background:var(--color-success-light, #dcfce7);color:var(--color-success, #22c55e)}.timeline-icon.rejected{background:var(--color-danger-light, #fee2e2);color:var(--color-danger, #ef4444)}.timeline-icon.cancelled{background:var(--color-warning-light, #fef3c7);color:var(--color-warning, #f59e0b)}.timeline-content{flex:1}.timeline-action{font-size:13px;font-weight:500;color:var(--color-text-primary, #0f172a);margin:0 0 2px}.timeline-actor{font-weight:400;color:var(--color-text-secondary, #475569)}.timeline-reason{font-size:12px;color:var(--color-text-secondary, #475569);margin:4px 0;padding:6px 10px;background:var(--color-bg-tertiary, #f8fafc);border-radius:4px}.timeline-date{font-size:11px;color:var(--color-text-muted, #94a3b8);margin:0}.confirm-text{font-size:14px;color:var(--color-text-secondary, #475569);margin-bottom:16px}.warning-text{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:var(--color-warning-light, #fef3c7);border:1px solid var(--color-warning, #f59e0b);border-radius:6px;color:var(--color-warning-dark, #d97706);font-size:13px;margin-bottom:16px}.empty-cell{text-align:center;padding:40px 20px!important}.empty-state{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--color-text-muted, #94a3b8)}.empty-state p{margin:0;font-size:14px}.error-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 20px;color:var(--color-danger, #ef4444)}.error-state p{margin:0;font-size:14px}.loading-state{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--color-text-muted, #94a3b8)}.leave-request-management .calculation-breakdown{background:#fff;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;padding:10px 12px;font-size:13px;margin-top:12px}.leave-request-management .breakdown-total{display:flex;justify-content:space-between;padding-bottom:8px;border-bottom:1px solid var(--color-border, #e2e8f0);margin-bottom:8px;color:var(--color-text-secondary, #475569)}.leave-request-management .breakdown-item{display:flex;justify-content:space-between;padding:4px 0;color:var(--color-text-secondary, #475569)}.leave-request-management .breakdown-item strong{color:var(--color-primary, #3b82f6);font-weight:600}.leave-request-management .breakdown-item.deduction{color:var(--color-danger, #ef4444)}.leave-request-management .holiday-list{margin:4px 0 8px;padding:8px;list-style:none;background:#fef2f2;border-radius:6px}.leave-request-management .holiday-list li{font-size:12px;color:#991b1b;padding:2px 0}@media(min-width:769px){.leave-request-management{gap:16px;padding:16px}.leave-request-management .page-header{margin-bottom:0}.leave-request-management .page-header h1{font-size:1.25rem}.leave-request-management .page-header .subtitle{display:block;font-size:12px;margin:2px 0 0}.leave-request-management .header-actions button{padding:8px 14px;font-size:13px;min-height:auto}.leave-request-management .filters{display:flex!important;grid-template-columns:none;flex-direction:row;align-items:center;justify-content:flex-start;gap:12px;flex-wrap:wrap;padding:10px 12px;border-radius:0;border-bottom:1px solid var(--color-border, #e2e8f0);background:transparent}.leave-request-management .filters .select-container.inline.filter-select{width:auto!important;display:inline-flex!important;flex:0 0 auto}.leave-request-management .filters .filter-select .ui-select{width:auto!important;min-width:130px!important;max-width:none!important;height:34px;min-height:34px;font-size:13px;padding:6px 32px 6px 10px}.leave-request-management .table-container{height:calc(100vh - 200px);padding:0}.detail-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.detail-actions{flex-direction:row}.detail-actions button{width:auto;min-height:auto}}.code-cell{display:flex;align-items:center;gap:6px}.default-star{color:var(--color-warning);fill:var(--color-warning)}.default-star.inline{margin-left:6px;vertical-align:middle}.allocation-badges{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.allocation-badge{display:inline-flex;align-items:center;gap:4px;background:var(--color-bg-tertiary);padding:2px 6px;border-radius:var(--radius-sm);font-size:11px}.allocation-badge .days{font-weight:500;color:var(--color-text-secondary)}.more-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--color-primary-light);color:var(--color-primary);padding:2px 6px;border-radius:var(--radius-sm);font-size:10px;font-weight:500}.employee-count{display:flex;align-items:center;gap:4px;color:var(--color-text-tertiary);font-size:13px}.allocation-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-top:8px}.allocation-item{display:flex;flex-direction:column;gap:6px;padding:10px 12px;background:var(--color-bg-tertiary);border-radius:var(--radius-md)}.allocation-item>label{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.allocation-input-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.use-default-checkbox{display:flex;align-items:center;gap:4px;cursor:pointer;font-size:12px;color:var(--color-text-tertiary)}.use-default-checkbox input[type=checkbox]{width:14px;height:14px;cursor:pointer}.use-default-checkbox span{-webkit-user-select:none;user-select:none}.allocation-input{display:flex;align-items:center;gap:4px}.allocation-input input{width:60px;padding:4px 8px;font-size:13px;text-align:right;border:1px solid var(--color-border);border-radius:var(--radius-sm)}.allocation-input input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.allocation-input .unit{font-size:12px;color:var(--color-text-muted)}.allocation-table{margin-top:8px;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.allocation-table table{width:100%;border-collapse:collapse}.allocation-table th,.allocation-table td{padding:8px 12px;text-align:left;border-bottom:1px solid var(--color-border)}.allocation-table th{background:var(--color-bg-tertiary);font-size:11px;font-weight:600;text-transform:uppercase;color:var(--color-text-tertiary)}.allocation-table tr:last-child td{border-bottom:none}.allocation-table td:last-child{text-align:right;font-weight:500}.form-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--color-border)}.form-section h4{margin:0 0 4px;font-size:14px;font-weight:600;color:var(--color-text-primary)}.form-section .form-hint{margin-bottom:8px}.detail-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--color-border)}.detail-section h4{margin:0 0 8px;font-size:14px;font-weight:600;color:var(--color-text-primary)}.warning-box{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#fff3cd;border:1px solid #ffc107;border-radius:var(--radius-md);color:#856404;font-size:13px;margin-top:12px}.warning-text{color:var(--color-warning);font-size:13px;margin-top:4px}.ui-select{font-family:inherit;font-size:.875rem;color:var(--color-text-primary);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.625rem 2.5rem .625rem .875rem;transition:all .2s ease;outline:none;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:var(--select-chevron);background-repeat:no-repeat;background-position:right .75rem center;background-size:1rem;cursor:pointer;line-height:normal;width:100%;max-width:100%;box-sizing:border-box}.ui-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.ui-select.has-error{border-color:var(--color-danger)}.ui-select:disabled{background-color:var(--color-bg-tertiary);cursor:not-allowed;opacity:.7}.select-container{display:flex;flex-direction:column;gap:6px;width:100%}.select-container.inline{width:auto;display:inline-flex}.select-label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.select-error{font-size:.75rem;color:var(--color-danger)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#111827,#374151)}.auth-card{background:#fff;border-radius:16px;padding:40px;max-width:450px;width:100%;text-align:center;box-shadow:0 10px 40px #0003}.auth-card.narrow{max-width:400px}.auth-card h1{margin:0 0 8px;color:#333;font-size:24px}.auth-card p{color:#718096;margin:8px 0}.auth-card.error h1{color:#e53e3e}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.auth-card.animated{animation:fadeIn .3s ease-out}.auth-user-info{background:#f7fafc;border-radius:8px;padding:16px;margin-bottom:24px;text-align:left}.auth-user-info p{margin:8px 0;color:#4a5568}.email-text{font-size:14px}.auth-role-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;color:#fff!important}.auth-role-badge.admin{background:#667eea}.auth-role-badge.employee{background:#48bb78}.line-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:#00b900;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s;width:100%}.line-button:hover{background:#00a000}.line-button.admin{background:#667eea}.line-button.admin:hover{background:#5a67d8}.login-options{display:flex;flex-direction:column;gap:12px;margin-top:24px}.dashboard-links{margin:24px 0;display:flex;flex-direction:column;gap:12px}.session-row{display:flex;gap:8px}.session-row .dashboard-button{flex:1}.dashboard-button{background:#06b6d4;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;width:100%;transition:all .2s}.dashboard-button:hover{background:#0891b2;transform:translateY(-1px)}.dashboard-button.admin{background:#8b5cf6}.dashboard-button.admin:hover{background:#7c3aed}.session-logout-btn{display:flex;align-items:center;justify-content:center;width:44px;min-width:44px;background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;cursor:pointer;transition:all .2s}.session-logout-btn:hover{background:#ef4444;color:#fff;border-color:#ef4444}.session-logout-btn.admin{background:#8b5cf61a;color:#8b5cf6;border-color:#8b5cf64d}.session-logout-btn.admin:hover{background:#8b5cf6;color:#fff;border-color:#8b5cf6}.auth-logout-button{background:#e53e3e;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;cursor:pointer;margin-top:12px;width:100%}.auth-logout-button:hover{background:#c53030}.activation-action{text-align:center}.activation-action p{color:#718096;margin-bottom:16px}.expires-info{margin-top:24px;text-align:center;color:#a0aec0;font-size:14px}.callback-card{background:#fff;border-radius:16px;padding:40px;max-width:400px;width:100%;text-align:center;box-shadow:0 10px 40px #0003}.callback-card h1{margin:16px 0;color:#333}.callback-card p{color:#718096;margin:8px 0}.auth-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;margin:0 auto;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-success-icon{width:64px;height:64px;background:#48bb78;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto}.auth-error-icon{width:64px;height:64px;background:#f56565;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto}.callback-user-info{background:#f7fafc;border-radius:8px;padding:16px;margin:16px 0}.callback-role-badge{display:inline-block;background:#667eea;color:#fff!important;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.redirect-info{color:#a0aec0!important;font-size:14px}.retry-button{background:#667eea;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;cursor:pointer;margin-top:16px}.retry-button:hover{background:#5a67d8}.authenticated,.unauthenticated{text-align:center}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-bg-primary: #f8fafc;--color-bg-secondary: #ffffff;--color-bg-tertiary: #f1f5f9;--color-text-primary: #0f172a;--color-text-secondary: #475569;--color-text-tertiary: #64748b;--color-text-muted: #94a3b8;--color-border: #e2e8f0;--color-border-light: #f1f5f9;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-primary-light: #eff6ff;--color-success: #22c55e;--color-success-light: #dcfce7;--color-success-dark: #166534;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-warning-dark: #92400e;--color-danger: #ef4444;--color-danger-light: #fee2e2;--color-danger-dark: #991b1b;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--select-padding-end: 2.5rem;--select-chevron: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='m6 9 6 6 6-6'/%3e%3c/svg%3e")}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--color-bg-primary);color:var(--color-text-primary)}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{color:var(--color-text-primary);font-weight:600;line-height:1.3;margin:0}h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}p{color:var(--color-text-secondary);margin:0}a{color:var(--color-primary);text-decoration:none;font-weight:500;transition:color .2s ease}a:hover{color:var(--color-primary-hover)}button{font-family:inherit;font-size:.875rem;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;outline:none;display:inline-flex;align-items:center;justify-content:center;gap:8px}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}input,textarea{font-family:inherit;font-size:.875rem;color:var(--color-text-primary);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.625rem .875rem;transition:all .2s ease;outline:none}select{font-family:inherit;font-size:.875rem;color:var(--color-text-primary);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.625rem var(--select-padding-end) .625rem .875rem;transition:all .2s ease;outline:none;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:var(--select-chevron);background-repeat:no-repeat;background-position:right .75rem center;background-size:1rem;cursor:pointer}input:focus,select:focus,textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}input::placeholder{color:var(--color-text-muted)}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);background:var(--color-bg-tertiary);padding:.5rem .75rem;border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:10}td{padding:.5rem .75rem;border-bottom:1px solid var(--color-border);color:var(--color-text-secondary);font-size:.8125rem}tr:hover{background:var(--color-bg-tertiary)}.skeleton{background:linear-gradient(90deg,var(--color-bg-tertiary) 25%,var(--color-border) 50%,var(--color-bg-tertiary) 75%);background-size:200% 100%;animation:skeleton-pulse 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-container{min-height:300px;display:flex;align-items:center;justify-content:center}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}::selection{background:var(--color-primary-light);color:var(--color-primary)}.terms-container{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);padding:40px 20px;display:flex;justify-content:center}.terms-card{max-width:800px;width:100%;background:#1e293bcc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden}.terms-header{padding:32px;border-bottom:1px solid rgba(255,255,255,.1);text-align:center}.terms-header .back-link{display:inline-flex;align-items:center;gap:8px;color:#94a3b8;text-decoration:none;font-size:14px;margin-bottom:24px;transition:color .2s}.terms-header .back-link:hover{color:#22d3ee}.terms-header .brand-section{display:flex;flex-direction:column;align-items:center;gap:8px}.terms-header h1{font-size:32px;font-weight:700;background:linear-gradient(135deg,#22d3ee,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.terms-header .subtitle{font-size:14px;color:#64748b;margin:0}.terms-content{padding:32px;color:#e2e8f0}.terms-content h2{font-size:24px;font-weight:600;color:#f1f5f9;margin:0 0 8px;text-align:center}.terms-content .last-updated{text-align:center;font-size:13px;color:#64748b;margin-bottom:32px}.terms-content section{margin-bottom:28px}.terms-content h3{font-size:16px;font-weight:600;color:#22d3ee;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid rgba(34,211,238,.2)}.terms-content p{font-size:14px;line-height:1.7;color:#cbd5e1;margin:0 0 12px}.terms-content ul{margin:0;padding-left:24px}.terms-content li{font-size:14px;line-height:1.7;color:#cbd5e1;margin-bottom:8px}.terms-content li::marker{color:#22d3ee}.terms-content .acceptance{background:#22d3ee1a;border:1px solid rgba(34,211,238,.3);border-radius:12px;padding:20px;margin-top:32px}.terms-content .acceptance p{margin:0;color:#a5f3fc;text-align:center}.terms-content .acceptance strong{color:#22d3ee}.terms-footer{padding:20px 32px;border-top:1px solid rgba(255,255,255,.1);text-align:center}.terms-footer .footer-links{margin-bottom:12px}.terms-footer .footer-links a{color:#22d3ee;text-decoration:none;font-size:13px;transition:color .2s}.terms-footer .footer-links a:hover{color:#a5f3fc;text-decoration:underline}.terms-footer p{font-size:12px;color:#64748b;margin:0}@media(max-width:640px){.terms-container{padding:20px 16px}.terms-card{border-radius:12px}.terms-header{padding:24px 20px}.terms-header h1{font-size:28px}.terms-content{padding:24px 20px}.terms-content h2{font-size:20px}.terms-content h3{font-size:15px}.terms-footer{padding:16px 20px}}.privacy-container{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);padding:40px 20px;display:flex;justify-content:center}.privacy-card{max-width:800px;width:100%;background:#1e293bcc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden}.privacy-header{padding:32px;border-bottom:1px solid rgba(255,255,255,.1);text-align:center}.privacy-header .back-link{display:inline-flex;align-items:center;gap:8px;color:#94a3b8;text-decoration:none;font-size:14px;margin-bottom:24px;transition:color .2s}.privacy-header .back-link:hover{color:#22d3ee}.privacy-header .brand-section{display:flex;flex-direction:column;align-items:center;gap:8px}.privacy-header h1{font-size:32px;font-weight:700;background:linear-gradient(135deg,#22d3ee,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.privacy-header .subtitle{font-size:14px;color:#64748b;margin:0}.privacy-content{padding:32px;color:#e2e8f0}.privacy-title-section{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}.privacy-icon{color:#22d3ee}.privacy-content h2{font-size:24px;font-weight:600;color:#f1f5f9;margin:0}.privacy-content .last-updated{text-align:center;font-size:13px;color:#64748b;margin-bottom:32px}.privacy-content section{margin-bottom:28px}.privacy-content h3{font-size:16px;font-weight:600;color:#22d3ee;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid rgba(34,211,238,.2)}.privacy-content h4{font-size:14px;font-weight:600;color:#a5f3fc;margin:16px 0 8px}.privacy-content p{font-size:14px;line-height:1.7;color:#cbd5e1;margin:0 0 12px}.privacy-content ul{margin:0 0 12px;padding-left:24px}.privacy-content li{font-size:14px;line-height:1.7;color:#cbd5e1;margin-bottom:8px}.privacy-content li::marker{color:#22d3ee}.privacy-content li strong{color:#f1f5f9}.privacy-content .contact-info{background:#0f172a80;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:16px;margin-top:12px}.privacy-content .contact-info p{margin:0;text-align:center}.privacy-content .contact-info p:first-child{margin-bottom:4px}.privacy-content .acceptance{background:#22d3ee1a;border:1px solid rgba(34,211,238,.3);border-radius:12px;padding:20px;margin-top:32px}.privacy-content .acceptance p{margin:0;color:#a5f3fc;text-align:center}.privacy-content .acceptance strong{color:#22d3ee}.privacy-footer{padding:20px 32px;border-top:1px solid rgba(255,255,255,.1);text-align:center}.privacy-footer .footer-links{margin-bottom:12px}.privacy-footer .footer-links a{color:#22d3ee;text-decoration:none;font-size:13px;transition:color .2s}.privacy-footer .footer-links a:hover{color:#a5f3fc;text-decoration:underline}.privacy-footer p{font-size:12px;color:#64748b;margin:0}@media(max-width:640px){.privacy-container{padding:20px 16px}.privacy-card{border-radius:12px}.privacy-header{padding:24px 20px}.privacy-header h1{font-size:28px}.privacy-content{padding:24px 20px}.privacy-title-section{flex-direction:column;gap:8px}.privacy-content h2{font-size:20px}.privacy-content h3{font-size:15px}.privacy-content h4{font-size:13px}.privacy-footer{padding:16px 20px}}.business-day-off-management .filters{padding:10px 12px;border-bottom:1px solid var(--color-border, #e2e8f0);display:flex;gap:20px;flex-wrap:wrap}.business-day-off-management .day-off-date{display:flex;align-items:center;gap:8px;font-weight:500;color:var(--color-text-primary, #0f172a)}.business-day-off-management .recurring-badge{font-size:.625rem;font-weight:700;text-transform:uppercase;padding:2px 6px;background:var(--color-primary-light, #dbeafe);color:var(--color-primary, #3b82f6);border-radius:4px;white-space:nowrap}.business-day-off-management .type-badge{display:inline-flex;font-size:.6875rem;font-weight:600;text-transform:uppercase;padding:4px 10px;border-radius:6px;white-space:nowrap}.business-day-off-management .status-badge{display:inline-flex;align-items:center;gap:4px;font-size:.6875rem;font-weight:500;padding:3px 8px;border-radius:4px;white-space:nowrap}@media(max-width:768px){.business-day-off-management .table-container{height:calc(100vh - 280px)}}.business-day-off-management .filters{display:flex;gap:20px;flex-wrap:wrap}.business-day-off-management .filter-group{display:flex;flex-direction:column;gap:6px}.business-day-off-management .filter-group label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary, #64748b)}.business-day-off-management .filter-group select{padding:8px var(--select-padding-end) 8px 12px;min-width:150px;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;font-size:.875rem;background:#fff}.business-day-off-management .day-off-list{display:flex;flex-direction:column;gap:12px}.business-day-off-management .day-off-item{display:grid;grid-template-columns:200px 1fr auto auto;gap:20px;align-items:center;padding:16px 20px;background:#fff;border:1px solid var(--color-border, #e2e8f0);border-radius:12px;transition:all .15s ease}.business-day-off-management .day-off-item:hover{box-shadow:var(--shadow-sm);border-color:var(--color-primary-light, #bfdbfe)}.business-day-off-management .day-off-item.inactive{opacity:.6;background:var(--color-bg-tertiary, #f8fafc)}.business-day-off-management .day-off-date{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--color-text-primary, #0f172a)}.business-day-off-management .day-off-date svg{color:var(--color-primary, #3b82f6)}.business-day-off-management .recurring-badge{font-size:.625rem;font-weight:700;text-transform:uppercase;padding:2px 6px;background:var(--color-primary-light, #dbeafe);color:var(--color-primary, #3b82f6);border-radius:4px}.business-day-off-management .day-off-info h4{margin:0 0 4px;font-size:.9375rem;font-weight:600;color:var(--color-text-primary, #0f172a)}.business-day-off-management .day-off-info .description{margin:0;font-size:.8125rem;color:var(--color-text-tertiary, #64748b);line-height:1.4}.business-day-off-management .day-off-meta{display:flex;flex-direction:column;gap:6px;align-items:flex-end}.business-day-off-management .type-badge{font-size:.6875rem;font-weight:600;text-transform:uppercase;padding:4px 10px;border-radius:6px}.business-day-off-management .type-badge.type-holiday{background:#fef3c7;color:#92400e}.business-day-off-management .type-badge.type-company{background:#dbeafe;color:#1e40af}.business-day-off-management .type-badge.type-blocked{background:#fecaca;color:#991b1b}.business-day-off-management .status-badge{display:flex;align-items:center;gap:4px;font-size:.6875rem;font-weight:500;padding:3px 8px;border-radius:4px}.business-day-off-management .status-badge.active{background:#dcfce7;color:#166534}.business-day-off-management .status-badge.inactive{background:#f1f5f9;color:#64748b}.business-day-off-management .day-off-actions{display:flex;gap:8px}.business-day-off-management .empty-state{text-align:center;padding:60px 20px}.business-day-off-management .empty-state svg{color:var(--color-text-tertiary, #94a3b8);margin-bottom:16px}.business-day-off-management .empty-state h3{margin:0 0 8px;font-size:1.125rem;color:var(--color-text-primary, #0f172a)}.business-day-off-management .empty-state p{color:var(--color-text-tertiary, #64748b);max-width:400px;margin:0 auto 24px}.business-day-off-management .loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--color-text-tertiary, #64748b)}.business-day-off-management .loading-state p{margin-top:12px}.business-day-off-management .error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--color-danger, #ef4444)}.business-day-off-management .error-state p{margin:12px 0 16px}.business-day-off-management .checkbox-group label{display:flex;align-items:center;gap:8px;cursor:pointer}.business-day-off-management .checkbox-group input[type=checkbox]{width:18px;height:18px;cursor:pointer}.business-day-off-management .form-hint{display:block;margin-top:4px;font-size:.75rem;color:var(--color-text-tertiary, #64748b)}@media(max-width:768px){.business-day-off-management .day-off-item{grid-template-columns:1fr;gap:12px}.business-day-off-management .day-off-meta{flex-direction:row;align-items:center;gap:8px}.business-day-off-management .day-off-actions{justify-content:flex-end}}.reports-page{max-width:1200px}.report-tabs{display:flex;gap:2px;margin-bottom:8px;background:var(--color-bg-secondary);padding:3px;border-radius:var(--radius-md);border:1px solid var(--color-border)}.tab-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease;flex:1;justify-content:center}.tab-btn:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.tab-btn.active{background:var(--color-primary);color:#fff}.tab-btn svg{flex-shrink:0}.report-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:8px;margin-bottom:8px;border-bottom:1px solid var(--color-border);flex-wrap:wrap}.filters.compact{display:flex;gap:6px;flex-wrap:wrap}.filters.compact .filter-select{min-width:90px;padding:4px 24px 4px 8px;font-size:12px}.inline-stats{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-right:8px}.stat-item{display:flex;align-items:center;gap:3px;font-size:11px;color:var(--color-text-secondary);white-space:nowrap}.stat-item svg{color:var(--color-text-tertiary)}.stat-item.used{color:var(--color-success)}.stat-item.used svg{color:var(--color-success)}.stat-item.available{color:var(--color-primary)}.stat-item.available svg{color:var(--color-primary)}.stat-item.approved{color:var(--color-success)}.stat-item.approved svg{color:var(--color-success)}.stat-item.rejected{color:var(--color-danger)}.stat-item.rejected svg{color:var(--color-danger)}.stat-item.pending{color:var(--color-warning)}.stat-item.pending svg{color:var(--color-warning)}.stat-item.rate{color:#9333ea}.stat-item.rate svg{color:#9333ea}.report-table.compact{font-size:10px}.report-table.compact th,.report-table.compact td{padding:3px 5px}.report-table.compact th{background:var(--color-bg-tertiary);font-weight:600;font-size:9px;text-transform:uppercase;letter-spacing:.2px;color:var(--color-text-tertiary)}.report-table .num{text-align:right;font-variant-numeric:tabular-nums}.report-table .employee-cell{min-width:90px}.report-table .emp-name{font-weight:500;color:var(--color-text-primary)}.report-table .emp-code{font-size:8px;color:var(--color-text-muted);margin-left:3px}.report-table .dept-cell{color:var(--color-text-secondary);max-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.report-table .carryover{color:#059669}.report-table .used{color:var(--color-success)}.report-table .pending{color:var(--color-warning)}.report-table .approved{color:var(--color-success)}.report-table .rejected{color:var(--color-danger)}.report-table .available{font-weight:600;color:var(--color-primary)}.report-table .available.zero{color:var(--color-text-muted);font-weight:400}.report-table .dept-name{font-weight:500;color:var(--color-text-primary)}.report-table .muted-row{opacity:.5}.report-table .high-util{color:var(--color-success);font-weight:600}.loading-container{display:flex;align-items:center;justify-content:center;min-height:200px}.urgency-badge{display:inline-block;padding:1px 6px;border-radius:8px;font-size:9px;font-weight:500;text-transform:uppercase}.urgency-badge.critical{background:var(--color-danger);color:#fff}.urgency-badge.warning{background:var(--color-warning);color:#1a1a1a}.urgency-badge.normal{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.report-table tr.urgency-critical{background:#ef44440d}.report-table tr.urgency-warning{background:#f59e0b0d}.report-table tr.weekend-row{background:var(--color-bg-tertiary);opacity:.8}.employees-list{font-size:9px;color:var(--color-text-secondary)}.emp-chip{white-space:nowrap}.more-chip{color:var(--color-text-muted);font-style:italic}@media(max-width:768px){.report-tabs{flex-direction:column}.tab-btn{justify-content:flex-start;padding:8px 10px}.report-header{flex-direction:column;align-items:flex-start;gap:8px}.inline-stats{width:100%;padding-top:6px;border-top:1px dashed var(--color-border)}.report-table.compact{font-size:9px}.report-table.compact th,.report-table.compact td{padding:2px 3px}.report-table th:nth-child(5),.report-table td:nth-child(5){display:none}.report-table .employee-cell{min-width:80px}.report-table .dept-cell{max-width:50px}}@media(max-width:480px){.filters.compact .filter-select{min-width:70px;font-size:11px;padding:4px 6px}.inline-stats{gap:6px}.stat-item{font-size:10px}.report-table th:nth-child(2),.report-table td:nth-child(2),.report-table th:nth-child(6),.report-table td:nth-child(6){display:none}}.employee-layout{display:flex;min-height:100vh;min-height:100dvh;background:var(--color-bg-primary, #f8fafc)}.employee-layout .mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:60px;padding-top:env(safe-area-inset-top);height:calc(60px + env(safe-area-inset-top));background:#fff;border-bottom:1px solid var(--color-border, #e2e8f0);padding:0 16px;align-items:center;gap:16px;z-index:90}.employee-layout .menu-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;color:var(--color-text-primary, #0f172a);cursor:pointer;border-radius:8px}.employee-layout .menu-toggle:hover{background:var(--color-bg-tertiary, #f1f5f9)}.employee-layout .mobile-logo{font-weight:700;font-size:18px;color:var(--color-text-primary, #0f172a)}.employee-layout .mobile-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:95}.employee-layout .sidebar{width:260px;background:#fff;border-right:1px solid var(--color-border, #e2e8f0);display:flex;flex-direction:column;transition:width .2s ease;position:fixed;left:0;top:0;bottom:0;z-index:100}.employee-layout .sidebar.collapsed{width:72px}.employee-layout .sidebar-header{padding:20px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--color-border, #e2e8f0);min-height:72px}.employee-layout .logo{display:flex;align-items:center;gap:12px;overflow:hidden}.employee-layout .logo-icon{width:40px;height:40px;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}.employee-layout .logo-text{font-weight:700;font-size:16px;color:var(--color-text-primary, #0f172a);white-space:nowrap}.employee-layout .collapse-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--color-bg-tertiary, #f1f5f9);border:1px solid var(--color-border, #e2e8f0);border-radius:8px;color:var(--color-text-tertiary, #64748b);cursor:pointer;flex-shrink:0}.employee-layout .collapse-btn:hover{background:var(--color-border, #e2e8f0);color:var(--color-text-primary, #0f172a)}.employee-layout .sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.employee-layout .nav-item{display:flex;align-items:center;gap:12px;padding:12px 14px;color:var(--color-text-secondary, #475569);text-decoration:none;border-radius:10px;margin-bottom:4px;transition:all .15s ease;font-size:14px;font-weight:500;width:100%;border:none;background:transparent;cursor:pointer;text-align:left}.employee-layout .nav-item:hover{background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-primary, #0f172a)}.employee-layout .nav-item.active{background:#dcfce7;color:#16a34a}.employee-layout .nav-icon{display:flex;align-items:center;justify-content:center;width:24px;flex-shrink:0}.employee-layout .nav-label{white-space:nowrap;overflow:hidden;flex:1}.employee-layout .sidebar-footer{padding:16px;border-top:1px solid var(--color-border, #e2e8f0)}.employee-layout .sidebar-footer .profile-item{margin-bottom:12px}.employee-layout .user-section{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding:8px;background:var(--color-bg-tertiary, #f1f5f9);border-radius:10px}.employee-layout .user-avatar{width:40px;height:40px;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:16px;flex-shrink:0;overflow:hidden}.employee-layout .user-avatar-image{width:100%;height:100%;object-fit:cover}.employee-layout .sidebar-footer .user-info{overflow:hidden;flex:1}.employee-layout .user-name{color:var(--color-text-primary, #0f172a);font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.employee-layout .user-role{color:var(--color-text-tertiary, #64748b);font-size:12px}.employee-layout .sidebar-footer .logout-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;background:var(--color-danger-light, #fee2e2);border:none;border-radius:8px;color:var(--color-danger, #ef4444);cursor:pointer;font-size:14px;font-weight:500;transition:all .15s ease}.employee-layout .sidebar-footer .logout-btn:hover{background:#fecaca}.employee-layout .sidebar-footer .build-version{margin-top:12px;padding:8px;text-align:center;font-size:11px;color:var(--color-text-tertiary, #94a3b8);border-radius:6px;background:var(--color-bg-secondary, #f8fafc);cursor:default}.employee-layout .sidebar.collapsed .build-version{font-size:10px;padding:6px 4px}.employee-layout .sidebar-footer .switch-context-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;background:var(--color-primary-light, #eff6ff);border:none;border-radius:8px;color:var(--color-primary, #3b82f6);cursor:pointer;font-size:14px;font-weight:500;transition:all .15s ease;margin-bottom:8px}.employee-layout .sidebar.collapsed .switch-context-btn{padding:10px 0;justify-content:center}.employee-layout .sidebar-footer .switch-context-btn:hover{background:var(--color-primary, #3b82f6);color:#fff}.employee-layout .main-content{flex:1;margin-left:260px;transition:margin-left .2s ease;min-height:100vh}.employee-layout:has(.sidebar.collapsed) .main-content{margin-left:72px}@media(max-width:1024px){.employee-layout .sidebar{width:72px}.employee-layout .sidebar .nav-label,.employee-layout .sidebar-footer .user-info,.employee-layout .sidebar .logo-text,.employee-layout .sidebar-footer .logout-btn span,.employee-layout .sidebar-footer .switch-context-btn span{display:none}.employee-layout .main-content{margin-left:72px}.employee-layout .desktop-only{display:none}.employee-layout .user-section{justify-content:center;padding:8px}}@media(max-width:768px){.employee-layout .mobile-header{display:flex}.employee-layout .mobile-overlay{display:block}.employee-layout .sidebar{width:280px;transform:translate(-100%);transition:transform .2s ease;box-shadow:var(--shadow-lg)}.employee-layout .sidebar.mobile-open{transform:translate(0)}.employee-layout .sidebar .nav-label,.employee-layout .sidebar-footer .user-info,.employee-layout .sidebar .logo-text,.employee-layout .sidebar-footer .logout-btn span,.employee-layout .sidebar-footer .switch-context-btn span{display:block}.employee-layout .main-content{margin-left:0;padding-top:calc(60px + env(safe-area-inset-top))}.employee-layout .user-section{justify-content:flex-start}}.employee-page{padding:24px;max-width:1400px;margin:0 auto}.employee-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:16px;flex-wrap:wrap}.employee-page .page-header h1{font-size:1.75rem;font-weight:700;color:var(--color-text-primary, #0f172a);margin:0 0 4px}.employee-page .subtitle{font-size:.875rem;color:var(--color-text-tertiary, #64748b);margin:0}.employee-page .btn-primary{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;border-radius:10px;font-weight:600;font-size:.875rem;cursor:pointer;text-decoration:none;transition:all .2s ease;box-shadow:0 2px 8px #22c55e4d}.employee-page .btn-primary:hover{background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 4px 12px #22c55e66;transform:translateY(-1px)}.employee-page .btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-secondary, #475569);border:1px solid var(--color-border, #e2e8f0);border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer;text-decoration:none;transition:all .2s ease}.employee-page .btn-secondary:hover{background:var(--color-border, #e2e8f0);color:var(--color-text-primary, #0f172a)}.employee-page .alert{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;margin-bottom:20px;font-size:.875rem}.employee-page .alert-error{background:var(--color-danger-light, #fee2e2);color:var(--color-danger-dark, #991b1b);border:1px solid #fecaca}.employee-page .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.employee-page .stat-card{display:flex;align-items:center;gap:16px;padding:20px;background:#fff;border-radius:12px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border, #e2e8f0);transition:all .2s ease}.employee-page .stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.employee-page .stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.employee-page .stat-available .stat-icon{background:#dcfce7;color:#16a34a}.employee-page .stat-pending .stat-icon{background:#fef3c7;color:#d97706}.employee-page .stat-used .stat-icon{background:#e0e7ff;color:#4f46e5}.employee-page .stat-requests .stat-icon{background:#fce7f3;color:#db2777}.employee-page .stat-content{display:flex;flex-direction:column}.employee-page .stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary, #0f172a);line-height:1.2}.employee-page .stat-label{font-size:.75rem;color:var(--color-text-tertiary, #64748b);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.employee-page .dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px}@media(max-width:900px){.employee-page .dashboard-grid{grid-template-columns:1fr}}.employee-page .dashboard-card{background:#fff;border-radius:12px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border, #e2e8f0);overflow:hidden}.employee-page .card-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border, #e2e8f0);background:var(--color-bg-tertiary, #f8fafc)}.employee-page .card-header h2{display:flex;align-items:center;gap:10px;font-size:1rem;font-weight:600;color:var(--color-text-primary, #0f172a);margin:0}.employee-page .card-link{display:flex;align-items:center;gap:4px;font-size:.8125rem;font-weight:500;color:var(--color-primary, #3b82f6);text-decoration:none;transition:gap .2s ease}.employee-page .card-link:hover{gap:8px}.employee-page .card-content{padding:16px 20px}.employee-page .empty-state{text-align:center;padding:32px 16px;color:var(--color-text-tertiary, #64748b)}.employee-page .empty-state p{margin-bottom:16px}.employee-page .balance-list{display:flex;flex-direction:column;gap:16px}.employee-page .balance-item{display:flex;align-items:center;gap:16px}.employee-page .balance-info{min-width:120px}.employee-page .balance-type{display:block;font-weight:600;font-size:.875rem;color:var(--color-text-primary, #0f172a)}.employee-page .balance-code{font-size:.75rem;color:var(--color-text-tertiary, #64748b)}.employee-page .balance-bar-container{flex:1}.employee-page .balance-bar{position:relative;height:8px;background:var(--color-bg-tertiary, #f1f5f9);border-radius:4px;overflow:hidden}.employee-page .balance-bar-used{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:4px;transition:width .3s ease}.employee-page .balance-bar-pending{position:absolute;top:0;height:100%;background:linear-gradient(90deg,#f59e0b,#d97706);border-radius:4px;transition:all .3s ease}.employee-page .balance-numbers{display:flex;align-items:baseline;gap:4px;min-width:70px;justify-content:flex-end}.employee-page .balance-numbers .available{font-weight:700;font-size:1rem;color:#16a34a}.employee-page .balance-numbers .separator{color:var(--color-text-muted, #94a3b8)}.employee-page .balance-numbers .total{font-size:.875rem;color:var(--color-text-tertiary, #64748b)}.employee-page .request-list{display:flex;flex-direction:column;gap:12px}.employee-page .request-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--color-bg-tertiary, #f8fafc);border-radius:10px;gap:16px}.employee-page .request-main{flex:1}.employee-page .request-type{font-weight:600;font-size:.875rem;color:var(--color-text-primary, #0f172a)}.employee-page .request-dates{font-size:.8125rem;color:var(--color-text-secondary, #475569)}.employee-page .request-days{color:var(--color-text-tertiary, #64748b);margin-left:4px}.employee-page .request-status{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.employee-page .status-pending{background:#fef3c7;color:#92400e}.employee-page .status-approved{background:#dcfce7;color:#166534}.employee-page .status-rejected{background:#fee2e2;color:#991b1b}.employee-page .status-cancelled{background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-tertiary, #64748b)}.employee-page .status-icon{flex-shrink:0}.employee-page .status-icon.pending{color:#d97706}.employee-page .status-icon.approved{color:#16a34a}.employee-page .status-icon.rejected{color:#dc2626}.employee-page .status-icon.cancelled{color:#64748b}.employee-page .loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;color:var(--color-text-tertiary, #64748b)}.employee-page .spinner-icon{animation:spin 1s linear infinite;color:#22c55e}@media(max-width:640px){.employee-page{padding:16px}.employee-page .page-header{flex-direction:column;align-items:stretch}.employee-page .page-header h1{font-size:1.5rem}.employee-page .stats-grid{grid-template-columns:repeat(2,1fr)}.employee-page .stat-card{padding:16px}.employee-page .stat-icon{width:40px;height:40px}.employee-page .stat-value{font-size:1.25rem}.employee-page .balance-item{flex-wrap:wrap}.employee-page .balance-bar-container{order:3;flex-basis:100%}}.employee-page .year-selector{display:flex;align-items:center;gap:8px}.employee-page .year-selector select{padding:8px var(--select-padding-end) 8px 16px;font-size:1rem;font-weight:600;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;background:#fff;cursor:pointer;min-width:100px;text-align:center}.employee-page .year-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#fff;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;color:var(--color-text-secondary, #475569);cursor:pointer;transition:all .15s ease}.employee-page .year-btn:hover:not(:disabled){background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-primary, #0f172a)}.employee-page .year-btn:disabled{opacity:.5;cursor:not-allowed}.employee-page .summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.employee-page .summary-card{display:flex;flex-direction:column;padding:20px;background:#fff;border-radius:12px;border:1px solid var(--color-border, #e2e8f0);box-shadow:var(--shadow-sm)}.employee-page .summary-card .summary-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary, #64748b);margin-bottom:8px}.employee-page .summary-card .summary-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary, #0f172a)}.employee-page .summary-card.total{border-left:4px solid #3b82f6}.employee-page .summary-card.used{border-left:4px solid #22c55e}.employee-page .summary-card.pending{border-left:4px solid #f59e0b}.employee-page .summary-card.available{border-left:4px solid #8b5cf6}.employee-page .balance-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.employee-page .balance-card{background:#fff;border-radius:16px;border:1px solid var(--color-border, #e2e8f0);box-shadow:var(--shadow-sm);padding:24px;transition:all .2s ease}.employee-page .balance-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.employee-page .balance-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.employee-page .balance-card-header h3{font-size:1.125rem;font-weight:700;color:var(--color-text-primary, #0f172a);margin:0 0 4px}.employee-page .balance-code{font-size:.75rem;color:var(--color-text-tertiary, #64748b);background:var(--color-bg-tertiary, #f1f5f9);padding:2px 8px;border-radius:4px}.employee-page .balance-available{text-align:right}.employee-page .balance-available .value{display:block;font-size:2rem;font-weight:800;color:#16a34a;line-height:1}.employee-page .balance-available .unit{font-size:.75rem;color:var(--color-text-tertiary, #64748b);text-transform:uppercase;letter-spacing:.05em}.employee-page .balance-progress{margin-bottom:20px}.employee-page .progress-bar{height:12px;background:var(--color-bg-tertiary, #f1f5f9);border-radius:6px;overflow:hidden;display:flex;margin-bottom:8px}.employee-page .progress-used{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);transition:width .3s ease}.employee-page .progress-pending{height:100%;background:linear-gradient(90deg,#fbbf24,#f59e0b);transition:width .3s ease}.employee-page .progress-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--color-text-tertiary, #64748b)}.employee-page .balance-details{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:16px;background:var(--color-bg-tertiary, #f8fafc);border-radius:10px;margin-bottom:16px}.employee-page .detail-item{display:flex;align-items:center;gap:8px}.employee-page .detail-item .dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.employee-page .detail-item .dot.base{background:#3b82f6}.employee-page .detail-item .dot.carryover{background:#8b5cf6}.employee-page .detail-item .dot.used{background:#22c55e}.employee-page .detail-item .dot.pending{background:#f59e0b}.employee-page .detail-item .label{flex:1;font-size:.8125rem;color:var(--color-text-secondary, #475569)}.employee-page .detail-item .value{font-weight:600;font-size:.875rem;color:var(--color-text-primary, #0f172a)}.employee-page .balance-description{font-size:.8125rem;color:var(--color-text-tertiary, #64748b);margin:0;line-height:1.5}.employee-page .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;background:#fff;border-radius:16px;border:1px solid var(--color-border, #e2e8f0);text-align:center;color:var(--color-text-tertiary, #64748b)}.employee-page .empty-state h3{margin:16px 0 8px;color:var(--color-text-primary, #0f172a)}.employee-page .empty-state p{margin:0}@media(max-width:640px){.employee-page .balance-cards,.employee-page .balance-details{grid-template-columns:1fr}.employee-page .balance-available .value{font-size:1.5rem}}.employee-page .filters-bar{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.employee-page .filters-bar select{padding:10px var(--select-padding-end) 10px 16px;min-width:140px}.employee-page .btn-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#fff;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;color:var(--color-text-secondary, #475569);cursor:pointer;transition:all .15s ease}.employee-page .btn-icon:hover{background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-primary, #0f172a)}.employee-page .requests-list{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.employee-page .request-card{background:#fff;border-radius:16px;border:1px solid var(--color-border, #e2e8f0);box-shadow:var(--shadow-sm);overflow:hidden;transition:all .2s ease}.employee-page .request-card:hover{box-shadow:var(--shadow-md)}.employee-page .request-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:var(--color-bg-tertiary, #f8fafc);border-bottom:1px solid var(--color-border, #e2e8f0)}.employee-page .request-type-badge{font-weight:700;font-size:1rem;color:var(--color-text-primary, #0f172a)}.employee-page .request-body{padding:20px}.employee-page .request-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:16px}.employee-page .info-item{display:flex;flex-direction:column;gap:4px}.employee-page .info-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary, #64748b)}.employee-page .info-value{font-size:.9375rem;font-weight:500;color:var(--color-text-primary, #0f172a)}.employee-page .request-reason{padding:12px 16px;background:var(--color-bg-tertiary, #f8fafc);border-radius:8px;font-size:.875rem;color:var(--color-text-secondary, #475569);line-height:1.5}.employee-page .reason-label{font-weight:600;margin-right:8px;color:var(--color-text-tertiary, #64748b)}.employee-page .admin-feedback{margin-top:16px;padding:14px 16px;border-radius:10px;border-left:4px solid}.employee-page .admin-feedback.rejected{background:#fef2f2;border-left-color:#dc2626}.employee-page .admin-feedback.cancelled{background:#fffbeb;border-left-color:#d97706}.employee-page .admin-feedback.cancelled.by-self{background:#f8fafc;border-left-color:#64748b}.employee-page .admin-feedback.cancelled.by-self .feedback-header{color:#64748b}.employee-page .feedback-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.employee-page .admin-feedback.rejected .feedback-header{color:#dc2626}.employee-page .admin-feedback.cancelled .feedback-header{color:#d97706}.employee-page .feedback-title{font-weight:600;font-size:.875rem}.employee-page .feedback-reason{margin:0;font-size:.875rem;color:var(--color-text-secondary, #475569);line-height:1.5}.employee-page .request-footer{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:var(--color-bg-tertiary, #f8fafc);border-top:1px solid var(--color-border, #e2e8f0)}.employee-page .request-date{font-size:.8125rem;color:var(--color-text-tertiary, #64748b)}.employee-page .btn-danger-outline{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:transparent;border:1px solid var(--color-danger, #ef4444);border-radius:6px;color:var(--color-danger, #ef4444);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s ease}.employee-page .btn-danger-outline:hover{background:var(--color-danger-light, #fee2e2)}.employee-page .pagination{display:flex;justify-content:center;align-items:center;gap:16px}.employee-page .page-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#fff;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;color:var(--color-text-secondary, #475569);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.employee-page .page-btn:hover:not(:disabled){background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-primary, #0f172a)}.employee-page .page-btn:disabled{opacity:.5;cursor:not-allowed}.employee-page .page-info{font-size:.875rem;color:var(--color-text-tertiary, #64748b)}.employee-page .modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000;padding:0}.employee-page .modal{background:#fff;border-radius:16px 16px 0 0;box-shadow:var(--shadow-lg);width:100%;max-width:100%;max-height:90vh;max-height:90dvh;overflow:hidden;display:flex;flex-direction:column;animation:employeeModalSlideUp .25s ease-out}@keyframes employeeModalSlideUp{0%{transform:translateY(100%);opacity:.5}to{transform:translateY(0);opacity:1}}.employee-page .modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border, #e2e8f0)}.employee-page .modal-header h3{font-size:1.125rem;font-weight:700;margin:0}.employee-page .modal-close{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;color:var(--color-text-tertiary, #64748b);border-radius:8px;cursor:pointer;flex-shrink:0}.employee-page .modal-close:hover{background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-primary, #0f172a)}.employee-page .modal-body{padding:20px;overflow-y:auto;-webkit-overflow-scrolling:touch}.employee-page .modal-body p{margin:0 0 16px;color:var(--color-text-secondary, #475569);line-height:1.6;font-size:.9375rem}.employee-page .form-group{display:flex;flex-direction:column;gap:8px}.employee-page .form-group label{font-size:.9375rem;font-weight:600;color:var(--color-text-primary, #0f172a)}.employee-page .form-group textarea{width:100%;padding:14px;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;font-size:1rem;resize:vertical;min-height:100px}.employee-page .modal-footer{display:flex;flex-direction:column-reverse;gap:10px;padding:16px 20px;padding-bottom:calc(16px + env(safe-area-inset-bottom));border-top:1px solid var(--color-border, #e2e8f0);background:var(--color-bg-tertiary, #f8fafc)}.employee-page .modal-footer button{width:100%;min-height:48px;justify-content:center}@media(min-width:640px){.employee-page .modal-overlay{align-items:center;padding:24px}.employee-page .modal{border-radius:16px;max-width:480px;animation:employeeModalFadeIn .2s ease-out}@keyframes employeeModalFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.employee-page .modal-header{padding:20px 24px}.employee-page .modal-close{width:32px;height:32px}.employee-page .modal-body{padding:24px}.employee-page .modal-body p,.employee-page .form-group label{font-size:.875rem}.employee-page .form-group textarea{font-size:.875rem;padding:12px;min-height:80px}.employee-page .modal-footer{flex-direction:row;justify-content:flex-end;gap:12px;padding:16px 24px}.employee-page .modal-footer button{width:auto;min-height:auto}}.employee-page .btn-danger{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:var(--color-danger, #ef4444);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .15s ease}.employee-page .btn-danger:hover:not(:disabled){background:var(--color-danger-dark, #dc2626)}.employee-page .btn-danger:disabled{opacity:.7;cursor:not-allowed}.employee-page .toast{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:10px;padding:14px 20px;border-radius:10px;font-size:.875rem;font-weight:500;box-shadow:var(--shadow-lg);z-index:1100;animation:slideIn .3s ease}.employee-page .toast-success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.employee-page .toast-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:640px){.employee-page .request-info{grid-template-columns:1fr 1fr}.employee-page .request-footer{flex-direction:column;gap:12px;align-items:stretch}.employee-page .btn-danger-outline{width:100%;justify-content:center}.employee-page .pagination{flex-wrap:wrap}}.request-form-container{padding:24px;max-width:600px;margin:0 auto}.header-content{display:flex;flex-direction:column;gap:16px}.title-group{display:flex;flex-direction:column;gap:4px}.page-title{display:flex;align-items:center;gap:12px}.page-title svg{color:var(--color-primary)}.request-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{display:flex;align-items:center;gap:8px;font-size:.875rem;font-weight:600;color:var(--color-text-secondary, #475569)}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--color-border, #e2e8f0);border-radius:8px;font-size:.9375rem;color:var(--color-text-primary, #0f172a);background-color:#fff;width:100%;box-sizing:border-box!important;max-width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;min-width:0;height:44px;line-height:normal}.form-group input,.form-group textarea{padding:10px 14px;width:100%;box-sizing:border-box}.form-group select{padding:10px var(--select-padding-end) 10px 14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary, #3b82f6);outline:2px solid var(--color-primary-light, #dbeafe)}.balance-info-card{background:var(--color-bg-tertiary, #f8fafc);border:1px solid var(--color-border, #e2e8f0);border-radius:12px;padding:16px;margin-bottom:8px}.balance-info-header{display:flex;align-items:center;gap:8px;font-size:.875rem;font-weight:600;color:var(--color-primary, #1e40af);margin-bottom:16px}.balance-info-content{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.balance-stat{display:flex;flex-direction:column;align-items:center;gap:4px}.stat-value{font-size:1.125rem;font-weight:700;color:var(--color-text-primary, #0f172a)}.stat-value.available{color:var(--color-success, #16a34a)}.stat-value.pending{color:var(--color-warning, #d97706)}.stat-label{font-size:.75rem;color:var(--color-text-tertiary, #64748b);text-transform:uppercase;letter-spacing:.05em}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.days-summary{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px;background:#eff6ff;border-radius:12px;color:#1e40af;text-align:center}.days-summary.warning{background:#fffbeb;color:#92400e}.days-value{font-size:2rem;font-weight:800;line-height:1}.days-label{font-size:.875rem;font-weight:600;text-transform:uppercase;opacity:.8}.days-warning{margin-top:4px;font-size:.75rem;font-weight:500;background:#ffffff80;padding:4px 8px;border-radius:4px}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:12px;padding-top:20px;border-top:1px solid var(--color-border, #e2e8f0)}.alert{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;font-size:.875rem}.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.calculation-breakdown{background:#fff;border:1px solid var(--color-border, #e2e8f0);border-radius:12px;padding:12px 16px;font-size:.875rem}.breakdown-total{display:flex;justify-content:space-between;padding-bottom:8px;border-bottom:1px solid var(--color-border, #e2e8f0);margin-bottom:8px;color:var(--color-text-secondary, #475569)}.breakdown-item{display:flex;justify-content:space-between;padding:4px 0}.breakdown-item.deduction{color:var(--color-danger, #ef4444)}.holiday-list{margin:4px 0 0;list-style:none;background:#fef2f2;border-radius:6px;padding:8px}.holiday-list li{display:flex;align-items:center;gap:8px;font-size:.8125rem;color:#991b1b;padding:2px 0}.holiday-list li .date{opacity:.7}.calculating{display:flex;align-items:center;gap:8px;color:var(--color-primary, #3b82f6)}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:600px){.balance-info-content{grid-template-columns:repeat(2,1fr)}.form-row{grid-template-columns:1fr}.request-form-container{padding:16px}}.employee-page .profile-container{max-width:640px}.employee-page .profile-header{display:flex;align-items:center;gap:24px;padding:32px;background:#fff;border-radius:16px;border:1px solid var(--color-border, #e2e8f0);box-shadow:var(--shadow-sm);margin-bottom:24px}.employee-page .profile-avatar{width:80px;height:80px;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:20px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;font-weight:700;flex-shrink:0;overflow:hidden;position:relative}.employee-page .profile-avatar-image{width:100%;height:100%;object-fit:cover}.employee-page .profile-avatar.fallback:after{content:attr(data-initial);position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-size:2rem;font-weight:700}.employee-page .profile-info{display:flex;flex-direction:column;gap:8px}.employee-page .profile-info h2{font-size:1.5rem;font-weight:700;color:var(--color-text-primary, #0f172a);margin:0}.employee-page .employee-id{font-size:.875rem;color:var(--color-text-tertiary, #64748b)}.employee-page .status-badge{display:inline-flex;padding:4px 12px;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;width:fit-content}.employee-page .status-active{background:#dcfce7;color:#166534}.employee-page .status-pending-activation{background:#fef3c7;color:#92400e}.employee-page .status-deactivated{background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-tertiary, #64748b)}.employee-page .profile-card{background:#fff;border-radius:16px;border:1px solid var(--color-border, #e2e8f0);box-shadow:var(--shadow-sm);padding:24px;margin-bottom:24px}.employee-page .profile-card h3{display:flex;align-items:center;gap:10px;font-size:1rem;font-weight:700;color:var(--color-text-primary, #0f172a);margin:0 0 20px;padding-bottom:16px;border-bottom:1px solid var(--color-border, #e2e8f0)}.employee-page .profile-details{display:flex;flex-direction:column;gap:16px}.employee-page .detail-item{display:flex;align-items:flex-start;gap:16px}.employee-page .detail-icon{width:40px;height:40px;background:var(--color-bg-tertiary, #f1f5f9);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary, #64748b);flex-shrink:0}.employee-page .detail-content{display:flex;flex-direction:column;gap:2px}.employee-page .detail-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary, #64748b)}.employee-page .detail-value{font-size:.9375rem;font-weight:500;color:var(--color-text-primary, #0f172a)}.employee-page .leave-profile-info{background:var(--color-bg-tertiary, #f8fafc);border-radius:12px;padding:16px 20px}.employee-page .leave-profile-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.employee-page .leave-profile-header .profile-name{font-weight:600;color:var(--color-text-primary, #0f172a)}.employee-page .leave-profile-header .profile-code{font-size:.75rem;color:var(--color-text-tertiary, #64748b);background:#fff;padding:2px 8px;border-radius:4px}.employee-page .profile-description{font-size:.875rem;color:var(--color-text-secondary, #475569);margin:0;line-height:1.5}@media(max-width:640px){.employee-page .profile-header{flex-direction:column;text-align:center;padding:24px}.employee-page .profile-info{align-items:center}}
