.progress-display{width:100%}.progress-extracting .ant-progress-bg{background:linear-gradient(45deg,#ff9800,#ffc107)!important;animation:pulse 2s infinite}.progress-analyzing .ant-progress-bg{background:linear-gradient(45deg,#2196f3,#03a9f4)!important}.progress-completed .ant-progress-bg{background:linear-gradient(45deg,#4caf50,#8bc34a)!important}.progress-error .ant-progress-bg{background:linear-gradient(45deg,#ff4d4f,#ff7875)!important}@keyframes pulse{0%{opacity:.8;filter:brightness(1)}50%{opacity:1;filter:brightness(1.2)}to{opacity:.8;filter:brightness(1)}}.phase-indicator{font-size:.9em;color:#666;font-style:italic;margin-left:8px;font-weight:500}.progress-text-container{margin-top:8px;display:flex;flex-direction:column;gap:4px}.progress-text{font-size:14px;font-weight:500;color:#262626}.status-text{font-size:12px;color:#555;font-weight:500;line-height:1.4}.progress-content{display:flex;align-items:center;justify-content:center;gap:4px}.progress-extracting .progress-content .anticon{animation:extracting-rotate 2s linear infinite}@keyframes extracting-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.progress-analyzing .progress-content .anticon{animation:analyzing-pulse 1.5s ease-in-out infinite}@keyframes analyzing-pulse{0%,to{transform:scale(1);color:#2196f3}50%{transform:scale(1.1);color:#03a9f4}}.progress-completed .progress-content .anticon{color:#52c41a}.progress-display{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:20px;margin:16px 0}.progress-display.loading{background:#f8f9fa;border:1px solid #e9ecef}.progress-display.error{background:#f8f9fa;border:1px solid #dc3545}.connection-status{display:flex;align-items:center;gap:8px;padding:4px 12px;border-radius:16px;font-size:12px;font-weight:500}.connection-status.connected{background-color:#e8f5e8;color:#2d5a2d}.connection-status.polling,.connection-status.reconnecting{background-color:#fff3cd;color:#856404}.connection-status.error{background-color:#f8d7da;color:#721c24}.connection-status.completed{background-color:#e8f5e8;color:#2d5a2d}.status-indicator{width:8px;height:8px;border-radius:50%;animation:none}.connection-status.connected .status-indicator{background-color:#28a745;animation:pulse 2s infinite}.connection-status.polling .status-indicator{background-color:#ffc107;animation:blink 1.5s infinite}.connection-status.reconnecting .status-indicator{background-color:#fd7e14;animation:spin 1s linear infinite}.connection-status.error .status-indicator{background-color:#dc3545}.progress-bar-container{position:relative;height:24px;background-color:#e9ecef;border-radius:12px;overflow:hidden;margin-bottom:8px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#28a745,#20c997);border-radius:12px;transition:width .3s ease;position:relative}.progress-bar-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 2s infinite}.realtime-pulse{display:flex;align-items:center;gap:8px;margin-top:12px;padding:8px 12px;background-color:#e8f5e8;border-radius:6px;font-size:12px;color:#2d5a2d}.pulse-dot{width:6px;height:6px;border-radius:50%;background-color:#28a745;animation:pulse 1.5s infinite}.loading-indicator{display:flex;align-items:center;gap:12px;padding:20px;text-align:center}.spinner{width:20px;height:20px;border:2px solid #e9ecef;border-left-color:#007bff;border-radius:50%;animation:spin 1s linear infinite}.error-message{display:flex;align-items:center;justify-content:space-between;padding:16px;background-color:#f8d7da;color:#721c24;border-radius:6px}.error-message button{background:#dc3545;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.95)}}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:.3}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(200%)}}@media(max-width:768px){.progress-display{padding:16px;margin:12px 0}.progress-text{font-size:13px}.status-text{font-size:11px}.phase-indicator{font-size:.8em}.connection-status{font-size:11px;padding:3px 8px}}.page-container{padding:12px}.job-filename{display:inline-block;max-width:66vw;overflow:hidden;text-overflow:ellipsis;vertical-align:middle}.ant-list-item-meta-title{display:flex;align-items:center;gap:12px}.ant-list-item-meta-description{width:100%}.jd-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:12px;flex-wrap:wrap}.jd-title{margin:0 0 8px;white-space:normal;flex:0 0 100%}.jd-action{width:auto}.jd-actions{display:flex;gap:8px;flex-wrap:wrap}@media(max-width:768px){.job-filename{max-width:70vw}}@media(max-width:480px){.job-filename{max-width:72vw}.ant-statistic{text-align:center}.ant-statistic-title{font-size:12px}.ant-statistic-content-value{font-size:18px}.ant-card-body{padding:12px}.ant-btn{height:32px;padding:0 10px;font-size:12px}.nav-menu,.connection-status{font-size:12px}}.app-layout{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.app-header{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.1);padding:0 2rem;height:80px;display:flex;align-items:center}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:1200px;margin:0 auto}.app-title{color:#fff!important;margin:0!important;font-weight:600}.language-switcher{margin-left:1rem}.app-content{padding:2rem;min-height:calc(100vh - 80px)}.content-wrapper{max-width:1200px;margin:0 auto;background:#fffffff2;border-radius:12px;padding:2rem;box-shadow:0 8px 32px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-height:calc(100vh - 144px)}.navigation{display:flex;align-items:center;gap:1rem}.nav-menu{background:transparent!important;border:none!important;line-height:80px;flex:0 0 auto;min-width:0;white-space:nowrap}.nav-menu .ant-menu-item{color:#fffc!important;border-bottom:2px solid transparent!important}.nav-menu .ant-menu-item:hover,.nav-menu .ant-menu-item-selected{color:#fff!important;border-bottom-color:#fff!important;background:#ffffff1a!important}.connection-status{display:flex;align-items:center;gap:.5rem;color:#fffc;font-size:.875rem}.status-indicator{width:8px;height:8px;border-radius:50%;background:#52c41a}.status-indicator.disconnected{background:#ff4d4f}.upload-container{text-align:center;padding:2rem 0}.upload-area{border:2px dashed #d9d9d9;border-radius:8px;background:#fafafa;padding:3rem;margin:2rem 0;transition:all .3s;cursor:pointer}.upload-area:hover,.upload-area.dragover{border-color:#1890ff;background:#f0f8ff}.upload-icon{font-size:3rem;color:#1890ff;margin-bottom:1rem}.upload-text{font-size:1.1rem;color:#666;margin-bottom:.5rem}.upload-hint{color:#999;font-size:.9rem}.job-card{margin-bottom:1rem;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000000f}.job-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.job-filename{font-weight:600;font-size:1.1rem;color:#262626}.job-status{display:flex;align-items:center;gap:.5rem}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.job-progress{margin:1rem 0}.job-actions{display:flex;gap:.5rem;margin-top:1rem}.job-meta{display:flex;justify-content:space-between;align-items:center;color:#666;font-size:.875rem;margin-top:1rem}.progress-container{background:#fff;border-radius:8px;padding:1.5rem;margin:1rem 0;border:1px solid #f0f0f0}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.progress-title{font-weight:600;color:#262626}.progress-percentage{font-weight:600;color:#1890ff}@media(max-width:768px){.app-header{padding:0 1rem}.header-content{flex-direction:column;gap:1rem;height:auto;padding:1rem 0}.app-content,.content-wrapper{padding:1rem}.job-header{flex-direction:column;gap:1rem;align-items:flex-start}.job-meta{flex-direction:column;gap:.5rem;align-items:flex-start}}.monitoring-dashboard{padding:24px;background-color:#f5f5f5;min-height:calc(100vh - 64px)}.monitoring-dashboard .ant-card{box-shadow:0 2px 8px #0000001a;border-radius:8px}.monitoring-dashboard .ant-statistic-title{font-size:14px;color:#8c8c8c}.monitoring-dashboard .ant-statistic-content{font-size:24px;font-weight:600}.monitoring-dashboard .ant-progress-text{font-size:12px}.monitoring-dashboard .ant-tag{border-radius:4px;font-weight:500}.monitoring-dashboard .ant-card-head-title{font-weight:600;color:#262626}.monitoring-dashboard .ant-typography h5{color:#262626;font-weight:600}.monitoring-dashboard .ant-space{gap:8px}.monitoring-dashboard .ant-btn-link{padding:0;height:auto;font-size:12px}.service-health-grid .ant-col{margin-bottom:16px}.service-health-grid .ant-card{transition:all .3s ease}.service-health-grid .ant-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.metrics-summary-grid .ant-col{margin-bottom:16px}.metrics-summary-grid .ant-card{text-align:center;transition:all .3s ease}.metrics-summary-grid .ant-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}@media(max-width:768px){.monitoring-dashboard{padding:16px}.monitoring-dashboard .ant-statistic-content{font-size:20px}.monitoring-dashboard .ant-card{margin-bottom:16px}}@media(max-width:576px){.monitoring-dashboard{padding:12px}.monitoring-dashboard .ant-statistic-content{font-size:18px}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}*{box-sizing:border-box}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}#root{width:100%;max-width:1200px;margin:0 auto;padding:2rem;text-align:center}.upload-area{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;border:2px dashed rgba(255,255,255,.3);padding:3rem;margin:2rem 0;transition:all .3s ease}.upload-area:hover{border-color:#fff9;background:#ffffff26}.upload-area.dragover{border-color:#1890ff;background:#1890ff1a}.progress-container{background:#fffffff2;border-radius:8px;padding:1.5rem;margin:1rem 0;box-shadow:0 4px 6px #0000001a}.job-card{background:#fffffff2;border-radius:8px;padding:1.5rem;margin:1rem 0;box-shadow:0 4px 6px #0000001a;text-align:left}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500;text-transform:uppercase}.status-uploading{background:#e6f7ff;color:#1890ff}.status-processing{background:#fff7e6;color:#fa8c16}.status-completed{background:#f6ffed;color:#52c41a}.status-error{background:#fff2f0;color:#ff4d4f}
