*{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;color:#333}#root{height:100vh;overflow:hidden}.app-wrapper{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{background:#1f2933;color:#fff;padding:1rem 2rem;box-shadow:0 2px 4px #0000001a;z-index:100}.header-content{max-width:100%;display:flex;align-items:center}.brand-name{font-size:1.75rem;font-weight:700;margin:0;letter-spacing:.5px;color:#fff}.app-container{display:flex;flex:1;gap:1px;background:#ddd;overflow:hidden}.column{flex:1;background:#fff;display:flex;flex-direction:column;overflow:hidden}.column-content{flex:1;overflow-y:auto;padding:1rem}.upload-section{margin-bottom:1.5rem}.upload-area{border:2px dashed #ccc;border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:all .3s;background:#fafafa}.upload-area:hover{border-color:#1f2933;background:#f0f9f6}.upload-area.dragover{border-color:#1f2933;background:#e8f5f0}.upload-button{margin-top:1rem;padding:.5rem 1.5rem;background:#1f2933;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background .3s}.upload-button:hover{background:#0f1419}.file-info{margin-top:1rem;padding:.75rem;background:#e8f5e9;border-radius:4px;font-size:.9rem}.override-section{margin-bottom:1.5rem}.override-section label{display:block;margin-bottom:.5rem;font-weight:500}.override-textarea{width:100%;min-height:150px;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-family:monospace;font-size:.9rem;resize:vertical}.run-section{margin-bottom:1.5rem;padding:1rem;background:#f0f9f6;border-radius:8px;border:1px solid #1F2933;border-width:2px}.run-controls{display:flex;flex-direction:column;gap:1rem}.control-group{display:flex;flex-direction:column;gap:.5rem}.control-group label{font-weight:500;font-size:.9rem}.control-group select,.control-group input[type=text]{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.toggle-group{display:flex;align-items:center;gap:.5rem}.toggle-group input[type=checkbox]{width:18px;height:18px;cursor:pointer}.run-button{padding:.75rem 2rem;background:#1f2933;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s,transform .1s;box-shadow:0 2px 4px #226c4f4d}.run-button:hover:not(:disabled){background:#0f1419;transform:translateY(-1px);box-shadow:0 4px 6px #226c4f66}.run-button:disabled{background:#95a5a6;cursor:not-allowed}.status-section{margin-bottom:1.5rem;padding:1rem;background:#fff;border-radius:8px;border:1px solid #1F2933;border-width:2px}.status-item{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #f0f0f0}.status-item:last-child{border-bottom:none}.status-label{font-weight:500;color:#666}.status-value{font-family:monospace;color:#333}.status-value.valid{color:#1f2933;font-weight:600}.status-value.invalid{color:#e74c3c}.runs-history{margin-top:1.5rem;padding:1rem;background:#f0f9f6;border-radius:8px;border:1px solid #1F2933;border-width:2px;max-height:400px;overflow-y:auto}.runs-history h3{margin-bottom:1rem;font-size:1rem}.run-item{padding:.75rem;margin-bottom:.5rem;background:#fff;border:1px solid #e0e0e0;border-radius:4px;cursor:pointer;transition:all .2s}.run-item:hover{border-color:#1f2933;background:#f0f9f6}.run-item.selected{border-color:#1f2933;background:#e8f5f0;border-width:2px}.run-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.run-item-time{font-size:.85rem;color:#666}.run-item-details{font-size:.85rem;color:#666;display:flex;gap:1rem;flex-wrap:wrap}.run-item-badge{display:inline-block;padding:.2rem .5rem;border-radius:3px;font-size:.75rem;font-weight:500}.badge-valid{background:#d4edda;color:#1f2933;font-weight:600}.badge-invalid{background:#f8d7da;color:#721c24}.output-tabs{display:flex;border-bottom:2px solid #e0e0e0;margin-bottom:1rem}.tab{padding:.75rem 1.5rem;background:#f5f5f5;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:.95rem;font-weight:500;color:#666;transition:all .2s;margin-bottom:-2px}.tab:hover{background:#e8e8e8}.tab.active{background:#fff;color:#1f2933;border-bottom-color:#1f2933;font-weight:600}.tab-content{padding:1rem;background:#fff;border-radius:4px;min-height:200px}.json-viewer{background:#f8f8f8;padding:1rem;border-radius:4px;border:1px solid #e0e0e0;font-family:Courier New,monospace;font-size:.85rem;white-space:pre-wrap;word-wrap:break-word;max-height:600px;overflow-y:auto}.copy-button{margin-top:.5rem;padding:.5rem 1rem;background:#1f2933;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .3s}.copy-button:hover{background:#0f1419}.raw-text{background:#f8f8f8;padding:1rem;border-radius:4px;border:1px solid #e0e0e0;font-family:Courier New,monospace;font-size:.85rem;white-space:pre-wrap;word-wrap:break-word;max-height:600px;overflow-y:auto}.validation-result{padding:1rem;border-radius:4px;margin-bottom:1rem}.validation-result.valid{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.validation-result.invalid{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.validation-errors{margin-top:1rem;padding:1rem;background:#fff;border-radius:4px;border:1px solid #e0e0e0;font-family:monospace;font-size:.85rem;white-space:pre-wrap}.logs{background:#f8f8f8;padding:1rem;border-radius:4px;border:1px solid #e0e0e0;font-family:Courier New,monospace;font-size:.85rem;white-space:pre-wrap;max-height:600px;overflow-y:auto}.log-line{margin-bottom:.25rem}.log-line.error{color:#e74c3c}.log-line.success{color:#27ae60}.compare-section{margin-top:1.5rem;padding:1rem;background:#f0f9f6;border-radius:8px;border:1px solid #1F2933;border-width:2px}.compare-controls{display:flex;gap:1rem;margin-bottom:1rem;align-items:center}.compare-select{flex:1;padding:.5rem;border:1px solid #ddd;border-radius:4px}.compare-button{padding:.5rem 1.5rem;background:#1f2933;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .3s}.compare-button:hover:not(:disabled){background:#0f1419}.diff-view{margin-top:1rem;padding:1rem;background:#fff;border-radius:4px;border:1px solid #e0e0e0;max-height:400px;overflow-y:auto}.diff-line{padding:.25rem .5rem;font-family:monospace;font-size:.85rem}.diff-line.added{background:#d4edda;color:#155724}.diff-line.removed{background:#f8d7da;color:#721c24}.diff-line.unchanged{color:#666}.json-diff-item{padding:.5rem;margin-bottom:.5rem;border-radius:4px;border-left:3px solid}.json-diff-item.added{background:#d4edda;border-color:#27ae60}.json-diff-item.removed{background:#f8d7da;border-color:#e74c3c}.json-diff-item.changed{background:#fff3cd;border-color:#f39c12}.json-diff-path{font-weight:600;font-family:monospace}.json-diff-value{margin-top:.25rem;font-family:monospace;font-size:.85rem}.loading{text-align:center;padding:2rem;color:#666}.spinner{border:3px solid #f3f3f3;border-top:3px solid #3498db;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.human-readable{padding:1rem}.human-readable-content{display:flex;flex-direction:column;gap:2rem}.readable-section{background:#fff;border-radius:8px;border:1px solid #e0e0e0;padding:1.5rem}.readable-section h3{margin:0 0 1rem;color:#1f2933;font-size:1.25rem;font-weight:600;border-bottom:2px solid #1F2933;padding-bottom:.5rem}.readable-item{margin-bottom:1rem;padding:1rem;background:#f9f9f9;border-radius:4px;border-left:3px solid #1F2933}.readable-item:last-child{margin-bottom:0}.readable-field{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.readable-field:last-child{margin-bottom:0}.readable-label{font-weight:600;color:#666;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.readable-value{color:#333;font-size:1rem;line-height:1.5}.readable-list{margin:.5rem 0 0;padding-left:1.5rem}.readable-list li{margin-bottom:.5rem;line-height:1.5}.readable-list li:last-child{margin-bottom:0}
