.mapping-review{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 8px #0000001a;max-width:1200px;margin:2rem auto}.mapping-header{margin-bottom:2rem}.mapping-header h2{color:#1f2937;margin-bottom:.5rem}.mapping-subtitle{color:#6b7280;font-size:.95rem;margin-bottom:1rem}.xml-format-badge{display:inline-block;background:#e0e7ff;color:#4f46e5;padding:.5rem 1rem;border-radius:4px;font-size:.9rem}.mappings-table{overflow-x:auto;margin-bottom:2rem}.mappings-table table{width:100%;border-collapse:collapse;font-size:.9rem}.mappings-table th{background:#f3f4f6;padding:.75rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.mappings-table td{padding:.75rem;border-bottom:1px solid #e5e7eb}.mappings-table tr:hover{background:#f9fafb}.source-field code{background:#f3f4f6;padding:.25rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.85rem;color:#1f2937}.field-select{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.9rem;background:#fff;cursor:pointer}.field-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.confidence{width:150px}.confidence-bar{position:relative;width:100%;height:24px;background:#e5e7eb;border-radius:4px;overflow:hidden}.confidence-fill{height:100%;transition:width .3s ease}.confidence-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:600;color:#1f2937}.sample-value{max-width:300px}.sample-text{color:#6b7280;font-size:.85rem;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mapping-notes{background:#fffbeb;border-left:4px solid #f59e0b;padding:1rem;margin-bottom:2rem;border-radius:4px}.mapping-notes h3{color:#92400e;font-size:.95rem;margin-bottom:.5rem}.mapping-notes p{color:#78350f;font-size:.9rem;margin:0}.mapping-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.btn-cancel,.btn-confirm{padding:.75rem 1.5rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s;border:none;font-size:.95rem}.btn-cancel{background:#f3f4f6;color:#374151}.btn-cancel:hover{background:#e5e7eb}.btn-confirm{background:#3b82f6;color:#fff}.btn-confirm:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.btn-confirm:active{transform:translateY(0)}.translation-controls{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-left:5px solid #0284c7;padding:2rem;border-radius:6px;margin:2rem 0;box-shadow:0 2px 8px #0284c71a}.translation-controls h3{color:#0c4a6e;font-size:1.1rem;margin:0 0 1.5rem;font-weight:600}.translation-controls>div:last-child{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;align-items:flex-end}.translation-controls label{display:block;font-size:.95rem;font-weight:500;color:#0c4a6e;margin-bottom:.75rem}.translation-controls select,.translation-controls input[type=checkbox]{font-size:.95rem}.translation-controls select{width:100%;padding:.7rem;border:2px solid #0284c7;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s;color:#0c4a6e}.translation-controls select:hover{border-color:#0ea5e9;box-shadow:0 0 0 3px #0284c71a}.translation-controls select:focus{outline:none;border-color:#0284c7;box-shadow:0 0 0 4px #0284c733}.translation-controls input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#0284c7}.translation-controls div:has(input[type=checkbox]){display:flex;align-items:center;gap:.8rem}.translation-controls div:has(input[type=checkbox]) label{margin-bottom:0}.feature-toggles{background:linear-gradient(135deg,#f0f9ff,#f5f3ff);border:2px solid #06b6d4;border-radius:8px;padding:1.5rem;margin:2rem 0}.feature-toggles h3{color:#0c4a6e;margin-top:0;margin-bottom:1.5rem;font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.feature-toggles>div{display:flex;flex-direction:column;gap:1rem}.feature-toggles>div>div{padding:1rem;background:#fff;border:1px solid #cffafe;border-radius:6px;transition:all .2s}.feature-toggles>div>div:hover{border-color:#06b6d4;box-shadow:0 2px 6px #06b6d41a}.feature-toggles label{display:flex;align-items:center;gap:.8rem;margin-bottom:.5rem;cursor:pointer;font-weight:500;color:#1f2937;-webkit-user-select:none;user-select:none}.feature-toggles input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#06b6d4;flex-shrink:0}.feature-toggles input[type=checkbox]:hover{transform:scale(1.1)}.feature-toggles small{display:block;color:#6b7280;font-size:.85rem;line-height:1.4;margin-left:2rem}.feature-toggles small br{content:""}@media (max-width: 768px){.feature-toggles{padding:1rem}.feature-toggles h3{font-size:1rem}.feature-toggles small{font-size:.8rem;margin-left:1.5rem}.translation-controls>div:last-child{grid-template-columns:1fr;gap:1.5rem}}.progress-tracker{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;margin:1rem 0}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.status-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;color:#fff;font-weight:500;font-size:.9rem;text-transform:capitalize}.status-icon{font-size:1.2rem;animation:rotate 2s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-badge[style*="22c55e"] .status-icon,.status-badge[style*=ef4444] .status-icon{animation:none}.progress-percentage{font-size:1.5rem;font-weight:700;color:#1f2937}.progress-bar-container{width:100%;height:12px;background:#e5e7eb;border-radius:6px;overflow:hidden;margin-bottom:1rem}.progress-bar-fill{height:100%;transition:width .5s ease,background-color .3s ease;border-radius:6px}.current-step{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#f3f4f6;border-radius:6px;margin-bottom:1rem}.step-label{font-weight:600;color:#374151;font-size:.9rem}.step-text{color:#6b7280;font-size:.9rem}.polling-indicator{display:flex;align-items:center;gap:.5rem;color:#6b7280;font-size:.85rem;padding-top:.5rem}.pulse-dot{width:8px;height:8px;background:#3b82f6;border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}*{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:#f5f5f5}.app{min-height:100vh;display:flex;flex-direction:column}.container{max-width:1200px;margin:0 auto;padding:0 20px;width:100%}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem 0;box-shadow:0 2px 10px #0000001a}.header h1{font-size:2.5rem;margin-bottom:.5rem}.header p{font-size:1.1rem;opacity:.9}.nav{background:#fff;box-shadow:0 2px 5px #0000000d;padding:1rem 0}.nav-link{display:inline-block;padding:.5rem 1.5rem;margin-right:1rem;text-decoration:none;color:#333;border-radius:5px;transition:all .3s}.nav-link:hover{background:#667eea;color:#fff}.main{flex:1;padding:2rem 0}.footer{background:#333;color:#fff;padding:1.5rem 0;text-align:center;margin-top:auto}.card{background:#fff;border-radius:10px;padding:2rem;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem}.card h2{margin-bottom:1.5rem;color:#333}.btn{padding:.75rem 1.5rem;border:none;border-radius:5px;font-size:1rem;cursor:pointer;transition:all .3s;font-weight:500}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5568d3}.btn-primary:disabled{background:#ccc;cursor:not-allowed}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.btn-success{background:#28a745;color:#fff}.btn-success:hover{background:#218838}.upload-area{border:2px dashed #667eea;border-radius:10px;padding:3rem;text-align:center;cursor:pointer;transition:all .3s;background:#f8f9ff}.upload-area:hover{border-color:#5568d3;background:#f0f2ff}.upload-area.dragging{border-color:#28a745;background:#f0fff4}.file-input{display:none}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:500}.status-uploaded{background:#e3f2fd;color:#1976d2}.status-processing{background:#fff3e0;color:#f57c00}.status-completed{background:#e8f5e9;color:#388e3c}.status-failed{background:#ffebee;color:#d32f2f}.table{width:100%;border-collapse:collapse;margin-top:1rem}.table th,.table td{padding:1rem;text-align:left;border-bottom:1px solid #eee}.table th{background:#f8f9fa;font-weight:600;color:#333}.table tr:hover{background:#f8f9fa}.json-editor{width:100%;min-height:400px;font-family:Courier New,monospace;padding:1rem;border:1px solid #ddd;border-radius:5px;font-size:.9rem}.alert{padding:1rem;border-radius:5px;margin-bottom:1rem}.alert-success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.alert-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.alert-info{background:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.loading{text-align:center;padding:2rem}.spinner{border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
