*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8fafc;color:#1e293b;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App,body{min-height:100vh}.App{display:flex;flex-direction:column}.App-header{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;padding:2rem;text-align:center}.App-header h1{color:#1e293b;font-size:2.5rem;font-weight:600;margin-bottom:.5rem}.App-header p{color:#64748b;font-size:1.1rem;font-weight:400}.tab-navigation{background:#fff;border-bottom:1px solid #e2e8f0;display:flex;gap:.5rem;justify-content:center;padding:1rem 1.5rem}.tab-button{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.tab-button:hover{background:#f8fafc;border-color:#cbd5e1;color:#475569}.tab-button.active{background:#2563eb;border-color:#2563eb;color:#fff;font-weight:600}.App-main{flex:1 1;margin:0 auto;max-width:1400px;padding:2rem;width:100%}.error-container,.loading-container{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:3rem;text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#2563eb;height:50px;margin:0 auto 1rem;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes flash{0%,to{opacity:1}50%{opacity:.4}}.thinking-indicator{animation:flash 1.5s ease-in-out infinite;color:#2563eb;font-size:14px;font-weight:500}.prediction-container,.recipe-generator-container{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:2rem}.intro-section{border-bottom:1px solid #e2e8f0;margin-bottom:2rem;padding-bottom:1.5rem}.intro-section h2{color:#1e293b;font-size:1.75rem;font-weight:600;margin-bottom:.5rem}.intro-section p{color:#64748b;font-size:1rem;line-height:1.6}.prediction-form,.recipe-form{display:flex;flex-direction:column;gap:2rem}.form-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:1.5rem}.form-section h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin-bottom:1rem}.section-help{color:#64748b;font-size:.875rem;line-height:1.5;margin-bottom:1rem}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.toggle-button{background:#fff;border:1px solid #cbd5e1;border-radius:4px;color:#475569;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s}.toggle-button:hover{background:#f1f5f9;border-color:#94a3b8}.features-grid,.settings-grid,.targets-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{align-items:center;color:#475569;display:flex;font-size:.875rem;font-weight:500;gap:.5rem}.feature-type-badge,.optional-badge{border-radius:3px;font-size:.75rem;font-weight:500;padding:.15rem .5rem}.feature-type-badge{background:#dbeafe;color:#1e40af}.optional-badge{background:#e2e8f0;color:#64748b}.section-subtitle{color:#64748b;font-size:.875rem;font-weight:400}.form-group input[type=number],.form-group input[type=text],.form-group select{background:#fff;border:1px solid #cbd5e1;border-radius:4px;color:#1e293b;font-size:.9375rem;padding:.625rem .75rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.confidence-slider input[type=range]{-webkit-appearance:none;background:#cbd5e1;border-radius:2px;height:4px;outline:none;width:100%}.confidence-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:#2563eb;border-radius:50%;cursor:pointer;height:16px;width:16px}.confidence-slider input[type=range]::-moz-range-thumb{background:#2563eb;border:none;border-radius:50%;cursor:pointer;height:16px;width:16px}.range-labels{color:#64748b;display:flex;font-size:.8125rem;justify-content:space-between;margin-top:.25rem}.fixed-features-list{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto;padding-right:.5rem}.fixed-feature-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:4px;display:flex;gap:1rem;padding:.75rem}.checkbox-label{flex:1 1}.inline-input,.inline-select{border:1px solid #cbd5e1;border-radius:4px;font-size:.875rem;min-width:120px;padding:.5rem}.submit-button{box-shadow:0 1px 2px #0000000d;font-size:1rem;padding:.875rem 1.75rem;transition:all .2s ease}.submit-button:hover:not(:disabled){background:#1d4ed8;box-shadow:0 4px 6px #2563eb33}.submit-button:disabled{cursor:not-allowed;opacity:.5}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#991b1b;margin-top:1rem;padding:1rem}.results-section{border-top:1px solid #e2e8f0;margin-top:2rem;padding-top:2rem}.results-section h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.sequential-flow-info{background:#eff6ff;border-left:3px solid #2563eb;border-radius:6px;margin-bottom:2rem;padding:1.5rem}.sequential-flow-info h4{color:#1e293b;font-size:.9375rem;font-weight:600;margin-bottom:.75rem}.flow-steps{display:flex;flex-direction:column;gap:.5rem}.flow-step{background:#fff;border:1px solid #dbeafe;border-radius:4px;color:#475569;font-size:.875rem;font-weight:500;padding:.5rem 1rem}.predictions-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem}.prediction-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem;transition:box-shadow .2s}.prediction-card:hover{box-shadow:0 4px 6px #0000001a}.prediction-card h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin-bottom:1rem;text-transform:capitalize}.prediction-main{margin-bottom:1rem}.prediction-value{align-items:baseline;color:#2563eb;display:flex;font-size:2.5rem;font-weight:700;gap:.5rem}.prediction-value .unit{color:#64748b;font-size:.875rem;font-weight:400}.confidence-interval{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;margin-top:1rem;padding:1rem}.ci-label{color:#475569;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.ci-range{color:#2563eb;font-size:1.0625rem;font-weight:600}.ci-width{color:#64748b;font-size:.8125rem;margin-top:.5rem}.prediction-bar{background:#e2e8f0;border-radius:3px;height:6px;margin-top:1rem;position:relative}.ci-bar{background:#2563eb;border-radius:3px;height:100%}.prediction-marker{background:#1e293b;border-radius:1.5px;height:12px;position:absolute;top:-3px;width:3px}.metadata-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;margin-top:2rem;padding:1.5rem}.metadata-section h4{color:#1e293b;font-size:.9375rem;font-weight:600;margin-bottom:1rem}.metadata-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.metadata-grid div{color:#64748b;font-size:.875rem}.metadata-grid strong{color:#1e293b;font-weight:600}.summary-card{background:#2563eb;border-radius:8px;box-shadow:0 1px 3px #0000001a;color:#fff;margin-bottom:2rem;padding:1.5rem}.summary-card h4{font-size:1.125rem;font-weight:600;margin-bottom:1rem}.summary-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-grid div{background:#ffffff26;border-radius:4px;font-size:.875rem;padding:.75rem}.summary-grid strong{font-weight:600}.recipes-list{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.recipe-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;transition:all .2s}.recipe-card.meets-target{background:#f0fdf4;border-color:#10b981}.recipe-card:hover{box-shadow:0 4px 6px #0000001a}.recipe-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.recipe-header h3{color:#1e293b;font-size:1.25rem;font-weight:600}.recipe-badges{display:flex;gap:.5rem}.badge{border-radius:4px;font-size:.8125rem;padding:.375rem .75rem}.badge.success{background:#dcfce7;color:#166534}.badge.info{background:#dbeafe;color:#1e40af}.recipe-metrics{margin-bottom:1.5rem}.metric{background:#f8fafc;border-radius:4px;display:flex;justify-content:space-between;padding:.75rem}.metric-label{color:#64748b;font-size:.875rem;font-weight:600}.metric-value{color:#2563eb;font-size:1rem;font-weight:700}.predicted-tt-section{margin-bottom:1.5rem}.predicted-tt-section h4{color:#1e293b;font-size:.9375rem;font-weight:600;margin-bottom:1rem}.predicted-tt-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.predicted-tt-item{background:#eff6ff;border:1px solid #dbeafe;border-radius:6px;padding:1rem;text-align:center}.tt-name{color:#2563eb;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.tt-value{color:#1e293b;font-size:1.25rem;font-weight:700}.tt-diff{font-size:.8125rem;font-weight:600;margin-top:.5rem}.tt-diff.positive{color:#dc2626}.tt-diff.negative{color:#10b981}.recipe-formulation{margin-top:1.5rem}.recipe-formulation h4{color:#1e293b;font-size:.9375rem;font-weight:600;margin-bottom:1rem}.expand-button{background:#2563eb;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;margin-bottom:1rem;padding:.5rem 1rem;transition:background .2s}.expand-button:hover{background:#1d4ed8}.formulation-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-top:1rem}.formulation-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;display:flex;font-size:.875rem;justify-content:space-between;padding:.75rem}.feature-name{color:#64748b;font-weight:500}.feature-value{color:#1e293b;font-weight:600}.warning-box{background:#fef3c7;border:1px solid #fbbf24;border-radius:6px;margin-top:2rem;padding:1.5rem}.warning-box h4{color:#92400e;font-size:.9375rem;font-weight:600;margin-bottom:1rem}.warning-box ul{color:#92400e;line-height:1.8;list-style-position:inside}.warning-box li{font-size:.875rem;margin-bottom:.5rem}.speed-indicator{background:#dbeafe;border-radius:12px;color:#1e40af;font-size:.8125rem;font-weight:600;margin-left:1rem;padding:.25rem .75rem}.additive-selection{margin-top:1rem}.additive-pills{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0;min-height:40px}.additive-pill{background:#2563eb;border-radius:16px;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem}.additive-pill,.remove-pill{align-items:center;color:#fff}.remove-pill{background:#ffffff40;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:1.1rem;height:18px;justify-content:center;line-height:1;transition:all .2s;width:18px}.remove-pill:hover{background:#fff6}.info-text{color:#64748b;font-size:.875rem;font-style:italic}.additive-selector{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;margin-top:1rem;padding:1rem}.additive-selector summary{color:#2563eb;cursor:pointer;font-size:.875rem;font-weight:600;padding:.5rem;-webkit-user-select:none;user-select:none}.additive-selector summary:hover{background:#eff6ff;border-radius:4px}.additive-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-top:1rem;padding:1rem 0}.checkbox-label{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:4px;cursor:pointer;display:flex;gap:.5rem;padding:.5rem;transition:all .2s}.checkbox-label:hover{background:#eff6ff;border-color:#bfdbfe}.checkbox-label input[type=checkbox]{accent-color:#2563eb;cursor:pointer;height:16px;width:16px}.checkbox-label span{color:#1e293b;font-size:.875rem}.explore-data-container{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:2rem}.explore-data-chat-container{background:#fff;border-left:1px solid #e2e8f0;border-right:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;display:flex;flex:1 1;flex-direction:column;min-height:0;position:relative}.chat-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1.5rem}.header-title h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.header-title p{color:#64748b;font-size:.875rem}.header-controls{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.session-button{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:4px;color:#475569;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.session-button:hover{background:#f8fafc;border-color:#cbd5e1}.session-button svg{height:18px;width:18px}.mode-toggle{background:#fff;border:1px solid #e2e8f0;border-radius:6px;display:flex;gap:.5rem;padding:.25rem}.mode-button{background:#0000;border:none;border-radius:4px;color:#64748b;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.mode-button:hover{background:#f8fafc;color:#475569}.mode-button.active{background:#2563eb;color:#fff;font-weight:600}.clear-button{background:#fff;border:1px solid #e2e8f0;border-radius:4px;color:#64748b;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.clear-button:hover{background:#f8fafc;border-color:#cbd5e1}.chat-body{display:flex;flex:1 1;overflow:hidden;position:relative}.chat-messages{background:#f8fafc;flex:1 1;overflow-y:auto;padding:1.5rem}.loading-history{align-items:center;display:flex;flex-direction:column;gap:1rem;height:100%;justify-content:center}.session-sidebar-overlay{background:#0000004d;inset:0;position:fixed;z-index:40}.session-sidebar{animation:slideInRight .2s ease;background:#fff;border-left:1px solid #e2e8f0;bottom:0;box-shadow:-2px 0 8px #0000001a;display:flex;flex-direction:column;position:absolute;right:0;top:0;width:320px;z-index:50}@keyframes slideInRight{0%{transform:translateX(100%)}to{transform:translateX(0)}}.session-sidebar-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1rem 1.5rem}.session-sidebar-header h3{color:#1e293b;font-size:1rem;font-weight:600;margin:0}.session-sidebar-header button{background:none;border:none;color:#64748b;cursor:pointer;padding:.25rem;transition:color .2s}.session-sidebar-header button:hover{color:#1e293b}.session-sidebar-header button svg{height:20px;width:20px}.session-list{flex:1 1;overflow-y:auto;padding:.75rem}.session-item{background:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;margin-bottom:.5rem;padding:.875rem;position:relative;transition:all .2s}.session-item:hover{background:#f8fafc;border-color:#cbd5e1}.session-item-active{background:#eff6ff;border-color:#2563eb}.session-title{color:#1e293b;font-size:.875rem;font-weight:500;margin-bottom:.375rem;overflow:hidden;padding-right:30px;text-overflow:ellipsis;white-space:nowrap}.session-meta{color:#94a3b8;font-size:.75rem}.session-delete{background:none;border:none;border-radius:3px;color:#94a3b8;cursor:pointer;padding:.25rem;position:absolute;right:.5rem;top:.5rem;transition:all .2s}.session-delete:hover{background:#fee2e2;color:#dc2626}.session-delete svg{height:16px;width:16px}.execution-time-badge{background:#f8fafc;border-radius:4px;color:#64748b;font-size:.8125rem;margin-top:.75rem;padding:.5rem;text-align:right}.message{display:flex;gap:.75rem;margin-bottom:1rem}.message.user{flex-direction:row-reverse}.message-avatar{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:.875rem;font-weight:600;height:32px;justify-content:center;width:32px}.message.user .message-avatar{background:#2563eb;color:#fff}.message.assistant .message-avatar{background:#e2e8f0;color:#475569}.message-bubble{border-radius:8px;box-shadow:0 1px 2px #0000000d;max-width:70%;padding:.75rem 1rem .5rem}.message.user .message-bubble{background:#2563eb;color:#fff}.message.assistant .message-bubble{background:#fff;border:1px solid #e2e8f0;color:#1e293b}.message-text{font-size:.9375rem;line-height:1.6;white-space:pre-wrap}.message-timestamp{font-size:.7rem;line-height:1;margin-top:4px;opacity:.55}.message-error{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;padding:1rem}.message-clarification{background:#fef3c7;border:1px solid #fbbf24;border-radius:6px;padding:1rem}.clarification-text{color:#92400e;line-height:1.6}.clarification-hint{border-top:1px solid #fbbf24;color:#92400e;font-size:.875rem;margin-top:.75rem;padding-top:.75rem}.message-table-result{background:#fff;border:1px solid #e2e8f0;border-radius:6px;overflow:hidden}.result-summary{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:1rem}.result-meta{background:#f8fafc;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;padding:.75rem}.meta-badge{background:#2563eb;border-radius:12px;color:#fff;font-size:.8125rem;font-weight:600;padding:.25rem .75rem}.meta-badge.warning{background:#f59e0b}.chat-input-container{background:#fff;border-top:1px solid #e2e8f0;padding:1rem 1.5rem}.examples-section{margin-bottom:1rem}.examples-label{color:#64748b;font-size:.8125rem;font-weight:500;margin-bottom:.5rem}.query-form{display:flex;gap:.75rem}.query-input{border:1px solid #cbd5e1;border-radius:6px;flex:1 1;font-family:inherit;font-size:.9375rem;max-height:120px;min-height:44px;padding:.75rem;resize:none}.query-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.send-button{background:#2563eb;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9375rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s;white-space:nowrap}.send-button:hover:not(:disabled){background:#1d4ed8}.send-button:disabled{cursor:not-allowed;opacity:.5}.example-pills{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.example-pill{background:#f8fafc;border:1px solid #cbd5e1;border-radius:4px;color:#475569;cursor:pointer;font-size:.8125rem;padding:.5rem .75rem;text-align:left;transition:all .2s}.example-pill:hover{background:#eff6ff;border-color:#2563eb;color:#2563eb}.query-form textarea{font-family:inherit;resize:vertical}.schema-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;margin:2rem 0;padding:1rem}.schema-section summary{color:#2563eb;cursor:pointer;font-size:.875rem;font-weight:600;padding:.5rem;-webkit-user-select:none;user-select:none}.schema-section summary:hover{background:#eff6ff;border-radius:4px}.schema-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-top:1rem}.schema-item{background:#fff;border:1px solid #e2e8f0;border-radius:4px;display:flex;font-size:.875rem;justify-content:space-between;padding:.5rem}.col-name{color:#1e293b;font-weight:600}.col-type{color:#64748b;font-size:.8125rem}.nl-results{background:#eff6ff;border-left:3px solid #2563eb;border-radius:6px;padding:1.5rem}.result-text{color:#1e293b;font-size:1rem;line-height:1.6;white-space:pre-wrap}.hint-message{background:#ffffffb3;border-radius:4px;font-size:.875rem;padding:1rem}.hint-message,.sql-results{margin-top:1rem}.table-container{border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 1px 3px #0000001a;margin-top:1rem;overflow-x:auto}.data-table{background:#fff;border-collapse:collapse;font-size:.875rem;width:100%}.data-table th{background:#1e293b;color:#fff;font-size:.8125rem;font-weight:600;padding:.75rem;position:-webkit-sticky;position:sticky;text-align:left;top:0;z-index:10}.data-table td{border-bottom:1px solid #e2e8f0;color:#1e293b;padding:.625rem .75rem}.data-table tbody tr:hover,.data-table tbody tr:nth-child(2n){background:#f8fafc}.data-table tbody tr:nth-child(2n):hover{background:#eff6ff}.App-footer{background:#fff;border-top:1px solid #e2e8f0;color:#64748b;padding:1.5rem;text-align:center}.similar-experiments-section{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-top:3rem;padding:2rem}.similar-experiments-section h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.section-description{color:#64748b;font-size:.875rem;margin-bottom:1.5rem}.similar-info{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.similar-info .badge{background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;color:#475569;font-size:.875rem;padding:.5rem 1rem}.similar-table-container{background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 1px 3px #0000001a;overflow-x:auto}.similar-table{border-collapse:collapse;font-size:.875rem;width:100%}.similar-table thead{background:#1e293b;color:#fff}.similar-table th{font-size:.8125rem;font-weight:600;letter-spacing:.025em;padding:.75rem;text-align:left;text-transform:uppercase}.similar-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .2s}.similar-table tbody tr:hover{background-color:#f8fafc}.similar-table td{color:#475569;padding:.75rem}.rank-cell{color:#2563eb;font-size:.9375rem;font-weight:600}.similarity-cell{min-width:120px}.similarity-bar-container{background:#e2e8f0;border-radius:4px;height:20px;overflow:hidden;position:relative;width:100%}.similarity-bar{background:#2563eb;border-radius:4px;height:100%;transition:width .3s ease}.similarity-text{color:#1e293b;font-size:.75rem;font-weight:600;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:1}.details-button{background:#2563eb;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8125rem;font-weight:500;padding:.375rem .75rem;transition:background .2s}.details-button:hover{background:#1d4ed8}.details-button:active{background:#1e40af}@media (max-width:1024px){.similar-table{font-size:.8125rem}.similar-table td,.similar-table th{padding:.5rem}}@media (max-width:768px){.App-header h1{font-size:1.75rem}.tab-navigation{flex-direction:column}.tab-button{width:100%}.features-grid,.predictions-grid,.targets-grid{grid-template-columns:1fr}.prediction-value{font-size:2rem}.similar-experiments-section{padding:1rem}.similar-table-container{overflow-x:scroll}.similar-table{min-width:800px}.message-bubble{max-width:85%}.chat-header{align-items:flex-start;flex-direction:column}}.login-page{align-items:center;background:linear-gradient(135deg,#f8fafc,#e2e8f0);display:flex;justify-content:center;min-height:100vh;padding:2rem}.login-container{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-width:450px;padding:3rem;width:100%}.login-header{margin-bottom:2.5rem;text-align:center}.logo-circle{align-items:center;background:#2563eb;border-radius:50%;box-shadow:0 2px 4px #2563eb33;display:flex;height:64px;justify-content:center;margin:0 auto 1.5rem;width:64px}.logo-circle span{color:#fff;font-size:2rem;font-weight:700}.login-header h1{color:#1e293b;font-size:1.875rem;font-weight:600;margin-bottom:.5rem}.login-header p{color:#64748b;font-size:.9375rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-form .form-group{display:flex;flex-direction:column;gap:.5rem}.login-form label{color:#475569;font-size:.875rem;font-weight:500}.login-form input{border:1px solid #cbd5e1;border-radius:6px;color:#1e293b;font-size:.9375rem;padding:.75rem;transition:all .2s}.login-form input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.login-form input:disabled{background:#f1f5f9;cursor:not-allowed}.login-error{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#991b1b;font-size:.875rem;padding:.75rem;text-align:center}.login-button{background:#2563eb;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:.875rem;transition:all .2s}.login-button:hover:not(:disabled){background:#1d4ed8;box-shadow:0 4px 6px #2563eb33}.login-button:disabled{cursor:not-allowed;opacity:.6}.login-footer{border-top:1px solid #e2e8f0;margin-top:2rem;padding-top:2rem;text-align:center}.help-text{color:#64748b;font-size:.875rem;margin-bottom:.5rem}.default-account-hint{color:#94a3b8;font-size:.75rem;font-style:italic}@media (max-width:640px){.login-container{padding:2rem 1.5rem}.login-header h1{font-size:1.5rem}}.admin-container{margin:0 auto;max-width:1400px}.admin-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.admin-header h1{color:#1e293b;font-size:2rem;font-weight:600;margin:0 0 .25rem}.admin-header p{color:#64748b;font-size:.9375rem;margin:0}.create-user-button{align-items:center;background:#2563eb;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9375rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:background .2s}.create-user-button:hover{background:#1d4ed8}.create-user-button svg{height:20px;width:20px}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 3px #0000000d;padding:1.5rem}.stat-label{color:#64748b;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.stat-value{color:#1e293b;font-size:2rem;font-weight:700}.users-table-container{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 3px #0000000d;overflow-x:auto}.users-table{border-collapse:collapse;width:100%}.users-table thead{background:#f8fafc;border-bottom:1px solid #e2e8f0}.users-table th{color:#64748b;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.75rem 1rem;text-align:left;text-transform:uppercase}.users-table td{border-bottom:1px solid #f1f5f9;color:#475569;font-size:.875rem;padding:1rem}.users-table tbody tr:hover{background:#f8fafc}.user-cell{gap:.75rem}.user-avatar-table,.user-cell{align-items:center;display:flex}.user-avatar-table{background:#e2e8f0;border-radius:50%;color:#475569;flex-shrink:0;font-size:.875rem;font-weight:600;height:36px;justify-content:center;width:36px}.user-full-name{color:#1e293b;font-size:.9375rem;font-weight:500}.user-username{color:#94a3b8;font-size:.8125rem}.date-cell{color:#64748b;font-size:.8125rem}.badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.025em;padding:.25rem .75rem;text-transform:uppercase}.badge-admin{background:#dbeafe;color:#1e40af}.badge-user{background:#f1f5f9;color:#475569}.badge-active{background:#dcfce7;color:#166534}.badge-inactive{background:#fee2e2;color:#991b1b}.action-buttons{display:flex;gap:.5rem}.action-btn{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;cursor:pointer;display:flex;justify-content:center;padding:.375rem;transition:all .2s}.action-btn svg{height:16px;width:16px}.edit-btn{color:#2563eb}.edit-btn:hover{background:#eff6ff;border-color:#2563eb}.toggle-admin-btn{color:#7c3aed}.toggle-admin-btn:hover{background:#faf5ff;border-color:#7c3aed}.activate-btn{color:#10b981}.activate-btn:hover{background:#f0fdf4;border-color:#10b981}.deactivate-btn{color:#ef4444}.deactivate-btn:hover{background:#fef2f2;border-color:#ef4444}.modal-overlay{animation:fadeIn .2s;background:#00000080;inset:0;position:fixed;z-index:50}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{animation:slideIn .2s;background:#fff;border-radius:8px;box-shadow:0 10px 15px #0000001a;left:50%;max-height:90vh;max-width:500px;overflow-y:auto;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%;z-index:51}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1.5rem}.modal-header h2{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0}.modal-close{background:none;border:none;color:#64748b;cursor:pointer;padding:.25rem;transition:color .2s}.modal-close:hover{color:#1e293b}.modal-close svg{height:24px;width:24px}.modal-form{padding:1.5rem}.modal-form .form-group{margin-bottom:1.25rem}.modal-form label{color:#475569;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.modal-form input[type=email],.modal-form input[type=password],.modal-form input[type=text]{border:1px solid #cbd5e1;border-radius:6px;font-size:.9375rem;padding:.75rem;transition:border-color .2s;width:100%}.modal-form input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.modal-form input:disabled{background:#f1f5f9;color:#94a3b8;cursor:not-allowed}.field-hint{color:#94a3b8;display:block;font-size:.8125rem;font-style:italic;margin-top:.375rem}.checkbox-label-modal{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;display:flex;gap:.5rem;padding:.75rem;transition:all .2s}.checkbox-label-modal:hover{background:#eff6ff;border-color:#bfdbfe}.checkbox-label-modal input[type=checkbox]{accent-color:#2563eb;cursor:pointer;height:18px;width:18px}.checkbox-label-modal span{color:#1e293b;font-weight:500}.user-status-display{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;gap:2rem;margin-bottom:1.25rem;padding:1rem}.user-status-display>div{display:flex;flex-direction:column;gap:.5rem}.user-status-display strong{color:#64748b;font-size:.75rem;font-weight:600;text-transform:uppercase}.modal-actions{border-top:1px solid #e2e8f0;display:flex;gap:.75rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem}.cancel-button{background:#fff;border:1px solid #cbd5e1;border-radius:6px;color:#475569;cursor:pointer;font-size:.9375rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.cancel-button:hover{background:#f8fafc;border-color:#94a3b8}.submit-button{background:#2563eb;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9375rem;font-weight:600;padding:.75rem 1.5rem;transition:background .2s}.submit-button:hover{background:#1d4ed8}@media (max-width:768px){.admin-header{align-items:flex-start;flex-direction:column}.stats-grid{grid-template-columns:1fr}.users-table{min-width:800px}.modal{max-width:95%}.user-status-display{flex-direction:column;gap:1rem}}.sidebar{background:#1e293b;box-shadow:2px 0 8px #0000001a;display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;transition:transform .3s ease;width:260px;z-index:40}@media (max-width:1024px){.sidebar{transform:translateX(-100%)}.sidebar-mobile-open{transform:translateX(0)}}@media (min-width:1024px){.sidebar{transform:translateX(0)}}.sidebar-overlay{display:none}@media (max-width:1024px){.sidebar-overlay{background:#00000080;display:block;inset:0;position:fixed;z-index:30}}.sidebar-logo{background:#0f172a;border-bottom:1px solid #334155;padding:1.5rem 1rem}.logo-icon,.sidebar-logo{align-items:center;display:flex}.logo-icon{background:#2563eb;border-radius:8px;flex-shrink:0;height:40px;justify-content:center;width:40px}.logo-icon span{color:#fff;font-size:1.5rem;font-weight:700}.logo-text{margin-left:.75rem}.logo-text h2{color:#fff;font-size:1.125rem;font-weight:600;line-height:1.2;margin:0}.logo-text p{color:#94a3b8;font-size:.75rem;margin:0}.sidebar-nav{flex:1 1;overflow-y:auto;padding:1rem .75rem}.nav-item{align-items:center;background:#0000;border:none;border-radius:6px;color:#cbd5e1;cursor:pointer;display:flex;font-size:.9375rem;font-weight:500;margin-bottom:.25rem;padding:.75rem 1rem;text-align:left;transition:all .2s;width:100%}.nav-item:hover{background:#334155;color:#fff}.nav-item-active{background:#2563eb;color:#fff}.nav-item-active:hover{background:#1d4ed8}.nav-icon{flex-shrink:0;height:20px;margin-right:.75rem;width:20px}.sidebar-user{background:#0f172a;border-top:1px solid #334155;gap:.75rem;padding:1rem}.sidebar-user,.user-avatar{align-items:center;display:flex}.user-avatar{background:#475569;border-radius:50%;flex-shrink:0;height:36px;justify-content:center;width:36px}.user-avatar span{color:#fff;font-size:.875rem;font-weight:600}.user-info{flex:1 1;min-width:0}.user-name{color:#f1f5f9;font-size:.875rem;font-weight:500;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{color:#94a3b8;font-size:.75rem;margin:0;text-transform:capitalize}.topbar{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d;position:-webkit-sticky;position:sticky;top:0;z-index:20}.topbar-content{align-items:center;display:flex;height:64px;justify-content:space-between;padding:0 1.5rem}.mobile-menu-button{background:none;border:none;color:#64748b;cursor:pointer;display:none;padding:.5rem;transition:color .2s}.mobile-menu-button:hover{color:#1e293b}.mobile-menu-button svg{height:24px;width:24px}@media (max-width:1024px){.mobile-menu-button{display:block}}.status-indicator{align-items:center;display:flex;gap:.5rem}.status-dot{animation:pulse 2s ease-in-out infinite;background:#10b981;border-radius:50%;height:8px;width:8px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-indicator span{color:#64748b;font-size:.875rem;font-weight:500}.user-menu-container{position:relative}.user-menu-button{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;display:flex;gap:.75rem;padding:.5rem 1rem;transition:all .2s}.user-menu-button:hover{background:#f1f5f9;border-color:#cbd5e1}.user-avatar-small{align-items:center;background:#2563eb;border-radius:50%;display:flex;height:32px;justify-content:center;width:32px}.user-avatar-small span{color:#fff;font-size:.875rem;font-weight:600}.user-name-topbar{color:#1e293b;font-size:.9375rem;font-weight:500}.chevron-icon{color:#64748b;height:16px;width:16px}.menu-overlay{inset:0;position:fixed;z-index:40}.user-dropdown{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 6px #0000001a;min-width:240px;overflow:hidden;position:absolute;right:0;top:calc(100% + .5rem);z-index:50}.dropdown-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:1rem}.dropdown-user-name{color:#1e293b;font-size:.9375rem;font-weight:600;margin:0 0 .25rem}.dropdown-user-email{color:#64748b;font-size:.8125rem;margin:0 0 .25rem}.dropdown-user-role{color:#2563eb;font-size:.75rem;font-weight:600;letter-spacing:.025em;margin:0;text-transform:uppercase}.dropdown-divider{background:#e2e8f0;height:1px}.dropdown-item{align-items:center;background:none;border:none;color:#475569;cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.75rem 1rem;text-align:left;transition:background .2s;width:100%}.dropdown-item:hover{background:#f8fafc;color:#1e293b}.dropdown-item svg{height:18px;width:18px}@media (max-width:640px){.user-name-topbar{display:none}}.layout-container{background:#f8fafc;display:flex;min-height:100vh}.layout-main{display:flex;flex:1 1;flex-direction:column;min-width:0;transition:margin-left .3s ease}@media (min-width:1024px){.layout-main{margin-left:260px}}.layout-content{flex:1 1;overflow-y:auto;padding:2rem}.layout-main--full{height:100vh;overflow:hidden}.layout-content--full{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden;padding:0}@media (max-width:1024px){.layout-main{margin-left:0}.layout-content{padding:1.5rem 1rem}.layout-main--full{height:100vh;overflow:hidden}.layout-content--full{flex:1 1;min-height:0;padding:0}}.layout-content .admin-container,.layout-content .explore-data-chat-container,.layout-content .explore-data-container,.layout-content .prediction-container,.layout-content .recipe-generator-container{margin-top:0}
/*# sourceMappingURL=main.681c06f3.css.map*/