.file-upload{width:100%}.upload-area{background:#fff;border:2px dashed #cbd5e1;border-radius:12px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease}.upload-area:hover{border-color:#667eea;background:#f8f9ff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.upload-area svg{color:#667eea;margin-bottom:1rem}.upload-area h3{font-size:1.5rem;color:#1e293b;margin-bottom:.5rem}.upload-area p{color:#64748b;font-size:.95rem}.spinner{border:3px solid #f3f4f6;border-top:3px solid #667eea;border-radius:50%;width:48px;height:48px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.variable-selector{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a;margin:2rem 0}.variable-selector h2{margin:0 0 1.5rem;color:#1a1a1a;font-size:1.5rem}.selector-grid{display:grid;gap:1.5rem;margin-bottom:1.5rem}.selector-section label{display:block;font-weight:600;color:#333;margin-bottom:.5rem;font-size:.95rem}.selector-section select{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;transition:all .2s}.selector-section select:hover:not(:disabled){border-color:#06c}.selector-section select:focus{outline:none;border-color:#06c;box-shadow:0 0 0 3px #0066cc1a}.selector-section select:disabled{background:#f5f5f5;cursor:not-allowed}.checkbox-controls{display:flex;gap:.5rem;margin-bottom:.75rem}.select-button{padding:.5rem 1rem;background:#f0f0f0;color:#333;border:1px solid #d0d0d0;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.select-button:hover:not(:disabled){background:#e0e0e0;border-color:#b0b0b0}.select-button:disabled{background:#f8f8f8;color:#999;cursor:not-allowed}.checkbox-group{border:2px solid #e0e0e0;border-radius:8px;padding:1rem;max-height:200px;overflow-y:auto}.checkbox-label{display:flex;align-items:center;padding:.5rem;cursor:pointer;transition:background .2s;border-radius:4px}.checkbox-label:hover{background:#f8f9fa}.checkbox-label input[type=checkbox]{width:18px;height:18px;margin-right:.75rem;cursor:pointer}.checkbox-label span{color:#333;font-size:.95rem}.selector-actions{display:flex;justify-content:flex-end;margin-top:1.5rem}.run-button{padding:.875rem 2rem;background:#06c;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.run-button:hover:not(:disabled){background:#0052a3;transform:translateY(-1px);box-shadow:0 4px 12px #0066cc4d}.run-button:disabled{background:#ccc;cursor:not-allowed;transform:none}.results{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 12px #0000001a}.results-header{margin-bottom:2rem}.results-header h2{font-size:2rem;color:#1e293b;margin-bottom:1rem}.meta-info{display:flex;gap:1rem;flex-wrap:wrap}.badge{background:#e0e7ff;color:#667eea;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500}.results-grid{display:flex;flex-direction:column;gap:2rem}.card{border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;background:#fafafa}.card.full-width{grid-column:1 / -1}.metrics-grid{display:grid;gap:1rem}.metric-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#fff;border-radius:6px;border:1px solid #e2e8f0}.metric-label{color:#666;font-size:.9rem}.metric-value{font-size:1.25rem;font-weight:600;color:#1a1a1a}.card h3{font-size:1.25rem;color:#334155;margin-bottom:1rem}.table-container{overflow-x:auto;background:#fff;border-radius:6px;border:1px solid #e2e8f0}table{width:100%;border-collapse:collapse}th{background:#f8fafc;color:#475569;font-weight:600;text-align:left;padding:.75rem 1rem;border-bottom:2px solid #e2e8f0;font-size:.9rem;white-space:nowrap}td{padding:.75rem 1rem;border-bottom:1px solid #f1f5f9;color:#334155}tr:last-child td{border-bottom:none}tr:hover td{background:#fafafa}.metric-name{font-weight:600;color:#667eea}@media(max-width:768px){.results{padding:1rem}.results-header h2{font-size:1.5rem}.card{padding:1rem}th,td{padding:.5rem;font-size:.85rem}}.log-viewer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;z-index:1000;display:flex;justify-content:center;align-items:center;padding:20px}.log-viewer{background:#1a1a1a;border:1px solid #333;border-radius:8px;width:100%;max-width:1400px;height:90vh;display:flex;flex-direction:column;color:#e0e0e0;font-family:Monaco,Courier New,monospace;box-shadow:0 10px 40px #000c}.log-viewer-header{padding:20px;border-bottom:1px solid #333;display:flex;justify-content:space-between;align-items:center;background:#222}.log-viewer-header h2{margin:0;font-size:20px;color:#fff}.header-controls{display:flex;gap:10px;align-items:center}.auto-refresh-toggle{display:flex;align-items:center;gap:5px;font-size:12px;color:#aaa;cursor:pointer}.auto-refresh-toggle input{cursor:pointer}.refresh-btn,.copy-btn,.clear-btn,.close-btn{padding:8px 16px;border:1px solid #444;background:#2a2a2a;color:#e0e0e0;cursor:pointer;border-radius:4px;font-size:14px;transition:all .2s}.refresh-btn:hover{background:#3a3a3a;border-color:#555}.copy-btn:hover{background:#1a4d1a;border-color:#2d7a2d}.clear-btn:hover{background:#4d1a1a;border-color:#7a2d2d}.close-btn{font-size:24px;padding:4px 12px;line-height:1}.close-btn:hover{background:#4a1a1a;border-color:#7a2d2d}.log-viewer-filters{padding:15px 20px;border-bottom:1px solid #333;display:flex;gap:20px;background:#1e1e1e}.filter-group{display:flex;align-items:center;gap:10px}.filter-group label{font-size:13px;color:#aaa}.filter-group select,.filter-group input{padding:6px 12px;background:#2a2a2a;border:1px solid #444;color:#e0e0e0;border-radius:4px;font-size:13px;font-family:inherit}.filter-group input{width:300px}.filter-group select:focus,.filter-group input:focus{outline:none;border-color:#555}.log-viewer-content{flex:1;overflow-y:auto;padding:10px;background:#1a1a1a}.log-loading,.log-empty{display:flex;justify-content:center;align-items:center;height:100%;color:#666;font-size:16px}.log-list{display:flex;flex-direction:column;gap:2px}.log-entry{padding:10px 15px;background:#222;border:1px solid #2a2a2a;border-radius:4px;cursor:pointer;transition:all .15s;font-size:13px}.log-entry:hover{background:#272727;border-color:#333}.log-entry.expanded{background:#2a2a2a;border-color:#444}.log-header-line{display:flex;gap:10px;align-items:center;margin-bottom:5px}.log-timestamp{color:#888;font-size:12px;min-width:140px}.log-level{font-weight:700;min-width:70px;font-size:12px}.log-method{color:#99f;min-width:50px;font-weight:600;font-size:12px}.log-endpoint{color:#6cf;flex:1}.log-status{padding:2px 8px;border-radius:3px;font-size:11px;font-weight:700}.log-status.success{background:#1a4d1a;color:#6f6}.log-status.error{background:#4d1a1a;color:#f66}.log-message{color:#ccc;padding-left:150px;line-height:1.4}.log-details{margin-top:15px;padding-top:15px;border-top:1px solid #333;padding-left:150px}.log-detail-item{margin-bottom:10px;font-size:12px}.log-detail-item strong{color:#888;display:block;margin-bottom:5px}.log-json{background:#1a1a1a;border:1px solid #333;padding:10px;border-radius:4px;overflow-x:auto;color:#6f6;font-size:11px;line-height:1.5;margin-top:5px;max-height:300px;overflow-y:auto}.log-viewer-footer{padding:12px 20px;border-top:1px solid #333;text-align:center;font-size:12px;color:#666;background:#1e1e1e}.log-viewer-content::-webkit-scrollbar{width:10px}.log-viewer-content::-webkit-scrollbar-track{background:#1a1a1a}.log-viewer-content::-webkit-scrollbar-thumb{background:#444;border-radius:5px}.log-viewer-content::-webkit-scrollbar-thumb:hover{background:#555}.log-json::-webkit-scrollbar{width:6px;height:6px}.log-json::-webkit-scrollbar-track{background:#1a1a1a}.log-json::-webkit-scrollbar-thumb{background:#333;border-radius:3px}.log-json::-webkit-scrollbar-thumb:hover{background:#444}.app{min-height:100vh}.header{display:flex;justify-content:space-between;align-items:center;color:#fff;margin-bottom:3rem}.header>div{text-align:center;flex:1}.header h1{font-size:3rem;font-weight:700;margin-bottom:.5rem}.header p{font-size:1.25rem;opacity:.9}.view-logs-btn{position:absolute;top:2rem;right:2rem;padding:.75rem 1.5rem;background:#2a2a2a;color:#fff;border:1px solid #444;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;z-index:10}.view-logs-btn:hover{background:#3a3a3a;border-color:#555;transform:translateY(-1px);box-shadow:0 4px 8px #0000004d}.main{display:flex;flex-direction:column;gap:2rem}.error{background:#fee;color:#c33;padding:1rem;border-radius:8px;border:1px solid #fcc;text-align:center}.data-info{display:flex;justify-content:space-between;align-items:center;background:#fff;border-radius:8px;padding:1rem 1.5rem;margin-bottom:1rem;box-shadow:0 2px 4px #0000001a}.data-info p{margin:0;color:#666;font-size:.95rem}.reset-button{padding:.5rem 1rem;background:#f5f5f5;color:#333;border:1px solid #ddd;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s}.reset-button:hover{background:#e8e8e8;border-color:#ccc}@media(max-width:768px){.header h1{font-size:2rem}.header p{font-size:1rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:2rem}#root{max-width:1200px;margin:0 auto}
