#app{font-family:Avenir,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-align:center;color:#2c3e50}.login-container[data-v-7296ea3e]{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#42b983,#35495e);padding:20px;box-sizing:border-box}.login-form[data-v-7296ea3e]{background-color:#fff;padding:2.5rem 2rem;border-radius:20px;box-shadow:0 15px 40px rgba(0,0,0,.12);width:100%;max-width:420px;backdrop-filter:blur(10px);background-color:hsla(0,0%,100%,.95);border:1px solid hsla(0,0%,100%,.18)}.login-form h2[data-v-7296ea3e]{text-align:center;margin-bottom:2rem;color:#2d3748;font-size:1.8rem;font-weight:700;letter-spacing:-.5px;background:linear-gradient(135deg,#42b983,#35495e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.form-group[data-v-7296ea3e]{margin-bottom:1.25rem;position:relative}.form-group label[data-v-7296ea3e]{display:block;margin-bottom:.5rem;color:#4a5568;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.form-group input[data-v-7296ea3e]{width:100%;padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;transition:all .2s ease;background-color:#f7fafc;color:#2d3748;box-sizing:border-box}.form-group input[data-v-7296ea3e]:hover{border-color:#cbd5e0;background-color:#fff}.form-group input[data-v-7296ea3e]:focus{outline:none;border-color:#42b983;background-color:#fff;box-shadow:0 0 0 3px rgba(66,185,131,.1)}.form-group input[data-v-7296ea3e]::-moz-placeholder{color:#a0aec0;font-size:.9rem}.form-group input[data-v-7296ea3e]::placeholder{color:#a0aec0;font-size:.9rem}.error-message[data-v-7296ea3e]{color:#e53e3e;margin-bottom:1.5rem;text-align:center;font-size:.875rem;font-weight:500;padding:.75rem;background-color:#fed7d7;border-radius:8px;border:1px solid #feb2b2;display:flex;align-items:center;justify-content:center;gap:.5rem}.login-btn[data-v-7296ea3e]{width:100%;padding:1rem;background:linear-gradient(135deg,#42b983,#35495e);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px rgba(66,185,131,.4);text-transform:uppercase;letter-spacing:.5px;position:relative;overflow:hidden}.login-btn[data-v-7296ea3e]:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.2),transparent);transition:left .5s ease}.login-btn[data-v-7296ea3e]:hover:before{left:100%}.login-btn[data-v-7296ea3e]:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(66,185,131,.5)}.login-btn[data-v-7296ea3e]:active{transform:translateY(0);box-shadow:0 4px 12px rgba(66,185,131,.3)}.login-btn[data-v-7296ea3e]:disabled{background:linear-gradient(135deg,#cbd5e0,#a0aec0);cursor:not-allowed;transform:none;box-shadow:none;opacity:.7}@media (max-width:768px){.login-container[data-v-7296ea3e]{padding:15px}.login-form[data-v-7296ea3e]{padding:2rem 1.5rem;max-width:100%;margin:0 auto}.login-form h2[data-v-7296ea3e]{font-size:1.5rem;margin-bottom:1.75rem}.form-group[data-v-7296ea3e]{margin-bottom:1rem}.form-group label[data-v-7296ea3e]{font-size:.8rem;margin-bottom:.4rem}.form-group input[data-v-7296ea3e]{padding:.8rem;font-size:.9rem}.login-btn[data-v-7296ea3e]{padding:.9rem;font-size:.95rem}.error-message[data-v-7296ea3e]{font-size:.8rem;margin-bottom:1rem;padding:.6rem}}[data-v-3039c286]{box-sizing:border-box;margin:0;padding:0}@media (max-width:768px){.navbar[data-v-3039c286]{padding:12px 16px}.navbar h1[data-v-3039c286]{font-size:18px}.address-info[data-v-3039c286]{padding:16px}.sign-buttons[data-v-3039c286]{flex-direction:column;gap:12px}.sign-btn[data-v-3039c286]{padding:14px 15px;font-size:16px}.map-container[data-v-3039c286]{height:40vh;min-height:250px}.card-header[data-v-3039c286]{flex-direction:row;align-items:center;gap:8px}.card-status[data-v-3039c286]{align-self:auto;justify-content:flex-start}.locate-btn[data-v-3039c286]{bottom:16px;right:16px;width:44px;height:44px}.punch-history[data-v-3039c286]{padding:16px}.history-item[data-v-3039c286]{flex-direction:column;gap:8px;padding:16px}.item-time[data-v-3039c286]{min-width:auto;font-size:16px}.item-address[data-v-3039c286]{font-size:14px}.item-state[data-v-3039c286]{align-self:flex-start}}.sign-container[data-v-3039c286]{display:flex;flex-direction:column;width:100%;min-height:100vh}.navbar[data-v-3039c286]{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background-color:#42b983;color:#fff;box-shadow:0 2px 4px rgba(0,0,0,.1)}.navbar h1[data-v-3039c286]{margin:0;font-size:20px;font-weight:700}.navbar-right[data-v-3039c286]{display:flex;align-items:center}.nav-link[data-v-3039c286]{color:#fff;text-decoration:none;font-size:14px;font-weight:500;padding:8px 16px;border-radius:4px;transition:background-color .3s}.nav-link[data-v-3039c286]:hover{background-color:hsla(0,0%,100%,.1)}.map-container[data-v-3039c286]{width:100%;height:20vh;min-height:200px;max-height:300px;position:relative}.locate-btn[data-v-3039c286]{position:absolute;bottom:20px;right:20px;width:40px;height:40px;border-radius:50%;background-color:#fff;border:2px solid #0090ff;color:#0090ff;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.2);display:flex;align-items:center;justify-content:center;z-index:1000;transition:all .3s ease}.locate-btn[data-v-3039c286]:hover{background-color:#0090ff;color:#fff;transform:scale(1.1)}.locate-btn[data-v-3039c286]:active{transform:scale(.95)}.punch-history[data-v-3039c286]{padding:20px;background-color:#f5f5f5;margin-top:20px;border-radius:8px}.punch-history h3[data-v-3039c286]{margin-top:0;margin-bottom:15px;color:#333;font-size:16px;font-weight:600}.history-list[data-v-3039c286]{display:flex;flex-direction:column;gap:10px}.history-item[data-v-3039c286]{display:flex;align-items:flex-start;padding:12px;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.1);transition:all .3s ease;border:1px solid #f0f0f0}.history-item[data-v-3039c286]:hover{box-shadow:0 4px 16px rgba(0,0,0,.12);transform:translateY(-2px)}.history-item.abnormal[data-v-3039c286]{border-left:4px solid #f44;background-color:#fff8f8}.history-item.abnormal[data-v-3039c286]:hover{box-shadow:0 4px 16px rgba(255,68,68,.12)}.item-time[data-v-3039c286]{font-weight:600;color:#333;margin-right:15px;min-width:150px}.item-info[data-v-3039c286]{flex:1}.item-address[data-v-3039c286]{color:#666;margin-bottom:5px;font-size:14px}.item-sign[data-v-3039c286]{color:#0090ff;font-size:14px}.item-state[data-v-3039c286]{background-color:#f44;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;white-space:nowrap}.address-info[data-v-3039c286]{padding:20px;background-color:#f5f5f5}.address-label[data-v-3039c286]{font-size:14px;color:#666;margin:0 0 8px 0}.address-text[data-v-3039c286]{font-size:16px;color:#333;font-weight:700;margin:0 0 8px 0}.sign-actions[data-v-3039c286]{margin-bottom:15px}.sign-buttons[data-v-3039c286]{display:flex;gap:10px;margin-bottom:15px}.sign-btn[data-v-3039c286]{flex:1;padding:12px 15px;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 2px 8px rgba(0,0,0,.15);text-transform:uppercase;letter-spacing:.5px}.sign-in-btn[data-v-3039c286]{background:linear-gradient(135deg,#42b983,#359a72);color:#fff}.sign-in-btn[data-v-3039c286]:hover{background:linear-gradient(135deg,#35a575,#2d8a62);transform:translateY(-2px);box-shadow:0 4px 12px rgba(66,185,131,.3)}.sign-out-btn[data-v-3039c286]{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.sign-out-btn[data-v-3039c286]:hover{background:linear-gradient(135deg,#2980b9,#1c6ea4);transform:translateY(-2px);box-shadow:0 4px 12px rgba(52,152,219,.3)}.sign-btn[data-v-3039c286]:active{transform:translateY(0)}.sign-btn[data-v-3039c286]:disabled{background:linear-gradient(135deg,#bdc3c7,#a0a7ad);cursor:not-allowed;transform:none;box-shadow:0 2px 4px rgba(0,0,0,.1)}.location-actions[data-v-3039c286]{margin-bottom:15px}.save-btn[data-v-3039c286]{background:linear-gradient(135deg,#42b983,#359a72);color:#fff;border:none;padding:12px 15px;border-radius:8px;font-size:14px;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px rgba(0,0,0,.1);margin-bottom:12px;width:100%}.save-btn[data-v-3039c286]:hover{background:linear-gradient(135deg,#35a575,#2d8a62);box-shadow:0 4px 12px rgba(66,185,131,.3);transform:translateY(-1px)}.save-btn[data-v-3039c286]:disabled{background:linear-gradient(135deg,#bdc3c7,#a0a7ad);cursor:not-allowed;transform:none;box-shadow:0 2px 4px rgba(0,0,0,.1)}.saved-locations[data-v-3039c286]{margin-top:12px}.dropdown[data-v-3039c286]{position:relative;width:100%}.dropdown-toggle[data-v-3039c286]{width:100%;padding:12px 15px;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;cursor:pointer;text-align:left;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px rgba(0,0,0,.05);transition:all .3s ease}.dropdown-toggle[data-v-3039c286]:hover{border-color:#42b983;box-shadow:0 2px 8px rgba(66,185,131,.15)}.dropdown-arrow[data-v-3039c286]{font-size:10px;margin-left:10px}.dropdown-menu[data-v-3039c286]{position:absolute;top:105%;left:0;right:0;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.12);z-index:100;max-height:300px;overflow-y:auto}.dropdown-item[data-v-3039c286]{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;cursor:pointer;transition:all .2s ease}.dropdown-item[data-v-3039c286]:hover{background-color:#f8f9fa;color:#42b983}.location-info[data-v-3039c286]{flex:1;cursor:pointer;word-break:break-all;font-size:14px}.delete-btn[data-v-3039c286]{background-color:#e74c3c;color:#fff;border:none;border-radius:50%;width:24px;height:24px;font-size:16px;line-height:1;cursor:pointer;margin-left:10px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 2px 4px rgba(0,0,0,.1)}.delete-btn[data-v-3039c286]:hover{background-color:#c0392b;transform:scale(1.1);box-shadow:0 2px 8px rgba(231,76,60,.3)}.delete-btn[data-v-3039c286]:active{transform:scale(.95)}.punch-cards[data-v-3039c286]{display:flex;flex-direction:column;gap:16px;margin-top:20px}.punch-card[data-v-3039c286]{background-color:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 8px rgba(0,0,0,.1);border:1px solid #f0f0f0}.card-header[data-v-3039c286]{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:nowrap}.card-title[data-v-3039c286]{margin:0;font-size:16px;font-weight:600;color:#333}.card-status[data-v-3039c286]{display:flex;align-items:center}.status-normal[data-v-3039c286]{background-color:#42b983}.status-abnormal[data-v-3039c286],.status-normal[data-v-3039c286]{color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600}.status-abnormal[data-v-3039c286]{background-color:#f44}.status-not-punched[data-v-3039c286]{background-color:#f39c12;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600}.card-content[data-v-3039c286]{display:flex;flex-direction:column;gap:8px;padding:12px;background-color:#f8f9fa;border-radius:6px;border-left:3px solid #42b983}.card-content.abnormal[data-v-3039c286]{background-color:#fff8f8;border-left-color:#f44}.record-time[data-v-3039c286]{font-weight:600;color:#333}.record-info[data-v-3039c286]{display:flex;flex-direction:column;gap:4px}.record-address[data-v-3039c286]{color:#666;font-size:14px}.record-sign[data-v-3039c286]{color:#0090ff;font-size:14px}.record-state[data-v-3039c286]{background-color:#f44;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;width:-moz-fit-content;width:fit-content}.re-sign-btn[data-v-3039c286]{margin-top:8px;padding:8px 12px;background-color:#42b983;color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:all .3s ease;align-self:flex-start}.re-sign-btn[data-v-3039c286]:hover{background-color:#35a575;transform:translateY(-1px);box-shadow:0 2px 8px rgba(66,185,131,.3)}.re-sign-btn[data-v-3039c286]:active{transform:translateY(0)}.re-sign-btn[data-v-3039c286]:disabled{background-color:#bdc3c7;cursor:not-allowed;transform:none;box-shadow:none}.card-actions[data-v-3039c286]{display:flex;justify-content:center}.coordinates[data-v-3039c286]{font-size:12px;color:#999;margin:15px 0 0 0}.address-detail[data-v-3039c286]{margin-top:15px;padding-top:15px;border-top:1px solid #e0e0e0}.detail-item[data-v-3039c286]{font-size:14px;color:#666;margin:8px 0}.detail-item .label[data-v-3039c286]{color:#999;margin-right:5px}@media (max-width:768px){.navbar[data-v-3039c286]{padding:10px 15px}.navbar h1[data-v-3039c286]{font-size:18px}.nav-link[data-v-3039c286]{font-size:13px;padding:6px 12px}.map-container[data-v-3039c286]{height:50vh;min-height:250px}.address-info[data-v-3039c286]{padding:15px}.address-label[data-v-3039c286]{font-size:13px;margin-bottom:6px}.address-text[data-v-3039c286]{font-size:14px;margin-bottom:6px;line-height:1.4}.address-detail[data-v-3039c286]{margin-top:12px;padding-top:12px}.detail-item[data-v-3039c286]{font-size:13px;margin:6px 0}.coordinates[data-v-3039c286]{font-size:11px;margin-top:12px}.dropdown-item[data-v-3039c286],.dropdown-toggle[data-v-3039c286],.save-btn[data-v-3039c286]{font-size:13px;padding:8px 12px}.location-actions[data-v-3039c286]{margin-bottom:12px}.sign-buttons[data-v-3039c286]{flex-direction:column;gap:8px;margin-bottom:12px}.sign-btn[data-v-3039c286]{font-size:13px;padding:10px 12px}}.profile-container[data-v-454dca2a]{min-height:100vh;background-color:#f5f5f5}.navbar[data-v-454dca2a]{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background-color:#42b983;color:#fff;box-shadow:0 2px 4px rgba(0,0,0,.1);height:auto;min-height:56px;box-sizing:border-box}.navbar h1[data-v-454dca2a]{margin:0;font-size:20px;font-weight:700}.navbar-right[data-v-454dca2a]{display:flex;align-items:center}.nav-link[data-v-454dca2a]{color:#fff;text-decoration:none;font-size:14px;font-weight:500;padding:8px 16px;border-radius:4px;transition:background-color .3s}.nav-link[data-v-454dca2a]:hover{background-color:hsla(0,0%,100%,.1)}.profile-container>h2[data-v-454dca2a]{text-align:center;color:#333;margin:40px 0 30px}.profile-container h2[data-v-454dca2a]{text-align:center;color:#333;margin-bottom:30px}.profile-card[data-v-454dca2a]{background-color:#fff;border-radius:12px;box-shadow:0 4px 16px rgba(0,0,0,.08);padding:24px 16px;margin:16px;border:1px solid rgba(0,0,0,.03)}.profile-header[data-v-454dca2a]{text-align:center;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #f0f0f0;background:linear-gradient(135deg,rgba(66,185,131,.05),rgba(66,185,131,.02));border-radius:8px;padding:20px 16px;margin:-16px -16px 24px -16px}.avatar[data-v-454dca2a]{width:100px;height:100px;margin:0 auto 20px;border-radius:50%;overflow:hidden;border:3px solid #f0f0f0}.avatar img[data-v-454dca2a]{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.avatar-placeholder[data-v-454dca2a]{width:100%;height:100%;background-color:#42b983;color:#fff;display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:700}.profile-header h3[data-v-454dca2a]{margin:0 0 10px 0;color:#333;font-size:24px}.name-title-container[data-v-454dca2a]{display:flex;align-items:center;justify-content:center;gap:15px;flex-wrap:wrap}.name[data-v-454dca2a]{margin:0;color:#333;font-size:24px;font-weight:600}.job-title[data-v-454dca2a]{margin:0;color:#666;font-size:16px;white-space:nowrap}.profile-info[data-v-454dca2a]{margin-bottom:24px;background-color:#fafafa;border-radius:8px;padding:4px 0;overflow:hidden}.info-item[data-v-454dca2a]{display:flex;margin-bottom:0;padding:12px 16px;border-bottom:1px solid rgba(0,0,0,.03);background-color:#fff;transition:background-color .2s ease}.info-item[data-v-454dca2a]:hover{background-color:#f8fff9}.info-item[data-v-454dca2a]:last-child{border-bottom:none}.label[data-v-454dca2a]{min-width:80px;color:#666;font-size:13px;font-weight:600;white-space:nowrap;margin-right:12px}.value[data-v-454dca2a]{flex:1;color:#333;font-size:13px;word-break:break-word;line-height:1.4;display:flex;align-items:center}.expire-date[data-v-454dca2a]{border-top:1px solid rgba(0,0,0,.05);margin-top:0;padding-top:0}.expire-date .value[data-v-454dca2a]{color:#e74c3c;font-weight:600;font-size:14px;display:flex;align-items:center}.expire-date .value[data-v-454dca2a]:before{content:"⚠️";margin-right:6px;font-size:12px}.profile-actions[data-v-454dca2a]{text-align:center;padding:0 16px}.logout-btn[data-v-454dca2a]{padding:14px 32px;background-color:#e74c3c;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px rgba(231,76,60,.2);width:100%;max-width:300px;min-height:44px}.logout-btn[data-v-454dca2a]:hover{background-color:#c0392b;transform:translateY(-1px);box-shadow:0 4px 12px rgba(231,76,60,.3)}.logout-btn[data-v-454dca2a]:active{transform:translateY(0);box-shadow:0 2px 4px rgba(231,76,60,.2)}@media (max-width:768px){.profile-card[data-v-454dca2a]{margin:8px;padding:16px 12px;border-radius:10px}.profile-header[data-v-454dca2a]{padding:16px 12px;margin:-12px -12px 16px -12px}.name-title-container[data-v-454dca2a]{gap:8px;flex-direction:column;align-items:center}.name[data-v-454dca2a]{font-size:20px}.job-title[data-v-454dca2a]{font-size:14px;white-space:normal;text-align:center;max-width:100%;overflow-wrap:break-word}.profile-info[data-v-454dca2a]{margin-bottom:16px}.info-item[data-v-454dca2a]{padding:10px 12px;flex-direction:row;align-items:flex-start}.label[data-v-454dca2a]{min-width:70px;font-size:12px;margin-right:8px}.value[data-v-454dca2a]{font-size:12px}.expire-date .value[data-v-454dca2a]{font-size:13px}.logout-btn[data-v-454dca2a]{padding:12px 24px;font-size:14px;width:100%;max-width:none}.navbar[data-v-454dca2a]{padding:12px 16px;min-height:52px}.navbar h1[data-v-454dca2a]{font-size:18px}.nav-link[data-v-454dca2a]{font-size:13px;padding:6px 12px}}