*{box-sizing:border-box;margin:0;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}body{background-color:#f5f5f5;color:#333;line-height:1.6}.container{max-width:1000px;margin:0 auto;padding:20px}h1{text-align:center;margin-bottom:30px;color:#2c3e50}h3{margin-bottom:15px;color:#2c3e50}.upload-section{background-color:#fff;border-radius:8px;padding:25px;margin-bottom:25px;box-shadow:0 2px 10px #0000001a}.form-group{margin-bottom:15px}label{display:block;margin-bottom:5px;font-weight:600}input[type=number],select{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:16px}.file-upload-container{margin:20px 0}.file-upload{position:relative;overflow:hidden;margin-bottom:10px}.file-upload input[type=file]{position:absolute;left:0;top:0;opacity:0;width:100%;height:100%;cursor:pointer}.primary-button{background-color:#3498db;color:#fff;border:none;padding:12px 20px;border-radius:4px;cursor:pointer;font-size:16px;transition:background-color .3s;width:100%}.primary-button:hover{background-color:#2980b9}.primary-button:disabled{background-color:#95a5a6;cursor:not-allowed}.file-name{font-size:14px;color:#7f8c8d;margin-top:5px}.results-section{display:grid;grid-template-columns:1fr 1fr;gap:20px}.result-box{background-color:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 10px #0000001a}.result-content{min-height:300px;max-height:500px;overflow-y:auto;white-space:pre-wrap;font-size:14px;line-height:1.6;border:1px solid #eee;border-radius:4px;padding:10px;background-color:#f9f9f9}.data-item{margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #eee}.data-item:last-child{border-bottom:none}.data-group{margin-bottom:15px}.nested-data{margin-left:20px;margin-top:5px;padding-left:10px;border-left:2px solid #3498db}.data-group ul{margin-left:20px;margin-top:5px}.data-group li{margin-bottom:5px}.placeholder{color:#95a5a6;text-align:center;margin-top:130px}.loading-indicator{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000}.spinner{border:6px solid #f3f3f3;border-radius:50%;border-top:6px solid #3498db;width:50px;height:50px;animation:spin 1s linear infinite;margin-bottom:15px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-indicator p{color:#fff;font-size:18px}.error-message{background-color:#e74c3c;color:#fff;padding:15px;border-radius:8px;margin-top:20px;text-align:center}.hidden{display:none}@media (max-width: 768px){.results-section{grid-template-columns:1fr}}
