:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:16px;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-primary: #f5f7fa;--bg-secondary: #ffffff;--bg-tertiary: #fafafa;--bg-panel: #ffffff;--bg-panel-secondary: #f8f9fa;--bg-image: #ffffff;--highlight-image-bg: #fff5f5;--text-primary: #2c3e50;--text-secondary: #6c757d;--text-tertiary: #495057;--label-node: #000000;--label-by-molecule: #000000;--label-by-molecule-hover: #4a90e2;--border-color: #dee2e6;--border-color-light: #e9ecef;--shadow: rgba(0, 0, 0, .1);--shadow-dark: rgba(0, 0, 0, .2);color:var(--text-primary);background-color:var(--bg-primary)}[data-theme=dark]{--bg-primary: #000000;--bg-secondary: #000000;--bg-tertiary: #000000;--bg-panel: #000000;--bg-panel-secondary: #000000;--bg-image: #000000;--highlight-image-bg: #000000;--text-primary: #e0e0e0;--text-secondary: #b0b0b0;--text-tertiary: #909090;--label-node: #f0f0f0;--label-by-molecule: #b8c5d9;--label-by-molecule-hover: #7db8d9;--border-color: #404040;--border-color-light: #353535;--shadow: rgba(0, 0, 0, .3);--shadow-dark: rgba(0, 0, 0, .5)}*{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden;background-color:var(--bg-primary)}body{min-width:320px;min-height:100vh;background-color:var(--bg-primary)}.app-container{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-title{transition:opacity .3s ease}.pathway-info{margin-top:1rem}.pathway-info h2{margin:0 0 .5rem;font-size:1.3rem;font-weight:500}.pathway-info p{margin:0 0 1rem;font-size:.9rem;opacity:.95}.pathway-stats{display:flex;gap:2rem;flex-wrap:wrap}.stat{display:flex;gap:.5rem;align-items:center}.stat-label{font-size:.9rem;opacity:.9}.stat-value{font-size:1.1rem;font-weight:600;background:#fff3;padding:.25rem .75rem;border-radius:4px}.main-content{display:flex;flex-direction:row;flex:1;overflow:hidden;gap:0;padding:0}.viewer-panel{flex:1 1 0%;display:flex;flex-direction:column;background:var(--bg-tertiary);overflow:hidden;min-height:0;min-width:0;position:relative}.panel-resizer{width:4px;background-color:var(--border-color-light);cursor:col-resize;-webkit-user-select:none;user-select:none;flex-shrink:0;position:relative;transition:background-color .2s}.panel-resizer:hover,.panel-resizer.active{background-color:#667eea}.viewer-controls{padding:1rem;background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.control-btn{padding:.5rem 1rem;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s}.control-btn:hover{background:#5568d3}.zoom-hint{font-size:.85rem;color:#6c757d}.metabolism-viewer{flex:1 1 auto;overflow:hidden;position:relative;min-height:400px;min-width:400px;width:100%;height:100%;box-sizing:border-box;max-width:100%;max-height:100%}.metabolism-viewer svg{width:100%;height:100%;display:block}.detail-panel{min-width:200px;max-width:50%;background:var(--bg-panel);display:flex;flex-direction:column;overflow:hidden;position:relative}.detail-tabs{display:flex;border-bottom:2px solid var(--border-color-light);background:var(--bg-panel-secondary);gap:0}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;font-size:.875rem;font-weight:500;line-height:1.25rem;border-radius:.375rem;border:none;cursor:pointer;transition:all .2s;margin:0;box-sizing:border-box;vertical-align:middle;text-align:center}.detail-tab{flex:1;padding:.75rem 1rem;margin:0;background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;font-weight:500;color:var(--text-secondary);transition:all .2s;box-sizing:border-box;vertical-align:middle;text-align:center}.detail-tab:hover{background:var(--border-color-light);color:var(--text-primary)}.detail-tab.active{color:#667eea;border-bottom-color:#667eea;background:var(--bg-panel)}.detail-content{flex:1;overflow-y:auto;overflow-x:hidden;position:relative}.detail-view{display:none;padding:1.5rem;height:100%}.detail-view.active{display:block}.molecule-detail-container{padding:1.5rem}.detail-placeholder{padding:3rem 2rem;text-align:center;color:var(--text-secondary);font-size:1.1rem}.pathway-button.btn rect,.help-button.btn circle{transition:all .2s ease}.pathway-button.btn text{transition:fill .1s ease}.pathway-button.btn:hover rect,.help-button.btn:hover circle{filter:brightness(.9)}.pathway-button.btn{opacity:.33;transition:opacity .2s ease}.pathway-button.btn:hover{opacity:1}.help-tooltip.btn rect{transition:opacity .2s ease}.reaction-detail{display:flex;flex-direction:column;gap:1.5rem}.reaction-flow{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.5rem;background:var(--bg-panel-secondary);border-radius:6px}.reaction-reactants{display:flex;flex-direction:column;gap:.5rem;flex:1}.reaction-molecule{flex:1;min-width:120px;text-align:center;padding:.5rem;background:var(--bg-panel);border-radius:4px;border:1px solid var(--border-color);transition:all .2s}.reaction-molecule.co-reactant,.reaction-molecule.co-product{font-size:.9rem;opacity:.85}.clickable-molecule{cursor:pointer}.clickable-molecule:hover{background:var(--border-color-light);border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.reaction-arrow{font-size:1.5rem;color:#667eea;font-weight:700;margin:0 .25rem}.reaction-products{display:flex;flex-direction:column;gap:.5rem;flex:1}.pathway-detail{display:flex;flex-direction:column;gap:1.5rem}.pathway-description{line-height:1.6;color:var(--text-tertiary)}.pathway-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;padding:1rem;background:var(--bg-panel-secondary);border-radius:6px}.pathway-stat-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:var(--bg-panel);border-radius:4px;border:1px solid #dee2e6;transition:background-color .2s ease,transform .1s ease,border-color .2s ease}.pathway-stat-item:hover{background:var(--bg-panel-secondary);transform:translate(4px);border-color:#4ecdc4}.pathway-stat-item .stat-label{font-weight:500;color:var(--text-primary)}.pathway-stat-item .stat-value{font-weight:600;color:#667eea;font-size:1.1rem}.regulatory-steps{list-style:none;padding:0;margin:0}.regulatory-steps li{padding:.75rem;margin-bottom:.5rem;background:var(--bg-panel-secondary);border-left:3px solid #667eea;border-radius:4px;transition:background-color .2s ease,transform .1s ease,border-left-color .2s ease}.regulatory-steps li:hover{background:var(--bg-panel);transform:translate(4px);border-left-color:#4ecdc4}.pathway-reactions{margin-top:1rem}.reaction-list{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem}.reaction-list .reaction-item{padding:1rem;background:var(--bg-panel-secondary);border-radius:6px;border:1px solid var(--border-color);transition:all .2s}.reaction-list .reaction-item:hover{background:var(--border-color-light);border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26;cursor:pointer}.reaction-selection-note{margin-top:.5rem;padding:.5rem;background:var(--bg-panel);border-radius:4px;font-size:.85rem;color:#667eea;font-style:italic;border-left:3px solid #667eea}.pathway-selection-indicator{margin-top:.5rem;padding:.75rem;background:var(--bg-panel-secondary);border-radius:6px;border-left:4px solid #667eea;font-size:.9rem;color:var(--text-primary);font-weight:500}.reaction-step{font-weight:600;color:#667eea;font-size:.9rem;margin-bottom:.25rem}.reaction-name{font-weight:500;color:var(--text-primary);margin-bottom:.25rem}.reaction-enzyme{font-size:.9rem;color:var(--text-secondary);font-style:italic}.molecule-detail{display:flex;flex-direction:column;gap:1.5rem}.detail-header h2{margin:0;font-size:1.5rem;color:var(--text-primary);border-bottom:2px solid #667eea;padding-bottom:.5rem}.detail-section{background:var(--bg-panel-secondary);padding:1.25rem;border-radius:6px;border-left:4px solid #667eea}.detail-section h3{margin:0 0 1rem;font-size:1.1rem;color:var(--text-primary);font-weight:600}.molecule-info,.enzyme-info,.cosubstrate-info,.byproduct-info{background:var(--bg-panel);padding:1rem;border-radius:4px;margin-bottom:.75rem}.molecule-name,.enzyme-name{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.molecule-formula{font-family:Courier New,monospace;font-size:.95rem;color:var(--text-tertiary);margin-bottom:.5rem}.molecule-description,.enzyme-description{font-size:.9rem;color:var(--text-secondary);margin-top:.5rem;line-height:1.6}.enzyme-ec{font-family:Courier New,monospace;font-size:.9rem;color:#667eea;margin-bottom:.5rem}.enzyme-cofactors{margin-top:.75rem;font-size:.9rem;color:var(--text-tertiary)}.consumed-badge,.reduced-badge{display:inline-block;padding:.25rem .75rem;border-radius:4px;font-size:.85rem;font-weight:500;margin-top:.5rem}.consumed-badge{background:#fff3cd;color:#856404}.reduced-badge{background:#d1ecf1;color:#0c5460}.structure-placeholder{margin-top:1rem}.structure-label{font-size:.85rem;color:var(--text-secondary);margin-bottom:.5rem;font-family:Courier New,monospace}.structure-representation{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:4px;padding:1rem}.structure-simple{text-align:center}.structure-molecule{font-size:1.5rem;font-weight:600;color:#667eea;margin-bottom:.5rem}.structure-note{font-size:.85rem;color:var(--text-secondary);font-style:italic}.pubchem-loading{margin-top:1rem;padding:.75rem;background:var(--bg-panel-secondary);border-radius:4px;text-align:center}.loading-indicator{color:#667eea;font-size:.9rem}.pubchem-data{margin-top:1rem;padding:1rem;background:var(--bg-panel);border:1px solid var(--border-color);border-radius:6px}.pubchem-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.pubchem-link{color:#667eea;text-decoration:none;font-size:.85rem;font-weight:500}.pubchem-link:hover{text-decoration:underline}.pubchem-description{margin-bottom:1rem;padding:1rem;background:var(--bg-panel);border-radius:6px;border-left:3px solid var(--accent-color)}.pubchem-description strong{color:var(--text-tertiary);display:block;margin-bottom:.5rem;font-size:.95rem}.description-text{font-size:.9rem;line-height:1.7;color:var(--text-primary);white-space:pre-wrap}.pubchem-properties{display:flex;flex-direction:column;gap:.5rem}.pubchem-property{font-size:.9rem;line-height:1.6;color:var(--text-primary)}.pubchem-property strong{color:var(--text-tertiary);margin-right:.5rem}.smiles-code,.inchi-code,.inchikey-code{display:block;font-family:Courier New,monospace;font-size:.85rem;background:var(--bg-panel);padding:.5rem;border-radius:4px;margin-top:.25rem;word-break:break-all;border:1px solid var(--border-color)}.pubchem-error{padding:.5rem;color:#856404;font-size:.85rem}.pubchem-error a{color:#667eea;text-decoration:none}.pubchem-error a:hover{text-decoration:underline}.pubchem-structures{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.structure-image-container{flex:1;min-width:200px;max-width:300px}.structure-image-label{font-size:.9rem;font-weight:600;color:var(--text-tertiary);margin-bottom:.5rem;text-align:center}.structure-image-wrapper{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:4px;padding:.5rem;display:flex;align-items:center;justify-content:center;min-height:200px}.structure-image{max-width:100%;height:auto;display:block}[data-theme=dark] .structure-image,[data-theme=dark] image.molecule-structure-image{filter:invert(1) hue-rotate(180deg)}.structure-image-error{color:#856404;font-size:.85rem;text-align:center;padding:1rem}.conditions-info{display:flex;flex-direction:column;gap:.75rem}.condition-item{padding:.75rem;background:var(--bg-panel);border-radius:4px;font-size:.95rem;line-height:1.6}.condition-item strong{color:var(--text-tertiary);margin-right:.5rem}.condition-item.regulation{background:var(--bg-panel-secondary);border-left:3px solid #2196F3}.reaction-node{transition:transform .2s}.connection{transition:stroke-width .2s ease,stroke-opacity .2s ease}.reaction-node:hover{transform:scale(1.1)}.theme-toggle-button{cursor:pointer}.theme-toggle-button circle{transition:all .2s ease}.theme-toggle-button .theme-icon-text{transition:transform .2s ease}.theme-toggle-button:hover .theme-icon-text{transform:rotate(15deg)}.detail-panel::-webkit-scrollbar{width:8px}.detail-panel::-webkit-scrollbar-track{background:var(--bg-panel-secondary)}.detail-panel::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.detail-panel::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.node-label{fill:var(--label-node)}.by-molecule-label{fill:var(--label-by-molecule);transition:fill .2s ease}.by-molecule-label:hover{fill:var(--label-by-molecule-hover)}.h-plus-label{font-size:11px;font-weight:500;fill:#ff6b6b;cursor:pointer;pointer-events:all;transition:fill .2s ease}.h-plus-label:hover{fill:#e74c3c}svg.metabolism-viewer{background:var(--bg-tertiary, #fafafa);cursor:grab;display:block}svg.metabolism-viewer:active{cursor:grabbing}.connection{pointer-events:none}.connection-hit{cursor:pointer;pointer-events:all}.etc-sub-arrow{cursor:pointer;pointer-events:all;stroke-opacity:.8;stroke-width:3;transition:stroke-width .2s ease,stroke-opacity .2s ease}.etc-sub-arrow:hover{stroke-width:4;stroke-opacity:1}.molecule-image-group{display:none}.molecule-image-group.visible{display:block}.molecule-structure-image{filter:none}[data-theme=dark] .molecule-structure-image{filter:invert(1) hue-rotate(180deg)}[data-theme=dark] .molecule-structure-image.no-filter{filter:none!important}[data-theme=dark] image.molecule-structure-image{filter:invert(1) hue-rotate(180deg)}[data-theme=dark] image.molecule-structure-image.no-filter{filter:none!important}.background-click-area{cursor:grab;pointer-events:all}.by-molecule-label{cursor:pointer;pointer-events:all}.by-molecule-label-separator{pointer-events:none}.byreactant-byproduct-arrow path{pointer-events:none}.byreactant-byproduct-arrow .hit-area{cursor:pointer;pointer-events:all}.reaction-node,.help-button{cursor:pointer}.help-tooltip{opacity:0;pointer-events:none;transition:opacity .2s ease}.help-button:hover .help-tooltip{opacity:1}.references-button,.pathway-button{cursor:pointer}.reaction-circle.hidden{display:none!important}.molecule-reaction-search{position:absolute;bottom:20px;right:20px;z-index:1000;width:300px;opacity:.4;transition:opacity .3s ease}.molecule-reaction-search:hover,.molecule-reaction-search.active{opacity:1}.search-input{width:100%;padding:.75rem 1rem;font-size:.9rem;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-panel);color:var(--text-primary);box-shadow:0 2px 8px var(--shadow);transition:all .2s ease}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 2px 12px #667eea4d}.search-input::placeholder{color:var(--text-secondary)}.search-dropdown{position:absolute;bottom:100%;left:0;right:0;margin-bottom:8px;max-height:400px;overflow-y:scroll;overflow-x:hidden;background:var(--bg-panel);border:2px solid var(--border-color);border-radius:8px;box-shadow:0 4px 16px var(--shadow-dark);z-index:1001;contain:layout}.search-section-header{padding:.5rem 1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);background:var(--bg-panel-secondary);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:1}.search-result-item{padding:.75rem calc(1rem + 4px) .75rem 1rem;cursor:pointer;transition:background-color .2s ease,padding-left .2s ease,padding-right .2s ease;border-bottom:1px solid var(--border-color-light);color:var(--text-primary)}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--bg-panel-secondary);padding-left:calc(1rem + 4px);padding-right:1rem;outline:none;border-top:none;border-right:none;border-bottom:1px solid var(--border-color-light)}.search-result-item.molecule-item{border-left:3px solid #5fa8d3}.search-result-item.molecule-item:hover{border-left:3px solid #ffffff}.search-result-item.reaction-item{border-left:3px solid #667eea}.search-result-item.reaction-item:hover{border-left:3px solid #ffffff}.search-result-item.pathway-item{border-left:3px solid #9966ff}.search-result-item.pathway-item:hover{border-left:3px solid #ffffff}.search-result-item.subpathway-item{border-left:3px solid #b399ff}.search-result-item.subpathway-item:hover{border-left:3px solid #ffffff}.search-result-item.no-results{color:var(--text-secondary);font-style:italic;cursor:default;border-left:none}.search-result-item.no-results:hover{background:transparent;transform:none}.search-dropdown::-webkit-scrollbar{width:6px}.search-dropdown::-webkit-scrollbar-track{background:var(--bg-panel-secondary)}.search-dropdown::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.search-dropdown::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.references-modal{display:none;position:fixed;z-index:2000;left:0;top:0;width:100%;height:100%;background-color:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);align-items:center;justify-content:center;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.references-modal-content{background:var(--bg-panel);border-radius:12px;box-shadow:0 8px 32px var(--shadow-dark);max-width:600px;width:90%;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .3s ease;border:1px solid var(--border-color)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.references-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid var(--border-color);background:var(--bg-panel-secondary);border-radius:12px 12px 0 0}.references-modal-header h2{margin:0;font-size:1.5rem;color:var(--text-primary);font-weight:600}.references-modal-close{background:none;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;line-height:1}.references-modal-close:hover{background:var(--border-color-light);color:var(--text-primary);transform:scale(1.1)}.references-modal-body{padding:1.5rem;overflow-y:auto;flex:1}.references-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1.5rem}.references-list li{padding:1rem;background:var(--bg-panel-secondary);border-radius:8px;border-left:4px solid #667eea;transition:all .2s ease}.references-list li:hover{transform:translate(4px);box-shadow:0 4px 12px var(--shadow)}.references-list a{color:#667eea;text-decoration:none;font-size:1.1rem;font-weight:600;display:block;margin-bottom:.5rem;transition:color .2s ease}.references-list a:hover{color:#5568d3;text-decoration:underline}.references-list p{margin:0;color:var(--text-secondary);font-size:.95rem;line-height:1.6}.references-modal-body::-webkit-scrollbar{width:8px}.references-modal-body::-webkit-scrollbar-track{background:var(--bg-panel-secondary)}.references-modal-body::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.references-modal-body::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media (max-width: 1024px){.main-content{flex-direction:column}.viewer-panel,.detail-panel{flex:1}.app-header h1{font-size:1.5rem}.molecule-reaction-search{width:250px;bottom:15px;right:15px}.references-modal-content{width:95%;max-height:90vh}.references-modal-header h2{font-size:1.25rem}.references-list a{font-size:1rem}}.pathway-buttons-scroll-container{position:absolute;top:0;left:0;right:0;height:60px;overflow-x:auto;overflow-y:hidden;z-index:10;pointer-events:none;-webkit-overflow-scrolling:touch}.pathway-buttons-scroll-container::-webkit-scrollbar{height:6px;transition:opacity .3s ease}.pathway-buttons-scroll-container::-webkit-scrollbar-track{background:transparent;transition:opacity .3s ease}.pathway-buttons-scroll-container::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px;opacity:0;transition:opacity .3s ease}.pathway-buttons-scroll-container::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.pathway-buttons-scroll-container.scrolling::-webkit-scrollbar-thumb{opacity:1}.pathway-buttons-scroll-container.scrolling::-webkit-scrollbar-track{opacity:.3}.pathway-buttons-scroll-container{scrollbar-width:thin;scrollbar-color:transparent transparent;transition:scrollbar-color .3s ease}.pathway-buttons-scroll-container.scrolling{scrollbar-color:var(--border-color) transparent}.pathway-buttons-inner{display:inline-flex;align-items:center;gap:15px;padding:20px;pointer-events:auto;min-width:100%}.pathway-button-html{padding:6px 8px;font-size:10px;font-weight:600;border:3px solid #667eea;border-radius:6px;box-sizing:border-box;cursor:pointer;white-space:nowrap;flex-shrink:0;background:transparent;color:var(--text-primary);opacity:.33;transition:all .2s ease;font-family:inherit}[data-theme=dark] .pathway-button-html{color:#fff}.pathway-button-html:hover{opacity:1;background:#667eea;border-color:#667eea;color:#fff}.pathway-button-html.show-all-button{border-color:#667eea}.pathway-button-html.show-all-button:hover{background:#5568d3;border-color:#5568d3}@media (max-width: 1023px){.main-content{flex-direction:column}.viewer-panel{flex:0 0 100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;width:100%}.detail-panel{width:100%;max-width:100%;min-width:100%}.panel-resizer{width:100%;height:8px;cursor:row-resize;background-color:var(--border-color-light)}.panel-resizer:hover,.panel-resizer.active{background-color:#667eea;height:10px}.metabolism-viewer{overflow-x:auto;overflow-y:hidden;min-width:100%}.metabolism-viewer svg{min-width:100%}.pathway-buttons-scroll-container{height:70px}}
