*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}#root{width:100%;max-width:600px}.container{background:#fff;border-radius:16px;padding:40px;box-shadow:0 20px 60px #0000004d}.header{text-align:center;margin-bottom:40px}.header h1{color:#2d3748;font-size:28px;margin-bottom:8px}.header p{color:#718096;font-size:14px}.form-group{margin-bottom:24px}.form-group label{display:block;color:#2d3748;font-weight:600;margin-bottom:8px;font-size:14px}.form-group select{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:16px;background:#fff;cursor:pointer;transition:all .2s}.form-group select:hover{border-color:#cbd5e0}.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.tabs{display:flex;border-bottom:2px solid #e2e8f0;margin-bottom:28px}.tab{padding:10px 24px;background:none;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;font-size:14px;font-weight:600;color:#a0aec0;cursor:pointer;transition:all .2s}.tab:hover{color:#667eea}.tab-active{color:#667eea;border-bottom-color:#667eea}.drop-zone{border:2px dashed #cbd5e0;border-radius:12px;padding:48px 24px;text-align:center;cursor:pointer;transition:all .2s;margin-bottom:24px;background:#f7fafc}.drop-zone:hover,.drop-zone.dragging{border-color:#667eea;background:#ebf4ff}.drop-zone.has-file{border-color:#48bb78;background:#f0fff4}.file-icon{font-size:36px;margin-bottom:12px}.drop-text{color:#2d3748;font-size:15px;font-weight:600;margin-bottom:4px}.file-name{color:#22543d;font-size:14px;font-weight:600;margin-bottom:4px;word-break:break-all}.file-hint{color:#a0aec0;font-size:12px}.button{width:100%;padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.button:active:not(:disabled){transform:translateY(0)}.button:disabled{opacity:.6;cursor:not-allowed}.progress-container{margin-top:32px;padding:24px;background:#f7fafc;border-radius:8px}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.progress-status{color:#2d3748;font-weight:600;font-size:14px}.progress-percentage{color:#667eea;font-weight:700;font-size:14px}.progress-bar-bg{width:100%;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;margin-bottom:12px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease;border-radius:4px}.progress-message{color:#718096;font-size:13px}.success-container{margin-top:32px;padding:24px;background:#f0fff4;border:2px solid #9ae6b4;border-radius:8px}.success-title{color:#22543d;font-weight:700;margin-bottom:16px;font-size:16px}.report-info{margin-bottom:20px}.report-info p{color:#2f855a;margin-bottom:6px;font-size:14px}.report-info strong{color:#22543d}.download-button{width:100%;padding:12px 24px;background:#48bb78;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;margin-bottom:12px}.download-button:hover{background:#38a169;transform:translateY(-2px);box-shadow:0 8px 16px #48bb784d}.new-report-button{width:100%;padding:10px 24px;background:#fff;color:#667eea;border:2px solid #667eea;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.new-report-button:hover{background:#667eea;color:#fff}.error-container{margin-top:32px;padding:24px;background:#fff5f5;border:2px solid #fc8181;border-radius:8px}.error-title{color:#742a2a;font-weight:700;margin-bottom:8px;font-size:16px}.error-message{color:#c53030;font-size:14px;margin-bottom:16px}.retry-button{width:100%;padding:12px 24px;background:#f56565;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.retry-button:hover{background:#e53e3e}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner{display:inline-block;width:16px;height:16px;border:2px solid #ffffff;border-top:2px solid transparent;border-radius:50%;animation:spin .6s linear infinite;margin-right:8px;vertical-align:middle}
