.file-upload-container{width:100%}.file-upload-area{border:2px dashed #ccc;border-radius:8px;padding:3rem;text-align:center;transition:all .3s ease;background:#fafafa;cursor:pointer}.file-upload-area:hover{border-color:#667eea;background:#f0f0ff}.file-upload-area.drag-active{border-color:#667eea;background:#e8e8ff;transform:scale(1.02)}.file-upload-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.upload-icon{width:48px;height:48px;color:#667eea}.upload-text{color:#666;font-size:1rem}.upload-button{background:#667eea;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:background .2s}.upload-button:hover{background:#5568d3}.config-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#333;font-size:.95rem}.form-input{padding:.75rem;border:2px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .2s}.form-input:focus{outline:none;border-color:#667eea}.form-input.disabled{background:#f5f5f5;cursor:not-allowed;color:#666}.form-group small{color:#666;font-size:.85rem;margin-top:-.25rem}.progress-display{background:#fff;border-radius:8px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.progress-display h3{margin-bottom:1rem;color:#333}.progress-bar-container{width:100%;height:30px;background:#e0e0e0;border-radius:15px;overflow:hidden;position:relative;margin-bottom:1rem}.progress-bar{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease;display:flex;align-items:center;justify-content:center;position:relative}.progress-text{color:#fff;font-weight:600;font-size:.9rem;text-shadow:0 1px 2px rgba(0,0,0,.2)}.progress-info{text-align:center;color:#666;font-size:.95rem}.results-list{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 8px #0000001a}.results-list h3{margin-bottom:1.5rem;color:#333}.results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.result-card{border:2px solid #ddd;border-radius:8px;padding:1rem;transition:transform .2s,box-shadow .2s}.result-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.result-card.success{border-color:#4caf50;background:#f1f8f4}.result-card.error{border-color:#f44336;background:#fff5f5}.result-card.processing{border-color:#ff9800;background:#fff8f0}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #ddd}.result-index{font-weight:600;color:#666}.result-status{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.result-status.success{background:#4caf50;color:#fff}.result-status.error{background:#f44336;color:#fff}.result-status.processing{background:#ff9800;color:#fff}.result-content{display:flex;flex-direction:column;gap:.5rem;font-size:.9rem}.result-content p{margin:0;color:#555}.result-content strong{color:#333}.validation-info{margin-top:.5rem;padding:.75rem;background:#f9f9f9;border-radius:4px}.validation-info ul{margin:.5rem 0 0 1.5rem;padding:0}.validation-info li{margin:.25rem 0}.error-message{color:#f44336!important;margin-top:.5rem;padding:.5rem;background:#ffebee;border-radius:4px}.logs-display{background:#1e1e1e;border-radius:8px;padding:1rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a;color:#d4d4d4;font-family:Consolas,Monaco,Courier New,monospace;font-size:.9rem}.logs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #3e3e3e}.logs-header h3{margin:0;color:#fff;font-size:1rem}.connection-status{font-size:.85rem;padding:.25rem .75rem;border-radius:12px;font-weight:500}.connection-status.connected{color:#4caf50;background:#4caf501a}.connection-status.disconnected{color:#f44336;background:#f443361a}.logs-content{max-height:400px;overflow-y:auto;padding:.5rem 0}.logs-content::-webkit-scrollbar{width:8px}.logs-content::-webkit-scrollbar-track{background:#2e2e2e;border-radius:4px}.logs-content::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.logs-content::-webkit-scrollbar-thumb:hover{background:#666}.logs-empty{text-align:center;color:#888;padding:2rem}.log-entry{display:flex;gap:1rem;padding:.5rem;margin-bottom:.25rem;border-left:3px solid transparent;transition:background .2s}.log-entry:hover{background:#ffffff0d}.log-time{color:#888;min-width:80px;font-size:.85rem}.log-message{flex:1;white-space:pre-wrap;word-break:break-word}.log-info{border-left-color:#2196f3;color:#d4d4d4}.log-success{border-left-color:#4caf50;color:#a5d6a7}.log-error{border-left-color:#f44336;color:#ef9a9a}.log-warning{border-left-color:#ff9800;color:#ffcc80}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;text-align:center;box-shadow:0 2px 10px #0000001a}.app-header h1{font-size:2rem;margin-bottom:.5rem}.app-header p{opacity:.9;font-size:1rem}.app-main{flex:1;padding:2rem}.app-container{max-width:1200px;margin:0 auto}section{background:#fff;border-radius:8px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}section h2{color:#333;margin-bottom:1.5rem;font-size:1.5rem;border-bottom:2px solid #667eea;padding-bottom:.5rem}.file-info{margin-top:1rem;padding:1rem;background:#f0f0f0;border-radius:4px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;width:100%;font-weight:600}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.actions-section{text-align:center}.actions-buttons{display:flex;gap:1rem;justify-content:center;align-items:center}.btn-cancel{background:#f44336;color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;font-weight:600}.btn-cancel:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f4433666;background:#d32f2f}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333}#root{min-height:100vh}
