.toast[data-v-9e804e6c]{position:fixed;top:20px;right:20px;min-width:300px;max-width:500px;padding:16px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;gap:12px;z-index:9999;pointer-events:auto}.toast-icon[data-v-9e804e6c]{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.toast-content[data-v-9e804e6c]{flex:1;color:#333;font-size:14px;line-height:1.5;word-break:break-word}.toast-close[data-v-9e804e6c]{flex-shrink:0;background:none;border:none;cursor:pointer;padding:4px;color:#999;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.toast-close[data-v-9e804e6c]:hover{background:#0000000d;color:#666}.toast-success[data-v-9e804e6c]{border-left:4px solid #4CAF50}.toast-success .toast-icon[data-v-9e804e6c]{color:#4caf50}.toast-error[data-v-9e804e6c]{border-left:4px solid #F44336}.toast-error .toast-icon[data-v-9e804e6c]{color:#f44336}.toast-warning[data-v-9e804e6c]{border-left:4px solid #FF9800}.toast-warning .toast-icon[data-v-9e804e6c]{color:#ff9800}.toast-info[data-v-9e804e6c]{border-left:4px solid #2196F3}.toast-info .toast-icon[data-v-9e804e6c]{color:#2196f3}.toast-enter-active[data-v-9e804e6c]{animation:toast-in-9e804e6c .3s ease-out}.toast-leave-active[data-v-9e804e6c]{animation:toast-out-9e804e6c .3s ease-in}@keyframes toast-in-9e804e6c{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toast-out-9e804e6c{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}@media(max-width:768px){.toast[data-v-9e804e6c]{left:20px;right:20px;min-width:auto;max-width:none}}.update-modal-wrapper[data-v-dbb83907]{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center}.update-backdrop[data-v-dbb83907]{position:absolute;inset:0;background:#00000080;z-index:1}.update-notification[data-v-dbb83907]{position:relative;z-index:2;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026,0 0 0 1px #0000000d;padding:24px;min-width:360px;max-width:420px}.update-notification.force-update[data-v-dbb83907]{border-left:4px solid #f59e0b}.update-content[data-v-dbb83907]{margin-bottom:20px}.update-text[data-v-dbb83907]{width:100%}.update-title[data-v-dbb83907]{margin:0 0 12px;font-size:18px;font-weight:600;color:#111827;text-align:center}.update-message[data-v-dbb83907]{margin:0;font-size:14px;color:#6b7280;line-height:1.6;text-align:center}.update-actions[data-v-dbb83907]{display:flex;justify-content:center}.btn[data-v-dbb83907]{padding:10px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-refresh[data-v-dbb83907]{background:#3b82f6;color:#fff;min-width:120px}.btn-refresh[data-v-dbb83907]:hover{background:#2563eb;transform:translateY(-1px)}.fade-scale-enter-active[data-v-dbb83907],.fade-scale-leave-active[data-v-dbb83907]{transition:all .3s ease}.fade-scale-enter-active .update-backdrop[data-v-dbb83907],.fade-scale-leave-active .update-backdrop[data-v-dbb83907]{transition:opacity .3s ease}.fade-scale-enter-active .update-notification[data-v-dbb83907],.fade-scale-leave-active .update-notification[data-v-dbb83907]{transition:all .3s ease}.fade-scale-enter-from .update-backdrop[data-v-dbb83907],.fade-scale-leave-to .update-backdrop[data-v-dbb83907]{opacity:0}.fade-scale-enter-from .update-notification[data-v-dbb83907],.fade-scale-leave-to .update-notification[data-v-dbb83907]{opacity:0;transform:scale(.9)}.fade-scale-enter-to .update-backdrop[data-v-dbb83907],.fade-scale-leave-from .update-backdrop[data-v-dbb83907]{opacity:1}.fade-scale-enter-to .update-notification[data-v-dbb83907],.fade-scale-leave-from .update-notification[data-v-dbb83907]{opacity:1;transform:scale(1)}@media(max-width:640px){.update-notification[data-v-dbb83907]{margin:0 20px;min-width:auto;max-width:90vw;padding:20px}.update-title[data-v-dbb83907]{font-size:16px}.update-message[data-v-dbb83907]{font-size:13px}.btn[data-v-dbb83907]{width:100%}}#app{width:100%;height:100%}:root{--color-primary: #2C3E50;--color-primary-light: #34495E;--color-primary-dark: #1A252F;--color-success: #4CAF50;--color-success-light: #E8F5E9;--color-warning: #F57C00;--color-warning-light: #FFF4E5;--color-danger: #F44336;--color-danger-light: #FFEBEE;--color-info: #2196F3;--color-info-light: #E3F2FD;--color-text: #333333;--color-text-secondary: #666666;--color-text-tertiary: #999999;--color-text-placeholder: #CCCCCC;--color-border: #E0E0E0;--color-border-light: #F0F0F0;--color-bg: #F5F5F5;--color-bg-dark: #FAFAFA;--color-white: #FFFFFF;--color-black: #000000;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--spacing-2xl: 24px;--spacing-3xl: 32px;--radius-xs: 2px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-2xl: 16px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .12);--shadow-xl: 0 8px 24px rgba(0, 0, 0, .15);--shadow-2xl: 0 12px 32px rgba(0, 0, 0, .2);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease;--font-size-xs: 11px;--font-size-sm: 12px;--font-size-base: 14px;--font-size-lg: 16px;--font-size-xl: 18px;--font-size-2xl: 20px;--font-size-3xl: 24px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--z-toast: 1080}.btn{padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:var(--transition-base);display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);white-space:nowrap}.btn:hover{opacity:.9;transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--color-primary);color:var(--color-white)}.btn-success{background:var(--color-success);color:var(--color-white)}.btn-warning{background:var(--color-warning);color:var(--color-white)}.btn-danger{background:var(--color-danger);color:var(--color-white)}.btn-outline{background:transparent;border:1px solid var(--color-border);color:var(--color-text)}.btn-outline:hover{background:var(--color-bg)}.btn-sm{padding:6px 12px;font-size:var(--font-size-sm)}.btn-lg{padding:12px 24px;font-size:var(--font-size-lg)}.card{background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--spacing-lg)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border-light)}.card-body{padding:var(--spacing-md) 0}.card-footer{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border-light)}.form-control{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);transition:var(--transition-fast)}.form-control:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2c3e501a}.form-control:disabled{background:var(--color-bg);cursor:not-allowed}.form-control.error{border-color:var(--color-danger)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:var(--z-modal-backdrop);padding:var(--spacing-lg)}.modal-content{background:var(--color-white);border-radius:var(--radius-xl);max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-2xl)}.modal-content.small{max-width:400px;width:100%}.modal-content.medium{max-width:600px;width:100%}.modal-content.large{max-width:900px;width:100%}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xl);border-bottom:1px solid var(--color-border-light)}.modal-header h2{margin:0;font-size:var(--font-size-xl);color:var(--color-text)}.modal-body{flex:1;overflow-y:auto;padding:var(--spacing-xl)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-xl);border-top:1px solid var(--color-border-light)}.close-btn{background:none;border:none;font-size:24px;color:var(--color-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:var(--transition-fast)}.close-btn:hover{background:var(--color-bg);color:var(--color-text)}.status-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);white-space:nowrap}.status-badge.pending{background:var(--color-warning-light);color:var(--color-warning)}.status-badge.approved{background:var(--color-success-light);color:var(--color-success)}.status-badge.rejected{background:var(--color-danger-light);color:var(--color-danger)}.status-badge.active{background:var(--color-success-light);color:var(--color-success)}.status-badge.inactive{background:var(--color-bg);color:var(--color-text-tertiary)}.table{width:100%;border-collapse:collapse;background:var(--color-white);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md)}.table thead{background:var(--color-bg)}.table th{padding:var(--spacing-md);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-text);font-size:var(--font-size-sm)}.table td{padding:var(--spacing-md);border-top:1px solid var(--color-border-light);color:var(--color-text-secondary);font-size:var(--font-size-base)}.table tbody tr:hover{background:var(--color-bg-dark)}.table .empty-cell{text-align:center;color:var(--color-text-tertiary);padding:var(--spacing-3xl)}.fade-enter-active,.fade-leave-active{transition:opacity var(--transition-base)}.fade-enter-from,.fade-leave-to{opacity:0}.modal-enter-active,.modal-leave-active{transition:all var(--transition-base)}.modal-enter-from,.modal-leave-to{opacity:0;transform:scale(.95)}.slide-enter-active,.slide-leave-active{transition:all var(--transition-base)}.slide-enter-from{transform:translateY(-20px);opacity:0}.slide-leave-to{transform:translateY(20px);opacity:0}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-column{flex-direction:column}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.items-center{align-items:center}.justify-center{justify-content:center}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.m-0{margin:0}.mt-xs{margin-top:var(--spacing-xs)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.p-0{padding:0}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.w-full{width:100%}.h-full{height:100%}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.cursor-pointer{cursor:pointer}@media(max-width:768px){.hide-mobile{display:none!important}}@media(min-width:769px){.hide-desktop{display:none!important}}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;color:var(--color-text)}#app{width:100%;min-height:100vh}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;max-width:500px;width:100%;max-height:90vh;overflow:hidden;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column}.modal-content.large{max-width:800px}.modal-content.small{max-width:400px}.modal-header{padding:20px;border-bottom:1px solid #F0F0F0;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.modal-header h3{font-size:18px;font-weight:600;color:#2c3e50;margin:0}.close-btn{width:32px;height:32px;border:none;background:transparent;font-size:24px;color:#999;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s;padding:0}.close-btn:hover{background:#f5f5f5;color:#333}.modal-body{padding:20px;overflow-y:auto;flex:1}.modal-body.no-padding{padding:0}.modal-footer{padding:16px 20px;border-top:1px solid #F0F0F0;display:flex;justify-content:flex-end;gap:12px;flex-shrink:0}.modal-footer.center{justify-content:center}.modal-footer.space-between{justify-content:space-between}.modal-btn{padding:10px 24px;font-size:14px;border:none;border-radius:8px;cursor:pointer;transition:all .2s;font-weight:500}.modal-btn:disabled{opacity:.5;cursor:not-allowed}.modal-btn.primary{background:#2c3e50;color:#fff}.modal-btn.primary:hover:not(:disabled){background:#1a252f}.modal-btn.secondary{background:#f5f5f5;color:#666}.modal-btn.secondary:hover:not(:disabled){background:#e0e0e0}.modal-btn.danger{background:#f44336;color:#fff}.modal-btn.danger:hover:not(:disabled){background:#d32f2f}.modal-btn.success{background:#4caf50;color:#fff}.modal-btn.success:hover:not(:disabled){background:#45a049}.form-message{padding:10px 12px;border-radius:6px;font-size:13px;margin-top:12px}.form-message.success{background:#e8f5e9;color:#2e7d32;border:1px solid #81C784}.form-message.error{background:#ffebee;color:#c62828;border:1px solid #E57373}.form-message.warning{background:#fff3e0;color:#e65100;border:1px solid #FFB74D}.form-message.info{background:#e3f2fd;color:#1565c0;border:1px solid #64B5F6}.modal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#666}.modal-loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #2C3E50;border-radius:50%;animation:modal-spin 1s linear infinite;margin-bottom:16px}@keyframes modal-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-empty{text-align:center;padding:40px 20px;color:#999}.modal-empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.modal-empty-text{font-size:14px}@media(max-width:768px){.modal-content{max-width:90vw;margin:0 20px}.modal-header,.modal-body,.modal-footer{padding:16px}.modal-header h3{font-size:16px}.modal-btn{padding:8px 16px;font-size:13px}}.form-group{margin-bottom:20px}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-size:14px;color:#333;margin-bottom:8px;font-weight:500}.form-group label .required{color:#f44336;margin-left:2px}.form-input,.form-group input[type=text],.form-group input[type=password],.form-group input[type=email],.form-group input[type=number],.form-group input[type=tel],.form-group input[type=url],.form-group input[type=search]{width:100%;padding:12px;font-size:14px;border:1px solid #E0E0E0;border-radius:8px;outline:none;transition:border-color .2s;box-sizing:border-box;color:#333;background:#fff}.form-input:focus,.form-group input:focus{border-color:#2c3e50}.form-input:disabled,.form-group input:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.form-input::placeholder,.form-group input::placeholder{color:#999}.form-textarea,.form-group textarea{width:100%;padding:12px;font-size:14px;border:1px solid #E0E0E0;border-radius:8px;outline:none;transition:border-color .2s;box-sizing:border-box;resize:vertical;min-height:100px;font-family:inherit;color:#333}.form-textarea:focus,.form-group textarea:focus{border-color:#2c3e50}.form-textarea:disabled,.form-group textarea:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.form-select,.form-group select{width:100%;padding:12px;font-size:14px;border:1px solid #E0E0E0;border-radius:8px;outline:none;transition:border-color .2s;box-sizing:border-box;background:#fff;color:#333;cursor:pointer}.form-select:focus,.form-group select:focus{border-color:#2c3e50}.form-select:disabled,.form-group select:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.form-checkbox,.form-radio{display:flex;align-items:center;gap:8px;cursor:pointer}.form-checkbox input[type=checkbox],.form-radio input[type=radio]{width:auto;margin:0;cursor:pointer}.form-checkbox label,.form-radio label{margin:0;cursor:pointer;font-weight:400}.form-group.error .form-input,.form-group.error input,.form-group.error textarea,.form-group.error select{border-color:#f44336}.form-group.success .form-input,.form-group.success input,.form-group.success textarea,.form-group.success select{border-color:#4caf50}.form-help{font-size:12px;color:#666;margin-top:4px;display:block}.form-error{font-size:12px;color:#f44336;margin-top:4px;display:block}.form-success{font-size:12px;color:#4caf50;margin-top:4px;display:block}.form-counter{text-align:right;font-size:12px;color:#999;margin-top:4px}.form-counter.warning{color:#ff9800}.form-counter.error{color:#f44336}.form-buttons{display:flex;gap:12px;margin-top:24px}.form-buttons.center{justify-content:center}.form-buttons.end{justify-content:flex-end}.form-buttons.space-between{justify-content:space-between}.form-btn{padding:12px 24px;font-size:14px;border:none;border-radius:8px;cursor:pointer;transition:all .2s;font-weight:500}.form-btn:disabled{opacity:.5;cursor:not-allowed}.form-btn.primary{background:#2c3e50;color:#fff}.form-btn.primary:hover:not(:disabled){background:#1a252f}.form-btn.secondary{background:#f5f5f5;color:#666}.form-btn.secondary:hover:not(:disabled){background:#e0e0e0}.form-btn.danger{background:#f44336;color:#fff}.form-btn.danger:hover:not(:disabled){background:#d32f2f}.form-btn.success{background:#4caf50;color:#fff}.form-btn.success:hover:not(:disabled){background:#45a049}.form-inline{display:flex;gap:12px;align-items:flex-end}.form-inline .form-group{flex:1;margin-bottom:0}.form-inline .form-btn{flex-shrink:0}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px}.form-row .form-group{margin-bottom:0}.form-file{position:relative}.form-file input[type=file]{position:absolute;opacity:0;width:0;height:0}.form-file-label{display:inline-block;padding:12px 24px;background:#f5f5f5;color:#666;border-radius:8px;cursor:pointer;transition:background .2s;font-size:14px;border:1px solid #E0E0E0}.form-file-label:hover{background:#e0e0e0}.form-file-name{margin-left:12px;font-size:14px;color:#666}@media(max-width:768px){.form-group label{font-size:13px}.form-input,.form-group input,.form-group textarea,.form-group select{padding:10px;font-size:13px}.form-btn{padding:10px 20px;font-size:13px}.form-inline{flex-direction:column;align-items:stretch}.form-inline .form-group{margin-bottom:12px}.form-row{grid-template-columns:1fr;gap:12px}}
