: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);--floating-light-bg: rgba(255, 255, 255, .96);--floating-light-border: rgba(34, 104, 42, .22);--floating-light-shadow: 0 16px 34px rgba(18, 44, 24, .14);--floating-dark-bg: rgba(12, 22, 16, .93);--floating-dark-border: rgba(255, 255, 255, .22);--floating-dark-shadow: 0 22px 52px rgba(0, 0, 0, .32);--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 );--time-date-bottom: 45px;--time-slider-center-bottom: calc(var(--space-6) + 19px);--time-date-slider-gap: calc( var(--time-date-bottom) - var(--time-slider-center-bottom) );--time-author-line-height: 1rem;--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}.herdlink-tooltip{position:fixed;left:-9999px;top:-9999px;z-index:30000;width:max-content;max-width:min(240px,72vw);padding:6px 9px;color:var(--color-text);font-size:.78rem;font-weight:700;line-height:1.2;text-align:center;white-space:normal;letter-spacing:0;pointer-events:none;background:var(--floating-light-bg);border:1px solid var(--floating-light-border);border-radius:var(--radius-sm);box-shadow:var(--floating-light-shadow);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:0;visibility:hidden;transform:translateY(4px);transition:opacity var(--transition-fast),transform var(--transition-fast),visibility var(--transition-fast)}.herdlink-tooltip.is-visible{opacity:1;visibility:visible;transform:translateY(0)}.herdlink-tooltip.is-rich{width:min(390px,calc(100vw - 24px));max-width:min(390px,calc(100vw - 24px));padding:0;text-align:left}.tip-card{display:grid;gap:10px;padding:12px}.tip-heading{display:flex;align-items:center;gap:8px;color:var(--color-accent-strong);font-size:.9rem;font-weight:850}.tip-heading i{width:18px;text-align:center}.tip-intro{margin:0;color:var(--color-text-muted);font-size:.78rem;font-weight:600;line-height:1.34}.tip-section-list,.tip-options{display:grid;gap:7px}.tip-section{display:grid;grid-template-columns:24px minmax(0,1fr);gap:8px;align-items:start;padding:7px;border:1px solid rgba(34,104,42,.13);border-radius:var(--radius-sm);background:#4caf500f}.tip-section-icon{display:inline-flex;width:24px;height:24px;align-items:center;justify-content:center;color:var(--color-accent-strong);border-radius:50%;background:#4caf501f}.tip-section-icon i{font-size:.72rem}.tip-section-copy,.tip-option{display:grid;min-width:0;gap:2px}.tip-section-copy strong,.tip-option strong{color:var(--color-text);font-size:.75rem;font-weight:850;line-height:1.2}.tip-section-copy span,.tip-option span{color:var(--color-text-muted);font-size:.72rem;font-weight:600;line-height:1.28}.tip-options{grid-template-columns:repeat(2,minmax(0,1fr))}.tip-option{padding:7px;border:1px solid rgba(34,104,42,.12);border-radius:var(--radius-sm);background:#ffffff9e}body.focus-mode-active .herdlink-tooltip{color:var(--color-text-on-dark);background:var(--floating-dark-bg);border-color:var(--floating-dark-border);box-shadow:var(--floating-dark-shadow)}body.focus-mode-active .tip-heading,body.focus-mode-active .tip-section-icon{color:#bff0b9}body.focus-mode-active .tip-intro,body.focus-mode-active .tip-section-copy span,body.focus-mode-active .tip-option span{color:#ffffffa8}body.focus-mode-active .tip-section,body.focus-mode-active .tip-option{border-color:#ffffff1f;background:#ffffff0f}body.focus-mode-active .tip-section-icon{background:#4caf5026}body.focus-mode-active .tip-section-copy strong,body.focus-mode-active .tip-option strong{color:#fff}.panel-title-label{display:flex;width:auto;max-width:none;min-height:18px;align-items:center;gap:8px;line-height:18px}.panel-label-text{display:inline-flex;min-width:0;align-items:center;gap:5px}.panel-title-label .panel-info-button,#globalStatsControls .panel-info-button,#nodeStatsControls .panel-info-button{margin-left:auto}.panel-info-button{display:inline-flex;width:18px;height:18px;flex:0 0 auto;align-items:center;justify-content:center;padding:0;color:var(--color-accent-strong);border:0;border-radius:50%;background:#4caf501a;cursor:help;transition:color var(--transition-fast),background var(--transition-fast),filter var(--transition-fast),transform var(--transition-fast)}.panel-info-button:hover,.panel-info-button:focus-visible{color:var(--color-accent-strong);background:#4caf502e;filter:brightness(1.12);transform:translateY(-1px)}.panel-info-button i{font-size:.78rem;line-height:1}body.mode-panels-rendering #tradeDistribution>:not(.panel-title-label),body.mode-panels-rendering #tradeClusters>:not(.panel-title-label),body.mode-panels-rendering #globalStats>:not(#globalStatsControls):not(.simulation-panel-heading),body.mode-panels-rendering #nodeStats>:not(#nodeStatsControls):not(.simulation-panel-heading),body.mode-panels-rendering #tradeNodeDistribution>:not(.panel-title-label),body.mode-panels-rendering #tradeNodeInsight>:not(.trade-nodeinsight-label):not(#tradeNodeInsightControls),body.mode-panels-rendering #inArboContainer>:not(.inArboTitle){filter:blur(3px);opacity:.48;pointer-events:none;transition:filter var(--transition-fast),opacity var(--transition-fast)}body.focus-mode-active .panel-info-button,.glowing-border .panel-info-button,.glowing-border-instant .panel-info-button{color:#ffffffe0;background:#ffffff1a}body.focus-mode-active .panel-info-button:hover,body.focus-mode-active .panel-info-button:focus-visible,.glowing-border .panel-info-button:hover,.glowing-border .panel-info-button:focus-visible,.glowing-border-instant .panel-info-button:hover,.glowing-border-instant .panel-info-button:focus-visible{color:#fff;background:#ffffff2e}::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)}.header-controls-row{display:grid;width:100%;grid-template-columns:minmax(0,1fr) 54px;gap:var(--space-2);align-items:stretch}.header-switcher-stack{display:flex;min-width:0;flex-direction:column}.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}.animal-switcher input[type=radio]:disabled+label{color:var(--color-disabled);background:none;cursor:not-allowed;filter:saturate(.45)}.animal-switcher input[type=radio]:disabled+label:hover{background:none}.csv-switcher.disabled{opacity:.65;pointer-events:none;border-color:var(--color-border-strong);background:var(--color-disabled-bg)}.animal-switcher.disabled{pointer-events:auto}.csv-switcher.disabled label{color:var(--color-disabled);cursor:not-allowed;background:none}.mode-switcher-frame{display:flex;min-width:0;min-height:94px;padding:4px;border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background:#ffffffbd;box-shadow:var(--shadow-soft)}.mode-switcher{display:flex;width:100%;overflow:hidden;flex-direction:column;border-radius:var(--radius-sm);background:var(--color-surface-strong)}.mode-switcher input[type=radio]{display:none}.mode-switcher label{display:flex;flex:1;min-height:0;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:.95rem;cursor:pointer;transition:background var(--transition-base),color var(--transition-base),filter var(--transition-fast)}.mode-switcher label+input[type=radio]+label{border-top:1px solid rgba(34,104,42,.18)}.mode-switcher input[type=radio]:checked+label{color:var(--color-text-on-dark);background:var(--gradient-brand)}.mode-switcher label:hover{background:#2e8d3414}.mode-switcher-frame.disabled{opacity:.65;pointer-events:none}.mode-switcher-frame.disabled .mode-switcher label{cursor:not-allowed;filter:saturate(.65)}.mode-switcher-frame.glowing-border-switcher .mode-switcher,.mode-switcher-frame.glowing-border-switcher-instant .mode-switcher{background:#0b1b0e4d}.mode-switcher-frame.glowing-border-switcher .mode-switcher label+input[type=radio]+label,.mode-switcher-frame.glowing-border-switcher-instant .mode-switcher label+input[type=radio]+label{border-top-color:#ffffff38}.mode-switcher-frame.glowing-border-switcher .mode-switcher label:hover,.mode-switcher-frame.glowing-border-switcher-instant .mode-switcher label:hover{background:#ffffff14}#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:var(--time-date-bottom);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}.time-author-credit{position:absolute;left:calc(var(--space-6) + var(--time-slider-offset));bottom:calc(var(--time-slider-center-bottom) - var(--time-date-slider-gap) - var(--time-author-line-height));z-index:9999;display:none;width:var(--time-slider-width);min-width:50px;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:.82rem;font-weight:600;line-height:var(--time-author-line-height);pointer-events:none;text-align:center}.simulation-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20000;display:flex;align-items:center;justify-content:center;padding:var(--space-6);pointer-events:none;background:#e8f0e49e;opacity:0;visibility:hidden;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:opacity var(--transition-base),visibility var(--transition-base)}.simulation-loading-overlay.is-visible{opacity:1;visibility:visible;pointer-events:auto}.simulation-loading-panel{width:min(460px,92%);padding:var(--space-5);color:var(--color-text);border:1px solid var(--floating-light-border);border-radius:var(--radius-lg);background:var(--floating-light-bg);box-shadow:var(--floating-light-shadow)}.simulation-loading-header{display:grid;grid-template-columns:36px minmax(0,1fr) auto;gap:var(--space-3);align-items:center}.simulation-loading-header>i{display:inline-flex;width:36px;height:36px;align-items:center;justify-content:center;color:#172218;border-radius:var(--radius-md);background:#f2c94c}.simulation-loading-title{font-size:1rem;font-weight:800;line-height:1.1}.simulation-loading-stage{margin-top:3px;color:var(--color-text-muted);font-size:.84rem;font-weight:600}.simulation-loading-percent{font-size:1.1rem;font-weight:800;font-variant-numeric:tabular-nums}.simulation-progress-track{height:8px;margin-top:var(--space-5);overflow:hidden;border-radius:var(--radius-pill);background:#22682a24}.simulation-progress-bar{width:0;height:100%;border-radius:inherit;background:linear-gradient(90deg,#7bb661,#f2c94c,#eb5757);transition:width .18s ease}.simulation-progress-items{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-2);margin-top:var(--space-5)}.simulation-progress-item{display:flex;min-width:0;align-items:center;gap:7px;color:var(--color-text-subtle);font-size:.8rem;font-weight:650}.simulation-progress-dot{width:9px;height:9px;flex:0 0 auto;border-radius:50%;background:#22682a33}.simulation-progress-item.is-running{color:var(--color-text)}.simulation-progress-item.is-running .simulation-progress-dot{background:#f2c94c;box-shadow:0 0 0 4px #f2c94c2e}.simulation-progress-item.is-done{color:var(--color-text-muted)}.simulation-progress-item.is-done .simulation-progress-dot{background:#7bb661}body.focus-mode-active .simulation-loading-overlay{background:#080e0a8c}body.focus-mode-active .simulation-loading-panel{color:var(--color-text-on-dark);border-color:var(--floating-dark-border);background:var(--floating-dark-bg);box-shadow:var(--floating-dark-shadow)}body.focus-mode-active .simulation-loading-stage{color:#ffffffb8}body.focus-mode-active .simulation-progress-track{background:#ffffff2e}body.focus-mode-active .simulation-progress-item{color:#ffffff94}body.focus-mode-active .simulation-progress-dot{background:#ffffff4d}body.focus-mode-active .simulation-progress-item.is-running{color:#fff}body.focus-mode-active .simulation-progress-item.is-done{color:#ffffffd6}.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}.simulation-controls-panel{position:absolute;top:var(--space-3);left:var(--space-3);right:calc(var(--space-3) + 10px);z-index:12;padding:var(--space-3);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background:#f9fcf8e6;box-shadow:var(--shadow-soft);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.simulation-controls-panel[hidden]{display:none!important}.simulation-controls-title{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-bottom:var(--space-2);color:var(--color-text);font-size:.82rem;font-weight:800}.simulation-controls-heading-text{display:inline-flex;min-width:0;align-items:center;gap:var(--space-2)}.simulation-controls-info{color:var(--color-accent-strong)}.simulation-controls-info:hover,.simulation-controls-info:focus-visible{color:var(--color-accent-strong);background:#4caf502e;filter:brightness(1.18);transform:translateY(-1px)}.simulation-controls-info i{font-size:.82rem;line-height:1}.simulation-control-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-2)}.simulation-control-grid label{display:flex;min-width:0;flex-direction:column;gap:2px;color:var(--color-text-muted);font-size:.68rem;font-weight:750}.simulation-control-grid input,.simulation-control-grid select{min-width:0;width:100%;padding:3px 5px;color:var(--color-text);font-size:.75rem;border:1px solid rgba(34,104,42,.2);border-radius:var(--radius-sm);background:var(--color-surface-strong)}.simulation-control-grid input:disabled,.simulation-control-grid select:disabled{color:var(--color-disabled);background:var(--color-disabled-bg)}.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}.simulation-focus-pill{float:right;margin-top:3px;padding:2px 7px;color:#172218;font-size:.72rem;font-weight:800;border-radius:var(--radius-pill);background:#f2c94c}.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);right:var(--space-3);z-index:11;display:flex;align-items:center;gap:var(--space-2);padding:0}#globalStatsControls label{display:inline-flex;align-items:center;gap:5px;margin-right:0;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)}body.simulation-mode-active:not(.focus-mode-active) #col3{gap:var(--space-3)}body.simulation-mode-active:not(.focus-mode-active) .simulation-controls-panel{position:relative;top:auto;left:auto;right:auto;order:0;flex:0 0 auto;width:calc(100% - 10px);margin:0;background:var(--color-surface);backdrop-filter:none;-webkit-backdrop-filter:none}body.simulation-mode-active:not(.focus-mode-active) .global-stats-chart,body.simulation-mode-active:not(.focus-mode-active) .node-stats-chart{position:relative;overflow:hidden;width:calc(100% - 10px);margin:0}body.simulation-mode-active:not(.focus-mode-active) .global-stats-chart{order:1;flex:0 0 27vh;height:auto}body.simulation-mode-active:not(.focus-mode-active) .node-stats-chart{order:2;flex:1 1 0;min-height:180px;height:auto}body.simulation-mode-active:not(.focus-mode-active) #tradeInfo{display:none!important}.simulation-global-chart text,.simulation-node-chart text,.simulation-spatial-chart text,.simulation-partition-chart text,.simulation-focus-chart text,.trade-nodeinsight-svg text{fill:var(--color-text-muted);font-size:10px;font-weight:650}.simulation-global-chart,.simulation-node-chart,.simulation-spatial-chart,.simulation-partition-chart{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.simulation-partition-chart,.trade-community-chart{transition:filter var(--transition-base),opacity var(--transition-base)}#tradeClusters.simulation-partition-map-expanded .simulation-partition-chart,#tradeClusters.simulation-partition-map-expanded .trade-community-chart{filter:blur(2.5px);opacity:.36}.trade-community-chart text{fill:var(--color-text-muted);font-size:9px;font-weight:750}.trade-community-cell,.trade-community-load-bar{vector-effect:non-scaling-stroke}.trade-community-column-label,.trade-community-row-label,.trade-community-load-label{fill:var(--color-text)!important}.trade-community-summary-label{fill:var(--color-text-muted)!important;font-size:9px;font-weight:800}.trade-community-summary-value{fill:var(--color-text)!important;font-size:11px;font-weight:850}.simulation-global-chart .tick line,.simulation-node-chart .tick line{stroke:#1722181f}.simulation-global-chart .domain,.simulation-node-chart .domain,.simulation-spatial-chart .domain,.simulation-partition-chart .domain,.simulation-focus-chart .domain,.trade-nodeinsight-svg .domain{stroke:#1722182e}.simulation-spatial-region{vector-effect:non-scaling-stroke}.simulation-spatial-flow{mix-blend-mode:multiply;pointer-events:none}.simulation-spatial-bubble,.simulation-partition-cell,.simulation-partition-burden{vector-effect:non-scaling-stroke}.simulation-spatial-mini-legend text{fill:var(--color-text-muted)!important;font-size:8.5px;font-weight:800}.simulation-kpi-label{fill:var(--color-text-muted)!important;font-size:9px;font-weight:750}.simulation-kpi-value{fill:var(--color-text)!important;font-size:11px;font-weight:850}.simulation-partition-column-label,.simulation-partition-row-label,.simulation-partition-burden-label{fill:var(--color-text)!important;font-size:9px;font-weight:750}.simulation-partition-map{position:absolute;right:var(--space-3);bottom:var(--space-3);left:var(--space-3);z-index:12;display:block;min-height:0;max-height:var(--partition-map-compact-height, 56px);overflow:hidden;padding:6px 8px;color:var(--color-text);border:1px solid rgba(34,104,42,.2);border-radius:var(--radius-sm);background:#f9fcf8eb;box-shadow:0 8px 20px #17221814;pointer-events:auto;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:max-height var(--transition-base),background var(--transition-base),box-shadow var(--transition-base)}.simulation-partition-map:hover,.simulation-partition-map:focus-visible,.simulation-partition-map:focus-within{max-height:var(--partition-map-expanded-height, 180px);overflow-y:auto;background:#f9fcf8f7;box-shadow:0 16px 34px #1722182e}.simulation-partition-map:focus-visible{outline:2px solid rgba(46,141,52,.45);outline-offset:2px}.simulation-partition-map-header{display:flex;min-width:0;align-items:center;justify-content:space-between;gap:var(--space-2);margin-bottom:5px}.simulation-partition-map-compact,.simulation-partition-map-full{display:grid;grid-template-columns:repeat(var(--partition-map-columns, 1),minmax(0,1fr));gap:4px 8px}.simulation-partition-map-full{display:none}.simulation-partition-map:hover .simulation-partition-map-compact,.simulation-partition-map:focus-visible .simulation-partition-map-compact,.simulation-partition-map:focus-within .simulation-partition-map-compact{display:none}.simulation-partition-map:hover .simulation-partition-map-full,.simulation-partition-map:focus-visible .simulation-partition-map-full,.simulation-partition-map:focus-within .simulation-partition-map-full{display:grid}.simulation-partition-map-title,.simulation-partition-map-more,.simulation-partition-map-hint{color:var(--color-text-muted);font-size:9px;font-weight:800;line-height:1}.simulation-partition-map-title{color:var(--color-text)}.simulation-partition-map-more{grid-column:1 / -1}.simulation-partition-map-hint{flex:0 0 auto;font-size:8px;text-transform:uppercase}.simulation-partition-map-row{display:flex;min-width:0;align-items:center;gap:6px;font-size:9px;font-weight:750;line-height:1.15}.simulation-partition-map-key{display:inline-flex;flex:0 0 auto;align-items:center;gap:4px;color:var(--color-text)}.simulation-partition-map-swatch{width:7px;height:7px;flex:0 0 auto;border-radius:50%}.simulation-partition-map-regions{min-width:0;overflow:hidden;color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap}.simulation-partition-map-full .simulation-partition-map-row{align-items:flex-start}.simulation-partition-map-full .simulation-partition-map-regions{overflow:visible;line-height:1.2;text-overflow:clip;white-space:normal}.simulation-current-line{stroke:#6b7280;stroke-width:1.5;stroke-dasharray:4 3}.simulation-current-range{fill:#6b72802e;pointer-events:none}.simulation-current-callout,.simulation-compartment-callouts{pointer-events:none}.simulation-current-callout-bg,.simulation-compartment-callout-bg{fill:#6b72806b}.simulation-current-callout-connector,.simulation-compartment-callout-connector{stroke:#6b7280;stroke-width:1;stroke-dasharray:4 3}.simulation-current-callout-text,.simulation-compartment-callout-text{fill:#fff!important;font-size:10px;font-weight:750}.simulation-compartment-callout-point{stroke:#ffffffe6;stroke-width:1.2}.simulation-chart-date-legend{fill:var(--color-text)!important;font-size:10px;font-weight:750}.simulation-ledger-axis-label{fill:var(--color-text)!important;font-size:11px;font-weight:750}.simulation-focus-legend text{fill:#fffffff2;font-size:10px;font-weight:700}body.simulation-mode-active #tradeNodeDistribution .simulation-focus-chart text,body.simulation-mode-active #tradeNodeInsight .trade-nodeinsight-svg.simulation-nodeinsight-svg text{fill:#fffffff2}body.simulation-mode-active #tradeNodeDistribution .simulation-focus-chart .simulation-focus-axis path,body.simulation-mode-active #tradeNodeDistribution .simulation-focus-chart .simulation-focus-axis line,body.simulation-mode-active #tradeNodeInsight .trade-nodeinsight-svg.simulation-nodeinsight-svg .simulation-focus-axis path,body.simulation-mode-active #tradeNodeInsight .trade-nodeinsight-svg.simulation-nodeinsight-svg .simulation-focus-axis line{stroke:#ffffff9e}body.simulation-mode-active #tradeNodeDistribution .simulation-focus-chart .simulation-focus-grid line,body.simulation-mode-active #tradeNodeInsight .trade-nodeinsight-svg.simulation-nodeinsight-svg .simulation-focus-grid line{stroke:#fff3;stroke-dasharray:3 3}body.simulation-mode-active #tradeNodeDistribution .simulation-focus-chart .simulation-focus-grid path,body.simulation-mode-active #tradeNodeInsight .trade-nodeinsight-svg.simulation-nodeinsight-svg .simulation-focus-grid path{stroke:none}#tradeNodeInsight.glowing-border .trade-nodeinsight-svg text,#tradeNodeInsight.glowing-border-instant .trade-nodeinsight-svg text{fill:#fffffff2}#tradeNodeInsight.glowing-border .trade-nodeinsight-svg .x-axis path,#tradeNodeInsight.glowing-border .trade-nodeinsight-svg .x-axis line,#tradeNodeInsight.glowing-border .trade-nodeinsight-svg .y-axis path,#tradeNodeInsight.glowing-border .trade-nodeinsight-svg .y-axis line,#tradeNodeInsight.glowing-border .trade-nodeinsight-svg .distance-axis-container path,#tradeNodeInsight.glowing-border .trade-nodeinsight-svg .distance-axis-container line,#tradeNodeInsight.glowing-border-instant .trade-nodeinsight-svg .x-axis path,#tradeNodeInsight.glowing-border-instant .trade-nodeinsight-svg .x-axis line,#tradeNodeInsight.glowing-border-instant .trade-nodeinsight-svg .y-axis path,#tradeNodeInsight.glowing-border-instant .trade-nodeinsight-svg .y-axis line,#tradeNodeInsight.glowing-border-instant .trade-nodeinsight-svg .distance-axis-container path,#tradeNodeInsight.glowing-border-instant .trade-nodeinsight-svg .distance-axis-container line{stroke:#ffffff9e}.simulation-chart-legend text,.simulation-panel-title{fill:var(--color-text);font-size:11px;font-weight:800}.simulation-panel-heading{position:absolute;top:var(--space-3);left:var(--space-3);right:var(--space-3);z-index:11;color:var(--color-text);font-size:.86rem;font-weight:800}.simulation-node-bar text{fill:var(--color-text);font-size:10px;font-weight:750;stroke:none}.simulation-donut{pointer-events:none}#nodeStatsControls{position:absolute;top:var(--space-3);left:var(--space-3);right:var(--space-3);z-index:11;display:flex;align-items:center;gap:var(--space-2);padding:0}#nodeStatsControls label{display:inline-flex;align-items:center;gap:5px;margin-right:0;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;z-index:9999;display:inline-flex;width:26px;height:26px;align-items:center;justify-content:center;cursor:pointer;font-size:18px;color:var(--color-accent-strong);border:0;background:none;transition:opacity var(--transition-base),transform var(--transition-base),visibility var(--transition-base)}body.simulation-mode-active .hotspotInfoButton{opacity:0;visibility:hidden;pointer-events:none}.hotspotInfoButton>div{display:inline-flex;width:100%;height:100%;align-items:center;justify-content:center}.hotspotInfoButton i{color:currentColor}.hotspotInfoButton:hover{transform:translateY(-1px)}.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)}.statsContainer.simulation-stats-container{height:auto}.statsContainer.simulation-stats-container .stat-item:last-child{margin-bottom:0}.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;top:0;left:0;right:0;z-index:6;padding:var(--space-3);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);right:var(--space-3);z-index:6;color:var(--color-text);font-size:14px;font-weight:700}.inArboTitle.panel-title-label{top:var(--space-3);left:var(--space-3);right:var(--space-3)}#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}.hotspot-info-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10020;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:#f5faf3b8;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:overlayFadeIn var(--transition-base) forwards}.hotspot-info-overlay.hide{animation:overlayFadeOut var(--transition-base) forwards;pointer-events:none}.hotspot-info-card{position:relative;width:min(980px,92vw);max-height:min(720px,90vh);overflow-y:auto;padding:22px;color:#111827;border:1px solid rgba(23,34,24,.08);border-radius:var(--radius-lg);background:var(--color-surface-strong);box-shadow:0 18px 36px #00000038;animation:contentSlideIn var(--transition-base) forwards}.hotspot-info-overlay.hide .hotspot-info-card{animation:contentSlideOut var(--transition-base) forwards}.hotspot-info-close{position:absolute;top:14px;right:14px;display:inline-flex;width:30px;height:30px;align-items:center;justify-content:center;color:var(--color-text-muted);border:1px solid rgba(23,34,24,.1);border-radius:50%;background:#ffffffd1;cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast),transform var(--transition-fast)}.hotspot-info-close:hover,.hotspot-info-close:focus-visible{color:var(--color-text-on-dark);background:var(--gradient-brand);transform:translateY(-1px)}.hotspot-info-head{display:flex;gap:14px;align-items:flex-start;margin-bottom:16px;padding-right:42px}.hotspot-info-badge{display:inline-flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);padding:6px 10px;color:var(--color-accent-strong);font-size:1rem;font-weight:750;border:1px solid rgba(76,175,80,.25);border-radius:12px;background:var(--color-accent-soft)}.hotspot-info-card h2{margin:0;color:var(--color-text);font-size:1.55rem;line-height:1.1}.hotspot-info-subtitle{max-width:720px;margin:8px 0 0;color:var(--color-text-muted);font-size:.96rem}.hotspot-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px}.hotspot-metric-card{display:flex;min-width:0;flex-direction:column;gap:7px;padding:11px 12px;border:1px solid rgba(23,34,24,.08);border-radius:var(--radius-md);background:linear-gradient(180deg,#fffffff7,#f4f8f2eb);box-shadow:0 8px 18px #122c180d}.hotspot-metric-head{display:flex;min-width:0;align-items:center;justify-content:space-between;gap:var(--space-2)}.hotspot-metric-code{display:inline-flex;width:28px;height:28px;flex:0 0 auto;align-items:center;justify-content:center;color:var(--color-accent-strong);font-size:.72rem;font-weight:850;border:1px solid rgba(46,141,52,.24);border-radius:50%;background:#4caf501f}.hotspot-metric-role{display:inline-flex;min-width:0;align-items:center;gap:5px;color:var(--color-accent-strong);font-size:.78rem;font-weight:800;white-space:nowrap}.hotspot-metric-card h3{margin:0;color:var(--color-text);font-size:.96rem;line-height:1.15}.hotspot-metric-card p{margin:0;color:var(--color-text-muted);font-size:.86rem;line-height:1.32}.hotspot-metric-method{margin-top:auto;padding-top:7px;color:var(--color-text-subtle);font-size:.76rem;font-weight:750;border-top:1px solid rgba(23,34,24,.08)}body.focus-mode-active .hotspot-info-overlay{background:#080e0ab8}body.focus-mode-active .hotspot-info-card{color:var(--color-text-on-dark);border-color:var(--floating-dark-border);background:linear-gradient(180deg,#0f1b12f5,#08110cf0);box-shadow:var(--floating-dark-shadow)}body.focus-mode-active .hotspot-info-close{color:#ffffffbd;border-color:#ffffff29;background:#ffffff14}body.focus-mode-active .hotspot-info-close:hover,body.focus-mode-active .hotspot-info-close:focus-visible{color:var(--color-text);background:#f2c94c}body.focus-mode-active .hotspot-info-badge{color:#bff0b9;border-color:#bff0b942;background:#4caf5029}body.focus-mode-active .hotspot-info-card h2{color:#fff}body.focus-mode-active .hotspot-info-subtitle{color:#ffffffb3}body.focus-mode-active .hotspot-metric-card{border-color:#ffffff24;background:linear-gradient(180deg,#ffffff14,#ffffff0a);box-shadow:none}body.focus-mode-active .hotspot-metric-code{color:#bff0b9;border-color:#bff0b947;background:#4caf5026}body.focus-mode-active .hotspot-metric-role{color:#bff0b9}body.focus-mode-active .hotspot-metric-card h3{color:#fff}body.focus-mode-active .hotspot-metric-card p{color:#ffffffad}body.focus-mode-active .hotspot-metric-method{color:#ffffff8a;border-top-color:#ffffff1f}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes overlayFadeOut{0%{opacity:1}to{opacity:0}}.intro-content{color:#111827;width:min(1080px,92vw);max-height:min(760px,92vh);overflow-y:auto;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-3);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:minmax(340px,.82fr) minmax(460px,1.1fr);gap:16px;align-items:start}@media (max-width: 900px){.intro-grid{grid-template-columns:1fr}}.intro-note-list{display:grid;gap:7px}.intro-note{display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;align-items:start;padding:8px 10px;border:1px solid rgba(23,34,24,.08);border-radius:var(--radius-md);background:linear-gradient(180deg,#fffffff7,#f4f8f2eb);box-shadow:0 8px 18px #122c180d}.intro-note--simulation{border-color:#2e8d3447;background:linear-gradient(180deg,#f1f9effa,#e5f2e2f0)}.intro-note-index{display:inline-flex;width:28px;height:28px;align-items:center;justify-content:center;color:var(--color-accent-strong);font-size:.72rem;font-weight:850;border:1px solid rgba(46,141,52,.24);border-radius:50%;background:#4caf501f}.intro-note-copy{min-width:0;color:var(--color-text);font-size:.94rem;line-height:1.35}.intro-note-copy i{margin:0 4px 0 6px;color:var(--color-accent-strong)}.intro-note-copy i:first-child{margin-left:0}.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--e{grid-column:2;grid-row:1;width:124px;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;width:132px;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--e .kbd-dot,.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)}.simulation-control-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@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--e,.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}}
