.project-sidebar[data-v-19b7c758]{width:320px;background:linear-gradient(135deg,#2c3e50 0%,#34495e 100%);color:#fff;display:flex;flex-direction:column;height:100vh;box-shadow:2px 0 12px #0000001a}.sidebar-header[data-v-19b7c758]{padding:24px;border-bottom:1px solid rgba(255,255,255,.1);background:rgba(0,0,0,.1)}.header-content h3[data-v-19b7c758]{margin:0 0 6px;font-size:18px;font-weight:600;color:#ecf0f1}.project-count[data-v-19b7c758]{font-size:13px;color:#bdc3c7;font-weight:400}.project-list[data-v-19b7c758]{flex:1;overflow-y:auto;padding:16px}.project-item[data-v-19b7c758]{display:flex;align-items:flex-start;justify-content:space-between;padding:16px;margin-bottom:12px;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid transparent;background:rgba(255,255,255,.05);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.project-item[data-v-19b7c758]:hover{background:rgba(255,255,255,.1);border-color:#3498db4d;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.project-item.active[data-v-19b7c758]{background:linear-gradient(135deg,#3498db 0%,#2980b9 100%);border-color:#3498db;box-shadow:0 4px 16px #3498db4d}.project-main[data-v-19b7c758]{display:flex;align-items:flex-start;flex:1}.project-icon[data-v-19b7c758]{font-size:20px;margin-right:14px;margin-top:2px;flex-shrink:0}.project-info[data-v-19b7c758]{flex:1;min-width:0}.project-name[data-v-19b7c758]{font-weight:600;margin-bottom:6px;font-size:14px;color:#ecf0f1;line-height:1.3}.project-description[data-v-19b7c758]{font-size:12px;color:#bdc3c7;margin-bottom:8px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-stats[data-v-19b7c758]{font-size:11px}.case-count[data-v-19b7c758]{background:rgba(255,255,255,.15);padding:4px 8px;border-radius:12px;color:#ecf0f1;font-weight:500}.btn-delete-project[data-v-19b7c758]{background:rgba(231,76,60,.1);border:1px solid rgba(231,76,60,.3);color:#e74c3c;cursor:pointer;padding:6px 8px;border-radius:6px;opacity:.7;transition:all .3s ease;flex-shrink:0;margin-left:10px;font-size:12px}.btn-delete-project[data-v-19b7c758]:hover{opacity:1;background:rgba(231,76,60,.2);border-color:#e74c3c80;transform:scale(1.05)}.create-project-section[data-v-19b7c758]{padding:20px;border-top:1px solid rgba(255,255,255,.1);background:rgba(0,0,0,.1)}.create-project-btn[data-v-19b7c758]{width:100%;background:linear-gradient(135deg,#27ae60 0%,#219955 100%);color:#fff;border:none;border-radius:10px;padding:14px 20px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;font-size:14px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #27ae604d}.create-project-btn[data-v-19b7c758]:hover{transform:translateY(-2px);box-shadow:0 4px 16px #27ae6066}.create-project-btn[data-v-19b7c758]:active{transform:translateY(0)}.sidebar-footer[data-v-19b7c758]{padding:20px;border-top:1px solid rgba(255,255,255,.1);background:rgba(0,0,0,.15)}.user-info[data-v-19b7c758]{display:flex;align-items:center}.user-avatar[data-v-19b7c758]{font-size:28px;margin-right:14px;background:rgba(255,255,255,.1);padding:8px;border-radius:12px}.user-details[data-v-19b7c758]{flex:1}.username[data-v-19b7c758]{font-weight:600;font-size:14px;color:#ecf0f1;margin-bottom:2px}.user-role[data-v-19b7c758]{font-size:12px;color:#bdc3c7;margin-bottom:10px}.approval-entry-btn[data-v-19b7c758]{width:100%;background:linear-gradient(135deg,#3498db 0%,#2980b9 100%);color:#fff;border:none;border-radius:8px;padding:10px 14px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #3498db4d}.approval-entry-btn[data-v-19b7c758]:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3498db66}.btn-icon[data-v-19b7c758]{font-size:14px}.btn-text[data-v-19b7c758]{flex:1;text-align:center}.project-list[data-v-19b7c758]::-webkit-scrollbar{width:6px}.project-list[data-v-19b7c758]::-webkit-scrollbar-track{background:rgba(255,255,255,.05);border-radius:3px}.project-list[data-v-19b7c758]::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}.project-list[data-v-19b7c758]::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.3)}.ai-modal[data-v-9343ba73]{max-width:800px;max-height:90vh;overflow-y:auto}.ai-modal-body[data-v-9343ba73]{padding:20px}.current-project[data-v-9343ba73]{background:#e3f2fd;border:1px solid #bbdefb;border-radius:8px;padding:12px 16px;margin-bottom:20px}.project-badge[data-v-9343ba73]{display:inline-flex;align-items:center;background:#2196f3;color:#fff;padding:4px 12px;border-radius:20px;font-size:14px;font-weight:700}.project-icon[data-v-9343ba73]{margin-right:6px}.project-hint[data-v-9343ba73]{font-size:12px;color:#666;margin-top:4px}.upload-area[data-v-9343ba73]{border:2px dashed #ddd;border-radius:12px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .3s ease;background:#fafafa}.upload-area[data-v-9343ba73]:hover{border-color:#3498db;background:#f0f8ff}.upload-area.has-image[data-v-9343ba73]{border-style:solid;border-color:#27ae60;padding:20px}.upload-placeholder .upload-icon[data-v-9343ba73]{font-size:48px;margin-bottom:16px;opacity:.6}.upload-placeholder h3[data-v-9343ba73]{margin:0 0 8px;color:#333}.upload-placeholder p[data-v-9343ba73]{margin:0 0 8px;color:#666}.upload-hint[data-v-9343ba73]{font-size:12px;color:#999}.image-preview[data-v-9343ba73]{position:relative}.preview-image[data-v-9343ba73]{max-width:100%;max-height:300px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.image-actions[data-v-9343ba73]{position:absolute;top:10px;right:10px}.analysis-options[data-v-9343ba73]{margin-top:20px;padding:20px;background:#f8f9fa;border-radius:8px}.analyze-btn[data-v-9343ba73]{width:100%;margin-top:16px;padding:12px;font-size:16px}.loading-spinner[data-v-9343ba73]{display:inline-block;width:16px;height:16px;border:2px solid #ffffff;border-top:2px solid transparent;border-radius:50%;animation:spin-9343ba73 1s linear infinite;margin-right:8px}@keyframes spin-9343ba73{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.analysis-result[data-v-9343ba73]{margin-top:20px}.generated-cases[data-v-9343ba73]{max-height:400px;overflow-y:auto;margin:16px 0}.generated-case[data-v-9343ba73]{background:white;border:1px solid #e9ecef;border-radius:8px;padding:16px;margin-bottom:12px;box-shadow:0 1px 3px #0000001a}.case-header[data-v-9343ba73]{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.case-id[data-v-9343ba73]{font-weight:700;color:#2c3e50}.case-priority[data-v-9343ba73]{font-size:12px;padding:2px 8px;border-radius:12px;color:#fff}.priority-high[data-v-9343ba73]{background:#e74c3c}.priority-medium[data-v-9343ba73]{background:#f39c12}.priority-low[data-v-9343ba73]{background:#27ae60}.case-description[data-v-9343ba73]{font-weight:500;margin-bottom:12px;color:#2c3e50}.case-field[data-v-9343ba73]{margin-bottom:8px}.case-field label[data-v-9343ba73]{font-weight:700;font-size:12px;color:#7f8c8d;display:block;margin-bottom:2px}.field-value[data-v-9343ba73]{font-size:14px;line-height:1.4;white-space:pre-line}.result-actions[data-v-9343ba73]{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:1px solid #e9ecef}.btn-sm[data-v-9343ba73]{padding:6px 12px;font-size:12px}.toast[data-v-25705140]{background:white;border-radius:8px;padding:16px;margin-bottom:10px;box-shadow:0 4px 12px #00000026;border-left:4px solid #3498db;display:flex;align-items:flex-start;gap:12px;animation:slideIn-25705140 .3s ease}.toast.success[data-v-25705140]{border-left-color:#27ae60}.toast.error[data-v-25705140]{border-left-color:#e74c3c}.toast.warning[data-v-25705140]{border-left-color:#f39c12}.toast.info[data-v-25705140]{border-left-color:#3498db}.toast-icon[data-v-25705140]{font-size:18px;margin-top:2px}.toast-content[data-v-25705140]{flex:1}.toast-title[data-v-25705140]{font-weight:600;margin-bottom:4px;font-size:14px}.toast-message[data-v-25705140]{font-size:13px;color:#6c757d;line-height:1.4}@keyframes slideIn-25705140{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideOut-25705140{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.modal-overlay[data-v-65c95467]{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.modal-content[data-v-65c95467]{background:white;border-radius:12px;box-shadow:0 10px 30px #0000004d;width:100%;max-width:400px;overflow:hidden;animation:modalSlideIn-65c95467 .3s ease}@keyframes modalSlideIn-65c95467{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header[data-v-65c95467]{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e9ecef;background:#f8f9fa}.modal-header h2[data-v-65c95467]{margin:0;font-size:18px;color:#2c3e50}.close-btn[data-v-65c95467]{background:none;border:none;font-size:24px;cursor:pointer;color:#6c757d;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%}.close-btn[data-v-65c95467]:hover{background:#e9ecef;color:#495057}.modal-body[data-v-65c95467]{padding:24px;color:#495057;line-height:1.5}.modal-actions[data-v-65c95467]{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e9ecef}.btn[data-v-65c95467]{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:all .3s}.btn-cancel[data-v-65c95467]{background:#6c757d;color:#fff}.btn-cancel[data-v-65c95467]:hover{background:#5a6268}.btn-confirm[data-v-65c95467]{background:#e74c3c;color:#fff}.btn-confirm[data-v-65c95467]:hover{background:#c0392b}.user-approval-container[data-v-15cdd7ed]{padding:0;background:#f8f9fa;min-height:100vh}.top-nav[data-v-15cdd7ed]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:white;border-bottom:1px solid #e9ecef}.nav-left[data-v-15cdd7ed]{display:flex;align-items:center;gap:16px}.back-btn[data-v-15cdd7ed]{background:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .3s ease}.back-btn[data-v-15cdd7ed]:hover{background:#5a6268;transform:translate(-2px)}.top-nav h1[data-v-15cdd7ed]{margin:0;font-size:20px;color:#2c3e50}.approval-content[data-v-15cdd7ed]{padding:20px;max-width:1200px;margin:0 auto}.stats-cards[data-v-15cdd7ed]{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card[data-v-15cdd7ed]{background:white;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #3498db}.stat-card.pending[data-v-15cdd7ed]{border-left-color:#f39c12}.stat-card.approved[data-v-15cdd7ed]{border-left-color:#27ae60}.stat-card.rejected[data-v-15cdd7ed]{border-left-color:#e74c3c}.stat-card.total[data-v-15cdd7ed]{border-left-color:#3498db}.stat-icon[data-v-15cdd7ed]{font-size:32px}.stat-info[data-v-15cdd7ed]{flex:1}.stat-number[data-v-15cdd7ed]{font-size:24px;font-weight:700;color:#2c3e50}.stat-label[data-v-15cdd7ed]{font-size:14px;color:#6c757d;margin-top:4px}.filter-tabs[data-v-15cdd7ed]{display:flex;gap:8px;margin-bottom:24px;background:white;padding:16px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.tab-btn[data-v-15cdd7ed]{padding:8px 16px;border:1px solid #e9ecef;border-radius:6px;background:white;cursor:pointer;transition:all .3s ease}.tab-btn[data-v-15cdd7ed]:hover{background:#f8f9fa}.tab-btn.active[data-v-15cdd7ed]{background:#3498db;color:#fff;border-color:#3498db}.users-section[data-v-15cdd7ed]{background:white;border-radius:12px;box-shadow:0 2px 8px #0000001a;max-height:500px;display:flex;flex-direction:column}.section-header[data-v-15cdd7ed]{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e9ecef;flex-shrink:0}.section-header h2[data-v-15cdd7ed]{margin:0;font-size:18px;color:#2c3e50}.header-actions[data-v-15cdd7ed]{display:flex;gap:12px}.table-container[data-v-15cdd7ed]{overflow:auto;flex:1}.user-table[data-v-15cdd7ed]{width:100%;border-collapse:collapse;min-width:800px}.user-table th[data-v-15cdd7ed],.user-table td[data-v-15cdd7ed]{padding:12px 16px;text-align:left;border-bottom:1px solid #e9ecef}.user-table th[data-v-15cdd7ed]{background:#f8f9fa;font-weight:600;color:#495057;position:sticky;top:0;z-index:10}.username-cell[data-v-15cdd7ed]{display:flex;align-items:center;gap:8px}.user-avatar[data-v-15cdd7ed]{font-size:16px}.role-badge[data-v-15cdd7ed]{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.role-badge.admin[data-v-15cdd7ed]{background:#e3f2fd;color:#1976d2}.role-badge.user[data-v-15cdd7ed]{background:#f3e5f5;color:#7b1fa2}.status-badge[data-v-15cdd7ed]{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.status-badge.pending[data-v-15cdd7ed]{background:#fff3cd;color:#856404}.status-badge.approved[data-v-15cdd7ed]{background:#d1edff;color:#0d6efd}.status-badge.rejected[data-v-15cdd7ed]{background:#f8d7da;color:#721c24}.actions[data-v-15cdd7ed]{display:flex;gap:8px}.no-action[data-v-15cdd7ed]{color:#6c757d;font-style:italic}.btn-refresh[data-v-15cdd7ed]{background:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px}.btn-refresh[data-v-15cdd7ed]:hover{background:#5a6268}.btn[data-v-15cdd7ed]{border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:all .3s ease}.btn-sm[data-v-15cdd7ed]{padding:4px 8px;font-size:11px}.btn-success[data-v-15cdd7ed]{background:#28a745;color:#fff}.btn-success[data-v-15cdd7ed]:hover:not(:disabled){background:#218838}.btn-danger[data-v-15cdd7ed]{background:#dc3545;color:#fff}.btn-danger[data-v-15cdd7ed]:hover:not(:disabled){background:#c82333}.btn[data-v-15cdd7ed]:disabled{opacity:.6;cursor:not-allowed}.loading[data-v-15cdd7ed]{text-align:center;padding:40px}.skeleton-loader[data-v-15cdd7ed]{display:flex;flex-direction:column;gap:12px}.skeleton-line[data-v-15cdd7ed]{height:20px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:loading-15cdd7ed 1.5s infinite;border-radius:4px}@keyframes loading-15cdd7ed{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state[data-v-15cdd7ed]{text-align:center;padding:60px 20px;color:#6c757d}.empty-icon[data-v-15cdd7ed]{font-size:48px;margin-bottom:16px;opacity:.5}@media (max-width: 768px){.approval-content[data-v-15cdd7ed]{padding:12px}.stats-cards[data-v-15cdd7ed]{grid-template-columns:1fr}.filter-tabs[data-v-15cdd7ed]{flex-wrap:wrap}.section-header[data-v-15cdd7ed]{flex-direction:column;gap:12px;align-items:flex-start}.actions[data-v-15cdd7ed]{flex-direction:column}}.large-modal-overlay[data-v-ac7883c5]{background:rgba(0,0,0,.7);z-index:2000}.extra-large-modal[data-v-ac7883c5]{width:95vw;height:90vh;max-width:1400px;max-height:900px;margin:5vh auto}.modal-content.extra-large-modal .modal-body[data-v-ac7883c5]{height:calc(100% - 60px);display:flex;flex-direction:column}.reports-list-container[data-v-ac7883c5]{flex:1;overflow:hidden;display:flex;flex-direction:column}.list-body[data-v-ac7883c5]{flex:1;overflow-y:auto;max-height:none}.list-header[data-v-ac7883c5]{display:grid;grid-template-columns:140px minmax(250px,1fr) 160px 100px 100px 180px;background:#343a40;color:#fff;font-weight:600;font-size:14px}.list-item[data-v-ac7883c5]{display:grid;grid-template-columns:140px minmax(250px,1fr) 160px 100px 100px 180px;border-bottom:1px solid #e9ecef;transition:background-color .2s;min-height:80px;align-items:stretch}.item-cell[data-v-ac7883c5]{padding:12px 10px;border-right:1px solid #e9ecef;display:flex;flex-direction:column;justify-content:center;overflow:hidden;word-break:break-word}.item-cell.name[data-v-ac7883c5]{padding:10px;min-width:250px}.report-name-text[data-v-ac7883c5]{font-weight:600;color:#2c3e50;margin-bottom:6px;line-height:1.4;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:14px}.report-server[data-v-ac7883c5]{font-size:12px;color:#6c757d;line-height:1.3;word-break:break-all}.item-cell.number[data-v-ac7883c5],.item-cell.date[data-v-ac7883c5],.item-cell.requests[data-v-ac7883c5],.item-cell.status[data-v-ac7883c5]{align-items:center;text-align:center;justify-content:center}.item-cell.actions[data-v-ac7883c5]{align-items:center;justify-content:center}.report-number[data-v-ac7883c5]{background:#3498db;color:#fff;padding:6px 10px;border-radius:6px;font-size:12px;font-weight:600;font-family:monospace;word-break:break-all;white-space:normal}.status-badge[data-v-ac7883c5]{padding:6px 12px;border-radius:12px;font-size:12px;font-weight:500;white-space:nowrap}.status-badge.success[data-v-ac7883c5]{background:#d1f2eb;color:#27ae60}.status-badge.failed[data-v-ac7883c5]{background:#f8d7da;color:#dc3545}.action-buttons[data-v-ac7883c5]{display:flex;gap:6px;justify-content:center;flex-wrap:nowrap}.btn-sm[data-v-ac7883c5]{padding:6px 10px;font-size:12px;min-width:50px;margin:1px}.btn-view[data-v-ac7883c5]{background:#3498db;color:#fff}.btn-edit[data-v-ac7883c5]{background:#f39c12;color:#fff}.btn-danger[data-v-ac7883c5]{background:#e74c3c;color:#fff}.btn-view[data-v-ac7883c5]:hover{background:#2980b9}.btn-edit[data-v-ac7883c5]:hover{background:#e67e22}.btn-danger[data-v-ac7883c5]:hover{background:#c0392b}.search-section[data-v-ac7883c5]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:0 10px}.search-box[data-v-ac7883c5]{display:flex;gap:10px;flex:1;max-width:400px}.search-input[data-v-ac7883c5]{flex:1;padding:10px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:14px}.filter-section[data-v-ac7883c5]{display:flex;gap:10px;align-items:center}.filter-select[data-v-ac7883c5]{padding:10px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:14px}.empty-list[data-v-ac7883c5]{grid-column:1 / -1;text-align:center;padding:60px 20px;color:#6c757d}.empty-icon[data-v-ac7883c5]{font-size:64px;margin-bottom:20px;opacity:.5}.empty-text[data-v-ac7883c5]{font-size:18px;margin-bottom:10px}.empty-desc[data-v-ac7883c5]{font-size:14px;opacity:.7}.pagination[data-v-ac7883c5]{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:20px;padding:20px;border-top:1px solid #e9ecef}.btn-pagination[data-v-ac7883c5]{padding:8px 16px;background:#3498db;color:#fff;border:none;border-radius:6px;cursor:pointer}.btn-pagination[data-v-ac7883c5]:disabled{background:#bdc3c7;cursor:not-allowed}.page-info[data-v-ac7883c5]{font-size:14px;color:#6c757d}@media (max-width: 1200px){.list-header[data-v-ac7883c5],.list-item[data-v-ac7883c5]{grid-template-columns:120px minmax(200px,1fr) 140px 90px 90px 160px}}@media (max-width: 992px){.list-header[data-v-ac7883c5],.list-item[data-v-ac7883c5]{grid-template-columns:100px minmax(150px,1fr) 120px 80px 80px 140px}.item-cell[data-v-ac7883c5]{padding:10px 6px;font-size:12px}}@media (max-width: 768px){.extra-large-modal[data-v-ac7883c5]{width:98vw;height:95vh;margin:2.5vh auto}.list-header[data-v-ac7883c5]{display:none}.list-item[data-v-ac7883c5]{display:flex;flex-direction:column;padding:16px;margin-bottom:16px;border:1px solid #e9ecef;border-radius:8px;background:white}.item-cell[data-v-ac7883c5]{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:8px 0;border-right:none;border-bottom:1px solid #f8f9fa}.item-cell[data-v-ac7883c5]:last-child{border-bottom:none;padding-bottom:0}.item-cell[data-v-ac7883c5]:before{content:attr(data-label);font-weight:600;color:#495057;min-width:80px;font-size:12px}.item-cell.number[data-v-ac7883c5]:before{content:"报告编号"}.item-cell.name[data-v-ac7883c5]:before{content:"报告名称"}.item-cell.date[data-v-ac7883c5]:before{content:"创建时间"}.item-cell.requests[data-v-ac7883c5]:before{content:"请求数"}.item-cell.status[data-v-ac7883c5]:before{content:"状态"}.item-cell.actions[data-v-ac7883c5]:before{content:"操作"}.action-buttons[data-v-ac7883c5]{justify-content:flex-end;flex-wrap:wrap}.search-section[data-v-ac7883c5]{flex-direction:column;gap:10px}.search-box[data-v-ac7883c5]{max-width:100%}}.jmeter-container[data-v-ac7883c5]{background:#f8f9fa;min-height:100vh}.fixed-progress-bar[data-v-ac7883c5]{position:fixed;top:0;left:0;right:0;z-index:1000;background:white;box-shadow:0 2px 10px #0000001a;border-bottom:1px solid #e9ecef}.progress-container[data-v-ac7883c5]{padding:12px 20px;display:flex;align-items:center;gap:15px;max-width:1000px;margin:0 auto}.progress-bar[data-v-ac7883c5]{flex:1;height:8px;background:#e9ecef;border-radius:4px;overflow:hidden}.progress-fill[data-v-ac7883c5]{height:100%;background:linear-gradient(90deg,#3498db,#27ae60);transition:width .4s ease;border-radius:4px}.progress-text[data-v-ac7883c5]{font-size:14px;font-weight:600;color:#2c3e50;min-width:150px;text-align:center}.progress-close[data-v-ac7883c5]{background:none;border:none;font-size:18px;cursor:pointer;color:#6c757d;padding:4px 8px;border-radius:4px}.progress-close[data-v-ac7883c5]:hover{background:#f8f9fa;color:#495057}.jmeter-content[data-v-ac7883c5]{padding:24px;max-width:1000px;margin:0 auto;transition:margin-top .3s ease}.jmeter-content.with-progress[data-v-ac7883c5]{margin-top:60px}.config-section[data-v-ac7883c5],.upload-section[data-v-ac7883c5],.action-section[data-v-ac7883c5]{background:white;border-radius:12px;padding:24px;margin-bottom:20px;box-shadow:0 2px 8px #0000001a}.section-header[data-v-ac7883c5]{margin-bottom:20px}.section-header h2[data-v-ac7883c5]{margin:0;font-size:18px;color:#2c3e50}.config-input[data-v-ac7883c5]{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:14px;transition:border-color .3s ease}.config-input[data-v-ac7883c5]:focus{border-color:#3498db;outline:none}.upload-area[data-v-ac7883c5]{border:2px dashed #3498db;border-radius:12px;padding:40px;text-align:center;cursor:pointer;transition:all .3s ease;background:#f8f9fa}.upload-area[data-v-ac7883c5]:hover,.upload-area.dragover[data-v-ac7883c5]{border-color:#2980b9;background:#e3f2fd}.upload-content h3[data-v-ac7883c5]{margin:0 0 8px;color:#2c3e50}.upload-content p[data-v-ac7883c5]{margin:0;color:#6c757d;font-size:14px}.upload-icon[data-v-ac7883c5]{font-size:48px;margin-bottom:16px}.file-info[data-v-ac7883c5]{display:flex;justify-content:space-between;align-items:center;background:#e3f2fd;padding:16px;border-radius:8px;margin-top:16px}.file-details[data-v-ac7883c5]{color:#2c3e50}.button-group[data-v-ac7883c5]{display:flex;gap:12px;justify-content:center}.btn[data-v-ac7883c5]{padding:12px 24px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;min-width:120px}.btn-primary[data-v-ac7883c5]{background:#3498db;color:#fff}.btn-primary[data-v-ac7883c5]:hover:not(:disabled){background:#2980b9}.btn-success[data-v-ac7883c5]{background:#27ae60;color:#fff}.btn-success[data-v-ac7883c5]:hover:not(:disabled){background:#219955}.btn-info[data-v-ac7883c5]{background:#17a2b8;color:#fff}.btn-info[data-v-ac7883c5]:hover:not(:disabled){background:#138496}.btn-clear[data-v-ac7883c5]{background:#6c757d;color:#fff;padding:8px 16px}.btn[data-v-ac7883c5]:disabled{opacity:.6;cursor:not-allowed}.btn-sm[data-v-ac7883c5]{padding:6px 12px;font-size:12px;min-width:auto}.status-message[data-v-ac7883c5]{padding:16px;border-radius:8px;margin:16px 0;text-align:center;font-weight:500}.status-message.info[data-v-ac7883c5]{background:#d1edff;color:#0d6efd;border:1px solid #b3d7ff}.status-message.success[data-v-ac7883c5]{background:#d1f2eb;color:#27ae60;border:1px solid #a3e4d7}.status-message.error[data-v-ac7883c5]{background:#f8d7da;color:#dc3545;border:1px solid #f5c6cb}.status-message.warning[data-v-ac7883c5]{background:#fff3cd;color:#856404;border:1px solid #ffeaa7}.test-info[data-v-ac7883c5],.debug-section[data-v-ac7883c5]{margin-top:20px}.info-card[data-v-ac7883c5],.debug-card[data-v-ac7883c5]{background:white;padding:20px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.info-card h3[data-v-ac7883c5],.debug-card h3[data-v-ac7883c5]{margin:0 0 16px;color:#2c3e50}.debug-links[data-v-ac7883c5]{display:flex;gap:16px;margin-top:12px;align-items:center}.debug-links a[data-v-ac7883c5]{color:#3498db;text-decoration:none;font-weight:500}.debug-links a[data-v-ac7883c5]:hover{text-decoration:underline}.top-nav[data-v-ac7883c5]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:white;border-bottom:1px solid #e9ecef;position:relative;z-index:999}.nav-left[data-v-ac7883c5]{display:flex;align-items:center;gap:16px}.back-btn[data-v-ac7883c5]{background:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .3s ease}.back-btn[data-v-ac7883c5]:hover{background:#5a6268;transform:translate(-2px)}.top-nav h1[data-v-ac7883c5]{margin:0;font-size:20px;color:#2c3e50}.modal-overlay[data-v-ac7883c5]{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content[data-v-ac7883c5]{background:white;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-width:90vw;max-height:90vh;overflow:hidden}.modal-header[data-v-ac7883c5]{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e9ecef;background:#f8f9fa}.modal-header h3[data-v-ac7883c5]{margin:0;color:#2c3e50;font-size:18px}.modal-close[data-v-ac7883c5]{background:none;border:none;font-size:24px;cursor:pointer;color:#6c757d;padding:4px;border-radius:4px}.modal-close[data-v-ac7883c5]:hover{background:#e9ecef;color:#495057}.modal-body[data-v-ac7883c5]{padding:24px;overflow-y:auto;max-height:calc(90vh - 100px)}@media (max-width: 768px){.button-group[data-v-ac7883c5]{flex-direction:column}.btn[data-v-ac7883c5]{width:100%}.upload-area[data-v-ac7883c5]{padding:24px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f5f7fa;color:#2c3e50}.app-container{height:100vh;display:flex;flex-direction:column;overflow:hidden}.main-layout{display:flex;height:100vh;overflow:hidden}.content-area{flex:1;display:flex;flex-direction:column;background:white;min-height:0;overflow:hidden}.top-nav{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;background:white;border-bottom:1px solid #e9ecef;box-shadow:0 2px 4px #0000000d;flex-shrink:0}.top-nav h1{font-size:24px;font-weight:600;color:#2c3e50}.user-area{display:flex;align-items:center;gap:16px}.username{font-weight:500;color:#5a6c7d}.logout-btn{background:#e74c3c;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;transition:background .3s}.logout-btn:hover{background:#c0392b}.ai-entry-section{padding:20px 30px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);margin:0 30px 20px;border-radius:12px;box-shadow:0 4px 15px #667eea4d;flex-shrink:0}.ai-upload-area{display:flex;align-items:center;justify-content:space-between;color:#fff;cursor:pointer;padding:20px;border:2px dashed rgba(255,255,255,.3);border-radius:8px;transition:all .3s ease}.ai-upload-area:hover{border-color:#fff9;background:rgba(255,255,255,.1)}.ai-icon{font-size:32px;margin-right:16px}.ai-text{flex:1}.ai-text h3{font-size:20px;margin-bottom:4px}.ai-text p{opacity:.9;font-size:14px}.ai-arrow{font-size:24px;opacity:.7}.cases-section{flex:1;padding:0 30px 30px;display:flex;flex-direction:column;min-height:0;overflow:hidden}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-shrink:0}.section-header h2{font-size:20px;color:#2c3e50}.filters{display:flex;gap:12px;align-items:center}.search-input{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;width:200px}.filter-select{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:white;cursor:pointer}.header-actions{display:flex;align-items:center;gap:20px}.action-buttons{display:flex;gap:10px}.btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:all .3s;text-decoration:none;display:inline-block;text-align:center;white-space:nowrap;line-height:normal!important;line-height:1.2!important;height:auto!important}.btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0003}.btn-primary{background:#3498db;color:#fff}.btn-primary:hover{background:#2980b9}.btn-danger{background:#e74c3c;color:#fff}.btn-danger:hover{background:#c0392b}.btn-success{background:#27ae60;color:#fff}.btn-success:hover{background:#219a52}.btn-export{background:#27ae60;color:#fff}.btn-export:hover:not(:disabled){background:#219a52}.btn-export:disabled{background:#95a5a6;cursor:not-allowed}.btn-batch-delete{background:#e74c3c;color:#fff}.btn-batch-delete:hover:not(:disabled){background:#c0392b}.btn-batch-delete:disabled{background:#95a5a6;cursor:not-allowed}.table-container{background:white;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow-x:auto;flex:1;min-height:0;margin-bottom:20px}.case-table{width:100%;border-collapse:collapse;table-layout:fixed;min-width:1200px}.case-table th:nth-child(1),.case-table td:nth-child(1){width:50px;min-width:50px;text-align:center}.case-table th:nth-child(2),.case-table td:nth-child(2){width:60px;min-width:60px;text-align:center}.case-table th:nth-child(3),.case-table td:nth-child(3){width:180px;min-width:180px}.case-table th:nth-child(4),.case-table td:nth-child(4){width:180px;min-width:180px}.case-table th:nth-child(5),.case-table td:nth-child(5){width:180px;min-width:180px}.case-table th:nth-child(6),.case-table td:nth-child(6){width:100px;min-width:100px}.case-table th:nth-child(7),.case-table td:nth-child(7){width:80px;min-width:80px}.case-table th:nth-child(8),.case-table td:nth-child(8){width:120px;min-width:120px}.case-table th:nth-child(9),.case-table td:nth-child(9){width:100px;min-width:100px}.case-table th:nth-child(10),.case-table td:nth-child(10){width:150px;min-width:150px}.case-table thead{position:sticky;top:0;background:#f8f9fa;z-index:10}.case-table th{padding:16px 12px;text-align:left;font-weight:600;color:#5a6c7d;border-bottom:1px solid #e9ecef;font-size:14px}.case-table td{padding:16px 12px;border-bottom:1px solid #f1f3f4;font-size:14px;vertical-align:top}.case-table tr:hover{background:#f8f9fa}.case-table tr:last-child td{border-bottom:none}.text-ellipsis-multi{word-wrap:break-word;word-break:break-all;white-space:normal;line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;max-height:4.2em}.description,.test-steps,.expected-result{max-height:60px;overflow:hidden}.description .text-ellipsis-multi,.test-steps .text-ellipsis-multi,.expected-result .text-ellipsis-multi{max-width:100%}.status-select{padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-size:13px;cursor:pointer;width:100%;min-width:100px;box-sizing:border-box}.status-select.result-testing{background:#fff3cd;border-color:#ffeaa7;color:#856404}.status-select.result-passed{background:#d1ecf1;border-color:#bee5eb;color:#0c5460}.status-select.result-failed{background:#f8d7da;border-color:#f5c6cb;color:#721c24}.status-select.result-pending{background:#e2e3e5;border-color:#d6d8db;color:#383d41}.priority-high{color:#e74c3c;font-weight:600}.priority-medium{color:#f39c12;font-weight:600}.priority-low{color:#27ae60;font-weight:600}.actions{display:flex;gap:6px;justify-content:center}.btn-sm{padding:4px 8px;font-size:12px;border-radius:4px}.loading,.empty-state{text-align:center;padding:40px 20px;color:#6c757d}.empty-state .empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-project{flex:1;display:flex;align-items:center;justify-content:center}.empty-content{text-align:center;color:#6c757d}.empty-content .empty-icon{font-size:64px;margin-bottom:20px;opacity:.5}.empty-content h3{margin-bottom:8px;font-size:20px}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:white;border-radius:12px;box-shadow:0 10px 30px #0000004d;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e9ecef;background:#f8f9fa;flex-shrink:0}.modal-header h2{margin:0;font-size:20px;color:#2c3e50}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#6c757d;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;line-height:normal!important}.close-btn:hover{background:#e9ecef;color:#495057}.modal-body{flex:1;overflow-y:auto;padding:0 24px;max-height:calc(90vh - 140px)}.modal-form{display:flex;flex-direction:column;min-height:100%}.modal-footer{flex-shrink:0;border-top:1px solid #e9ecef;background:#f8f9fa;padding:20px 24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#495057}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .3s;line-height:normal!important}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.form-group textarea{resize:vertical;min-height:80px;max-height:200px}.form-actions{display:flex!important;justify-content:flex-end!important;gap:12px!important;padding:0!important}.modal-btn{padding:10px 24px!important;border:1px solid!important;border-radius:6px!important;cursor:pointer!important;font-size:14px!important;font-weight:500!important;transition:all .3s ease!important;min-width:80px!important;display:inline-block!important;text-align:center!important;text-decoration:none!important;line-height:normal!important;line-height:1.2!important;height:auto!important;visibility:visible!important;opacity:1!important;font-family:inherit!important}.modal-btn-cancel{background:white!important;color:#6c757d!important;border-color:#6c757d!important}.modal-btn-cancel:hover{background:#6c757d!important;color:#fff!important;border-color:#6c757d!important}.modal-btn-primary{background:#007bff!important;color:#fff!important;border-color:#007bff!important}.modal-btn-primary:hover:not(:disabled){background:#0056b3!important;color:#fff!important;border-color:#0056b3!important;transform:translateY(-1px)!important;box-shadow:0 2px 4px #007bff4d!important}.modal-btn-primary:disabled{background:#6c757d!important;color:#fff!important;border-color:#6c757d!important;cursor:not-allowed!important;opacity:.6!important;transform:none!important;box-shadow:none!important}.char-count{text-align:right;font-size:12px;color:#6c757d;margin-top:4px}.pagination-controls{display:flex;flex-direction:column;gap:12px;padding:15px;background:#f8f9fa;border-radius:8px;border:1px solid #e1e5e9;margin-top:0}.pagination-info{color:#495057;font-size:14px;font-weight:500;text-align:left}.pagination-buttons{display:flex;flex-direction:column;gap:12px}.pagination-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.page-navigation{display:flex;align-items:center;gap:8px}.page-size-control{display:flex;align-items:center;gap:8px;margin-left:auto}.btn-pagination{padding:8px 16px;border:1px solid #007bff;background:white;color:#007bff;border-radius:6px;cursor:pointer;font-size:14px;transition:all .3s ease;line-height:normal!important}.btn-pagination:hover:not(:disabled){background:#007bff;color:#fff}.btn-pagination:disabled{background:#f8f9fa;color:#6c757d;border-color:#dee2e6;cursor:not-allowed}.page-info{font-size:14px;color:#495057;margin:0 15px;font-weight:500}.page-size-select{padding:8px 12px;border:1px solid #dee2e6;border-radius:6px;background:white;font-size:14px;color:#495057}.page-size-label{font-size:14px;color:#495057;white-space:nowrap}.skeleton-loader{padding:10px}.skeleton-line{height:20px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite;border-radius:4px;margin-bottom:8px}.skeleton-line:last-child{margin-bottom:0}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.toast-container{position:fixed;top:20px;right:20px;z-index:1100;max-width:400px}.toast{background:white;border-radius:8px;padding:16px;margin-bottom:10px;box-shadow:0 4px 12px #00000026;border-left:4px solid #3498db;display:flex;align-items:flex-start;gap:12px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast.success{border-left-color:#27ae60}.toast.error{border-left-color:#e74c3c}.toast.warning{border-left-color:#f39c12}.toast.info{border-left-color:#3498db}.toast-icon{font-size:18px;margin-top:2px}.toast-content{flex:1}.toast-title{font-weight:600;margin-bottom:4px;font-size:14px}.toast-message{font-size:13px;color:#6c757d;line-height:1.4}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.modal-body::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.modal-body::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width: 768px){.main-layout{flex-direction:column}.top-nav{flex-direction:column;gap:16px;align-items:flex-start}.filters{flex-wrap:wrap}.search-input{width:100%}.ai-entry-section{margin:0 15px 15px}.cases-section{padding:0 15px 15px}.section-header{flex-direction:column;align-items:flex-start;gap:12px}.actions{flex-direction:column}.modal-content{margin:10px;max-height:calc(100vh - 20px)}.form-actions{flex-direction:column}.modal-btn{width:100%}.pagination-row{flex-direction:column;align-items:flex-start;gap:10px}.page-size-control{margin-left:0}}@media (max-width: 480px){.pagination-controls{margin:5px 0;padding:10px}.pagination-info,.page-info{font-size:13px}.btn-pagination{padding:6px 12px;font-size:13px}.modal-content{max-height:95vh}.modal-body{max-height:calc(95vh - 140px)}}.ai-analysis-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.ai-analysis-modal .modal-content{background:white;border-radius:12px;box-shadow:0 10px 30px #0000004d;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease;margin:0 auto}.login-container{display:flex;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:20px}.login-card{background:white;padding:2.5rem;border-radius:12px;box-shadow:0 20px 40px #0000001a;width:100%;max-width:400px;animation:slideUp .5s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}div.modal-overlay{position:fixed!important;top:0!important;left:0!important;width:100%!important;height:100%!important;background:rgba(0,0,0,.5)!important;display:flex!important;align-items:center!important;justify-content:center!important;z-index:9999!important;padding:20px!important;margin:0!important}div.ai-modal{position:relative!important;margin:auto!important;max-width:800px!important;width:100%!important;background:white!important;border-radius:12px!important;box-shadow:0 10px 30px #0000004d!important;max-height:90vh!important;overflow:hidden!important}.modal-overlay,.ai-modal{transform:none!important}.modal-overlay{display:flex!important;align-items:center!important;justify-content:center!important}.btn-delete-project{background:none;border:none;cursor:pointer;padding:6px;border-radius:4px;opacity:.6;transition:all .3s;font-size:14px}.btn-delete-project:hover{opacity:1;background-color:#ffebee;color:#d32f2f;transform:scale(1.1)}.project-item{transition:all .3s ease}.project-item:hover .btn-delete-project{opacity:.8}.nav-left[data-v-350f6287]{display:flex;align-items:center;gap:32px}.nav-links[data-v-350f6287]{display:flex;gap:8px}.nav-link[data-v-350f6287]{padding:8px 16px;border:1px solid #e9ecef;border-radius:6px;background:white;cursor:pointer;transition:all .3s ease;font-size:14px}.nav-link[data-v-350f6287]:hover{background:#f8f9fa}.nav-link.active[data-v-350f6287]{background:#3498db;color:#fff;border-color:#3498db}.user-role[data-v-350f6287]{font-size:12px;opacity:.8;margin-left:4px}.login-container{display:flex;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:20px;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent,rgba(255,255,255,.1),transparent);animation:shine 6s infinite linear}@keyframes shine{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-card{background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:3rem 2.5rem;border-radius:20px;box-shadow:0 25px 50px #00000026;width:100%;max-width:420px;animation:slideUp .6s ease;position:relative;z-index:2;border:1px solid rgba(255,255,255,.2)}@keyframes slideUp{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.login-header{text-align:center;margin-bottom:2.5rem}.login-logo{font-size:3rem;margin-bottom:1rem;display:block}.login-title{font-size:1.75rem;font-weight:700;color:#2c3e50;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{color:#6c757d;font-size:.95rem;font-weight:400}.login-form-group{margin-bottom:1.5rem;position:relative}.login-form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#495057;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.login-input-wrapper{position:relative}.login-input-wrapper input{width:100%;padding:.875rem 1rem .875rem 3rem;border:2px solid #e9ecef;border-radius:12px;font-size:1rem;transition:all .3s ease;background:#f8f9fa;color:#2c3e50;font-weight:500}.login-input-wrapper input:focus{outline:none;border-color:#667eea;background:white;box-shadow:0 0 0 4px #667eea1a;transform:translateY(-1px)}.login-input-wrapper:before{position:absolute;left:1rem;top:50%;transform:translateY(-50%);font-size:1.1rem;color:#6c757d;z-index:3}.login-input-wrapper.username:before{content:"👤"}.login-input-wrapper.password:before{content:"🔒"}.login-btn{width:100%;padding:1rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:1rem;position:relative;overflow:hidden}.login-btn: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}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 25px #667eea66}.login-btn:hover:not(:disabled):before{left:100%}.login-btn:active{transform:translateY(0)}.login-btn:disabled{background:#95a5a6;cursor:not-allowed;transform:none;box-shadow:none}.login-btn:disabled:before{display:none}.login-loading{display:inline-block;width:16px;height:16px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-right:8px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-error{color:#e74c3c;text-align:center;margin-top:1rem;padding:.875rem;background:linear-gradient(135deg,#ffeaea 0%,#ffd5d5 100%);border:1px solid #fbd5d5;border-radius:10px;font-size:.9rem;font-weight:500;animation:shake .5s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.login-footer{text-align:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e9ecef;color:#6c757d;font-size:.85rem}.login-version{opacity:.7;margin-top:.5rem}.floating-elements{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.floating-element{position:absolute;background:rgba(255,255,255,.1);border-radius:50%;animation:float 6s ease-in-out infinite}.floating-element:nth-child(1){width:80px;height:80px;top:10%;left:10%;animation-delay:0s}.floating-element:nth-child(2){width:60px;height:60px;top:70%;left:80%;animation-delay:-2s}.floating-element:nth-child(3){width:100px;height:100px;top:40%;left:85%;animation-delay:-4s}.floating-element:nth-child(4){width:50px;height:50px;top:80%;left:15%;animation-delay:-1s}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(180deg)}}@media (max-width: 480px){.login-container{padding:15px}.login-card{padding:2.5rem 1.5rem;border-radius:16px}.login-title{font-size:1.5rem}.login-logo{font-size:2.5rem}.floating-element{display:none}}@media (prefers-color-scheme: dark){.login-card{background:rgba(40,44,52,.95);border-color:#ffffff1a}.login-title{color:#fff}.login-subtitle{color:#a0a0a0}.login-form-group label{color:#d0d0d0}.login-input-wrapper input{background:#2c3e50;border-color:#34495e;color:#fff}.login-input-wrapper input:focus{background:#34495e}.login-input-wrapper:before{color:#a0a0a0}}.login-footer-actions{text-align:center;margin-top:20px;padding-top:20px;border-top:1px solid #e9ecef}.register-link{color:#667eea;cursor:pointer;font-size:14px;text-decoration:none;transition:color .3s ease}.register-link:hover{color:#764ba2;text-decoration:underline}.register-hint{font-size:12px;color:#6c757d;margin-top:4px}@media (max-width: 480px){.login-footer-actions{margin-top:15px;padding-top:15px}.register-link{font-size:13px}}
