body{font-family:Arial,sans-serif;margin:0;padding:10px;background-color:#1a1a1a;min-height:100vh;display:flex;flex-direction:column;color:#e0e0e0}#app{display:flex;flex-direction:column;min-height:100vh;margin:-10px;padding:10px}.main-content{flex:1}.schedule-table{width:100%;border-collapse:collapse;background-color:#2d2d2d;box-shadow:0 2px 10px #0000004d;border-radius:8px;overflow:hidden}.court-header{text-align:center;font-weight:700;padding:12px 8px;background-color:#3a3a3a;border:1px solid #555;position:sticky;top:0;color:#e0e0e0}td{-webkit-tap-highlight-color:transparent}.time-range{font-size:14px;margin-bottom:5px;font-weight:700;color:#b0b0b0;margin-top:12px}.status{font-size:12px;padding:2px 6px;border-radius:10px;display:inline-block}.action-buttons{display:flex;justify-content:space-between;flex-wrap:wrap;width:100%}.action-button{height:48px;font-size:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;line-height:1;box-sizing:border-box;flex:1;min-width:0}.action-button:first-child{margin-left:0}.action-button:last-child{margin-right:0}.action-button:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.booking-button{background-color:#404040;color:#b0b0b0;min-width:50px}.booking-button.booked{background-color:#5a5a5a;color:#fff}.upload-button,.view-button,.delete-button{background-color:#5a5a5a;color:#fff;font-size:14px}.file-input{display:none}.booked{background-color:#2e7d32}.booked .status,.booked .time-range{color:#fff}.available{background-color:#3a3a3a}.available .status{color:#b0b0b0}.merged-cell{background-color:#2e7d32;color:#fff}.disabled{opacity:.6;cursor:not-allowed}.controls{display:flex;justify-content:center;align-items:center;border-radius:8px;flex-wrap:wrap}button{padding:10px 20px;background-color:#388e3c;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:700;transition:all .3s;margin:5px;flex-grow:1;min-width:100px}button:disabled{background-color:#555;cursor:not-allowed}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 0;margin:-10px -10px 20px;text-align:center;position:relative;overflow:hidden}.app-header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><circle cx="50" cy="50" r="40" fill="none" stroke="rgba(255,255,255,0.1)" stroke-width="2"/></svg>') repeat;opacity:.3;pointer-events:none}.app-title{font-size:28px;font-weight:700;margin:0;letter-spacing:1px;position:relative;z-index:1}.app-subtitle{font-size:14px;opacity:.9;margin:5px 0 0;font-weight:400;position:relative;z-index:1}.calendar-header{display:flex;align-items:baseline;gap:12px;margin-bottom:8px;align-self:flex-start;margin-left:18px}.calendar-year{color:#ff4d4f;font-size:22px;font-weight:700;letter-spacing:2px}.calendar-month{color:#fff;font-size:38px;font-weight:700;letter-spacing:4px;margin-left:8px}.calendar-week{display:none}.calendar-days{display:flex;justify-content:space-around;width:100%;padding:0 15px}.calendar-day{display:flex;flex-direction:column;align-items:center;justify-content:center;width:58px;height:58px;margin:0 1px;border-radius:64px;background:transparent;color:#fff;font-size:16px;font-weight:500;cursor:pointer;transition:background .2s,color .2s;position:relative}.calendar-day.selected{background:#ff4d4f;color:#fff;font-size:18px;font-weight:700;box-shadow:0 2px 8px #ff4d4f2e;z-index:2}.calendar-day.selected .day-label{color:#fff}.calendar-day .day-label{font-size:11px;color:#bdbdbd;margin-bottom:2px;order:-1}.calendar-day .special-tag{position:absolute;right:2px;bottom:2px;background:#7c4dff;color:#fff;font-size:10px;border-radius:8px;padding:0 4px;font-weight:700}.calendar-day.selected .special-tag{background:#fff;color:#7c4dff}.calendar-day.weekend{color:#666;background:transparent;opacity:.4;cursor:not-allowed}.calendar-day.weekend .day-label{color:#666}.calendar-reset-btn{position:absolute;right:18px;top:18px;background:#d32f2f;color:#fff;border:none;border-radius:8px;padding:6px 18px;font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 2px 6px #d32f2f33;transition:background .2s}.calendar-reset-btn:active{background:#b71c1c}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:9999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.loading-container{background-color:#fff;padding:30px;border-radius:10px;box-shadow:0 4px 20px #0000004d;text-align:center;min-width:200px}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #4CAF50;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 15px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{color:#333;font-size:16px;font-weight:700;margin:0}.loading-subtext{color:#666;font-size:14px;margin:5px 0 0}.footer{margin-top:auto;padding:20px;background-color:#2d2d2d;border-radius:12px;text-align:center;color:#b0b0b0;font-size:14px;line-height:1.6;flex-shrink:0}.footer-content{max-width:800px;margin:0 auto}.footer-title{font-weight:700;color:#e0e0e0;margin-bottom:8px}.footer-info{margin:5px 0;color:#b0b0b0}.footer-info a{color:#64b5f6;text-decoration:none;transition:color .3s;cursor:pointer}.footer-info a:hover{color:#90caf9}.footer-version{margin-top:15px;padding-top:15px;border-top:1px solid #555;font-size:12px;color:#888}.footer-tech{font-family:Courier New,monospace;background-color:#404040;color:#e0e0e0;padding:2px 6px;border-radius:3px;margin:0 2px}.admin-controls{text-align:center;margin-bottom:15px}.admin-toggle-btn{background:linear-gradient(135deg,#9c27b0,#7b1fa2);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 2px 8px #9c27b04d}.admin-toggle-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #9c27b066}.admin-auth-panel{background-color:#3a3a3a;border-radius:8px;padding:15px;text-align:center}.admin-settings-panel{background-color:#3a3a3a;border-radius:8px;padding:15px}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;flex-wrap:wrap;gap:10px}.admin-header h4{color:#e0e0e0;margin:0;font-size:16px}.admin-badge{background-color:#9c27b0;color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:700}.auth-header h4{color:#e0e0e0;margin:0 0 8px;font-size:18px}.auth-header p{color:#b0b0b0;margin:0 0 15px;font-size:14px}.auth-form{display:flex;gap:10px;justify-content:center;align-items:center;flex-wrap:wrap}.auth-input{padding:10px 15px;border:1px solid #555;border-radius:8px;background-color:#404040;color:#e0e0e0;font-size:16px;min-width:200px;flex:1;max-width:300px}.auth-input::placeholder{color:#999}.auth-input:focus{outline:none;border-color:#ff9800;box-shadow:0 0 0 2px #ff980033}.auth-btn{padding:10px 20px;background-color:#ff9800;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s}.auth-btn:hover:not(:disabled){background-color:#f57c00;transform:translateY(-1px)}.auth-btn:disabled{background-color:#555;cursor:not-allowed}.setting-item{margin-bottom:15px}.setting-label{display:flex;align-items:center;cursor:pointer;color:#e0e0e0;font-size:14px;font-weight:700}.setting-checkbox{margin-right:10px;transform:scale(1.2);accent-color:#9c27b0}.setting-text{-webkit-user-select:none;user-select:none}.setting-desc{color:#b0b0b0;font-size:12px;margin:5px 0 0 32px;line-height:1.4}.user-info-panel{background-color:#1b5e20;border-radius:8px;padding:12px 16px;margin:10px 0}.user-info{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.user-label{color:#c8e6c9;font-size:14px}.user-wechat{color:#fff;font-weight:700;font-family:Courier New,monospace;background-color:#ffffff1a;padding:4px 8px;border-radius:4px}.logout-btn{background-color:#f44336;color:#fff;border:none;padding:4px 8px;border-radius:4px;font-size:12px;cursor:pointer;transition:all .3s}.logout-btn:hover{background-color:#d32f2f}.desktop-table{display:block}.mobile-tables{display:none}@media (max-width: 768px){.desktop-table{display:none}.mobile-tables{display:block}.mobile-tables .schedule-table{margin-bottom:20px}}@media (max-width: 600px){.app-header{margin:-10px -10px 15px;padding:15px 0}.app-title{font-size:22px}.app-subtitle{font-size:12px}.calendar-header{align-items:flex-start;margin-left:12px}.calendar-month{font-size:28px}.calendar-year{font-size:16px}.calendar-day,.calendar-day.selected{width:48px;height:48px;font-size:13px;border-radius:32px}.calendar-days{padding:0 8px}.calendar-day .day-label{font-size:9px}.auth-form{flex-direction:column;align-items:stretch}.auth-input{width:100%;min-width:auto;max-width:none;margin-bottom:10px}.user-info{flex-direction:column;gap:8px}.admin-header{flex-direction:column;align-items:stretch;gap:8px}.admin-badge{align-self:center}.setting-desc{margin-left:0;text-align:center}}.date-selector[data-v-834d7b57]{display:flex;flex-direction:column;align-items:center;width:100%;border-radius:18px;position:relative}.calendar-header[data-v-834d7b57]{display:flex;align-items:flex-end;gap:12px;margin-bottom:8px;align-self:flex-start;margin-left:18px}.calendar-year[data-v-834d7b57]{color:#ff4d4f;font-size:22px;font-weight:700;letter-spacing:2px}.calendar-month[data-v-834d7b57]{color:#fff;font-size:38px;font-weight:700;letter-spacing:4px;margin-left:8px}.calendar-days[data-v-834d7b57]{display:flex;justify-content:space-around;width:100%;padding:0 15px}.calendar-day[data-v-834d7b57]{display:flex;flex-direction:column;align-items:center;justify-content:center;width:58px;height:58px;margin:0 1px;border-radius:64px;background:transparent;color:#fff;font-size:16px;font-weight:500;cursor:pointer;transition:background .2s,color .2s;position:relative}.calendar-day.selected[data-v-834d7b57]{background:#ff4d4f;color:#fff;font-size:18px;font-weight:700;box-shadow:0 2px 8px #ff4d4f2e;z-index:2}.calendar-day.selected .day-label[data-v-834d7b57]{color:#fff}.calendar-day .day-label[data-v-834d7b57]{font-size:11px;color:#bdbdbd;margin-bottom:2px;order:-1}.calendar-day .special-tag[data-v-834d7b57]{position:absolute;right:2px;bottom:2px;background:#7c4dff;color:#fff;font-size:10px;border-radius:8px;padding:0 4px;font-weight:700}.calendar-day.selected .special-tag[data-v-834d7b57]{background:#fff;color:#7c4dff}.calendar-day.weekend[data-v-834d7b57]{color:#666;background:transparent;opacity:.4;cursor:not-allowed}.calendar-day.weekend .day-label[data-v-834d7b57]{color:#666}.action-buttons[data-v-834d7b57]{position:absolute;right:18px;top:18px;display:flex;gap:8px}.calendar-action-btn[data-v-834d7b57]{height:2.5rem;width:60px;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 2px 6px #00000026;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.calendar-action-btn[data-v-834d7b57]:disabled{opacity:.6;cursor:not-allowed}.refresh-btn[data-v-834d7b57]{background:#2196f3;color:#fff}.refresh-btn[data-v-834d7b57]:hover:not(:disabled){background:#1976d2;transform:translateY(-1px)}.refresh-btn[data-v-834d7b57]:active:not(:disabled){background:#1565c0;transform:translateY(0)}.reset-btn[data-v-834d7b57]{background:#d32f2f;color:#fff}.reset-btn[data-v-834d7b57]:hover:not(:disabled){background:#c62828;transform:translateY(-1px)}.reset-btn[data-v-834d7b57]:active:not(:disabled){background:#b71c1c;transform:translateY(0)}.loading-spinner[data-v-834d7b57]{animation:spin 1s linear infinite;display:inline-block}@media (max-width: 600px){.calendar-header[data-v-834d7b57]{align-items:flex-end;margin-left:12px}.calendar-month[data-v-834d7b57]{font-size:28px}.calendar-year[data-v-834d7b57]{font-size:16px}.calendar-day[data-v-834d7b57],.calendar-day.selected[data-v-834d7b57]{width:48px;height:48px;font-size:13px;border-radius:32px}.calendar-days[data-v-834d7b57]{padding:0 8px}.calendar-day .day-label[data-v-834d7b57]{font-size:9px}.action-buttons[data-v-834d7b57]{right:12px;top:12px;gap:6px}.calendar-action-btn[data-v-834d7b57]{width:48px;height:2rem;font-size:12px}}.admin-panel[data-v-2c8426f7]{background-color:#2d2d2d;border-radius:12px;padding:15px;margin-bottom:10px;border:2px solid #9c27b0}.admin-controls[data-v-2c8426f7]{text-align:center;margin-bottom:15px}.admin-toggle-btn[data-v-2c8426f7]{background:linear-gradient(135deg,#9c27b0,#7b1fa2);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 2px 8px #9c27b04d}.admin-toggle-btn[data-v-2c8426f7]:hover{transform:translateY(-2px);box-shadow:0 4px 12px #9c27b066}.admin-settings-panel[data-v-2c8426f7]{background-color:#3a3a3a;border-radius:8px;padding:15px}.auth-modal[data-v-2c8426f7]{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.auth-modal-content[data-v-2c8426f7]{background-color:#2d2d2d;border-radius:12px;width:90%;max-width:400px;box-shadow:0 10px 25px #00000080;animation:modalFadeIn-2c8426f7 .3s ease-out}@keyframes modalFadeIn-2c8426f7{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.admin-header[data-v-2c8426f7]{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;flex-wrap:wrap;gap:10px}.admin-header h4[data-v-2c8426f7]{color:#e0e0e0;margin:0;font-size:16px}.admin-badge[data-v-2c8426f7]{background-color:#9c27b0;color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:700}.auth-header[data-v-2c8426f7]{display:flex;justify-content:space-between;align-items:center;padding:20px 25px 15px;border-bottom:1px solid #444}.auth-header h4[data-v-2c8426f7]{color:#e0e0e0;margin:0;font-size:18px}.close-btn-container[data-v-2c8426f7]{display:flex;justify-content:flex-end;align-items:center}.close-btn[data-v-2c8426f7]{background:none;border:none;color:#999;font-size:24px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s}.close-btn[data-v-2c8426f7]:hover{background-color:#444;color:#fff}.auth-body[data-v-2c8426f7]{padding:25px;text-align:center}.auth-body p[data-v-2c8426f7]{color:#b0b0b0;margin:0 0 20px;font-size:14px}.validating-text[data-v-2c8426f7]{color:#ff9800!important;font-weight:700;animation:pulse-2c8426f7 1.5s ease-in-out infinite alternate}@keyframes pulse-2c8426f7{0%{opacity:.6}to{opacity:1}}.auth-footer[data-v-2c8426f7]{display:flex;gap:10px;justify-content:flex-end;padding:15px 25px 25px;border-top:1px solid #444}.auth-input[data-v-2c8426f7]{padding:12px 15px;border:1px solid #555;border-radius:8px;background-color:#404040;color:#e0e0e0;font-size:16px;width:100%;box-sizing:border-box}.auth-input[data-v-2c8426f7]::placeholder{color:#999}.auth-input[data-v-2c8426f7]:focus{outline:none;border-color:#ff9800;box-shadow:0 0 0 2px #ff980033}.auth-btn[data-v-2c8426f7]{padding:10px 20px;background-color:#ff9800;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s}.auth-btn[data-v-2c8426f7]:hover:not(:disabled){background-color:#f57c00;transform:translateY(-1px)}.auth-btn[data-v-2c8426f7]:disabled{background-color:#555;cursor:not-allowed}.cancel-btn[data-v-2c8426f7]{padding:10px 20px;background-color:#555;color:#ccc;border:none;border-radius:8px;font-size:16px;cursor:pointer;transition:all .3s}.cancel-btn[data-v-2c8426f7]:hover{background-color:#666;color:#fff}.setting-item[data-v-2c8426f7]{margin-bottom:15px}.setting-label[data-v-2c8426f7]{display:flex;align-items:center;cursor:pointer;color:#e0e0e0;font-size:14px;font-weight:700}.setting-checkbox[data-v-2c8426f7]{margin-right:10px;transform:scale(1.2);accent-color:#9c27b0}.setting-text[data-v-2c8426f7]{-webkit-user-select:none;user-select:none}.setting-desc[data-v-2c8426f7]{color:#b0b0b0;font-size:12px;margin:5px 0 0 32px;line-height:1.4}.whitelist-btn[data-v-2c8426f7]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 2px 8px #667eea4d;width:100%;margin-top:5px}.whitelist-btn[data-v-2c8426f7]:hover{background:linear-gradient(135deg,#5a6fd8,#6a1b9a);transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.whitelist-panel[data-v-2c8426f7]{background-color:#333;border-radius:8px;padding:15px;margin-top:15px;border:1px solid #555}.whitelist-panel h5[data-v-2c8426f7]{color:#e0e0e0;margin:0 0 8px;font-size:16px}.whitelist-desc[data-v-2c8426f7]{color:#b0b0b0;font-size:12px;margin:0;line-height:1.4}.permission-error-modal[data-v-2c8426f7]{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:2000}.permission-error-content[data-v-2c8426f7]{background:linear-gradient(135deg,#2d2d2d,#3a3a3a);border-radius:16px;width:90%;max-width:500px;box-shadow:0 20px 40px #000000b3;animation:errorModalFadeIn-2c8426f7 .4s ease-out;border:2px solid #ff5252}@keyframes errorModalFadeIn-2c8426f7{0%{opacity:0;transform:scale(.8) translateY(-30px)}to{opacity:1;transform:scale(1) translateY(0)}}.permission-error-header[data-v-2c8426f7]{text-align:center;padding:25px 25px 15px;border-bottom:1px solid #555}.error-icon[data-v-2c8426f7]{font-size:48px;margin-bottom:10px;filter:drop-shadow(0 0 10px rgba(255,82,82,.5))}.permission-error-header h3[data-v-2c8426f7]{color:#ff5252;margin:0;font-size:20px;font-weight:700}.permission-error-body[data-v-2c8426f7]{padding:25px}.error-details[data-v-2c8426f7]{text-align:center}.error-wechat[data-v-2c8426f7]{background-color:#444;padding:12px 15px;border-radius:8px;margin-bottom:15px;color:#fff;font-size:16px}.error-message[data-v-2c8426f7]{color:#ffb74d;font-size:15px;line-height:1.5;margin-bottom:20px;padding:15px;background-color:#424242;border-radius:8px;border-left:4px solid #ff5252}.contact-info[data-v-2c8426f7]{background-color:#383838;padding:20px;border-radius:10px;border:1px solid #555}.contact-info p[data-v-2c8426f7]{color:#b0b0b0;margin:0 0 15px;font-size:14px}.admin-contact[data-v-2c8426f7]{display:flex;justify-content:center;align-items:center;background-color:#2d2d2d;padding:15px;border-radius:8px;border:1px solid #666}.contact-name[data-v-2c8426f7]{color:#4caf50;font-weight:700;font-size:16px}.contact-btn[data-v-2c8426f7]{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;transition:all .3s}.contact-btn[data-v-2c8426f7]:hover{transform:translateY(-1px);box-shadow:0 4px 8px #4caf504d}.permission-error-footer[data-v-2c8426f7]{padding:15px 25px 25px;text-align:center;border-top:1px solid #555}.confirm-btn[data-v-2c8426f7]{background:linear-gradient(135deg,#666,#555);color:#fff;border:none;padding:12px 30px;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s;min-width:120px}.confirm-btn[data-v-2c8426f7]:hover{background:linear-gradient(135deg,#777,#666);transform:translateY(-1px)}.user-info-panel[data-v-2c8426f7]{background-color:#1b5e20;border-radius:8px;padding:12px 16px;margin:10px 0}.user-info[data-v-2c8426f7]{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.user-label[data-v-2c8426f7]{color:#c8e6c9;font-size:14px}.user-wechat[data-v-2c8426f7]{color:#fff;font-weight:700;font-family:Courier New,monospace;background-color:#ffffff1a;padding:4px 8px;border-radius:4px}.logout-btn[data-v-2c8426f7]{background-color:#f44336;color:#fff;border:none;padding:4px 8px;border-radius:4px;font-size:12px;cursor:pointer;transition:all .3s}.logout-btn[data-v-2c8426f7]:hover{background-color:#d32f2f}.confirm-modal[data-v-2c8426f7]{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.confirm-modal-content[data-v-2c8426f7]{background-color:#2d2d2d;border-radius:12px;width:90%;max-width:400px;box-shadow:0 10px 25px #00000080;animation:modalFadeIn-2c8426f7 .3s ease-out}.confirm-header[data-v-2c8426f7]{display:flex;justify-content:space-between;align-items:center;padding:20px 25px 15px;border-bottom:1px solid #444}.confirm-header h4[data-v-2c8426f7]{color:#e0e0e0;margin:0;font-size:18px}.confirm-body[data-v-2c8426f7]{padding:25px;text-align:center}.confirm-body p[data-v-2c8426f7]{color:#e0e0e0;margin:0 0 10px;font-size:16px}.confirm-warning[data-v-2c8426f7]{color:#ff9800!important;font-size:14px!important}.confirm-footer[data-v-2c8426f7]{display:flex;gap:10px;justify-content:flex-end;padding:15px 25px 25px;border-top:1px solid #444}.confirm-btn[data-v-2c8426f7]{padding:10px 20px;background-color:#f44336;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s}.confirm-btn[data-v-2c8426f7]:hover{background-color:#d32f2f}@media (max-width: 768px){.user-info[data-v-2c8426f7]{flex-direction:column;gap:8px}.user-label[data-v-2c8426f7],.user-wechat[data-v-2c8426f7]{font-size:12px}.logout-btn[data-v-2c8426f7]{font-size:11px;padding:6px 12px}.confirm-modal-content[data-v-2c8426f7]{width:95%;margin:20px}.confirm-header[data-v-2c8426f7]{padding:15px 20px 10px}.confirm-header h4[data-v-2c8426f7]{font-size:16px}.confirm-body[data-v-2c8426f7]{padding:20px}.confirm-footer[data-v-2c8426f7]{padding:10px 20px 20px;flex-direction:column;gap:8px}.confirm-footer button[data-v-2c8426f7]{width:100%;margin:0}}.whitelist-panel[data-v-2b83e6ec]{background-color:#2d2d2d;border-radius:12px;padding:20px;margin-top:20px;color:#e0e0e0}.whitelist-header[data-v-2b83e6ec]{display:flex;flex-direction:column;gap:15px;margin-bottom:20px}.whitelist-header h3[data-v-2b83e6ec]{margin:0;color:#e0e0e0;font-size:20px;font-weight:700}.whitelist-controls[data-v-2b83e6ec]{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.whitelist-input[data-v-2b83e6ec]{padding:8px 12px;border:1px solid #555;border-radius:6px;background-color:#404040;color:#e0e0e0;font-size:14px;min-width:150px;flex:1}.whitelist-input[data-v-2b83e6ec]::placeholder{color:#999}.whitelist-input[data-v-2b83e6ec]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.whitelist-btn[data-v-2b83e6ec]{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;transition:all .3s;white-space:nowrap}.whitelist-btn[data-v-2b83e6ec]:disabled{opacity:.5;cursor:not-allowed}.add-btn[data-v-2b83e6ec]{background-color:#4caf50;color:#fff}.add-btn[data-v-2b83e6ec]:hover:not(:disabled){background-color:#45a049}.refresh-btn[data-v-2b83e6ec]{background-color:#9a21f3;color:#fff}.close-btn[data-v-2b83e6ec]{background-color:#f44336;color:#fff}.close-btn[data-v-2b83e6ec]:hover{background-color:#d32f2f}.whitelist-stats[data-v-2b83e6ec]{display:flex;gap:20px;margin-bottom:15px;padding:12px;background-color:#3a3a3a;border-radius:8px;flex-wrap:wrap}.stat-item[data-v-2b83e6ec]{font-size:14px;color:#b0b0b0;font-weight:700}.table-container[data-v-2b83e6ec]{overflow-x:auto;border-radius:8px;background-color:#3a3a3a}.whitelist-table[data-v-2b83e6ec]{width:100%;border-collapse:collapse;background-color:#3a3a3a}.whitelist-table th[data-v-2b83e6ec]{background-color:#4a4a4a;color:#e0e0e0;padding:12px 8px;text-align:left;font-weight:700;border-bottom:2px solid #555;position:sticky;top:0;z-index:1}.whitelist-table td[data-v-2b83e6ec]{padding:10px 8px;border-bottom:1px solid #555;color:#e0e0e0;font-size:13px}.active-user[data-v-2b83e6ec]{background-color:#4caf501a}.inactive-user[data-v-2b83e6ec]{background-color:#f443361a}.wechat-id[data-v-2b83e6ec]{font-family:Courier New,monospace;font-weight:700;color:#64b5f6;cursor:pointer;position:relative;transition:background-color .2s}.copy-tooltip[data-v-2b83e6ec]{position:absolute;background-color:#212121e6;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;top:50%;left:100%;transform:translate(10px,-50%);opacity:0;visibility:hidden;transition:all .2s ease;white-space:nowrap;pointer-events:none;z-index:1}.wechat-id.copy-success .copy-tooltip[data-v-2b83e6ec]{opacity:1;visibility:visible}.wechat-id.copy-success[data-v-2b83e6ec]{background-color:#4caf501a}.user-name[data-v-2b83e6ec]{font-weight:500}.status-badge[data-v-2b83e6ec]{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:700}.status-active[data-v-2b83e6ec]{background-color:#4caf5033;color:#4caf50}.status-inactive[data-v-2b83e6ec]{background-color:#f4433633;color:#f44336}.ip-address[data-v-2b83e6ec]{font-family:Courier New,monospace;font-size:12px;color:#90caf9}.ip-history-btn[data-v-2b83e6ec]{padding:4px 8px;background-color:#555;color:#e0e0e0;border:none;border-radius:4px;font-size:12px;cursor:pointer;transition:background-color .3s}.ip-history-btn[data-v-2b83e6ec]:hover{background-color:#666}.user-actions[data-v-2b83e6ec]{display:flex;gap:5px;flex-wrap:wrap}.action-btn[data-v-2b83e6ec]{padding:4px 8px;border:none;border-radius:4px;font-size:12px;cursor:pointer;transition:all .3s;font-weight:700}.edit-btn[data-v-2b83e6ec]{background-color:#428aeb;color:#fff}.delete-btn[data-v-2b83e6ec]{background-color:#f44336;color:#fff}.check-btn[data-v-2b83e6ec]{background-color:#36b027;color:#fff}.empty-row[data-v-2b83e6ec]{text-align:center;color:#999;font-style:italic;padding:30px}.whitelist-pagination[data-v-2b83e6ec]{display:flex;justify-content:center;align-items:center;gap:15px;margin-top:20px;padding:15px}.page-btn[data-v-2b83e6ec]{padding:8px 16px;background-color:#555;color:#e0e0e0;border:none;border-radius:6px;cursor:pointer;transition:background-color .3s;font-size:14px}.page-btn[data-v-2b83e6ec]:hover:not(:disabled){background-color:#666}.page-btn[data-v-2b83e6ec]:disabled{opacity:.5;cursor:not-allowed}.page-info[data-v-2b83e6ec]{font-size:14px;color:#b0b0b0;font-weight:700}.ip-history-modal[data-v-2b83e6ec]{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:10000;cursor:pointer}.ip-history-content[data-v-2b83e6ec]{background-color:#2d2d2d;border-radius:12px;padding:20px;max-width:90vw;max-height:90vh;overflow:auto;cursor:default;color:#e0e0e0}.ip-history-header[data-v-2b83e6ec]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #555}.ip-history-title[data-v-2b83e6ec]{margin:0;font-size:18px;color:#e0e0e0}.ip-history-close[data-v-2b83e6ec]{padding:8px 16px;background-color:#f44336;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:700}.ip-history-close[data-v-2b83e6ec]:hover{background-color:#d32f2f}.ip-history-table[data-v-2b83e6ec]{width:100%;border-collapse:collapse;background-color:#3a3a3a;border-radius:8px;overflow:hidden}.ip-history-table th[data-v-2b83e6ec]{background-color:#4a4a4a;color:#e0e0e0;padding:12px;text-align:left;font-weight:700;border-bottom:2px solid #555}.ip-history-table td[data-v-2b83e6ec]{padding:10px 12px;border-bottom:1px solid #555;color:#e0e0e0}.ip-record-ip[data-v-2b83e6ec]{font-family:Courier New,monospace;color:#90caf9;font-weight:700}.ip-record-count[data-v-2b83e6ec]{background-color:#555;color:#e0e0e0;padding:2px 6px;border-radius:10px;font-size:12px;font-weight:700}.ip-record-time[data-v-2b83e6ec]{font-size:13px;color:#b0b0b0}.no-ip-history[data-v-2b83e6ec]{text-align:center;color:#999;padding:40px;font-style:italic}@media (max-width: 768px){.whitelist-controls[data-v-2b83e6ec]{flex-direction:column;align-items:stretch}.whitelist-input[data-v-2b83e6ec]{min-width:unset}.whitelist-stats[data-v-2b83e6ec]{flex-direction:column;gap:10px}.table-container[data-v-2b83e6ec]{font-size:12px}.whitelist-table th[data-v-2b83e6ec],.whitelist-table td[data-v-2b83e6ec]{padding:8px 4px}.user-actions[data-v-2b83e6ec]{flex-direction:column;gap:3px}.action-btn[data-v-2b83e6ec]{font-size:11px;padding:3px 6px}.ip-history-content[data-v-2b83e6ec]{max-width:95vw;padding:15px}.ip-history-header[data-v-2b83e6ec]{flex-direction:column;gap:10px;align-items:stretch}}.admin-option[data-v-2b83e6ec]{display:flex;align-items:center;margin:10px 0}.admin-label[data-v-2b83e6ec]{display:flex;align-items:center;cursor:pointer;color:#e0e0e0;font-size:14px;font-weight:700}.admin-checkbox[data-v-2b83e6ec]{margin-right:8px;transform:scale(1.2);accent-color:#9c27b0}.admin-text[data-v-2b83e6ec]{-webkit-user-select:none;user-select:none}.disable-btn[data-v-2b83e6ec]{background-color:#ff9800;color:#fff}.disable-btn[data-v-2b83e6ec]:hover{background-color:#f57c00}.enable-btn[data-v-2b83e6ec]{background-color:#4caf50;color:#fff}.enable-btn[data-v-2b83e6ec]:hover{background-color:#45a049}.booking-tables[data-v-0449982d]{width:100%;-webkit-overflow-scrolling:touch;touch-action:pan-y}.flex-col[data-v-0449982d]{display:flex;flex-direction:column}.flex-row[data-v-0449982d]{display:flex;flex-direction:row}.flex-item[data-v-0449982d]{flex:1;min-width:0}.header-row[data-v-0449982d]{background-color:#3a3a3a;border-radius:8px 8px 0 0;border-bottom:1px solid #555}.time-row[data-v-0449982d]{border-bottom:1px solid #555}.time-row[data-v-0449982d]:last-child{border-bottom:none}.body-rows[data-v-0449982d]{background-color:#2d2d2d;border-radius:0 0 8px 8px}.schedule-table[data-v-0449982d]{width:100%;background-color:#2d2d2d;box-shadow:0 2px 10px #0000004d;border-radius:8px;overflow:hidden;margin-bottom:20px;touch-action:manipulation}.court-header[data-v-0449982d]{text-align:center;font-weight:700;padding:12px 8px;background-color:#3a3a3a;border-right:1px solid #555;color:#e0e0e0;min-height:40px;display:flex;align-items:center;justify-content:center}.court-header[data-v-0449982d]:last-child{border-right:none}.time-cell[data-v-0449982d]{border-right:1px solid #555;text-align:center;cursor:pointer;transition:all .3s;position:relative;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;gap:8px}.time-cell[data-v-0449982d]:last-child{border-right:none}.cell-info[data-v-0449982d]{cursor:pointer;width:100%;display:flex;flex-direction:column;align-items:center;gap:4px;padding:4px 8px;border-radius:6px;transition:all .3s ease}.booked .cell-info[data-v-0449982d]{color:#fff}.time-range[data-v-0449982d]{font-size:14px;font-weight:700;color:#b0b0b0;margin:12px 0 0;flex-shrink:0}.status[data-v-0449982d]{font-size:12px;padding:4px 8px;border-radius:8px;display:inline-block;margin:0;flex-shrink:0}.booking-type[data-v-0449982d]{font-size:1rem;color:#fff;font-weight:700;padding:8px 12px;position:absolute;top:0;right:0;line-height:1;min-width:20px;text-align:center;border-radius:0 0 0 8px;transition:all .3s ease;z-index:2;box-shadow:0 2px 4px #0003}.booking-type[data-v-0449982d]:hover{transform:scale(1.05);box-shadow:0 3px 6px #0000004d}.type-duikang[data-v-0449982d]{background-color:#dc2626;color:#fff;border:1px solid #b91c1c}.type-weiduikang[data-v-0449982d]{background-color:#f59e0b;color:#fff;border:1px solid #d97706}.type-lunzhuan[data-v-0449982d]{background-color:#8b5cf6;color:#fff;border:1px solid #7c3aed}.type-yangsheng[data-v-0449982d]{background-color:#059669;color:#fff;border:1px solid #047857}.type-lianqiu[data-v-0449982d]{background-color:#2563eb;color:#fff;border:1px solid #1d4ed8}.type-zengsong[data-v-0449982d]{background-color:#e11dbd;color:#fff;border:1px solid #e11dbd}.type-qita[data-v-0449982d]{background-color:#6b7280;color:#fff;border:1px solid #4b5563}.action-buttons[data-v-0449982d]{display:flex;justify-content:space-between;flex-wrap:wrap;width:100%;box-sizing:border-box;position:relative;z-index:10;pointer-events:auto;flex-shrink:0}.action-button[data-v-0449982d]{height:4rem;font-size:12px;font-weight:700;position:relative;z-index:11;pointer-events:auto;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;line-height:1;box-sizing:border-box;flex:1;min-width:0;border:none}.action-button[data-v-0449982d]:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.booking-button[data-v-0449982d]{background-color:#404040;color:#b0b0b0;min-width:50px}.booking-button.booked[data-v-0449982d]{background-color:#5a5a5a;color:#fff}.upload-button[data-v-0449982d],.view-button[data-v-0449982d],.delete-button[data-v-0449982d]{background-color:#5a5a5a;color:#fff;font-size:14px}.smart-upload[data-v-0449982d]{background:linear-gradient(135deg,#4caf50,#2196f3);font-size:12px;font-weight:700;transition:all .3s ease;position:relative;overflow:hidden}.smart-upload[data-v-0449982d]:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.smart-upload[data-v-0449982d]:hover:before{left:100%}.smart-upload[data-v-0449982d]:hover{transform:scale(1.05);box-shadow:0 4px 8px #0000004d}.file-input[data-v-0449982d]{visibility:hidden;position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}.booked .status[data-v-0449982d]{color:#fff}.booked .time-range[data-v-0449982d]{color:#e0e0e0}.available[data-v-0449982d]{background-color:#3a3a3a}.available .status[data-v-0449982d]{color:#b0b0b0}.merged-cell[data-v-0449982d]{background-color:#2e7d32;color:#fff}.desktop-table[data-v-0449982d]{display:block}.mobile-tables[data-v-0449982d]{display:none}@media (max-width: 768px){.desktop-table[data-v-0449982d]{display:none}.mobile-tables[data-v-0449982d]{display:block}.mobile-tables .schedule-table[data-v-0449982d]{margin-bottom:20px}.time-cell[data-v-0449982d]{touch-action:manipulation;-webkit-tap-highlight-color:rgba(255,255,255,.1);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.time-cell[data-v-0449982d]:active{background-color:#ffffff0d;transform:scale(.98)}.action-buttons[data-v-0449982d]{flex-direction:row;justify-content:space-between}.action-button[data-v-0449982d]{font-size:11px;flex:1;min-width:0;touch-action:manipulation;-webkit-tap-highlight-color:rgba(255,255,255,.2)}.action-button[data-v-0449982d]:active{transform:scale(.95);background-color:#ffffff1a}.time-range[data-v-0449982d]{font-size:12px;margin-top:6px;margin-bottom:6px}.status[data-v-0449982d]{font-size:10px}.booking-type[data-v-0449982d]{font-size:.8rem;padding:4px 8px}}@media (max-width: 600px){.action-buttons[data-v-0449982d]{flex-direction:row;justify-content:space-between}.action-button[data-v-0449982d]{font-size:10px;flex:1;min-width:0}.time-range[data-v-0449982d]{margin-top:8px;margin-bottom:8px}}@media (max-width: 480px){.action-buttons[data-v-0449982d]{flex-direction:row;justify-content:space-between}.action-button[data-v-0449982d]{font-size:9px;flex:1;min-width:0;margin:0}.time-range[data-v-0449982d]{font-size:11px;margin-top:4px;margin-bottom:4px}.status[data-v-0449982d]{font-size:9px}.booking-type[data-v-0449982d]{font-size:.7rem;padding:3px 6px;min-width:16px}}.modal-overlay[data-v-0449982d]{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content[data-v-0449982d]{background-color:#3a3a3a;padding:20px;border-radius:8px;box-shadow:0 4px 15px #00000080;position:relative;width:90%;max-width:400px;color:#e0e0e0;text-align:left;pointer-events:auto}.modal-content h3[data-v-0449982d]{margin-top:0;margin-bottom:20px;text-align:center}.type-options[data-v-0449982d]{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.type-options label[data-v-0449982d]{display:flex;align-items:center;cursor:pointer;padding:10px;border-radius:4px;transition:background-color .3s}.type-options label[data-v-0449982d]:hover{background-color:#4a4a4a}.type-options input[type=radio][data-v-0449982d]{margin-right:10px}.modal-actions[data-v-0449982d]{display:flex;justify-content:flex-end;gap:10px}.modal-actions button[data-v-0449982d]{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s;font-weight:700;min-width:80px}.modal-actions button[data-v-0449982d]:disabled{opacity:.5;cursor:not-allowed}.cancel-btn[data-v-0449982d]{background-color:#6c757d;color:#fff}.confirm-btn[data-v-0449982d]{background-color:#28a745;color:#fff}.modal-header[data-v-0449982d]{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:20px}.modal-header h3[data-v-0449982d]{flex:1;text-align:center;margin:0;font-size:1.2rem}.close-button[data-v-0449982d]{position:absolute;top:0;right:0;background:none;border:none;font-size:24px;color:#aaa;cursor:pointer;line-height:1;padding:0;margin:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50px;transition:all .3s}.close-button[data-v-0449982d]:hover{background-color:#ffffff1a;color:#fff}.loading-overlay[data-v-748731b5]{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:9999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.loading-container[data-v-748731b5]{background-color:#fff;padding:30px;border-radius:10px;box-shadow:0 4px 20px #0000004d;text-align:center;min-width:200px}.loading-spinner[data-v-748731b5]{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #4CAF50;border-radius:50%;animation:spin-748731b5 1s linear infinite;margin:0 auto 15px}@keyframes spin-748731b5{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text[data-v-748731b5]{color:#333;font-size:16px;font-weight:700;margin:0}.loading-subtext[data-v-748731b5]{color:#666;font-size:14px;margin:5px 0 0}@media (max-width: 480px){.loading-container[data-v-748731b5]{margin:0 20px;padding:20px;min-width:auto;max-width:90%}.loading-text[data-v-748731b5]{font-size:14px}.loading-subtext[data-v-748731b5]{font-size:12px}}#app[data-v-98cfcf94]{display:flex;flex-direction:column;min-height:100vh;margin:-10px;padding:10px}.main-content[data-v-98cfcf94]{flex:1}.app-header[data-v-98cfcf94]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 0;margin:-10px -10px 20px;text-align:center;position:relative;overflow:hidden}.app-header[data-v-98cfcf94]:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><circle cx="50" cy="50" r="40" fill="none" stroke="rgba(255,255,255,0.1)" stroke-width="2"/></svg>') repeat;opacity:.3;pointer-events:none}.app-title[data-v-98cfcf94]{font-size:28px;font-weight:700;margin:0;letter-spacing:1px;position:relative;z-index:1}.controls[data-v-98cfcf94]{display:flex;justify-content:center;align-items:center;border-radius:8px;flex-wrap:wrap;flex-direction:column;gap:10px}.footer[data-v-98cfcf94]{margin-top:24px;padding:20px;background-color:#2d2d2d;border-radius:12px;text-align:center;color:#b0b0b0;font-size:14px;line-height:1.6;flex-shrink:0}.footer-content[data-v-98cfcf94]{max-width:800px;margin:0 auto}.footer-title[data-v-98cfcf94]{font-weight:700;color:#e0e0e0;margin-bottom:8px}.footer-info[data-v-98cfcf94]{margin:5px 0;color:#b0b0b0}.footer-info a[data-v-98cfcf94]{color:#64b5f6;text-decoration:none;transition:color .3s}.footer-info a[data-v-98cfcf94]:hover{color:#90caf9}.footer-version[data-v-98cfcf94]{margin-top:15px;padding-top:15px;border-top:1px solid #555;font-size:12px;color:#888}.footer-tech[data-v-98cfcf94]{font-family:Courier New,monospace;background-color:#404040;color:#e0e0e0;padding:2px 6px;border-radius:3px;margin:0 2px}.debug-panel[data-v-98cfcf94]{margin-top:10px;padding:10px;background:#ffc1071a;border:1px dashed #ffc107;border-radius:8px;text-align:center}.debug-btn[data-v-98cfcf94]{background:#ffc107;color:#000;border:none;padding:8px 16px;border-radius:6px;font-weight:700;cursor:pointer;transition:all .3s;font-size:14px}.debug-btn[data-v-98cfcf94]:hover{background:#ffb300;transform:translateY(-2px);box-shadow:0 4px 8px #ffc1074d}.debug-btn[data-v-98cfcf94]:active{transform:translateY(0)}.debug-info[data-v-98cfcf94]{margin-top:8px;font-size:12px;color:#666;text-align:center}@media (max-width: 600px){.app-header[data-v-98cfcf94]{margin:-10px -10px 15px;padding:15px 0}.app-title[data-v-98cfcf94]{font-size:22px}.footer[data-v-98cfcf94]{padding:15px;font-size:12px}.footer-version[data-v-98cfcf94]{font-size:11px}}
