#app[data-v-f13e67bf]{min-height:100vh}.login-container[data-v-b5b1224d]{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box[data-v-b5b1224d]{background:#fff;padding:40px;border-radius:10px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.login-box h1[data-v-b5b1224d]{text-align:center;margin-bottom:30px;color:#333;font-size:28px;display:flex;flex-direction:column;gap:5px}.title-ja[data-v-b5b1224d]{font-size:28px;font-weight:600}.title-zh[data-v-b5b1224d]{font-size:20px;color:#666;font-weight:400}.login-form[data-v-b5b1224d]{display:flex;flex-direction:column}.form-group[data-v-b5b1224d]{margin-bottom:20px}.form-group label[data-v-b5b1224d]{display:block;margin-bottom:8px;color:#555;font-weight:500}.form-group input[data-v-b5b1224d]{width:100%;padding:12px;border:1px solid #ddd;border-radius:5px;font-size:16px;transition:border-color .3s}.form-group input[data-v-b5b1224d]:focus{outline:none;border-color:#667eea}.error-message[data-v-b5b1224d]{color:#e74c3c;margin-bottom:15px;padding:10px;background-color:#fee;border-radius:5px;font-size:14px}.login-button[data-v-b5b1224d]{padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:5px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s}.login-button[data-v-b5b1224d]:hover:not(:disabled){transform:translateY(-2px)}.login-button[data-v-b5b1224d]:disabled{opacity:.6;cursor:not-allowed}.dialog-overlay[data-v-3ea5c6eb]{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.dialog-content[data-v-3ea5c6eb]{background:#fff;padding:30px;border-radius:10px;width:90%;max-width:500px;box-shadow:0 10px 25px #0000004d}.dialog-content h3[data-v-3ea5c6eb]{margin-bottom:20px;color:#333}.change-password-form .form-group[data-v-3ea5c6eb]{margin-bottom:20px}.change-password-form label[data-v-3ea5c6eb]{display:block;margin-bottom:8px;color:#555;font-weight:500}.change-password-form input[data-v-3ea5c6eb]{width:100%;padding:12px;border:1px solid #ddd;border-radius:5px;font-size:16px;box-sizing:border-box}.change-password-form input[data-v-3ea5c6eb]:focus{outline:none;border-color:#667eea}.error-message[data-v-3ea5c6eb]{color:#e74c3c;margin-bottom:15px;padding:10px;background-color:#fee;border-radius:5px;font-size:14px}.dialog-actions[data-v-3ea5c6eb]{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.btn-cancel[data-v-3ea5c6eb]{padding:10px 20px;background-color:#ccc;color:#fff;border:none;border-radius:5px;cursor:pointer}.btn-cancel[data-v-3ea5c6eb]:hover{background-color:#bbb}.btn-save[data-v-3ea5c6eb]{padding:10px 20px;background-color:#667eea;color:#fff;border:none;border-radius:5px;cursor:pointer}.btn-save[data-v-3ea5c6eb]:hover:not(:disabled){background-color:#5568d3}.btn-save[data-v-3ea5c6eb]:disabled{opacity:.6;cursor:not-allowed}.calendar-container[data-v-bd046558]{min-height:100vh;background-color:#f5f5f5}.calendar-header[data-v-bd046558]{background:#fff;padding:20px 30px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center}.calendar-header h1[data-v-bd046558]{color:#333;font-size:24px}.user-info[data-v-bd046558]{display:flex;align-items:center;gap:15px;flex-wrap:wrap}.header-actions[data-v-bd046558]{display:flex;align-items:center;gap:10px}.language-select[data-v-bd046558]{padding:6px 12px;border:1px solid #ddd;border-radius:5px;font-size:14px;background:#fff;cursor:pointer}.change-password-btn[data-v-bd046558]{padding:6px 12px;background-color:#667eea;color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:14px}.change-password-btn[data-v-bd046558]:hover{background-color:#5568d3}.logout-btn[data-v-bd046558]{padding:8px 16px;background-color:#e74c3c;color:#fff;border:none;border-radius:5px;cursor:pointer}.logout-btn[data-v-bd046558]:hover{background-color:#c0392b}.calendar-content[data-v-bd046558]{max-width:1200px;margin:30px auto;padding:0 20px}.legend-container[data-v-bd046558]{background:#fff;border-radius:10px;padding:15px 20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.legend-title[data-v-bd046558]{font-weight:600;font-size:14px;color:#333;margin-bottom:12px}.legend-items[data-v-bd046558]{display:flex;flex-wrap:wrap;gap:20px}.legend-item[data-v-bd046558]{display:flex;align-items:center;gap:8px;font-size:13px;color:#666}.legend-color[data-v-bd046558]{width:30px;height:30px;border-radius:5px;border:2px solid #e0e0e0;position:relative;flex-shrink:0}.legend-color.has-attendance-demo[data-v-bd046558]{background-color:#e3f2fd;border-color:#90caf9}.legend-color.no-work-demo[data-v-bd046558]{background-color:#f5f5f5;border-color:#ccc;border-style:dashed}.legend-color.pending-approval-demo[data-v-bd046558]{background-color:#e3f2fd;border-color:#f48fb1;border-width:3px;border-style:solid}.legend-color.pending-approval-demo .legend-inner[data-v-bd046558]{width:100%;height:100%;border:2px solid #f48fb1;border-radius:3px;box-shadow:0 0 5px #f48fb180}.legend-color.normal-day-demo[data-v-bd046558]{background-color:#fff;border-color:#e0e0e0}.approval-link-container[data-v-bd046558]{margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0}.approval-link[data-v-bd046558]{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background-color:#667eea;color:#fff;text-decoration:none;border-radius:5px;font-size:14px;font-weight:500;transition:all .2s;position:relative}.approval-link[data-v-bd046558]:hover{background-color:#5568d3;transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.approval-icon[data-v-bd046558]{font-size:16px}.approval-badge[data-v-bd046558]{background-color:#f44336;color:#fff;border-radius:12px;padding:2px 8px;font-size:12px;font-weight:600;min-width:20px;text-align:center;margin-left:4px}.calendar-controls[data-v-bd046558]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.calendar-controls h2[data-v-bd046558]{color:#333;font-size:24px}.nav-btn[data-v-bd046558]{padding:10px 20px;background-color:#667eea;color:#fff;border:none;border-radius:5px;cursor:pointer}.nav-btn[data-v-bd046558]:hover:not(.nav-btn-disabled){background-color:#5568d3}.nav-btn-disabled[data-v-bd046558]{opacity:.5;cursor:not-allowed;background-color:#ccc}.calendar-grid[data-v-bd046558]{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 8px #0000001a}.weekdays[data-v-bd046558]{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-bottom:10px}.weekday[data-v-bd046558]{text-align:center;font-weight:600;color:#666;padding:10px}.calendar-days[data-v-bd046558]{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}.calendar-day[data-v-bd046558]{min-height:100px;border:2px solid #e0e0e0;border-radius:5px;padding:10px;cursor:pointer;transition:all .2s;background-color:#fff;position:relative;overflow:hidden;word-wrap:break-word;word-break:break-all}@media (max-width: 768px){.calendar-header[data-v-bd046558]{padding:15px 20px;flex-direction:column;gap:15px}.calendar-header h1[data-v-bd046558]{font-size:20px}.user-info[data-v-bd046558]{width:100%;justify-content:space-between;flex-wrap:wrap}.header-actions[data-v-bd046558]{order:-1;width:100%;justify-content:flex-end;margin-bottom:10px}.calendar-content[data-v-bd046558]{padding:0 10px;margin:15px auto}.calendar-grid[data-v-bd046558]{padding:15px}.weekdays[data-v-bd046558]{gap:5px}.weekday[data-v-bd046558]{padding:8px 5px;font-size:12px}.calendar-days[data-v-bd046558]{gap:5px}.calendar-day[data-v-bd046558]{min-height:80px;padding:8px 5px}.day-number[data-v-bd046558]{font-size:14px;margin-bottom:3px}.day-info[data-v-bd046558]{font-size:10px}.time-range[data-v-bd046558]{font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.remark[data-v-bd046558]{font-size:9px;margin-top:2px}.calendar-controls[data-v-bd046558]{flex-wrap:wrap;gap:10px}.calendar-controls h2[data-v-bd046558]{font-size:18px;width:100%;text-align:center;order:-1}.nav-btn[data-v-bd046558]{padding:8px 12px;font-size:14px}}.calendar-day.other-month[data-v-bd046558]{opacity:.3;cursor:default}.calendar-day.has-attendance[data-v-bd046558]{background-color:#e3f2fd;border-color:#90caf9}.calendar-day.pending-approval[data-v-bd046558]{border-color:#f48fb1;border-width:3px;box-shadow:0 0 5px #f48fb180}.calendar-day.no-work[data-v-bd046558]{background-color:#f5f5f5;border-color:#ccc;border-style:dashed}.calendar-day.no-work.pending-approval[data-v-bd046558]{border-color:#f48fb1;border-style:solid;border-width:3px}.calendar-day[data-v-bd046558]:hover:not(.other-month){border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.day-number[data-v-bd046558]{font-weight:600;font-size:16px;margin-bottom:5px;color:#333}.day-info[data-v-bd046558]{font-size:12px;color:#666}.time-range[data-v-bd046558]{margin-bottom:3px}.remark[data-v-bd046558]{font-style:italic;color:#888;margin-top:5px;word-break:break-word}.no-work-info[data-v-bd046558]{color:#999}.no-work-label[data-v-bd046558]{font-weight:600;color:#666;margin-bottom:3px}.dialog-overlay[data-v-bd046558]{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.dialog-content[data-v-bd046558]{background:#fff;padding:30px;border-radius:10px;width:90%;max-width:500px;box-shadow:0 10px 25px #0000004d}.dialog-content h3[data-v-bd046558]{margin-bottom:20px;color:#333}.edit-form .form-group[data-v-bd046558]{margin-bottom:20px}.edit-form label[data-v-bd046558]{display:block;margin-bottom:8px;color:#555;font-weight:500}.edit-form input[data-v-bd046558],.edit-form textarea[data-v-bd046558]{width:100%;padding:10px;border:1px solid #ddd;border-radius:5px;font-size:14px}.edit-form input[data-v-bd046558]:focus,.edit-form textarea[data-v-bd046558]:focus{outline:none;border-color:#667eea}.dialog-actions[data-v-bd046558]{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.btn-cancel[data-v-bd046558],.btn-delete[data-v-bd046558],.btn-save[data-v-bd046558]{padding:10px 20px;border:none;border-radius:5px;cursor:pointer;font-size:14px}.btn-cancel[data-v-bd046558]{background-color:#ccc;color:#333}.btn-delete[data-v-bd046558]{background-color:#e74c3c;color:#fff}.btn-save[data-v-bd046558]{background-color:#667eea;color:#fff}.btn-save[data-v-bd046558]:disabled{opacity:.6;cursor:not-allowed}.no-work-notice[data-v-bd046558]{background-color:#fff3cd;border:1px solid #ffc107;border-radius:5px;padding:10px;margin-bottom:15px;color:#856404;font-size:14px}.init-dialog[data-v-bd046558]{max-width:600px}.init-hint[data-v-bd046558]{color:#666;margin-bottom:20px;font-size:14px}.init-form[data-v-bd046558]{margin-top:20px}.init-form .form-group[data-v-bd046558]{margin-bottom:25px}.init-form label[data-v-bd046558]{display:block;margin-bottom:10px;color:#555;font-weight:500}.work-days-selector[data-v-bd046558]{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.day-checkbox[data-v-bd046558]{display:flex;align-items:center;gap:6px;cursor:pointer;padding:10px 15px;border:2px solid #ddd;border-radius:5px;transition:all .2s;-webkit-user-select:none;user-select:none;min-width:60px;justify-content:center}.day-checkbox[data-v-bd046558]:hover{background-color:#f5f5f5;border-color:#667eea}.day-checkbox input[type=checkbox][data-v-bd046558]{cursor:pointer;width:18px;height:18px;margin:0}.day-checkbox span[data-v-bd046558]{font-size:14px;color:#333}.day-checkbox[data-v-bd046558]:has(input:checked){background-color:#e3f2fd;border-color:#667eea}.day-checkbox:has(input:checked) span[data-v-bd046558]{color:#667eea;font-weight:600}.day-checkbox input[type=checkbox][data-v-bd046558]:disabled{cursor:not-allowed;opacity:.5}.time-inputs[data-v-bd046558]{display:flex;gap:20px;margin-top:10px}.time-inputs>div[data-v-bd046558]{flex:1}.time-inputs>div>label[data-v-bd046558]{display:block;margin-bottom:8px;color:#555;font-size:14px;font-weight:500}.time-inputs input[type=time][data-v-bd046558]{width:100%;padding:10px;border:1px solid #ddd;border-radius:5px;font-size:14px}.time-inputs input[type=time][data-v-bd046558]:focus{outline:none;border-color:#667eea}.work-days-hint[data-v-bd046558]{margin-top:10px;font-size:12px;color:#999;font-style:italic}.approvals-container[data-v-4ee95a23]{min-height:100vh;background-color:#f5f5f5}.approvals-header[data-v-4ee95a23]{background:#fff;padding:20px 30px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center}.approvals-header h1[data-v-4ee95a23]{color:#333;font-size:24px;margin:0}.header-actions[data-v-4ee95a23]{display:flex;gap:15px}.back-btn[data-v-4ee95a23]{padding:8px 16px;background-color:#667eea;color:#fff;text-decoration:none;border-radius:5px;font-size:14px;transition:background-color .2s}.back-btn[data-v-4ee95a23]:hover{background-color:#5568d3}.approvals-content[data-v-4ee95a23]{max-width:1200px;margin:30px auto;padding:0 20px}.loading[data-v-4ee95a23]{text-align:center;padding:40px;color:#666;font-size:16px}.empty-state[data-v-4ee95a23]{background:#fff;border-radius:10px;padding:60px;text-align:center;box-shadow:0 2px 8px #0000001a}.empty-state p[data-v-4ee95a23]{color:#999;font-size:16px;margin:0}.approvals-list[data-v-4ee95a23]{display:flex;flex-direction:column;gap:20px}.approval-item[data-v-4ee95a23]{background:#fff;border-radius:10px;padding:25px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;align-items:flex-start;gap:20px}.approval-info[data-v-4ee95a23]{flex:1}.approval-header-info[data-v-4ee95a23]{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:15px;border-bottom:1px solid #e0e0e0}.employee-name[data-v-4ee95a23]{font-size:18px;color:#333}.approval-date[data-v-4ee95a23]{font-size:14px;color:#666}.date-label[data-v-4ee95a23]{color:#999}.date-value[data-v-4ee95a23]{color:#333;font-weight:500}.approval-details[data-v-4ee95a23]{display:flex;flex-direction:column;gap:10px}.detail-row[data-v-4ee95a23]{display:flex;font-size:14px}.detail-label[data-v-4ee95a23]{color:#666;min-width:80px}.detail-value[data-v-4ee95a23]{color:#333;flex:1}.detail-value.remark[data-v-4ee95a23]{color:#555;font-style:italic}.approval-actions[data-v-4ee95a23]{display:flex;flex-direction:column;gap:10px;min-width:120px}.btn-approve[data-v-4ee95a23],.btn-reject[data-v-4ee95a23]{padding:10px 20px;border:none;border-radius:5px;cursor:pointer;font-size:14px;transition:all .2s}.btn-approve[data-v-4ee95a23]{background-color:#4caf50;color:#fff}.btn-approve[data-v-4ee95a23]:hover:not(:disabled){background-color:#45a049}.btn-reject[data-v-4ee95a23]{background-color:#f44336;color:#fff}.btn-reject[data-v-4ee95a23]:hover:not(:disabled){background-color:#da190b}.btn-approve[data-v-4ee95a23]:disabled,.btn-reject[data-v-4ee95a23]:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.approval-item[data-v-4ee95a23]{flex-direction:column}.approval-actions[data-v-4ee95a23]{width:100%;flex-direction:row}.btn-approve[data-v-4ee95a23],.btn-reject[data-v-4ee95a23]{flex:1}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#f5f5f5}#app{min-height:100vh}
