:root{--font-body: "Avenir Next", "Segoe UI", sans-serif;--color-page-bg: #ecf2e8;--color-page-bg-alt: #d7e5d2;--color-surface: rgba(249, 252, 248, .92);--color-surface-strong: rgba(255, 255, 255, .96);--color-surface-muted: #f5f8f3;--color-panel-dark: rgba(11, 27, 14, .42);--color-panel-dark-strong: rgba(11, 27, 14, .58);--color-text: #172218;--color-text-muted: #5a685b;--color-text-subtle: #7b887c;--color-text-on-dark: #fff;--color-border: rgba(34, 104, 42, .26);--color-border-strong: rgba(28, 111, 39, .62);--color-border-soft: rgba(255, 255, 255, .2);--color-accent: #2e8d34;--color-accent-strong: #1b872b;--color-accent-soft: rgba(76, 175, 80, .12);--color-glow: lightgreen;--color-track: #cad2c6;--color-disabled: #a1aca1;--color-disabled-bg: #d7ddd4;--color-focus: #166534;--gradient-brand: linear-gradient(135deg, #4caf50, #1b872b);--gradient-brand-soft: linear-gradient(135deg, #445b3e, #2e8d34);--gradient-mode-map: linear-gradient(135deg, #570ea6, #1c5bc8);--gradient-mode-graph: linear-gradient(135deg, #e53935, #e35d5b);--shadow-card: 0 18px 40px rgba(18, 44, 24, .08);--shadow-soft: 0 2px 8px rgba(0, 0, 0, .08);--shadow-control: 0 10px 18px rgba(18, 42, 21, .18);--shadow-glow: 0 0 12px 2px rgba(144, 238, 144, .8);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-pill: 999px;--space-1: 4px;--space-2: 8px;--space-3: 10px;--space-4: 12px;--space-5: 16px;--space-6: 20px;--control-size: 38px;--time-controls-width: min(54%, 420px);--time-slider-offset: calc( var(--control-size) + var(--control-size) + var(--space-3) + var(--space-3) + 5px );--time-slider-width: calc( var(--time-controls-width) - var(--control-size) - var(--control-size) - var(--space-3) - var(--space-3) - 10px );--transition-fast: .16s ease;--transition-base: .24s ease}html{box-sizing:border-box}*,*:before,*:after{box-sizing:inherit}html,body,#root{min-height:100%}body{margin:0;color:var(--color-text);font-family:var(--font-body);line-height:1.5;background:radial-gradient(circle at top left,rgba(255,255,255,.75),transparent 34%),linear-gradient(180deg,var(--color-page-bg),var(--color-page-bg-alt));text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,svg{display:block}button,input,select,textarea{font:inherit}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}::selection{background:#4caf5033}#mainContainer{display:grid;grid-template-columns:minmax(0,20fr) minmax(0,50fr) minmax(0,30fr);gap:var(--space-4);height:100vh;padding:var(--space-3);overflow:hidden}#col1,#col2,.col3{min-width:0}.glowing-border,.glowing-border-instant,.glowing-border-switcher,.glowing-border-switcher-instant,.header-row-dark,.header-row-dark-instant{border:2px solid var(--color-glow)!important;box-shadow:var(--shadow-glow)!important}.glowing-border{transition:box-shadow var(--transition-base),border var(--transition-base)}.glowing-border-switcher,.glowing-border-switcher-instant,.header-row-dark,.header-row-dark-instant{background:var(--color-panel-dark)!important}.glowing-border-switcher{transition:box-shadow var(--transition-base),border var(--transition-base),background var(--transition-base),color var(--transition-base)}.glowing-border-switcher,.glowing-border-switcher-instant,.glowing-border-switcher label,.glowing-border-switcher-instant label{color:var(--color-text-on-dark)!important}.header-row-dark{transition:background var(--transition-base)}#col1{width:auto;height:calc(100vh - 20px);background:transparent}#col1 .card,.col1-top{background:transparent;border:none}#col1 .card{display:flex;height:100%;flex-direction:column;box-shadow:none}.col1-bottom{flex:1;min-height:0;overflow-y:hidden;padding:var(--space-3);padding-top:5px;background:transparent}#col1 .card-header{position:relative;display:flex;overflow:hidden;flex-direction:column;padding:var(--space-3);padding-bottom:5px;background:transparent;border:none}.header-row,.header-row-2,.header-row-3{width:100%;display:flex;justify-content:flex-start;background:transparent}.header-row{margin-bottom:0}.header-row:last-child{border-bottom:none}.header-row-1{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-3);padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);background:var(--gradient-brand-soft);box-shadow:var(--shadow-soft)}.logo-container{display:flex;height:100%;flex-direction:column;justify-content:flex-start;gap:2px;padding-top:2px}.logo-container .app-title{margin-top:-4px;line-height:1.05}.logo-container .app-version{font-size:.85rem;font-weight:600;line-height:1;color:#ffffffd9}.logo-container .app-credit{font-size:.78rem;font-weight:600;line-height:1.1;color:#ffffffb8}.app-credit-link{color:inherit;text-decoration:none}.app-credit-link:hover{text-decoration:underline;text-decoration-thickness:1.5px}.app-credit-link i{margin-right:6px}.logo-container h4{margin:0;font-size:1.8rem;color:var(--color-text-on-dark)}.logo-svg-container{width:80px;flex-shrink:0;opacity:.88;transition:opacity var(--transition-base),transform var(--transition-base)}.logo-svg-container svg{width:100%;height:auto}.logo-svg-container:hover{opacity:1;filter:brightness(1.15);transform:scale(1.05)}.csv-switcher{display:flex;width:100%;height:47px;overflow:hidden;border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background:var(--color-surface-strong);box-shadow:var(--shadow-soft)}.upper-switcher{border-bottom-left-radius:0;border-bottom-right-radius:0}.lower-switcher{border-top-left-radius:0;border-top-right-radius:0}.csv-switcher input[type=radio]{display:none}.csv-switcher label{display:flex;flex:1;align-items:center;justify-content:center;padding:var(--space-3);color:var(--color-text-muted);font-weight:600;text-align:center;cursor:pointer;transition:background var(--transition-base),color var(--transition-base),filter var(--transition-fast)}.csv-switcher input[type=radio]:checked+label{color:var(--color-text-on-dark);background:var(--gradient-brand)}.csv-switcher label:hover{background:#2e8d3414}.csv-switcher.disabled{opacity:.65;pointer-events:none;border-color:var(--color-border-strong);background:var(--color-disabled-bg)}.csv-switcher.disabled label{color:var(--color-disabled);background:none}#col2{width:auto;position:relative;height:calc(100vh - 40px);margin-block:var(--space-3);overflow:hidden;border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);background:linear-gradient(180deg,#fbfdfaf5,#eaf1e7f0);box-shadow:var(--shadow-card)}#col2.glowing-border,#col2.glowing-border-instant{background:gray!important}.watermark{position:absolute;bottom:65px;right:var(--space-3);display:flex;align-items:center;gap:var(--space-2);opacity:.5;font-size:.8rem;color:var(--color-text-on-dark)}.watermark-text{font-weight:700}.watermark-logo{width:140px;height:40px}.help-overlay-button,.map-layer-button,.screenshot-button,.restore-button,#timeControlsContainer button{display:inline-flex;align-items:center;justify-content:center;width:var(--control-size);height:var(--control-size);padding:0;color:var(--color-text-on-dark);background:var(--gradient-brand);border:none;border-radius:var(--radius-md);box-shadow:var(--shadow-control);cursor:pointer;transition:transform var(--transition-fast),filter var(--transition-fast),opacity var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast)}.help-overlay-button:hover,.map-layer-button:hover:not(:disabled),.screenshot-button:hover:not(:disabled),.restore-button:hover:not(:disabled),#timeControlsContainer button:hover{filter:brightness(1.12);transform:translateY(-2px)}.help-overlay-button:active,.map-layer-button:active:not(:disabled),.screenshot-button:active:not(:disabled),.restore-button:active:not(:disabled),#timeControlsContainer button:active{transform:scale(.97)}.map-layer-button:disabled,.screenshot-button:disabled,.restore-button:disabled,#timeControlsContainer button:disabled,.toggle-button-container .btn:disabled{opacity:.5;cursor:not-allowed;background:linear-gradient(135deg,#999,#ccc);box-shadow:none;transform:none}.help-overlay-button{position:absolute;top:var(--space-6);right:var(--space-6);z-index:100}.toggle-button-container{position:absolute;bottom:var(--space-6);right:164px;min-width:37px;justify-content:center}.toggle-button-container .btn{position:relative;z-index:0;overflow:hidden;width:var(--control-size);height:var(--control-size);display:inline-flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;padding:0;text-align:center;color:var(--color-text-on-dark);border:none;border-radius:var(--radius-md);cursor:pointer;background:transparent;filter:brightness(1);transition:transform var(--transition-base),filter var(--transition-base),opacity var(--transition-base);will-change:filter,opacity;box-shadow:var(--shadow-control)}.toggle-button-container .btn .btn-text{position:relative;z-index:3;color:var(--color-text-on-dark)}.toggle-button-container .btn:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:var(--gradient-mode-map);transition:opacity var(--transition-base);z-index:1;opacity:1}.toggle-button-container .btn:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:var(--gradient-mode-graph);transition:opacity var(--transition-base);z-index:1;opacity:0}.toggle-button-container .btn.map-mode:before{opacity:1}.toggle-button-container .btn.map-mode:after{opacity:0}.toggle-button-container .btn.graph-mode:before{opacity:0}.toggle-button-container .btn.graph-mode:after{opacity:1}.toggle-button-container .btn:hover{transform:translateY(-2px);filter:brightness(1.2)}.toggle-button-container .btn:active{transform:scale(.97)}.toggle-button-container .btn:disabled:before,.toggle-button-container .btn:disabled:after{opacity:.5!important;transition:opacity var(--transition-base)}.screenshot-button,.restore-button,.map-layer-button{z-index:9999}.map-layer-button{position:absolute;bottom:var(--space-6);right:116px}.map-layer-menu{position:absolute;bottom:70px;right:116px;overflow:hidden;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffffeb;box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transform-origin:bottom;transform:scaleY(0);opacity:0;transition:transform var(--transition-base),opacity var(--transition-base);z-index:9998}.map-layer-menu.active{transform:scaleY(1);opacity:1}.map-layer-menu .menu-entry{display:flex;align-items:center;padding:var(--space-3) 15px;border-bottom:1px solid rgba(23,34,24,.08);background:transparent}.map-layer-menu .menu-entry:last-child{border-bottom:none}.map-layer-menu .menu-entry i{width:20px;margin-right:10px;text-align:center}.map-layer-menu .menu-text{flex:1;font-size:.9rem;color:var(--color-text)}.map-layer-menu .switch{position:relative;display:inline-block;width:40px;height:20px}.map-layer-menu .switch input{opacity:0;width:0;height:0}.map-layer-menu .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-track);transition:background-color var(--transition-base);border-radius:20px}.map-layer-menu .slider:before{position:absolute;content:"";height:16px;width:16px;left:2px;bottom:2px;background-color:#fff;transition:transform var(--transition-base);border-radius:50%}.map-layer-menu .switch input:checked+.slider{background-color:var(--color-accent)}.map-layer-menu .switch input:checked+.slider:before{transform:translate(20px)}.screenshot-button{position:absolute;right:var(--space-6);bottom:var(--space-6)}.restore-button{position:absolute;right:68px;bottom:var(--space-6)}#timeControlsContainer{position:absolute;left:var(--space-6);bottom:var(--space-6);z-index:9999;display:none;width:var(--time-controls-width);align-items:center;gap:var(--space-3);color:var(--color-text-on-dark)}#timeControlsContainer button{flex:0 0 auto;margin:0}#timeControlsContainer input[type=range]{flex:1;width:100%;margin:0 5px;-webkit-appearance:none;background:transparent;cursor:pointer}#timeControlsContainer input[type=range]::-webkit-slider-runnable-track{height:6px;background:var(--color-track);border-radius:3px}#timeControlsContainer input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:var(--gradient-brand);border-radius:50%;margin-top:-4px;transition:transform var(--transition-fast)}#timeControlsContainer input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1)}#timeControlsContainer input[type=range]::-moz-range-track{height:6px;background:var(--color-track);border-radius:3px}#timeControlsContainer input[type=range]::-moz-range-thumb{width:14px;height:14px;background:var(--gradient-brand);border:none;border-radius:50%;transition:transform var(--transition-fast)}#timeControlsContainer input[type=range]::-moz-range-thumb:hover{transform:scale(1.1)}#timeControlsContainer button:focus,#timeControlsContainer input[type=range]:focus{outline:none}.current-date-widget{position:absolute;left:calc(var(--space-6) + var(--time-slider-offset));bottom:45px;z-index:9999;display:inline-flex!important;width:var(--time-slider-width);min-width:50px;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:.9rem;pointer-events:none;text-align:center}.current-date-label{margin-right:5px;font-weight:700;text-align:right}.current-date-value{font-weight:400;text-align:left}.col3{position:relative;display:flex;width:auto;height:calc(100vh - 20px);padding:var(--space-3);flex-direction:column;border:none}#col1 #tradeDistribution,#col1 #tradeClusters,#col1 #tradeNodeDistribution,#col1 #tradeNodeInsight{box-shadow:none}.col1-bottom-section-content{padding:6px 10px}#networkTransRiskScore{position:absolute;top:var(--space-6);left:22px;z-index:9999;display:none;color:var(--color-accent-strong);font-size:1rem;font-weight:600}.initial-sr,.current-sr{font-family:inherit}.trade-info-header,.trade-section,.in-arbo-container{border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);background:var(--color-panel-dark);box-shadow:var(--shadow-soft);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.trade-info-header{flex:0 0 45px;margin-bottom:5px;padding:8px 10px;color:var(--color-text-on-dark);font-size:18px;font-weight:700}.trade-section{display:flex;flex:1;width:100%;min-width:0;flex-direction:column;overflow:hidden}.trade-section:first-child{margin-bottom:0}.trade-section-header{flex:0 0 auto;height:37px;padding:8px 8px 8px 11px;color:var(--color-text-on-dark);font-size:14px;font-weight:700;background:var(--gradient-brand);border-bottom:1px solid var(--color-border-soft);border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg)}.trade-list::-webkit-scrollbar{width:8px}.trade-list::-webkit-scrollbar-thumb{background-color:var(--color-accent);border-radius:4px}.trade-list::-webkit-scrollbar-thumb:hover{filter:brightness(1.2)}.trade-list::-webkit-scrollbar-track{background-color:#0003;border-radius:4px}.trade-list{flex:1;min-height:0;color:var(--color-text-on-dark);background:transparent;padding:var(--space-3);padding-top:5px;overflow-y:auto;border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg);scrollbar-color:var(--color-accent) rgba(0,0,0,.2)}.trade-item{display:flex;align-items:center;gap:var(--space-3);padding:.25rem 0;border-bottom:1px solid rgba(255,255,255,.16);font-size:.8rem}.trade-item:last-child{border-bottom:none}.trade-item-main{display:flex;flex:1;min-width:0;align-items:center;justify-content:space-between;gap:var(--space-3)}.trade-dest,.trade-src{display:flex;flex:1;min-width:0;align-items:center;gap:6px;font-weight:500}.trade-icon{flex:0 0 20px;text-align:center}.trade-distance{display:inline-flex;flex:0 0 auto;align-items:center}.distance-bar{width:50px;height:10px;display:block;flex:0 0 auto}.trade-route-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trade-volume{display:inline-flex;flex:0 0 72px;min-width:72px;align-items:center;justify-content:flex-end;font-weight:600;font-size:.95rem;line-height:1;text-align:right;font-variant-numeric:tabular-nums}.trade-header-checkbox{position:relative;display:inline-block;width:18px;height:18px;bottom:1px;border:2px solid rgba(255,255,255,.45);border-radius:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:background var(--transition-base),border-color var(--transition-base);vertical-align:middle;margin-left:10px}.trade-header-checkbox:enabled:checked{background:var(--color-accent);border-color:transparent}.trade-header-checkbox:disabled,.trade-header-checkbox:disabled:checked{background:var(--color-disabled);border-color:var(--color-disabled);cursor:not-allowed}.trade-checkbox{position:relative;flex:0 0 auto;width:20px;height:20px;border:2px solid rgba(255,255,255,.45);border-radius:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:background var(--transition-base),border-color var(--transition-base);margin-left:0}.trade-checkbox:enabled:checked{background:var(--color-accent);border-color:transparent}.trade-checkbox:disabled,.trade-checkbox:disabled:checked{background:var(--color-disabled);border-color:var(--color-disabled);cursor:not-allowed}.trade-header-checkbox:checked:after{content:"";position:absolute;left:4px;top:0;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.trade-checkbox:checked:after{content:"";position:absolute;left:4px;top:0;width:6px;height:12px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.no-trades{justify-content:center;text-align:center;font-style:italic;color:#ffffffa8}.trade-info-container{width:100%;height:100%;display:flex;min-height:0;flex-direction:column}.trade-panel{height:60%;width:100%;position:relative;display:flex;min-height:0;flex-direction:column;margin-bottom:var(--space-3);overflow:visible}.trade-sections{flex:1 1 auto;min-height:0;display:grid;grid-template-rows:minmax(0,1fr) minmax(0,1fr);gap:var(--space-3);padding:2px;overflow:visible}.in-arbo-container{visibility:hidden;height:calc(40% - 10px);width:100%;position:relative;padding:var(--space-3)}.inArboTitle{position:absolute;z-index:11;font-size:14px;font-weight:700;color:var(--color-text-on-dark)}.arbo-link{opacity:1;stroke:#46fa46;stroke-width:1;stroke-dasharray:5 5;stroke-linecap:round;animation:dashFlow 2s linear infinite}@keyframes dashFlow{to{stroke-dashoffset:-10}}.no-arbo{position:absolute;top:40px;text-align:center;font-style:italic;color:#ffffffa8}.global-stats-chart{width:calc(100% - 10px);height:33.3vh;position:absolute;z-index:10;margin-bottom:var(--space-3);padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}#globalStatsControls{position:absolute;top:var(--space-3);left:var(--space-3);z-index:11;padding:var(--space-3)}#globalStatsControls label{margin-right:5px;font-size:14px;font-weight:700}#globalStatsControls select{padding:2px 8px;color:var(--color-text-on-dark);font-size:14px;background:var(--gradient-brand);border:1px solid rgba(27,135,43,.3);border-radius:var(--radius-sm);box-shadow:var(--shadow-soft);outline:none}#globalStatsControls select:hover{filter:brightness(1.08)}.node-stats-chart{width:calc(100% - 10px);height:calc(66.7vh - 50px);margin-top:calc(33.3vh + 10px);margin-bottom:var(--space-3);position:absolute;z-index:10;padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}#nodeStatsControls{position:absolute;top:calc(33.3vh + 20px);left:var(--space-3);z-index:11;padding:var(--space-3)}#nodeStatsControls label{margin-right:5px;font-size:14px;font-weight:700}#nodeStatsControls select{padding:2px 8px;color:var(--color-text-on-dark);font-size:14px;background:var(--gradient-brand);border:1px solid rgba(27,135,43,.3);border-radius:var(--radius-sm);box-shadow:var(--shadow-soft);outline:none}#nodeStatsControls select:hover{filter:brightness(1.08)}.node{cursor:pointer;stroke-width:4.5px;stroke-dasharray:5 5;animation:dash 2s linear infinite}.nodeOver{cursor:pointer}circle:hover,g.node:hover{cursor:pointer}.trade-donut{cursor:pointer}.inactive-overlay-selected i{color:#fff}@keyframes breathing{0%{stroke-opacity:1;transform:scale(1)}50%{stroke-opacity:1;transform:scale(1.15)}to{stroke-opacity:1;transform:scale(1)}}@keyframes breathing-legend{0%{stroke-opacity:1;transform:scale(1)}50%{stroke-opacity:1;transform:scale(1)}to{stroke-opacity:1;transform:scale(1)}}.hotspotStroke{stroke-dasharray:5 5;animation:dash 2s linear infinite,breathing 2.5s ease-in-out infinite}.hotspotHalo{fill:none;stroke:orange;stroke-width:2;opacity:.8;animation:pulseHalo 1.5s infinite}@keyframes pulseHalo{0%{r:0;opacity:.8}to{transform:scale(1.5);opacity:0}}.hotspotLegend{stroke-dasharray:5 5;animation:dash 2s linear infinite,breathing-legend 2.5s ease-in-out infinite;right:20px;bottom:120px;min-width:95px;height:140px;position:absolute;border-radius:4px;cursor:move}.hotspotInfoButton{position:absolute;left:238px;top:18px;width:26px;height:26px;cursor:pointer;font-size:18px;background:none;border:none}.hotspotInfoButton i{color:var(--color-accent-strong)}.statsContainer{cursor:move;position:absolute;top:60px;left:20px;width:220px;height:190px;display:flex;flex-direction:column;justify-content:flex-start;border:none;border-radius:4px;padding:4px 8px 4px 4px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.stat-item{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;color:gray;font-family:sans-serif;font-size:.8rem;font-weight:500}.stat-icon{width:24px;text-align:center}.stat-label{flex:1;text-align:left;margin-left:8px}.stat-value{text-align:right;margin-left:8px}.link{fill:none;stroke-width:1.5px;opacity:.2}.linkOver{fill:none;stroke:#2ca02c;stroke-width:4px;opacity:1;stroke-dasharray:5 5;animation:dash 2s linear infinite}.linkSelectOut{fill:none;opacity:1;stroke:#46fa46;stroke-width:1.5px;stroke-dasharray:5 5;animation:dash 2s linear infinite}.linkSelectOutOver{fill:none;opacity:1;stroke:#f0f;stroke-width:2.5px;stroke-dasharray:5 5;animation:dash 1s linear infinite}.linkSelectIn{fill:none;opacity:1;stroke:#fcc67e;stroke-width:1.5px;stroke-dasharray:5 5;animation:dash 2s linear infinite}.linkSelectInOver{fill:none;opacity:1;stroke:#f0f;stroke-width:2.5px;stroke-dasharray:5 5;animation:dash 1s linear infinite}@keyframes dash{to{stroke-dashoffset:-10}}.bubble text{font:12px sans-serif;fill:#000}.map path{fill:none;stroke:#999;stroke-width:1}.annotation-group{pointer-events:none;position:relative}.current-date-annotation{font-size:.9rem;fill:#000;pointer-events:none}.annotation-connector{stroke-dasharray:4,2;opacity:.9}#radial-labels-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999}#tradeClusters,#tradeDistribution,#tradeNodeDistribution,#tradeNodeInsight{position:relative;min-height:200px;height:calc(50% - 5px);overflow:hidden;margin-bottom:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-card)}#tradeNodeDistribution,#tradeNodeInsight{visibility:hidden}.trade-clusters-label,.trade-distribution-label,.trade-node-distribution-label{position:absolute;padding:var(--space-3);margin-right:5px;color:var(--color-text);font-size:14px;font-weight:700}#tradeNodeInsight svg.trade-placeholder-svg{position:absolute;top:0;right:0;bottom:0;left:0}.trade-nodeinsight-label{position:absolute;top:8px;left:var(--space-3);z-index:6;color:var(--color-text);font-size:14px;font-weight:700;pointer-events:none}#tradeNodeInsightControls{position:absolute;top:32px;left:var(--space-3);right:var(--space-3);z-index:6;display:flex;align-items:center;gap:var(--space-2);font-size:12px}#tradeNodeInsightControls label{margin:0;color:var(--color-text);white-space:nowrap}#tradeNodeInsightSelect{flex:1;min-width:0;background:var(--color-surface-strong);color:var(--color-text);border:1px solid rgba(23,34,24,.12);border-radius:var(--radius-sm);padding:2px 6px;font-size:12px}#tradeNodeInsightSummary{position:absolute;top:58px;left:var(--space-3);right:var(--space-3);z-index:6;font-size:11px;line-height:1.25;color:var(--color-text-muted);pointer-events:none}#tradeNodeDistribution.glowing-border .trade-node-distribution-label,#tradeNodeDistribution.glowing-border-instant .trade-node-distribution-label,#tradeNodeInsight.glowing-border .trade-nodeinsight-label,#tradeNodeInsight.glowing-border-instant .trade-nodeinsight-label,#tradeNodeInsight.glowing-border #tradeNodeInsightControls label,#tradeNodeInsight.glowing-border-instant #tradeNodeInsightControls label,#tradeNodeInsight.glowing-border #tradeNodeInsightSummary,#tradeNodeInsight.glowing-border-instant #tradeNodeInsightSummary{color:var(--color-text-on-dark)}.cluster-annotation .annotation-note-label{font-size:8px}.cluster-annotation .annotation-note-title{font-size:10px}.node-annotation rect.annotation-note-bg{fill:var(--color-accent-strong);fill-opacity:.8;rx:4;ry:4}.node-annotation .annotation-connector .connector,.node-annotation .annotation-note .note-line{stroke:var(--color-accent-strong)}.node-annotation .annotation-note text{fill:#fff}.node-annotation.selected rect.annotation-note-bg{fill:#fff}.node-annotation.selected .annotation-connector .connector,.node-annotation.selected .annotation-note .note-line{stroke:#fff}.node-annotation.selected .annotation-note text{fill:var(--color-text-muted)}svg.custom-radar rect.annotation-bg{fill:var(--color-accent-strong);fill-opacity:.8;rx:4;ry:4}svg.custom-radar.selected rect.annotation-bg{fill:#fff}svg.custom-radar path.node-radar{fill:#fff3;stroke:#fff;stroke-width:2}svg.custom-radar.selected path.node-radar{fill:#0003;stroke:#000}svg.custom-radar line{stroke:#ffffff80}svg.custom-radar.selected line{stroke:#00000080}svg.custom-radar path.radar-baseline{stroke:#ffffffb3}svg.custom-radar.selected path.radar-baseline{stroke:#000000b3}circle.vertex{fill:#fff}circle.vertex.selected{fill:#000}.radial-axis-label{color:#fff;font-size:10px}.radial-axis-label.selected{color:var(--color-text-muted)}.line{fill:none;stroke:#e3d000;stroke-miterlimit:10;stroke-width:1;animation:line-pulse 5s ease infinite}.circle{fill:transparent;transition:fill var(--transition-base)}.blue-bg{fill:#e3d000;animation:circle-pulse 10s linear infinite;animation-delay:3s}@keyframes circle-pulse{0%,to{fill:#e3d000}50%{fill:#00fff7}}@keyframes line-pulse{0%,to{stroke:#e3d000}50%{stroke:#00f7ff}}@keyframes svg-pulse{0%,to{stroke:#00e3c5}50%{stroke:#fff}}.intro-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;justify-content:center;align-items:center;background:#0a120ba8;z-index:10000;animation:overlayFadeIn var(--transition-base) forwards}.intro-overlay.hide{animation:overlayFadeOut var(--transition-base) forwards;pointer-events:none}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes overlayFadeOut{0%{opacity:1}to{opacity:0}}.intro-content{color:#111827;width:min(1080px,92vw);padding:22px 22px 18px;background:var(--color-surface-strong);border:1px solid rgba(23,34,24,.08);border-radius:var(--radius-lg);box-shadow:0 18px 36px #00000038;animation:contentSlideIn var(--transition-base) forwards}.intro-overlay.hide .intro-content{animation:contentSlideOut var(--transition-base) forwards}@keyframes contentSlideIn{0%{transform:translateY(-24px);opacity:.5}to{transform:translateY(0);opacity:1}}@keyframes contentSlideOut{0%{transform:translateY(0);opacity:1}to{transform:translateY(-16px);opacity:0}}.intro-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:12px}.intro-subtitle{margin:6px 0 0;color:var(--color-text-muted)}.intro-left,.intro-right{display:flex;flex-direction:column}.intro-badge{display:inline-flex;align-items:center;gap:var(--space-2);width:100%;margin-bottom:var(--space-5);padding:6px 10px;color:var(--color-accent-strong);font-size:1.2em;font-weight:750;white-space:nowrap;background:var(--color-accent-soft);border:1px solid rgba(76,175,80,.25);border-radius:12px}.intro-badge-left,.intro-badge-right{align-self:center;text-align:center;justify-content:center}.intro-grid{display:grid;grid-template-columns:.8fr 1.1fr;gap:18px;align-items:start}@media (max-width: 900px){.intro-grid{grid-template-columns:1fr}}.intro-note{padding:10px 12px;margin-bottom:6px;border:1px solid rgba(23,34,24,.08);border-radius:12px;background:linear-gradient(180deg,#fffffff2,#f4f8f2e6)}.intro-dont-show-again{padding:6px 10px;background:#af4c4c12;border:1px solid rgba(175,76,76,.25);border-radius:var(--radius-sm)}.intro-dont-show-again label{display:flex;gap:var(--space-2);align-items:center}.intro-meta{margin-top:10px;color:#6b7280}.intro-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:16px;flex-wrap:wrap}.kbd-annotated{position:relative;display:grid;grid-template-columns:1fr minmax(260px,360px) 1fr;grid-template-rows:auto auto auto;gap:12px;align-items:center;padding:14px;border:1px solid rgba(23,34,24,.08);border-radius:12px;background:linear-gradient(180deg,#1e1e1e0f,#1e1e1e05)}.kbd-callout{position:relative;max-width:240px;padding:6px 10px;border-radius:12px;color:var(--color-text-on-dark);font-size:.85rem;line-height:1.25;background:var(--color-panel-dark-strong);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}#introKeyboard{grid-column:2;grid-row:2;width:100%;justify-self:center}.kbd-callout__title{font-weight:800;margin-bottom:4px}.kbd-callout__title kbd{padding:2px 6px;border-radius:6px;background:#000000d7;color:#fff;margin-right:6px;font-weight:900}.kbd-callout--s{grid-column:1;grid-row:1;justify-self:start;align-self:start}.kbd-callout--m{grid-column:3;grid-row:3;justify-self:end;align-self:start}.kbd-callout--q{grid-column:1;grid-row:2;justify-self:start;align-self:center}.kbd-callout--h{grid-column:3;grid-row:1;justify-self:center;align-self:start}.kbd-callout--r{grid-column:2;grid-row:1;justify-self:end;align-self:start}.kbd-callout--space{grid-column:1;grid-row:3;justify-self:start;align-self:end}.kbd-callout--f{grid-column:3;grid-row:2;justify-self:end;align-self:end}.kbd-callout--arrows{grid-column:2;grid-row:3;justify-self:center;align-self:end}.kbd-dot{position:absolute;width:10px;height:10px;border-radius:999px;background:#fff;box-shadow:0 0 0 3px #2e8d3459}.kbd-callout--s .kbd-dot{right:-6px;top:50%;transform:translateY(-50%)}.kbd-callout--r .kbd-dot,.kbd-callout--h .kbd-dot{bottom:-6px;left:50%;transform:translate(-50%)}.kbd-callout--m .kbd-dot,.kbd-callout--f .kbd-dot{left:-6px;top:50%;transform:translateY(-50%)}.kbd-callout--space .kbd-dot,.kbd-callout--q .kbd-dot,.kbd-callout--arrows .kbd-dot{top:-6px;left:50%;transform:translate(-50%)}#introKeyboard .hg-button{border-radius:10px;font-weight:700}#introKeyboard .hg-button.intro-key--hot{background:#fff2b8!important;color:#000!important;border:2px solid rgba(46,141,52,.7)!important;box-shadow:0 0 0 2px #69ff7366!important;font-weight:900!important}svg.leader-line,svg.leader-line:not(:root){overflow:visible!important;z-index:25000!important;pointer-events:none!important}.leader-line{z-index:25000!important}@media (max-width: 1280px){#mainContainer{grid-template-columns:minmax(0,22fr) minmax(0,48fr) minmax(0,30fr);gap:var(--space-2)}:root{--time-controls-width: min(60%, 390px)}.hotspotInfoButton{left:224px}}@media (max-width: 1040px){#mainContainer{grid-template-columns:minmax(0,24fr) minmax(0,44fr) minmax(0,32fr);padding:var(--space-2)}.col3{padding:var(--space-2)}.statsContainer{width:204px}.hotspotInfoButton{left:208px}.watermark-logo{width:112px}:root{--time-controls-width: min(64%, 340px)}}@media (max-width: 900px){.kbd-annotated{grid-template-columns:1fr;grid-template-rows:auto}#introKeyboard{grid-column:1;grid-row:auto;max-width:360px}.kbd-callout,.kbd-callout--s,.kbd-callout--m,.kbd-callout--q,.kbd-callout--h,.kbd-callout--r,.kbd-callout--space,.kbd-callout--f,.kbd-callout--arrows{grid-column:1;grid-row:auto;justify-self:stretch;align-self:auto;max-width:none}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
