@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=IBM+Plex+Sans:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600;700&family=Noto+Sans+SC:wght@300;400;500;600;700&display=swap";*{box-sizing:border-box;margin:0;padding:0}:root{--bg-page: #f1f5f9;--bg-canvas: #f8fafc;--bg-card: #ffffff;--bg-card-tint: #f8fafc;--bg-hover: #e0f2fe;--bg-active: #dbeafe;--bg-input: #f1f5f9;--border: #e2e8f0;--border-strong: #cbd5e1;--border-active: #38bdf8;--text: #0f172a;--text-2: #475569;--text-3: #64748b;--text-4: #94a3b8;--accent: #0284c7;--accent-2: #0ea5e9;--accent-light: #e0f2fe;--teal: #0d9488;--warning: #ea580c;--danger: #dc2626;--success: #059669;--violet: #7c3aed;--shadow-sm: 0 1px 2px rgba(15,23,42,.04);--shadow: 0 1px 3px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);--shadow-md: 0 4px 12px rgba(15,23,42,.06), 0 2px 4px rgba(15,23,42,.04);--shadow-lg: 0 12px 32px rgba(15,23,42,.1), 0 4px 8px rgba(15,23,42,.04)}body{background:var(--bg-page)}.solpred-root{font-family:IBM Plex Sans,Noto Sans SC,sans-serif;background:var(--bg-page);color:var(--text);height:100vh;display:flex;flex-direction:column;overflow:hidden;font-size:13px;line-height:1.5;letter-spacing:-.005em}.solpred-root:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 1200px 800px at 100% 0%,rgba(186,230,253,.35),transparent 60%),radial-gradient(ellipse 800px 600px at 0% 100%,rgba(199,210,254,.22),transparent 60%);pointer-events:none;z-index:0}.topbar{height:60px;background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:18px;flex-shrink:0;z-index:30;position:relative}.brand{display:flex;align-items:center;gap:11px}.brand-mark{width:36px;height:36px;background:linear-gradient(135deg,#0284c7,#0ea5e9 60%,#38bdf8);border-radius:9px;display:grid;place-items:center;box-shadow:0 4px 12px #0284c740;position:relative}.brand-mark:after{content:"";position:absolute;inset:1px;border-radius:8px;background:linear-gradient(135deg,transparent 50%,rgba(255,255,255,.25) 100%)}.brand-mark svg{position:relative;z-index:1}.brand-text{display:flex;flex-direction:column}.brand-name{font-family:Bricolage Grotesque,sans-serif;font-size:19px;font-weight:700;letter-spacing:-.02em;color:var(--text);line-height:1}.brand-sub{font-size:10px;font-weight:500;color:var(--text-3);letter-spacing:.06em;text-transform:uppercase;margin-top:2px}.breadcrumb{display:flex;align-items:center;gap:8px;padding:6px 14px;background:var(--bg-card-tint);border:1px solid var(--border);border-radius:8px;font-size:12px;color:var(--text-2)}.breadcrumb strong{color:var(--text);font-weight:600}.breadcrumb .formula{font-family:IBM Plex Sans,sans-serif;font-weight:600}.breadcrumb .sep{color:var(--text-4)}.global-search{display:flex;align-items:center;gap:8px;padding:7px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;width:280px;transition:all .15s}.global-search:focus-within{border-color:var(--border-active);box-shadow:0 0 0 3px #38bdf826}.global-search input{background:transparent;border:none;outline:none;font-family:inherit;font-size:12px;color:var(--text);width:100%}.kbd{font-family:JetBrains Mono,monospace;font-size:10px;padding:2px 6px;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;color:var(--text-3)}.topbar-spacer{flex:1}.top-stat{display:flex;flex-direction:column;align-items:flex-end;padding:0 14px;border-left:1px solid var(--border);min-width:70px}.top-stat-label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.top-stat-value{font-family:JetBrains Mono,monospace;font-size:13px;font-weight:700;color:var(--text)}.top-stat-value.accent{color:var(--accent)}.top-stat-value.success{color:var(--success)}.pulse-dot{width:7px;height:7px;border-radius:50%;background:var(--success);box-shadow:0 0 #05966999;animation:pulse 2.4s infinite;display:inline-block;margin-right:6px}@keyframes pulse{0%{box-shadow:0 0 #05966999}70%{box-shadow:0 0 0 8px #05966900}to{box-shadow:0 0 #05966900}}.icon-btn{width:34px;height:34px;display:grid;place-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;cursor:pointer;color:var(--text-2);transition:all .15s}.icon-btn:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--border-active)}.avatar{width:34px;height:34px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:8px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px;font-family:JetBrains Mono,monospace;cursor:pointer}.main{display:flex;flex:1;overflow:hidden;position:relative;z-index:1}.sidebar{width:296px;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:16px 18px 12px;border-bottom:1px solid var(--border)}.section-tag{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:10px}.section-tag:before{content:"";width:4px;height:4px;background:var(--accent);border-radius:50%}.sidebar-search{display:flex;align-items:center;gap:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;padding:7px 10px;transition:all .15s}.sidebar-search:focus-within{border-color:var(--border-active);background:var(--bg-card);box-shadow:0 0 0 3px #38bdf81f}.sidebar-search input{background:transparent;border:none;outline:none;font-family:inherit;font-size:12px;color:var(--text);width:100%}.filter-section{padding:14px 18px;border-bottom:1px solid var(--border);background:var(--bg-card)}.filter-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.filter-title{font-size:12px;font-weight:700;color:var(--text);letter-spacing:.02em}.filter-hint{font-size:11px;color:var(--accent);cursor:pointer;font-weight:500;transition:color .15s}.filter-hint:hover{color:var(--text);text-decoration:underline}.molecule-grid{display:flex;flex-wrap:wrap;gap:6px}.molecule-pill{padding:7px 14px;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:999px;font-family:IBM Plex Sans,Noto Sans SC,sans-serif;font-size:12px;font-weight:600;color:var(--text);cursor:pointer;transition:all .18s cubic-bezier(.4,0,.2,1);user-select:none;letter-spacing:-.01em}.molecule-pill:hover{border-color:var(--text);background:var(--bg-card-tint);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.molecule-pill.active{background:var(--text);color:#fff;border-color:var(--text);box-shadow:0 4px 12px #0f172a2e}.empty-state{padding:40px 20px;text-align:center;color:var(--text-3)}.system-list{flex:1;overflow-y:auto;padding:8px}.system-list::-webkit-scrollbar{width:6px}.system-list::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.system-list::-webkit-scrollbar-track{background:transparent}.system-card{padding:12px 13px;border-radius:10px;cursor:pointer;transition:all .15s;margin-bottom:4px;border:1px solid transparent;position:relative}.system-card:hover{background:var(--bg-card-tint);border-color:var(--border)}.system-card.active{background:linear-gradient(135deg,#bae6fd80,#dbeafe66);border-color:var(--border-active);box-shadow:var(--shadow-sm)}.system-card.active:before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:3px;background:var(--accent);border-radius:0 2px 2px 0}.system-id-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.system-id{font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600;color:var(--text-3)}.status-chip{font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;letter-spacing:.05em;text-transform:uppercase}.status-chip.production{background:#0596691a;color:var(--success)}.status-chip.training{background:#ea580c1a;color:var(--warning)}.status-chip.queued{background:#64748b1a;color:var(--text-3)}.system-formula{font-size:14px;font-weight:700;color:var(--text);margin-bottom:6px;letter-spacing:-.01em}.system-meta{display:flex;gap:11px;font-size:10px;color:var(--text-3);font-family:JetBrains Mono,monospace}.system-meta span{display:inline-flex;align-items:center;gap:4px}.system-meta .dot{width:6px;height:6px;border-radius:50%}.system-meta .dot.green{background:var(--success)}.system-meta .dot.amber{background:var(--warning)}.system-meta .dot.gray{background:var(--text-4)}.sidebar-footer{padding:14px 18px;border-top:1px solid var(--border);background:var(--bg-card-tint)}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.stat-mini{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:8px 10px}.stat-mini-label{font-size:9px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.stat-mini-value{font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700;color:var(--text);margin-top:2px}.content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.meta-bar{padding:14px 24px;background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:24px;flex-shrink:0}.meta-title-block{display:flex;flex-direction:column;gap:4px}.meta-title{font-family:Bricolage Grotesque,sans-serif;font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.02em;line-height:1.1}.meta-subtitle{font-size:11px;color:var(--text-3);font-family:JetBrains Mono,monospace}.meta-stats{display:flex;gap:0;margin-left:auto;align-items:stretch}.meta-stat{padding:0 18px;border-left:1px solid var(--border);display:flex;flex-direction:column;justify-content:center;min-width:90px}.meta-stat:first-child{border-left:none;padding-left:0}.meta-stat-label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.meta-stat-value{font-family:JetBrains Mono,monospace;font-size:18px;font-weight:700;color:var(--text);margin-top:1px}.meta-stat-value.accent{color:var(--accent)}.meta-stat-value.success{color:var(--success)}.meta-stat-sub{font-size:10px;color:var(--text-3);font-family:JetBrains Mono,monospace;margin-top:1px}.tabbar{display:flex;gap:2px;padding:0 16px;background:var(--bg-card);border-bottom:1px solid var(--border);overflow-x:auto;flex-shrink:0}.tabbar::-webkit-scrollbar{display:none}.tab{padding:11px 16px;font-size:12px;font-weight:600;color:var(--text-3);cursor:pointer;border-bottom:2px solid transparent;display:flex;align-items:center;gap:7px;white-space:nowrap;transition:all .15s;user-select:none;position:relative}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-icon{font-family:JetBrains Mono,monospace;font-size:13px;opacity:.65}.tab.active .tab-icon{opacity:1}.tab-desc{font-family:JetBrains Mono,monospace;font-size:9px;color:var(--text-4);letter-spacing:.05em;text-transform:uppercase}.workspace{flex:1;display:flex;overflow:hidden;min-height:0}.canvas-area{flex:1;display:flex;flex-direction:column;padding:20px 24px;overflow-y:auto;background:var(--bg-page);min-width:0}.canvas-area::-webkit-scrollbar{width:8px}.canvas-area::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}.canvas-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-sm);padding:18px;position:relative}.canvas-card.full{flex:1;display:flex;flex-direction:column;min-height:540px}.canvas-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--border)}.canvas-title{font-family:Bricolage Grotesque,sans-serif;font-size:16px;font-weight:700;letter-spacing:-.01em;color:var(--text)}.canvas-subtitle{font-size:11px;color:var(--text-3);font-family:JetBrains Mono,monospace}.canvas-tools{margin-left:auto;display:flex;align-items:center;gap:8px}.tool-btn{padding:5px 11px;font-size:11px;font-weight:500;color:var(--text-2);background:var(--bg-card-tint);border:1px solid var(--border);border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:all .15s}.tool-btn:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--border-active)}.tool-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.diagram-box{flex:1;display:grid;place-items:center;min-height:460px;position:relative}.diagram-svg-wrap{width:100%;max-width:600px;height:100%;max-height:540px}.rightpanel{width:320px;background:var(--bg-card);border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.rightpanel::-webkit-scrollbar{width:6px}.rightpanel::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.panel-section{padding:16px 18px;border-bottom:1px solid var(--border)}.panel-section:last-child{border-bottom:none}.panel-title{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:12px;display:flex;align-items:center;gap:6px}.panel-title:before{content:"";width:3px;height:12px;background:var(--accent);border-radius:2px}.temp-display{display:flex;align-items:baseline;gap:4px;margin-bottom:14px;font-family:Bricolage Grotesque,sans-serif}.temp-value{font-size:40px;font-weight:700;color:var(--text);letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums}.temp-unit{font-size:18px;color:var(--text-3);font-weight:500}.temp-state{margin-left:auto;font-size:10px;padding:3px 8px;border-radius:5px;font-family:JetBrains Mono,monospace;font-weight:600}.temp-state.predicting{background:#0284c71a;color:var(--accent)}.temp-state.idle{background:#0596691a;color:var(--success)}.temp-slider-wrap{position:relative;padding:6px 0}.temp-slider{width:100%;-webkit-appearance:none;appearance:none;height:4px;background:linear-gradient(90deg,#38bdf8,#fbbf24,#ef4444);border-radius:999px;outline:none;cursor:pointer}.temp-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;background:#fff;border:2px solid var(--text);border-radius:50%;cursor:grab;box-shadow:var(--shadow)}.temp-slider::-moz-range-thumb{width:18px;height:18px;background:#fff;border:2px solid var(--text);border-radius:50%;cursor:grab}.temp-range{display:flex;justify-content:space-between;margin-top:6px;font-size:10px;color:var(--text-3);font-family:JetBrains Mono,monospace}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0}.toggle-row+.toggle-row{border-top:1px solid var(--border)}.toggle-label{font-size:12px;color:var(--text);font-weight:500}.toggle{width:32px;height:18px;background:var(--bg-input);border-radius:999px;position:relative;cursor:pointer;transition:background .2s;border:1px solid var(--border)}.toggle.on{background:var(--accent);border-color:var(--accent)}.toggle-knob{position:absolute;top:1px;left:1px;width:14px;height:14px;background:#fff;border-radius:50%;transition:left .2s;box-shadow:var(--shadow-sm)}.toggle.on .toggle-knob{left:15px}.phase-legend{display:flex;flex-direction:column;gap:4px}.phase-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:7px;cursor:pointer;font-size:12px;transition:background .15s;border:1px solid transparent}.phase-item:hover{background:var(--bg-card-tint)}.phase-item.active{background:var(--bg-active);border-color:var(--border-active)}.phase-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.phase-name{flex:1;color:var(--text)}.phase-count{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--text-3)}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.info-card{background:var(--bg-card-tint);border:1px solid var(--border);border-radius:8px;padding:9px 11px}.info-card-label{font-size:9px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-bottom:2px}.info-card-value{font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.01em;font-variant-numeric:tabular-nums}.input-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.input-label{font-size:11px;color:var(--text-2);font-weight:500;width:50px}.input-num{flex:1;padding:6px 10px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:600;color:var(--text);outline:none;transition:all .15s}.input-num:focus{border-color:var(--border-active);background:var(--bg-card);box-shadow:0 0 0 3px #38bdf81f}.predict-btn{width:100%;padding:11px 16px;background:var(--text);color:#fff;border:none;border-radius:8px;font-family:inherit;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--shadow)}.predict-btn:hover{background:var(--accent);transform:translateY(-1px);box-shadow:var(--shadow-md)}.predict-btn:disabled{background:var(--text-3);cursor:not-allowed;transform:none}.live-result{margin-top:14px;padding:14px;background:linear-gradient(135deg,var(--accent-light),#f0f9ff);border:1px solid var(--border-active);border-radius:10px}.live-result-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:12px}.live-result-row+.live-result-row{border-top:1px dashed rgba(56,189,248,.4)}.live-result-label{color:var(--text-2)}.live-result-value{font-family:JetBrains Mono,monospace;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.live-result-value.accent{color:var(--accent)}.live-result-value.danger{color:var(--danger)}.live-result-value.success{color:var(--success)}.data-table-wrap{flex:1;overflow-x:auto;overflow-y:auto}table.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:12px}.data-table thead th{position:sticky;top:0;z-index:1;background:var(--bg-card-tint);padding:10px 14px;text-align:left;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);border-bottom:1px solid var(--border);white-space:nowrap}.data-table tbody td{padding:10px 14px;border-bottom:1px solid var(--border);font-family:JetBrains Mono,monospace;color:var(--text);font-variant-numeric:tabular-nums}.data-table tbody tr:hover{background:var(--bg-card-tint)}.data-table tbody tr.row-selected{background:linear-gradient(90deg,#0284c71a,#0284c70a)!important;box-shadow:inset 3px 0 0 var(--accent)}.data-table tbody tr.row-selected td:first-child{color:var(--accent)!important;font-weight:800}.phase-tag{display:inline-block;font-family:IBM Plex Sans,sans-serif;padding:2px 8px;border-radius:5px;font-size:10px;font-weight:600}.diag-grid{display:grid;gap:16px;grid-template-columns:1.2fr 1fr}.diag-summary{grid-column:1 / -1;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.metric-card{padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;position:relative;overflow:hidden}.metric-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent)}.metric-card.success:before{background:var(--success)}.metric-card.warn:before{background:var(--warning)}.metric-card.violet:before{background:var(--violet)}.metric-label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:700;margin-bottom:6px}.metric-value{font-family:Bricolage Grotesque,sans-serif;font-size:26px;font-weight:700;color:var(--text);letter-spacing:-.02em;line-height:1}.metric-sub{font-size:11px;color:var(--text-3);font-family:JetBrains Mono,monospace;margin-top:4px}.statusbar{height:28px;background:var(--bg-card);border-top:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:16px;font-size:10px;color:var(--text-3);font-family:JetBrains Mono,monospace;flex-shrink:0;position:relative;z-index:5}.statusbar .right{margin-left:auto}.status-divider{width:1px;height:14px;background:var(--border)}.fade-in{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.detail-panel{display:flex;flex-direction:column;gap:4px}.detail-tag{display:inline-block;padding:5px 10px;border-radius:999px;font-size:11px;font-weight:700;width:fit-content;margin-bottom:8px;letter-spacing:.02em}.detail-grid{background:var(--bg-card-tint);border:1px solid var(--border);border-radius:8px;padding:4px 0}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:7px 12px;font-size:11px}.detail-row+.detail-row{border-top:1px solid var(--border)}.detail-row.highlight{background:#0284c70f;font-weight:600}.detail-key{color:var(--text-2);font-family:IBM Plex Sans,sans-serif}.detail-val{font-family:JetBrains Mono,monospace;font-weight:700;color:var(--text);font-size:12px;font-variant-numeric:tabular-nums}.detail-phase{margin-top:8px;padding:10px 12px;background:var(--bg-card-tint);border:1px solid var(--border);border-left:3px solid currentColor;border-radius:8px}.detail-clear{margin-top:12px;padding:7px 14px;background:transparent;color:var(--text-3);border:1px solid var(--border);border-radius:6px;font-family:inherit;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}.detail-clear:hover{background:var(--bg-card-tint);color:var(--danger);border-color:var(--danger)}.detail-empty{padding:24px 16px;text-align:center;background:var(--bg-card-tint);border:1px dashed var(--border-strong);border-radius:8px}
