*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.flex-center{display:flex;align-items:center;justify-content:center}.container-xl{max-width:1115px;width:100%;background:hsla(0,0%,100%,.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 20px 40px rgba(0,0,0,.1);padding:40px;margin:0 auto}.heading-gradient{font-size:2.5rem;font-weight:700;text-align:center;margin-bottom:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.instructions-box{background:linear-gradient(135deg,#f8f9ff,#e8f2ff);padding:20px;border-radius:15px;margin-bottom:30px;border-left:4px solid #667eea}.file-section{margin-bottom:15px;padding:20px;border:2px dashed #ddd;border-radius:15px;transition:all .3s ease}.file-section:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 10px 20px rgba(0,0,0,.1)}.file-label{font-weight:600;color:#333;margin-bottom:10px;font-size:1.1em}.file-input{width:100%;padding:12px;border:2px solid #e1e5e9;border-radius:10px;font-size:16px;transition:all .3s ease;background:#fff}.file-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px rgba(102,126,234,.1)}.file-input.valid{border-color:#28a745;background:#f8fff9}.file-info{margin-top:8px;font-size:.9em;color:#666;font-style:italic}.process-btn{width:100%;padding:15px;border-radius:15px;font-size:18px;margin-top:30px;display:flex;align-items:center;justify-content:center}.btn-enabled{background:linear-gradient(135deg,#667eea,#764ba2)}.btn-enabled:hover{transform:translateY(-2px);box-shadow:0 15px 30px rgba(102,126,234,.4)}.btn-disabled{background:#ccc;cursor:not-allowed}.spinner{display:inline-block;width:20px;height:20px;border-radius:50%;border:3px solid #fff;border-top-color:transparent;animation:spin 1s ease-in-out infinite;margin-right:10px}.progress-container{width:100%;height:8px;background:#e9ecef;border-radius:4px;margin-top:15px;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.status-message{margin-top:20px;padding:15px;border-radius:10px;text-align:center;font-weight:500}.status-success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.status-error{background:#f8d7da;color:#721c24;border:1px solid #f5c2c7}.status-info{background:#cce7ff;color:#004085;border:1px solid #99d1ff}.container{max-width:1200px;margin:0 auto;background:#fff;border-radius:20px;box-shadow:0 20px 40px rgba(0,0,0,.1);overflow:hidden}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:30px;text-align:center}.user-info{text-align:right;padding:10px 20px;color:#fff;font-size:.9em}.header h1{font-size:2.5em;margin-bottom:10px;font-weight:700}.header p{font-size:1.1em;opacity:.9}.main-content{padding:40px}.steps{display:flex;justify-content:space-between;margin-bottom:40px;position:relative}.step{flex-direction:column;text-align:center;z-index:2}.step,.step-number{display:flex;align-items:center}.step-number{width:50px;height:50px;border-radius:50%;background:#e0e0e0;justify-content:center;font-weight:700;margin-bottom:10px;transition:all .3s ease}.step.active .step-number{background:#667eea;color:#fff;transform:scale(1.1)}.step.completed .step-number{background:#4caf50;color:#fff}.upload-card{border:3px dashed #ddd;border-radius:15px;padding:30px;text-align:center;transition:all .3s ease;background:#fafafa;cursor:pointer}.upload-card:hover{border-color:#667eea;background:#f8f9ff;transform:translateY(-5px)}.upload-card.has-file{border-color:#4caf50;background:#f8fff8}.file-input{display:none}.upload-icon{font-size:3em;margin-bottom:15px;color:#667eea}.upload-text{font-size:1.1em;color:#666;margin-bottom:15px}.file-status{margin-top:15px;padding:10px;border-radius:8px;font-weight:500;white-space:pre-line}.file-status.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.file-status.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.process-section{display:flex;flex-direction:column;align-items:center;justify-content:center;margin:30px 0;gap:20px}.process-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:15px 30px;font-size:1.1em;border-radius:25px;cursor:pointer;transition:all .3s ease;font-weight:600;min-width:250px}.process-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px rgba(102,126,234,.3)}.process-btn:disabled{background:#ccc;cursor:not-allowed}.download-btn{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;padding:15px 30px;font-size:1.1em;border-radius:25px;cursor:pointer;margin-left:15px;font-weight:600;display:none}.download-btn:hover{transform:translateY(-2px);box-shadow:0 10px 20px rgba(76,175,80,.3)}.progress-bar{width:100%;height:8px;background:#f0f0f0;border-radius:4px;margin:20px 0;overflow:hidden;display:none}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);width:0;transition:width .3s ease}.loading-spinner{display:none;margin:20px auto;width:50px;height:50px;border:5px solid #f3f3f3;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.processing-log{max-height:300px;overflow-y:auto;font-family:Courier New,monospace;font-size:.9em}.data-preview,.processing-log{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:20px;margin:20px 0;display:none}.data-preview{overflow-x:auto}.preview-table{width:100%;border-collapse:collapse;margin-top:10px}.preview-table td,.preview-table th{border:1px solid #ddd;padding:8px;text-align:left;font-size:.9em}.preview-table th{background:#f2f2f2;font-weight:700}.file-input-container{position:relative;width:100%}.file-badge{top:50%;transform:translateY(-50%);max-width:60%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-badge-icon{width:18px;height:18px;background:#28a745;color:#fff;border-radius:50%;margin-right:8px;font-size:12px}.file-badge-icon,.file-clear-btn{display:inline-flex;align-items:center;justify-content:center}.file-clear-btn{background:transparent;color:#555;border:none;width:20px;height:20px;border-radius:50%;margin-left:8px;cursor:pointer;font-size:16px;font-weight:700}.file-clear-btn:hover{background:rgba(0,0,0,.1)}.results-section{margin-top:30px;padding:20px;background:#f9f9ff;border-radius:15px;border-left:4px solid #667eea}.results-list{max-height:300px;overflow-y:auto;margin-top:10px}.result-item{display:flex;justify-content:space-between;align-items:center;padding:10px 15px;background:#fff;border-radius:8px;margin-bottom:8px;box-shadow:0 2px 5px rgba(0,0,0,.05)}.result-name{font-size:14px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70%}.file-drop-area{position:relative;width:100%;min-height:150px;border:2px dashed #ddd;border-radius:15px;display:flex;align-items:center;justify-content:center;padding:20px;transition:all .3s ease;cursor:pointer;background:#f9f9f9}.file-drop-area:hover{border-color:#667eea;background:#f5f7ff}.file-drop-area.dragging{border-color:#667eea;background:#eef1ff;transform:scale(1.02)}.file-drop-area.valid{border-color:#28a745;background:#f8fff9}.file-drop-content{display:flex;flex-direction:column;align-items:center;text-align:center}.file-drop-icon{font-size:2.5rem;margin-bottom:10px;color:#667eea}.file-drop-text{color:#555;margin-bottom:15px;font-size:1rem;line-height:1.5}.file-drop-subtext{display:inline-block;margin:5px 0;color:#888;font-size:.9rem}.file-select-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:8px 20px;border-radius:30px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease;position:relative;overflow:hidden}.file-select-btn:hover{transform:translateY(-2px);box-shadow:0 10px 20px rgba(102,126,234,.3)}.file-input-hidden{position:absolute;opacity:0;width:0;height:0;z-index:-1}.file-badge{position:absolute;top:10px;right:10px;display:flex;align-items:center;background:rgba(40,167,69,.15);padding:5px 10px;border-radius:20px;font-size:14px;color:#28a745;z-index:2}@media (max-width:768px){.upload-section{grid-template-columns:1fr}.steps{flex-direction:column;align-items:center}.step{margin-bottom:20px}.container-xl{padding:20px}.heading-gradient{font-size:2rem}.file-section{padding:15px}.file-badge{max-width:50%}.file-drop-area{min-height:120px}.file-drop-icon{font-size:2rem}.file-drop-text{font-size:.9rem}.file-select-btn{padding:6px 16px;font-size:.8rem}}.error-message{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;margin-bottom:20px;display:none}.debug-info,.error-message{padding:10px;border-radius:8px}.debug-info{background:#e2f3f5;margin-top:10px;font-family:monospace;font-size:.85em;white-space:pre-wrap;overflow-x:auto;max-height:150px}.horizontal-upload-container{display:flex;flex-direction:row;gap:20px;margin:30px 0;width:100%;flex-wrap:wrap}.upload-section{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:30px;width:100%}@media (max-width:992px){.upload-section{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.upload-section{grid-template-columns:1fr}}