body{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:#1a1a1a;color:#fff;margin:0;padding:0;overflow:hidden}#root{height:100vh;overflow:hidden}.app{height:100vh;display:flex;flex-direction:column;overflow:hidden}.main-container{display:flex;gap:10px;flex:1;overflow:hidden;padding:0 10px 10px;min-height:0}.canvas-section{flex:1;min-width:0;display:flex;align-items:center;justify-content:center;background:#1a1a1a;border:1px solid #444444;border-radius:6px;padding:10px;position:relative}.sidebar{width:450px;flex-shrink:0;background:#2a2a2a;border:1px solid #444444;border-radius:6px;display:flex;flex-direction:column;min-height:0;overflow:hidden}.tab-buttons{display:flex;background:#1a1a1a;border-bottom:1px solid #444444}.tab-button{flex:1;padding:16px;background:transparent;border:none;color:#888;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease;border-bottom:2px solid transparent}.tab-button:hover{background:#3a3a3a;color:#ccc}.tab-button.active{background:#2a2a2a;color:#fff;border-bottom-color:#4caf50}.tab-content{padding:12px;flex:1;overflow-y:auto;min-height:0;box-sizing:content-box}.tab-content::-webkit-scrollbar{width:8px}.tab-content::-webkit-scrollbar-track{background:#1a1a1a;border-radius:4px}.tab-content::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.tab-content::-webkit-scrollbar-thumb:hover{background:#555}.creature-viewer{display:flex;flex-direction:column;height:100%;min-height:0}.creature-viewer h2{color:#fff;margin-bottom:12px;font-size:18px;font-weight:600;flex-shrink:0}.overlay-toggles{display:grid;grid-template-columns:1fr 1fr;gap:8px;background:#2a2a2a;border:1px solid #444444;border-radius:6px;padding:12px;margin-bottom:12px}.overlay-toggle-item{display:flex;align-items:center;gap:10px;background:#1a1a1a;border:1px solid #444444;padding:10px 12px;border-radius:6px;cursor:pointer;transition:all .2s ease}.overlay-toggle-item:hover{background:#3a3a3a;border-color:#666}.overlay-toggle-item:has(input:checked){background:#2a2a2a;border-color:#4caf50}.overlay-checkbox{width:18px;height:18px;accent-color:#4caf50;cursor:pointer;flex-shrink:0}.overlay-label{color:#ccc;font-size:.9rem;font-weight:500;-webkit-user-select:none;user-select:none}.species-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:12px;flex-wrap:wrap}.species-header h3{margin:0;color:#fff;font-size:1.1rem;font-weight:600}.species-header-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.select-all-controls{display:flex;gap:4px;background:#2a2a2a;padding:4px;border-radius:6px;border:1px solid #444444}.select-all-btn{padding:6px 12px;background:transparent;border:none;color:#888;font-weight:600;font-size:.85rem;cursor:pointer;border-radius:6px;transition:all .2s ease}.select-all-btn:hover{background:#3a3a3a;color:#ccc}.select-all-btn:active{transform:scale(.95)}.compare-button{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#3a3a3a;border:1px solid #4caf50;border-radius:6px;color:#4caf50;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease;flex-shrink:0}.compare-button:hover{background:#4a4a4a;border-color:#66bb6a;transform:translateY(-1px)}.compare-button:active{transform:translateY(0)}.species-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;flex-shrink:0;padding:10px}.species-item{display:flex;align-items:center;gap:8px;background:#2a2a2a;border:1px solid #444444;border-radius:6px;overflow:hidden;transition:all .2s ease}.species-item:hover{border-color:#666;background:#3a3a3a;transform:translateY(-1px)}.species-item.selected,.species-item.selected-for-comparison{border-color:#4caf50;background:#2a2a2a}.species-checkbox{appearance:none;-webkit-appearance:none;width:20px;height:20px;margin-left:12px;cursor:pointer;flex-shrink:0;border:2px solid #444444;border-radius:4px;background:#1a1a1a;transition:all .2s ease;position:relative}.species-checkbox:hover{border-color:#4caf50;background:#2a2a2a;transform:scale(1.1)}.species-checkbox:checked{background:#4caf50;border-color:#4caf50}.species-checkbox:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;font-weight:700}.species-item-main{flex:1;display:flex;align-items:center;gap:12px;padding:12px;cursor:pointer}.species-thumb{width:40px;height:40px;border-radius:50%;flex-shrink:0;border:2px solid rgba(255,255,255,.2);box-shadow:0 2px 8px #0000004d;background:#00000026}.species-info{flex:1}.species-name{font-weight:600;color:#fff;font-size:.95rem;margin-bottom:2px}.species-count{font-size:.85rem;color:#888}.species-info-btn{padding:8px 12px;background:#3a3a3a;border:none;border-left:1px solid #444444;color:#ccc;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;height:100%}.species-info-btn:hover{background:#4a4a4a;color:#fff}.species-info-btn:active{transform:scale(.95)}.load-more-controls{display:flex;justify-content:center;align-items:center;gap:12px;padding:16px;background:#2a2a2a;border-radius:6px;margin-top:12px}.load-more-btn{padding:10px 18px;background:#3a3a3a;border:1px solid #555555;border-radius:6px;color:#ccc;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease}.load-more-btn:hover{background:#4a4a4a;border-color:#666;transform:translateY(-1px)}.load-more-btn:active{transform:translateY(0)}.species-details{background:#2a2a2a;border:1px solid #444444;border-radius:6px;padding:16px;margin-top:16px}.species-details h3{color:#fff;margin-bottom:16px;font-size:1.2rem;font-weight:600}.species-details h4{color:#ccc;margin-top:16px;margin-bottom:12px;font-size:1rem;font-weight:600}.species-stats{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.stat-row{display:flex;justify-content:space-between;padding:8px;background:#1a1a1a;border:1px solid #444444;border-radius:6px;font-size:.9rem}.stat-row span:first-child{color:#888}.stat-row span:last-child{color:#fff;font-weight:600}.trait-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.trait-item{display:flex;justify-content:space-between;padding:8px;background:#1a1a1a;border:1px solid #444444;border-radius:6px;font-size:.85rem}.trait-item span:first-child{color:#888}.trait-item span:last-child{color:#fff;font-weight:600}.trait-item.highlight{background:#2a2a2a;border:1px solid #ef4444}.trait-item.highlight span:last-child{color:#ef4444}.genome-display{display:flex;flex-direction:column;gap:12px}.gene-summary{padding:12px;background:#1a1a1a;border:1px solid #444444;border-radius:6px}.gene-name{font-weight:600;color:#fff;margin-bottom:6px;text-transform:capitalize}.gene-seq{font-family:Courier New,monospace;font-size:.75rem;color:#4caf50;background:#2a2a2a;padding:6px;border-radius:4px;margin-bottom:6px;word-break:break-all}.protein-summary{font-size:.75rem;color:#888}.environment-controls{display:flex;flex-direction:column;min-height:0}.environment-controls h2{color:#fff;margin-bottom:12px;font-size:18px;font-weight:600;flex-shrink:0}.control-group{margin-bottom:20px;padding:16px;background:#2a2a2a;border:1px solid #444444;border-radius:6px}.control-group label{display:block;color:#fff;font-weight:600;margin-bottom:8px;font-size:.95rem}.control-group input[type=range]{width:100%;height:4px;background:#444;border-radius:2px;outline:none;appearance:none;-webkit-appearance:none;margin-bottom:8px}.control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:#4caf50;border-radius:50%;cursor:pointer;transition:all .2s ease}.control-group input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}.control-group input[type=range]::-moz-range-thumb{width:16px;height:16px;background:#4caf50;border-radius:50%;cursor:pointer;border:none;transition:all .2s ease}.control-group input[type=range]::-moz-range-thumb:hover{transform:scale(1.2)}.control-value{display:block;color:#4caf50;font-weight:600;font-size:.9rem;margin-top:4px}.controls-description{color:#888;font-size:.85rem;margin-top:8px;font-style:italic}.genome-popup-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;animation:fadeIn .2s ease;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.genome-popup{position:relative;background:#1a1a1a;border:2px solid #444444;border-radius:8px;width:100%;display:flex;flex-direction:column;box-shadow:0 10px 40px #00000080;animation:slideUp .3s ease;z-index:10000;margin:auto}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.genome-popup-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #444444;flex-shrink:0}.genome-popup-title{display:flex;align-items:center;gap:12px;color:#fff}.genome-popup-title h2{font-size:1.5rem;font-weight:600;margin:0}.genome-popup-close{background:#2a2a2a;border:1px solid #444444;border-radius:4px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .2s ease;flex-shrink:0}.genome-popup-close:hover{background:#ef4444;border-color:#dc2626}.genome-popup-content{padding:24px;overflow-y:auto;flex:1}.genome-popup-content::-webkit-scrollbar{width:10px}.genome-popup-content::-webkit-scrollbar-track{background:#1a1a1a;border-radius:5px}.genome-popup-content::-webkit-scrollbar-thumb{background:#444;border-radius:5px}.genome-popup-content::-webkit-scrollbar-thumb:hover{background:#555}.genome-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #444444}.overview-stat{display:flex;flex-direction:column;gap:4px;padding:12px;background:#2a2a2a;border-radius:6px;border:1px solid #444444}.stat-label{font-size:.85rem;color:#888;font-weight:500}.stat-value{font-size:1.1rem;color:#fff;font-weight:700}.genome-genes-section h3{color:#fff;margin-bottom:16px;font-size:1.3rem;font-weight:600}.gene-detail-card{background:#2a2a2a;border:1px solid #444444;border-radius:6px;padding:16px;margin-bottom:16px;transition:all .2s ease}.gene-detail-card:hover{border-color:#666}.gene-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.gene-detail-header h4{color:#fff;font-size:1.1rem;font-weight:600;text-transform:capitalize;margin:0}.gene-length{font-size:.85rem;color:#888;background:#1a1a1a;padding:4px 10px;border-radius:4px}.gene-sequence{margin-bottom:16px}.sequence-label{font-size:.9rem;color:#888;margin-bottom:8px;font-weight:600}.sequence-text{background:#1a1a1a;border:1px solid #444444;border-radius:6px;padding:12px;font-family:Courier New,monospace;font-size:.85rem}.sequence-line{display:flex;gap:12px;margin-bottom:4px}.line-number{color:#555;min-width:50px;text-align:right;-webkit-user-select:none;user-select:none}.sequence-chunk{color:#4caf50;letter-spacing:2px}.protein-section{background:#2a2a2a;border:1px solid #444444;border-radius:6px;padding:12px}.protein-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;color:#fff;font-size:.95rem;font-weight:600}.protein-length{color:#888;font-weight:400}.amino-acid-sequence{margin-bottom:16px}.amino-acids{display:flex;flex-wrap:wrap;gap:4px;padding:12px;background:#1a1a1a;border-radius:6px;margin-top:8px}.amino-acid{display:inline-block;padding:4px 8px;background:#3a3a3a;border:1px solid #444444;border-radius:4px;font-family:Courier New,monospace;font-size:.85rem;font-weight:600;color:#fff;cursor:default;transition:all .2s ease}.amino-acid:hover{transform:translateY(-1px);border-color:#666}.amino-acid.aa-a,.amino-acid.aa-g,.amino-acid.aa-v,.amino-acid.aa-l,.amino-acid.aa-i{background:#2a4a2a;border-color:#4caf50}.amino-acid.aa-f,.amino-acid.aa-w,.amino-acid.aa-y{background:#3a2a4a;border-color:#9c27b0}.amino-acid.aa-k,.amino-acid.aa-r,.amino-acid.aa-h{background:#2a3a4a;border-color:#2196f3}.amino-acid.aa-d,.amino-acid.aa-e{background:#4a2a2a;border-color:#ef4444}.amino-acid.aa-s,.amino-acid.aa-t,.amino-acid.aa-n,.amino-acid.aa-q{background:#2a3a3a;border-color:#00bcd4}.protein-properties{margin-top:12px}.property-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}.property-item{display:flex;justify-content:space-between;padding:8px 10px;background:#1a1a1a;border:1px solid #444444;border-radius:6px;font-size:.85rem}.property-label{color:#888}.property-value{color:#fff;font-weight:600}.radar-chart-container{position:relative;display:flex;flex-direction:column;align-items:center;padding:20px;margin-bottom:24px;background:#2a2a2a;border:1px solid #444444;border-radius:6px}.radar-header{display:flex;align-items:center;gap:16px;width:100%;margin-bottom:16px}.radar-thumbnail{width:80px;height:80px;flex-shrink:0;border-radius:50%;border:2px solid #444444;background:#1a1a1a;overflow:hidden;transition:all .3s ease}.radar-thumbnail:hover{border-color:#666;transform:scale(1.05)}.radar-thumbnail img{width:100%;height:100%;object-fit:cover}.radar-chart-title{color:#fff;font-size:1.4rem;font-weight:600;text-align:left;flex:1;margin:0}.radar-chart-svg{max-width:100%;height:auto;filter:drop-shadow(0 4px 12px rgba(139,92,246,.2))}.radar-grid-circle,.radar-axis-line{transition:all .3s ease}.radar-polygon{transition:all .3s ease;filter:drop-shadow(0 0 8px rgba(139,92,246,.4))}.radar-polygon:hover{fill:#8b5cf64d;stroke:#8b5cf6;filter:drop-shadow(0 0 12px rgba(139,92,246,.6))}.radar-point{transition:all .2s ease;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.radar-point:hover{filter:drop-shadow(0 4px 8px rgba(0,0,0,.5));transform:scale(1.2)}.radar-label{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-user-select:none;user-select:none}.radar-tooltip{position:absolute;bottom:20px;left:50%;transform:translate(-50%);padding:12px 20px;background:#2a2a2a;border:1px solid #444444;border-radius:6px;text-align:center;min-width:200px;pointer-events:none;animation:tooltipSlideIn .2s ease;z-index:10}@keyframes tooltipSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.radar-tooltip-name{font-size:1rem;font-weight:700;color:#fff;margin-bottom:6px}.radar-tooltip-value{font-size:.9rem;color:#ccc;margin-bottom:4px}.radar-tooltip-percent{font-size:1.3rem;font-weight:700;color:#4caf50}.comparison-popup-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;animation:fadeIn .2s ease;overflow-y:auto}.comparison-popup{position:relative;background:#1a1a1a;border:2px solid #444444;border-radius:8px;max-width:95vw;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #00000080;animation:slideUp .3s ease;z-index:10000;margin:auto}.comparison-popup-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #444444;flex-shrink:0}.comparison-popup-title{display:flex;align-items:center;gap:12px;color:#fff}.comparison-popup-title h2{font-size:1.5rem;font-weight:600;margin:0}.view-mode-toggle{display:flex;gap:4px;background:#2a2a2a;padding:4px;border-radius:6px;border:1px solid #444444}.view-mode-btn{padding:8px 16px;background:transparent;border:none;color:#888;font-weight:600;font-size:.9rem;cursor:pointer;border-radius:6px;transition:all .2s ease}.view-mode-btn:hover{background:#3a3a3a;color:#ccc}.view-mode-btn.active{background:#3a3a3a;color:#4caf50;border:1px solid #4caf50}.comparison-popup-close{background:#2a2a2a;border:1px solid #444444;border-radius:4px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .2s ease;flex-shrink:0}.comparison-popup-close:hover{background:#ef4444;border-color:#dc2626}.comparison-popup-content{padding:24px;overflow-y:auto;flex:1}.comparison-popup-content::-webkit-scrollbar{width:10px}.comparison-popup-content::-webkit-scrollbar-track{background:#1a1a1a;border-radius:5px}.comparison-popup-content::-webkit-scrollbar-thumb{background:#444;border-radius:5px}.comparison-popup-content::-webkit-scrollbar-thumb:hover{background:#555}.comparison-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:24px}.comparison-item{background:#2a2a2a;border:1px solid #444444;border-radius:6px;padding:16px;transition:all .3s ease}.comparison-item:hover{border-color:#666}.comparison-item-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #444444}.comparison-item-header h3{color:#fff;font-size:1.2rem;font-weight:600;margin:0 0 8px}.comparison-stats{display:flex;gap:16px;flex-wrap:wrap}.comparison-stat{font-size:.85rem;color:#888;background:#1a1a1a;padding:4px 10px;border-radius:4px}.comparison-notice{text-align:center;padding:24px;background:#2a2a2a;border:1px solid #ffa726;border-radius:6px;margin-top:24px}.comparison-notice p{color:#ffa726;margin:0;font-size:1rem}.comparison-overlay-view{display:flex;flex-direction:column;align-items:center;gap:24px}.overlay-radar-chart-container{position:relative;display:flex;flex-direction:column;align-items:center;padding:20px;background:#2a2a2a;border:1px solid #444444;border-radius:6px;width:100%;margin:0 auto}.overlay-radar-chart-svg{max-width:100%;height:auto}.overlay-radar-polygon{filter:drop-shadow(0 0 4px currentColor)}.overlay-radar-tooltip{margin-top:16px;padding:12px 20px;background:#2a2a2a;border:1px solid #444444;border-radius:6px;text-align:center;min-width:200px;animation:tooltipSlideIn .2s ease}.tooltip-organism{font-size:1rem;font-weight:700;color:#fff;margin-bottom:4px}.tooltip-trait{font-size:.9rem;color:#ccc;margin-bottom:6px}.tooltip-value{font-size:.85rem;color:#888;margin-bottom:4px}.tooltip-percent{font-size:1.2rem;font-weight:700;color:#4caf50}.comparison-legend{display:flex;flex-direction:column;gap:12px;width:100%;max-width:800px;background:#2a2a2a;border:1px solid #444444;border-radius:6px;padding:16px}.legend-item{display:flex;align-items:center;gap:12px;padding:10px;background:#1a1a1a;border:1px solid #444444;border-radius:6px;transition:all .2s ease}.legend-item:hover{background:#3a3a3a;border-color:#666;transform:translate(4px)}.legend-color{width:20px;height:20px;border-radius:4px;flex-shrink:0;box-shadow:0 0 6px currentColor}.legend-label{font-weight:600;color:#fff;font-size:.95rem;min-width:150px}.legend-stats{font-size:.85rem;color:#888;margin-left:auto}.simulation-controls{border-radius:16px;padding:10px 15px;margin:10px;display:flex;align-items:center;justify-content:space-between;gap:15px;flex-shrink:0}.controls-left{display:flex;gap:10px;align-items:center}.controls-center{display:flex;gap:20px;align-items:center;flex:1;justify-content:end}.controls-right{display:flex;align-items:center}.control-button{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;border:2px solid;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease;background:none}.control-button.playing{background:#3a3a3a;border-color:#ef4444;color:#ef4444}.control-button.playing:hover{background:#4a4a4a;border-color:#f87171;transform:translateY(-1px)}.control-button.paused{background:#3a3a3a;border-color:#4caf50;color:#4caf50}.control-button.paused:hover{background:#4a4a4a;border-color:#66bb6a;transform:translateY(-1px)}.control-button.restart-button{background:#3a3a3a;border-color:#ffa726;color:#ffa726}.control-button.restart-button:hover{background:#4a4a4a;border-color:#ffb74d;transform:translateY(-1px)}.control-button:active{transform:translateY(0)}.control-button:disabled{opacity:.4;cursor:not-allowed}.control-button:disabled:hover{transform:none;box-shadow:none}.control-button.settings-button{background:#3a3a3a;border-color:#60a5fa;color:#60a5fa}.control-button.settings-button:hover{background:#4a4a4a;border-color:#93c5fd;transform:translateY(-1px)}.zoom-controls{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#2a2a2a;border:1px solid #444444;border-radius:6px}.zoom-button{padding:6px 10px!important;min-width:auto;background:#3a3a3a!important;border-color:#555!important;color:#ccc!important}.zoom-button:hover:not(:disabled){background:#4a4a4a!important;border-color:#666!important}.zoom-display{font-size:.9rem;color:#888;font-weight:600;min-width:50px;text-align:center}.speed-controls{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#2a2a2a;border:1px solid #444444;border-radius:6px}.speed-button{padding:6px 10px!important;min-width:auto;background:#3a3a3a!important;border-color:#555!important;color:#ccc!important}.speed-button:hover:not(:disabled){background:#4a4a4a!important;border-color:#666!important}.speed-display{font-size:.9rem;color:#888;font-weight:600;min-width:50px;text-align:center}.reset-view-button{background:#3a3a3a!important;border-color:#2196f3!important;color:#2196f3!important}.reset-view-button:hover{background:#4a4a4a!important;border-color:#42a5f5!important;transform:translateY(-1px)}.reset-view-button span{font-size:.9rem}.floating-action{position:absolute;top:14px;right:14px;z-index:5;width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;background:#2a2a2a;border:1px solid #444;border-radius:8px;color:#e2e8f0;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000004d}.floating-action:hover{background:#3a3a3a;border-color:#666;transform:translateY(-1px)}.floating-action.camera{display:flex;border-color:#60a5fa;color:#93c5fd;background-color:transparent;align-items:center;justify-content:center;width:42px;height:42px}.stat-display{display:flex;align-items:center;gap:10px;padding:8px 14px;background:#2a2a2a;border:1px solid #444444;border-radius:6px}.stat-icon{font-size:1.3rem}.stat-info{display:flex;flex-direction:column;gap:2px}.stat-display .stat-label{font-size:.7rem;color:#888;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.stat-display .stat-value{font-size:1.1rem;color:#fff;font-weight:700}.status-indicator{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#2a2a2a;border:1px solid #444444;border-radius:6px}.status-dot{width:10px;height:10px;border-radius:50%;animation:statusPulse 2s ease-in-out infinite}.status-dot.running{background:#4caf50;box-shadow:0 0 8px #4caf50}.status-dot.paused{background:#ffa726;box-shadow:0 0 8px #ffa726;animation:none}@keyframes statusPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}.status-text{font-size:.85rem;color:#ccc;font-weight:600}.control-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.control-header label{display:flex;align-items:center;gap:8px;margin:0}.control-icon{font-size:1.2rem}.toasts-container{position:fixed;bottom:20px;left:20px;z-index:9999;display:flex;flex-direction:column-reverse;gap:12px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#2a2a2a;border:2px solid #444444;border-left-width:4px;border-radius:8px;box-shadow:0 4px 12px #0006;min-width:280px;max-width:400px;pointer-events:auto;animation:toastSlideIn .3s ease}@keyframes toastSlideIn{0%{transform:translate(-400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{font-size:1.5rem;flex-shrink:0}.toast-message{flex:1;color:#e2e8f0;font-size:.95rem;line-height:1.4}.toast-close{background:transparent;border:none;color:#888;font-size:1.2rem;cursor:pointer;padding:4px;line-height:1;transition:color .2s ease;flex-shrink:0}.toast-close:hover{color:#e2e8f0}.settings-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.settings-modal{background:#1a1a1a;border:1px solid #444444;border-radius:12px;width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000080;animation:slideUp .3s ease}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #333333}.settings-header h3{margin:0;color:#fff;font-size:1.5rem;font-weight:600}.settings-close{background:transparent;border:none;color:#888;font-size:1.5rem;cursor:pointer;padding:4px 8px;line-height:1;transition:all .2s ease;border-radius:4px}.settings-close:hover{color:#e2e8f0;background:#2a2a2a}.settings-content{padding:24px;overflow-y:auto}.settings-content::-webkit-scrollbar{width:8px}.settings-content::-webkit-scrollbar-track{background:#1a1a1a}.settings-content::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.settings-content::-webkit-scrollbar-thumb:hover{background:#555}.settings-section{display:flex;flex-direction:column;gap:16px}.settings-section h4{margin:0;color:#fff;font-size:1.2rem;font-weight:600}.settings-description{margin:0;color:#888;font-size:.9rem;line-height:1.5}.settings-toggles{display:flex;flex-direction:column;gap:12px}.toggle-row{position:relative;display:flex;align-items:center;justify-content:space-between;padding:16px;background:#2a2a2a;border:1px solid #444444;border-radius:8px;cursor:pointer;transition:all .2s ease}.toggle-row:hover:not(.disabled){background:#333;border-color:#555}.toggle-row.disabled{opacity:.5;cursor:not-allowed}.toggle-info{display:flex;flex-direction:column;gap:4px;flex:1}.toggle-label{color:#fff;font-size:1rem;font-weight:500}.toggle-hint{color:#888;font-size:.85rem}.toggle-input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.toggle-slider{position:relative;display:inline-block;width:48px;height:24px;background:#444;border-radius:24px;transition:all .3s ease;flex-shrink:0}.toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:all .3s ease}.toggle-input:checked+.toggle-slider{background:#4ade80}.toggle-input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-input:disabled+.toggle-slider{background:#333}@media (max-width: 1200px){.main-container{flex-direction:column}.sidebar{width:100%;max-height:300px}.canvas-section{min-height:400px}.toasts-container{bottom:10px;right:10px}.toast{min-width:240px;max-width:calc(100vw - 20px)}}@media (max-width: 768px){body{-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:pan-x pan-y}.app{height:100vh;height:100dvh}.simulation-controls{padding:8px;gap:8px;flex-wrap:wrap}.controls-left,.controls-center,.controls-right{gap:6px}.controls-center{flex-wrap:wrap;justify-content:center}.control-button{min-width:44px;min-height:44px;padding:8px;font-size:14px}.zoom-controls,.speed-controls{gap:6px}.zoom-display,.speed-display{font-size:12px;min-width:40px}.stat-display{padding:6px 10px;min-height:44px}.stat-icon{font-size:18px}.stat-label{font-size:10px}.stat-value{font-size:14px}.main-container{padding:0 5px 5px;gap:5px}.canvas-section{min-height:300px;max-height:50vh;padding:5px}.sidebar{width:100%;max-height:none;height:auto;flex:1;min-height:0}.tab-buttons{gap:4px;padding:4px;overflow-x:auto;-webkit-overflow-scrolling:touch}.tab-button{padding:10px 14px;font-size:13px;white-space:nowrap;min-height:44px}.tab-content{padding:10px;max-height:calc(50vh - 60px)}.floating-action{width:44px;height:44px;bottom:12px;right:12px}.floating-action svg{width:20px;height:20px}.creature-viewer h2{font-size:16px;margin-bottom:12px}.overlay-toggles{gap:8px}.overlay-toggle-item{padding:10px 12px;min-height:44px}.species-list{gap:8px}.species-item{padding:10px;min-height:44px}.species-thumb{width:40px;height:40px}.species-name{font-size:14px}.species-count{font-size:12px}.select-all-btn,.compare-button{padding:10px 16px;font-size:14px;min-height:44px}.genome-popup-overlay,.comparison-popup-overlay,.family-tree-popup-overlay{padding:0}.genome-popup,.comparison-popup,.family-tree-popup{max-width:100vw;max-height:100vh;height:100vh;border-radius:0;padding:15px}.genome-popup-header,.comparison-popup-header,.popup-header{margin-bottom:12px;padding-bottom:12px}.genome-popup-title h2,.comparison-popup-title h2,.popup-header h2{font-size:18px}.genome-popup-close,.comparison-popup-close,.close-button,.maximize-button{width:44px;height:44px;font-size:20px}.genome-popup-content,.comparison-popup-content{max-height:calc(100vh - 80px)}.radar-chart-container,.overlay-radar-chart-container{padding:12px}.radar-chart-svg,.overlay-radar-chart-svg{max-height:250px}.comparison-grid{grid-template-columns:1fr;gap:12px}.control-group{margin-bottom:16px}.control-group label{font-size:13px}.stats-summary{grid-template-columns:1fr 1fr;gap:8px}.stat-card{padding:8px}.stat-card .stat-label{font-size:10px}.stat-card .stat-value{font-size:16px}.export-controls{flex-wrap:wrap}.export-button{flex:1 1 calc(50% - 5px);min-width:120px;padding:12px;min-height:44px}.genealogy-stats{grid-template-columns:1fr 1fr;gap:8px}.tree-legend{gap:12px}.legend-item{font-size:11px}.tree-container,.tree-container-popup{min-height:250px}.toasts-container{bottom:80px;left:10px;right:10px;max-width:none}.toast{min-width:auto;width:100%;padding:12px 16px}.settings-modal{max-width:100vw;width:100vw;max-height:100vh;height:100vh;border-radius:0;padding:15px}.toggle-row{padding:12px;min-height:54px}.toggle-label{font-size:14px}*::-webkit-scrollbar{width:4px;height:4px}*::-webkit-scrollbar-thumb{background:#555}}@media (max-width: 480px){.simulation-controls{padding:6px}.controls-left{flex-wrap:wrap}.controls-center{display:none}.stat-display{padding:4px 8px}.control-button{min-width:40px;min-height:40px;padding:6px}.zoom-controls,.speed-controls{display:none}.canvas-section{min-height:250px;max-height:40vh}.tab-button{padding:8px 10px;font-size:12px}.floating-action{width:40px;height:40px;bottom:10px;right:10px}.stats-summary{grid-template-columns:1fr}.export-button{flex:1 1 100%;width:100%}}.family-tree{display:flex;flex-direction:column;height:100%;padding:15px;overflow:hidden;box-sizing:border-box}.family-tree-header{position:relative;display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.family-tree h2{margin:0;font-size:18px;font-weight:600;color:#fff}.maximize-button{background:#2a2a2a;border:1px solid #444444;border-radius:4px;color:#fff;font-size:18px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.maximize-button:hover{background:#3a3a3a;border-color:#666;transform:scale(1.05)}.genealogy-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:15px}.stat-item{display:flex;justify-content:space-between;align-items:center;background:#2a2a2a;border:1px solid #444444;border-radius:6px;padding:8px 12px}.stat-label{font-size:12px;color:#888}.stat-value{font-size:16px;font-weight:700;color:#fff}.stat-value.alive{color:#4caf50}.stat-value.extinct{color:#999}.tree-legend{display:flex;gap:20px;margin-bottom:15px;padding:10px;background:#2a2a2a;border:1px solid #444444;border-radius:6px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:#ccc}.legend-icon{width:20px;height:20px;border-radius:50%;border:2px solid}.legend-icon.alive-node{background:#2a2a2a;border-color:#4caf50}.legend-icon.extinct-node{background:#3a3a3a;border-color:#666}.legend-badge{width:24px;height:24px;border-radius:50%;background:#4caf50;color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.tree-container{flex:1;background:#1a1a1a;border:1px solid #444444;border-radius:6px;overflow:auto;position:relative;min-height:0}.tree-container canvas{display:block;cursor:default;min-height:100%}.tree-container::-webkit-scrollbar{width:10px;height:10px}.tree-container::-webkit-scrollbar-track{background:#1a1a1a}.tree-container::-webkit-scrollbar-thumb{background:#444;border-radius:5px}.tree-container::-webkit-scrollbar-thumb:hover{background:#555}.tree-container::-webkit-scrollbar-corner{background:#1a1a1a}.family-tree-popup-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.family-tree-popup{background:#1a1a1a;border:2px solid #444444;border-radius:8px;padding:20px;max-width:95vw;max-height:95vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #00000080}.popup-header{position:relative;display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #444444}.popup-header h2{margin:0;font-size:20px;font-weight:600;color:#fff}.close-button{background:#2a2a2a;border:1px solid #444444;border-radius:4px;color:#fff;font-size:20px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.close-button:hover{background:#ef4444;border-color:#dc2626}.tree-container-popup{position:relative;flex:1;background:#1a1a1a;border:1px solid #444444;border-radius:6px;overflow-y:auto;overflow-x:hidden;min-height:0;max-height:calc(95vh - 280px)}.tree-container-popup canvas{display:block;cursor:default;width:100%;height:auto}.tree-container-popup::-webkit-scrollbar{width:12px;height:12px}.tree-container-popup::-webkit-scrollbar-track{background:#1a1a1a}.tree-container-popup::-webkit-scrollbar-thumb{background:#444;border-radius:6px}.tree-container-popup::-webkit-scrollbar-thumb:hover{background:#555}.tree-container-popup::-webkit-scrollbar-corner{background:#1a1a1a}.statistics{padding:15px;height:100%;display:flex;flex-direction:column;box-sizing:border-box;gap:15px}.statistics h2{margin:0 0 10px;font-size:18px;font-weight:600;color:#fff}.stats-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{background:#2a2a2a;border:1px solid #444444;border-radius:6px;padding:10px;text-align:center}.stat-label{font-size:11px;color:#888;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:20px;font-weight:700;color:#fff}.stats-controls{background:#2a2a2a;border:1px solid #444444;border-radius:6px;padding:12px}.control-label{display:block;font-size:13px;color:#ccc;margin-bottom:8px}.slider{width:100%;height:4px;border-radius:2px;background:#444;outline:none;margin-top:8px;cursor:pointer}.slider::-webkit-slider-thumb{appearance:none;width:16px;height:16px;border-radius:50%;background:#4caf50;cursor:pointer}.slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#4caf50;cursor:pointer;border:none}.control-hint{font-size:11px;color:#666;margin-top:6px;font-style:italic}.export-controls{display:flex;align-items:center;gap:10px;margin-top:12px;padding-top:12px;border-top:1px solid #444444}.export-label{font-size:13px;color:#ccc;font-weight:500}.export-button{display:inline-flex;align-items:center;gap:4px;padding:8px 14px;font-size:13px;font-weight:500;color:#fff;background:#3a3a3a;border:1px solid #555555;border-radius:5px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.export-button:hover:not(:disabled){background:#4a4a4a;border-color:#666;transform:translateY(-1px);box-shadow:0 2px 8px #0000004d}.export-button:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #0003}.export-button:disabled{opacity:.4;cursor:not-allowed}.export-button:nth-child(2){background:linear-gradient(135deg,#1e88e5,#1565c0);border-color:#1565c0}.export-button:nth-child(3){background:linear-gradient(135deg,#43a047,#2e7d32);border-color:#2e7d32}.export-button:nth-child(4){background:linear-gradient(135deg,#fb8c00,#e65100);border-color:#e65100}.metric-toggles{display:flex;flex-wrap:wrap;gap:15px;padding:10px;background:#2a2a2a;border:1px solid #444444;border-radius:6px}.metric-toggles label{display:flex;align-items:center;gap:6px;font-size:13px;color:#ccc;cursor:pointer;-webkit-user-select:none;user-select:none}.metric-toggles input[type=checkbox]{cursor:pointer;width:16px;height:16px}.charts-container{display:flex;flex-direction:column;gap:20px;padding-block:20px}.statistics-chart{border:1px solid #444444;border-radius:6px;background:#1a1a1a}.no-data{padding:40px 20px;text-align:center;background:#2a2a2a;border:1px dashed #444444;border-radius:6px;color:#888;font-size:14px}.no-data p{margin:0}.statistics::-webkit-scrollbar{width:8px}.statistics::-webkit-scrollbar-track{background:#1a1a1a}.statistics::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.statistics::-webkit-scrollbar-thumb:hover{background:#555}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh}
