.seismic-viewer{width:100%;height:100%;display:flex;flex-direction:column}.viewer-container{flex:1;display:flex;justify-content:center;align-items:center;overflow:hidden}.viewer-controls{background-color:#333;padding:1rem;display:flex;gap:.5rem;border-top:1px solid #555}.control-btn{background-color:#4a90e2;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.875rem;transition:background-color .2s}.control-btn:hover{background-color:#357abd}.control-btn:active{background-color:#2d5d8a}.chat-panel{height:50%;display:flex;flex-direction:column;border-bottom:1px solid #444}.chat-header{background-color:#333;padding:1rem;border-bottom:1px solid #444}.chat-header h3{margin:0;font-size:1.1rem;color:#fff}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem}.message{display:flex;max-width:85%}.user-message{align-self:flex-end}.ai-message{align-self:flex-start}.message-content{background-color:#4a90e2;padding:.75rem;border-radius:1rem;position:relative}.user-message .message-content{background-color:#4a90e2;color:#fff}.ai-message .message-content{background-color:#444;color:#fff}.message-content p{margin:0;font-size:.9rem;line-height:1.4}.message-time{font-size:.75rem;opacity:.7;display:block;margin-top:.25rem}.typing-indicator{display:flex;gap:.25rem;align-items:center}.typing-indicator span{width:6px;height:6px;background-color:#888;border-radius:50%;animation:typing 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.chat-input-form{display:flex;padding:1rem;gap:.5rem;background-color:#333;border-top:1px solid #444}.chat-input{flex:1;background-color:#555;color:#fff;border:1px solid #666;border-radius:4px;padding:.75rem;font-size:.9rem}.chat-input:focus{outline:none;border-color:#4a90e2}.chat-input::placeholder{color:#aaa}.send-button{background-color:#4a90e2;color:#fff;border:none;border-radius:4px;padding:.75rem 1.25rem;cursor:pointer;font-size:.9rem;transition:background-color .2s}.send-button:hover:not(:disabled){background-color:#357abd}.send-button:disabled{background-color:#666;cursor:not-allowed}.file-upload{width:400px;height:300px;border:2px dashed #666;border-radius:12px;display:flex;align-items:center;justify-content:center;background-color:#2d2d2d;transition:all .3s ease;cursor:pointer}.file-upload.dragging{border-color:#4a90e2;background-color:#1a3a5c;transform:scale(1.02)}.file-upload.uploading{border-color:#28a745;cursor:default}.upload-content{text-align:center;padding:2rem}.upload-icon{font-size:3rem;margin-bottom:1rem}.upload-content h3{color:#fff;margin:0 0 1rem;font-size:1.5rem}.upload-content p{color:#ccc;margin:0 0 1rem;line-height:1.4}.file-select-label{color:#4a90e2;cursor:pointer;text-decoration:underline}.file-select-label:hover{color:#357abd}.supported-formats{color:#888;font-size:.875rem;margin-top:1rem}.upload-progress{width:100%}.upload-progress h3{color:#28a745}.progress-bar{width:100%;height:8px;background-color:#444;border-radius:4px;overflow:hidden;margin:1rem 0}.progress-fill{height:100%;background-color:#28a745;transition:width .3s ease;border-radius:4px}.processing-history{height:50%;display:flex;flex-direction:column}.history-header{background-color:#333;padding:1rem;border-bottom:1px solid #444;display:flex;justify-content:space-between;align-items:center}.history-header h3{margin:0;font-size:1.1rem;color:#fff}.step-count{background-color:#4a90e2;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:700}.history-list{flex:1;overflow-y:auto;padding:1rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:#888}.empty-state p{margin:0 0 .5rem;font-size:1rem}.empty-state small{font-size:.875rem;opacity:.7}.history-item{display:flex;gap:.75rem;margin-bottom:1rem;padding:.75rem;background-color:#333;border-radius:8px;border-left:3px solid #4a90e2}.step-indicator{display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:40px}.step-icon{font-size:1.25rem}.step-number{background-color:#555;color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.step-content{flex:1}.step-title{font-weight:700;color:#fff;margin-bottom:.25rem;font-size:.9rem}.step-params{color:#ccc;font-size:.8rem;margin-bottom:.25rem;font-family:monospace;background-color:#444;padding:.25rem .5rem;border-radius:4px}.step-timestamp{color:#888;font-size:.75rem}.history-actions{padding:1rem;border-top:1px solid #444;display:flex;gap:.5rem}.action-btn{flex:1;padding:.5rem;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;transition:background-color .2s}.clear-btn{background-color:#dc3545;color:#fff}.clear-btn:hover{background-color:#c82333}.export-btn{background-color:#28a745;color:#fff}.export-btn:hover{background-color:#218838}.app{height:100vh;display:flex;flex-direction:column;background-color:#1a1a1a;color:#fff}.app-header{background-color:#2d2d2d;padding:1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #444}.app-header h1{margin:0;font-size:1.5rem;color:#fff}.status{display:flex;align-items:center;gap:.5rem}.status-indicator{display:flex;align-items:center;gap:.25rem;font-size:.875rem}.status-indicator.connected{color:#4ade80}.status-indicator.disconnected{color:#f87171}.app-main{flex:1;display:flex;overflow:hidden}.viewer-section{flex:1;background-color:#262626;display:flex;align-items:center;justify-content:center;position:relative}.upload-container{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.control-panel{width:350px;background-color:#2d2d2d;border-left:1px solid #444;display:flex;flex-direction:column}body{margin:0;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-color:#1a1a1a;color:#fff}*{box-sizing:border-box}#root{height:100vh;width:100vw}
