body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.axis-corner-wrapper{position:absolute;left:0;bottom:72px;z-index:9999;pointer-events:none}.axis-corner-wrapper .axis-corner-root{position:absolute;left:0;bottom:0}.axis-corner-scale{position:fixed;left:0;bottom:0;transform-origin:0 100%;pointer-events:none}.axis-corner-root{position:fixed;left:0;bottom:5.5vmin;padding:10px 12px 14px 14px;min-width:140px;z-index:2147483647;pointer-events:none;background:#0009;border-radius:0 10px 0 0;border:1px solid rgba(255,255,255,.1);font-family:system-ui,-apple-system,sans-serif}.axis-corner-title{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#ffffff80;margin-bottom:10px;line-height:1}.axis-corner-layout{position:relative;display:flex;flex-direction:row;align-items:flex-end;gap:0;min-height:44px}.axis-corner-spine{flex-shrink:0;width:32px;height:28px;margin-right:6px;border-left:2px solid rgba(255,255,255,.6);border-bottom:2px solid rgba(255,255,255,.6)}.axis-corner-y{position:relative;display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between;height:28px;margin-right:14px;flex-shrink:0}.axis-corner-y .axis-corner-caption{position:absolute;top:-18px;right:0;font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#ffffffb3}.axis-corner-ticks-y{display:flex;flex-direction:column;justify-content:space-between;height:100%;line-height:1}.axis-corner-ticks-y .axis-corner-tick{display:block}.axis-corner-x{display:flex;flex-direction:row;align-items:center;gap:6px;flex-shrink:0;min-width:80px}.axis-corner-x .axis-corner-caption{font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#ffffffb3;margin-right:6px;flex-shrink:0}.axis-corner-ticks-x{display:flex;flex-direction:row;justify-content:space-between;flex:1;gap:2px}.axis-corner-ticks-x .axis-corner-tick{flex-shrink:0;min-width:12px;text-align:center}.axis-corner-tick{font-size:11px;font-weight:600;font-variant-numeric:tabular-nums;color:#fffffff2;line-height:1}.tier-trl-axes-overlay{z-index:2}.tier-trl-axis-label{fill:#ffffffbf;font-size:10px;font-weight:600;font-variant-numeric:tabular-nums;font-family:system-ui,-apple-system,sans-serif}.tier-trl-axis-label-y,.tier-trl-axis-label-x{font-size:10px}.tier-trl-axis-title{fill:#ffffff80;font-size:9px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;font-family:system-ui,-apple-system,sans-serif}.tech-tree-graph{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:hidden;background-color:#0a0a1a}.tech-tree-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:auto}.selection-ring-overlay{z-index:2}.selection-ring{animation:selection-ring-pulse 1.5s ease-in-out infinite}.selection-ring-outer{animation:selection-ring-pulse 1.5s ease-in-out infinite .2s}@keyframes selection-ring-pulse{0%,to{opacity:1}50%{opacity:.7}}.tech-tree-labels{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:1}.tech-tree-label{position:absolute;padding:5px 10px;font-size:13px;font-weight:500;line-height:1.35;letter-spacing:.02em;font-family:system-ui,-apple-system,sans-serif;color:#fffffff2;background:#000c;border-left:4px solid;border-radius:4px;white-space:nowrap;max-width:240px;overflow:hidden;text-overflow:ellipsis;box-shadow:0 1px 4px #0006}.tech-tree-canvas canvas{display:block;width:100%!important;height:100%!important;pointer-events:auto;cursor:grab}.tech-tree-canvas canvas:active{cursor:grabbing}.tech-tree-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:16px;color:#ffffffb3;font-family:system-ui,-apple-system,sans-serif;pointer-events:none;z-index:0}.loading-spinner{width:40px;height:40px;border:3px solid rgba(139,92,246,.3);border-top-color:#8b5cf6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.tech-tree-tooltip{position:fixed;background:#000000e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:10px 14px;pointer-events:none;z-index:1000;display:flex;align-items:center;gap:10px;box-shadow:0 4px 20px #00000080}.tooltip-indicator{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 8px currentColor}.tooltip-content{display:flex;flex-direction:column;gap:2px}.tooltip-title{color:#fff;font-size:13px;font-weight:600;font-family:system-ui,-apple-system,sans-serif;white-space:nowrap}.tooltip-meta{color:#ffffff80;font-size:10px;font-family:system-ui,-apple-system,sans-serif}.tooltip-domain{letter-spacing:.5px}.tooltip-sep{opacity:.6}.node-detail{position:absolute;right:24px;top:24px;bottom:24px;width:380px;max-width:calc(100vw - 48px);background:#0f0f1ef2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow-y:auto;z-index:200;font-family:system-ui,-apple-system,sans-serif}.node-detail-close{position:absolute;top:16px;right:16px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:8px;color:#fff9;cursor:pointer;transition:all .2s}.node-detail-close:hover{background:#ffffff26;color:#fff}.node-detail-header{padding:24px;border-bottom:1px solid rgba(255,255,255,.1)}.node-detail-domain{display:inline-block;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#fff}.node-detail-title{margin:16px 0 8px;font-size:24px;font-weight:700;color:#fff;line-height:1.2}.node-detail-description{margin:0;font-size:14px;color:#fff9;line-height:1.5}.node-detail-meta{padding:20px 24px;display:flex;flex-direction:column;gap:16px;border-bottom:1px solid rgba(255,255,255,.1)}.meta-item{display:flex;align-items:center;gap:12px}.meta-label{font-size:13px;color:#fff6;text-transform:uppercase;letter-spacing:.5px;min-width:80px}.meta-value{font-size:15px;font-weight:600;color:#fff}.progress-bar{flex:1;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .5s ease}.node-detail-section{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1)}.node-detail-section:last-child{border-bottom:none}.node-detail-section h3{margin:0 0 12px;font-size:13px;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}.key-players{display:flex;flex-wrap:wrap;gap:8px}.player-tag{padding:8px 14px;background:#ffffff14;border-radius:8px;font-size:15px;color:#ffffffe6}.milestones{display:flex;flex-direction:column;gap:16px}.milestone{display:flex;gap:16px}.milestone-date{flex-shrink:0;width:88px;font-size:13px;color:#ffffff80;padding-top:2px}.milestone-content{flex:1}.milestone-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:#fff;margin-bottom:4px}.milestone-source-link{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;color:#6366f1e6;text-decoration:none;flex-shrink:0;transition:background .15s,color .15s}.milestone-source-link:hover{background:#6366f133;color:#fff}.milestone-description{font-size:14px;color:#fff9;line-height:1.45}.dependencies{display:flex;flex-wrap:wrap;gap:8px}.dep-tag{padding:8px 14px;background:#6366f133;border:1px solid rgba(99,102,241,.3);border-radius:8px;font-size:14px;font-family:inherit;color:#ffffffe6}.dep-tag-clickable{font-family:inherit;cursor:pointer;transition:background .15s,border-color .15s}.dep-tag-clickable:hover{background:#6366f159;border-color:#6366f180;color:#fff}.sources-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}.sources-list li{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.source-link{color:#6366f1f2;text-decoration:none;font-size:14px}.source-link:hover{text-decoration:underline}.source-type{font-size:12px;color:#fff6;text-transform:capitalize}.node-detail::-webkit-scrollbar{width:8px}.node-detail::-webkit-scrollbar-track{background:transparent}.node-detail::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.node-detail::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media (max-width: 768px){.node-detail{position:fixed;right:0;top:auto;bottom:0;left:0;width:100%;max-width:100%;max-height:60vh;border-radius:16px 16px 0 0}}.domain-filter{position:absolute;left:50%;transform:translate(-50%);bottom:60px;z-index:100;font-family:system-ui,-apple-system,sans-serif;display:flex;flex-direction:column;align-items:center;gap:8px}.domain-filter-header{display:flex;align-items:center;gap:12px}.domain-filter-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:#ffffff59}.domain-filter-clear{background:#ffffff1a;border:none;font-size:10px;color:#fff9;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.domain-filter-clear:hover{background:#fff3;color:#ffffffe6}.domain-filter-list{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center;gap:6px;max-width:90vw}.domain-filter-item{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:20px;cursor:pointer;transition:all .2s;font-size:0}.domain-filter-item:hover{background:#ffffff1a;border-color:var(--domain-color);transform:translateY(-1px)}.domain-filter-item.active{border-color:var(--domain-color);background:#ffffff14;box-shadow:0 0 12px rgba(var(--domain-color-rgb, 139, 92, 246),.3)}.domain-filter-item.inactive{opacity:.35;border-color:transparent}.domain-filter-item.inactive:hover{opacity:.7}.domain-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px currentColor}.domain-name{font-size:11px;font-weight:500;color:#ffffffd9;white-space:nowrap}@media (max-width: 768px){.domain-filter{bottom:16px;left:8px;right:8px;transform:none}.domain-filter-list{max-width:100%}.domain-filter-item{padding:5px 10px;gap:5px}.domain-indicator{width:6px;height:6px}.domain-name{font-size:10px}}.tech-tree-header{position:absolute;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:linear-gradient(to bottom,rgba(10,10,26,.95),transparent);font-family:system-ui,-apple-system,sans-serif}.header-brand{display:flex;flex-direction:column;gap:4px}.header-title{margin:0;font-size:20px;font-weight:700;letter-spacing:-.5px}.title-main{color:#fff}.title-dot{color:#8b5cf6}.title-tld{color:#fff9}.header-subtitle{margin:0;font-size:12px;color:#fff6}.header-progress{margin:6px 0 0;font-size:11px;color:#ffffff80;font-weight:500}.header-progress-item{display:inline}.header-progress-sep{color:#fff3;margin:0 2px}.header-progress-dot{display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:4px;vertical-align:middle;background:currentColor}.header-progress-count{font-variant-numeric:tabular-nums;color:#ffffffd9}.header-stats{display:flex;gap:32px}.stat{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-value{font-size:18px;font-weight:700;color:#fff;font-variant-numeric:tabular-nums}.stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#fff6}.header-actions{display:flex;align-items:center;gap:8px}.header-view-toggle{display:flex;gap:2px}.header-view-toggle .header-btn.active{background:#8b5cf640;border-color:#8b5cf680;color:#fff}.header-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff9;cursor:pointer;transition:all .2s;text-decoration:none}.header-btn:hover{background:#ffffff1f;color:#fff}@media (max-width: 768px){.tech-tree-header{padding:12px 16px}.header-title{font-size:16px}.header-subtitle,.header-progress,.header-stats{display:none}}.timeline-slider{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:#0a0a1ad9;border-radius:8px;border:1px solid rgba(139,92,246,.25)}.timeline-slider__label{font-size:.75rem;font-weight:600;color:#ffffffb3;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.timeline-slider__row{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.timeline-slider__min,.timeline-slider__max{font-size:.7rem;color:#ffffff73;min-width:2ch}.timeline-slider__input{flex:1;min-width:80px;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#8b5cf633;border-radius:3px;outline:none}.timeline-slider__input::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#8b5cf6;cursor:pointer;box-shadow:0 0 0 2px #0a0a1ae6;transition:transform .15s ease,box-shadow .15s ease}.timeline-slider__input::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 0 0 3px #8b5cf666}.timeline-slider__input::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#8b5cf6;cursor:pointer;border:none;box-shadow:0 0 0 2px #0a0a1ae6;transition:transform .15s ease,box-shadow .15s ease}.timeline-slider__input::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:0 0 0 3px #8b5cf666}.timeline-slider__value{font-size:1rem;font-weight:700;color:#fff;min-width:3ch;text-align:right}.embedding-view{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:hidden;background-color:#0a0a1a}.embedding-view canvas{display:block;width:100%!important;height:100%!important}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;width:100%;height:100%;min-height:100vh;overflow:hidden;background-color:#0a0a1a}html,body{height:100vh}.app{position:relative;width:100%;height:100%;min-height:100vh;overflow:hidden}.app-timeline{position:absolute;top:72px;left:24px;z-index:100;max-width:min(320px,90vw)}.app-footer{position:absolute;bottom:16px;left:24px;display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:6px 12px;max-width:min(96vw,720px);background:#0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;font-size:10px;color:#ffffff4d;font-family:system-ui,-apple-system,sans-serif;z-index:50}.footer-sep{opacity:.3}.footer-definitions{color:#ffffff80}.footer-definitions strong{color:#ffffffb3;font-weight:600}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff40}::selection{background:#8b5cf64d}:focus{outline:2px solid rgba(139,92,246,.5);outline-offset:2px}:focus:not(:focus-visible){outline:none}@media (max-width: 768px){.app-footer{bottom:80px}}
