*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;background:#f0f2f5;color:#333;line-height:1.6;min-height:100vh}.app{max-width:800px;margin:0 auto;padding:24px 16px 48px;min-height:100vh;display:flex;flex-direction:column}.app-header{text-align:center;margin-bottom:32px}.app-header h1{font-size:28px;color:#d4380d;margin-bottom:8px}.app-header .subtitle{font-size:14px;color:#888}.app-main{flex:1}.app-footer{text-align:center;margin-top:40px;padding-top:16px;border-top:1px solid #e8e8e8;font-size:12px;color:#aaa}.upload-card,.progress-card,.result-card,.status-card{background:#fff;border-radius:12px;padding:32px;box-shadow:0 2px 8px #0000000f}.status-card{text-align:center;padding:48px 32px}.status-card.error{border:1px solid #ffccc7}.status-card.error p{color:#cf1322;margin-bottom:16px}.auth-card{background:#fff;border-radius:12px;padding:40px 32px;box-shadow:0 2px 8px #0000000f;text-align:center;max-width:440px;margin:0 auto}.auth-card h2{margin-bottom:20px;font-size:20px}.auth-form{display:flex;gap:10px;margin-bottom:12px}.auth-input{flex:1;padding:10px 14px;border:1px solid #d9d9d9;border-radius:8px;font-size:14px;outline:none;transition:border-color .3s}.auth-input:focus{border-color:#d4380d}.drop-zone{border:2px dashed #d9d9d9;border-radius:12px;padding:48px 24px;text-align:center;transition:border-color .3s,background .3s;cursor:pointer}.drop-zone:hover,.drop-zone.drag-over{border-color:#d4380d;background:#fff7e6}.drop-content{display:flex;flex-direction:column;align-items:center;gap:12px}.upload-icon{font-size:48px}.upload-title{font-size:16px;font-weight:500;color:#333}.upload-hint{font-size:13px;color:#999}.file-input{position:absolute;width:0;height:0;opacity:0}.error-text{color:#cf1322;font-size:13px}.template-hint{margin-top:16px;text-align:center;font-size:13px;color:#888}.template-hint a{color:#d4380d;text-decoration:none}.template-hint a:hover{text-decoration:underline}.btn{display:inline-block;padding:10px 24px;border:none;border-radius:8px;font-size:15px;cursor:pointer;transition:all .3s;text-decoration:none;text-align:center}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#d4380d;color:#fff}.btn-primary:hover:not(:disabled){background:#ad2e0a}.btn-secondary{background:#f0f0f0;color:#333}.btn-secondary:hover{background:#e0e0e0}.btn-download{display:block;width:100%;padding:14px 24px;font-size:16px}.progress-card h2{margin-bottom:20px}.progress-bar-wrapper{display:flex;align-items:center;gap:12px;margin-bottom:20px}.progress-bar{flex:1;height:12px;background:#f0f0f0;border-radius:6px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#d4380d,#fa8c16);border-radius:6px;transition:width .5s ease;min-width:2px}.progress-text{font-size:14px;font-weight:600;color:#d4380d;min-width:45px}.progress-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:16px}.info-row{background:#fafafa;border-radius:8px;padding:12px;text-align:center}.info-row span{display:block;font-size:12px;color:#888;margin-bottom:4px}.info-row strong{font-size:20px;color:#333}.info-row .error-text{color:#cf1322}.eta-text{text-align:center;font-size:13px;color:#888;margin-bottom:16px}.row-results{margin-top:16px;max-height:300px;overflow-y:auto}.row-results h3,.error-list h3{font-size:14px;margin-bottom:8px;color:#555}.row-item{padding:8px 12px;border-bottom:1px solid #f0f0f0;font-size:13px}.row-item.row-error{background:#fff2f0}.row-top{display:flex;justify-content:space-between;align-items:center}.row-num{color:#888}.row-status{font-weight:500}.row-status.is-normal{color:#52c41a}.row-law{margin-top:4px;font-size:12px;color:#d4380d}.error-list{margin-top:16px}.error-item{padding:8px 12px;background:#fff2f0;border:1px solid #ffccc7;border-radius:6px;margin-bottom:8px;font-size:13px}.error-row{font-weight:600;margin-right:8px;color:#cf1322}.error-msg{color:#666}.result-header{text-align:center;margin-bottom:24px}.result-header h2{font-size:24px}.result-summary{display:flex;justify-content:center;gap:24px;margin-bottom:24px}.summary-item{text-align:center}.summary-label{display:block;font-size:13px;color:#888;margin-bottom:4px}.summary-value{font-size:28px;font-weight:700}.summary-value.success{color:#52c41a}.summary-value.error{color:#cf1322}.row-preview{margin-bottom:24px;max-height:300px;overflow-y:auto}.row-preview h3{font-size:14px;margin-bottom:8px;color:#555}.preview-table{border:1px solid #f0f0f0;border-radius:8px;overflow:hidden}.preview-row{padding:10px 14px;border-bottom:1px solid #f0f0f0;font-size:13px}.preview-row:last-child{border-bottom:none}.preview-top{display:flex;justify-content:space-between;align-items:center}.preview-num{color:#888}.preview-status{font-weight:500}.preview-status.is-normal{color:#52c41a}.preview-law{margin-top:4px;font-size:12px;color:#d4380d}.download-section{margin-bottom:16px}.reset-section{text-align:center}.spinner{width:40px;height:40px;margin:0 auto 16px;border:3px solid #f0f0f0;border-top-color:#d4380d;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
