html,body{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}@-ms-viewport{width:device-width}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[title],abbr[data-original-title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=text],input[type=password],input[type=number],textarea{-webkit-appearance:none}ol,ul,dl{margin-top:0;margin-bottom:1em}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}pre,code,kbd,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}a,area,button,[role=button],input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}input,button,select,optgroup,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{padding:0;border-style:none}input[type=radio],input[type=checkbox]{box-sizing:border-box;padding:0}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}mark{padding:.2em;background-color:#feffe6}:root{color-scheme:light;--custom-bg-image: none;--bg: #f7f8fa;--surface: #ffffff;--surface-soft: #f8fafc;--surface-strong: #ffffff;--border: #e5e7eb;--border-strong: #d8dee6;--text: #111827;--muted: #6b7280;--muted-strong: #374151;--green: #16a34a;--green-soft: #ecfdf3;--blue: #2563eb;--blue-soft: #eff6ff;--amber: #f59e0b;--amber-soft: #fffbeb;--red: #ef4444;--red-soft: #fef2f2;--shadow: 0 12px 30px rgba(15, 23, 42, .06);--page-overlay: linear-gradient(180deg, #fbfcfd, #f7f8fa);--page-overlay-strong: linear-gradient(180deg, #fbfcfd, #f7f8fa);background:var(--bg);min-height:100%}:root.dark{color-scheme:dark;--bg: #07120f;--surface: rgba(13, 21, 18, .5);--surface-soft: rgba(17, 30, 25, .32);--surface-strong: rgba(15, 25, 21, .72);--border: rgba(255, 255, 255, .12);--border-strong: rgba(255, 255, 255, .2);--text: #f5f5f5;--muted: #a9bbb4;--muted-strong: #d7e4df;--green: #73d13d;--green-soft: rgba(115, 209, 61, .12);--blue: #38bdf8;--blue-soft: rgba(56, 189, 248, .12);--amber: #ffd666;--amber-soft: rgba(255, 214, 102, .13);--red: #ff7875;--red-soft: rgba(255, 120, 117, .13);--shadow: 0 24px 80px rgba(0, 0, 0, .36);--page-overlay: radial-gradient(circle at 16% 10%, rgba(42, 92, 72, .3), transparent 28%), linear-gradient(135deg, rgba(2, 8, 6, .58), rgba(8, 20, 17, .5) 48%, rgba(24, 12, 22, .5));--page-overlay-strong: linear-gradient(135deg, rgba(5, 13, 10, .58), rgba(9, 22, 18, .46)), radial-gradient(circle at 78% 16%, rgba(29, 78, 58, .22), transparent 32%);background:var(--bg)}*{box-sizing:border-box}html,body,#root{height:100%;min-height:100%;margin:0}body{overflow:hidden;background:var(--bg);color:var(--text);font-family:IBM Plex Sans,Avenir Next,Segoe UI Variable,PingFang SC,Hiragino Sans GB,Noto Sans SC,sans-serif;text-rendering:optimizeLegibility}.page-shell{height:100vh;min-height:100vh;overflow-x:hidden;overflow-y:auto;scrollbar-gutter:stable;background:var(--page-overlay-strong);scrollbar-color:rgba(37,99,235,.38) #eef2f7;scrollbar-width:thin}.page-shell::-webkit-scrollbar{width:12px}.page-shell::-webkit-scrollbar-track{border-left:1px solid var(--border);background:#eef2f7}.page-shell::-webkit-scrollbar-thumb{border:3px solid #eef2f7;border-radius:999px;background:#2563eb61;background-clip:padding-box}.page-shell::-webkit-scrollbar-thumb:hover{background:#2563eb8f;background-clip:padding-box}.page-background{display:none}.page-background-left{top:74px;left:max(-90px,-8vw);width:260px;height:260px;border-radius:999px;background:radial-gradient(circle,rgba(255,208,221,.42),transparent 70%)}.page-background-right{right:max(-120px,-10vw);bottom:48px;width:340px;height:340px;border-radius:999px;background:radial-gradient(circle,rgba(116,211,255,.36),transparent 70%)}.app-shell{position:relative;z-index:1;width:min(1120px,calc(100% - 32px));margin:0 auto;padding:24px 0 42px}.hero-panel{display:flex;justify-content:space-between;gap:20px;align-items:center;padding:2px 0 26px;margin-bottom:0;border:0;border-radius:0;background:transparent;box-shadow:none}.hero-panel .ant-typography{margin-bottom:0}.hero-panel h1.ant-typography{font-size:18px;line-height:1.2}.eyebrow{margin-bottom:2px;color:var(--green);font-size:11px;font-weight:700;text-transform:uppercase}.hero-copy{display:none;max-width:820px;margin-top:8px;color:var(--muted);font-size:14px;line-height:1.7}.hero-actions{display:flex;align-items:flex-start;gap:10px;flex-wrap:wrap}.hero-actions-column{flex-direction:column;min-width:min(100%,390px)}.hero-actions-column .ant-space{width:100%}.personal-center-button{width:100%;min-height:48px;justify-content:flex-start;border-color:color-mix(in srgb,var(--green) 35%,transparent);background:color-mix(in srgb,var(--card) 78%,var(--green-soft));box-shadow:0 12px 28px #0f766e1f;color:var(--text);font-weight:800}.personal-center-button span:last-child{margin-left:auto;color:var(--green);font-size:13px;font-weight:700}.personal-center-panel{display:grid;gap:18px}.personal-center-profile{display:flex;align-items:center;gap:16px;padding:18px;border:1px solid color-mix(in srgb,var(--green) 24%,transparent);border-radius:24px;background:radial-gradient(circle at 15% 15%,color-mix(in srgb,var(--green) 22%,transparent),transparent 32%),color-mix(in srgb,var(--card) 82%,white)}.personal-center-profile .ant-typography{margin:0}.personal-center-avatar{display:grid;width:64px;height:64px;place-items:center;border-radius:22px;background:var(--green);color:#fff;font-size:28px;box-shadow:0 18px 36px #0f766e38}.personal-center-actions{display:grid;gap:10px}.personal-center-actions .ant-btn{min-height:44px;justify-content:flex-start}.client-install-switch{display:flex;align-items:center;min-height:32px;gap:10px}.client-install-command-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.client-install-command,.client-install-command textarea{font-family:JetBrains Mono,SFMono-Regular,Consolas,monospace;font-size:12px;line-height:1.7}.login-shell{display:grid;min-height:100vh;place-items:center;padding:24px;background:var(--page-overlay-strong),var(--custom-bg-image) center / cover no-repeat,var(--bg)}.login-panel{width:min(100%,420px);padding:28px;border:1px solid var(--border);border-radius:10px;background:var(--surface);box-shadow:var(--shadow)}.login-brand{display:flex;align-items:center;gap:14px;margin-bottom:26px}.login-brand .ant-typography{margin-bottom:0}.login-mark{display:grid;width:46px;height:46px;place-items:center;border-radius:10px;background:var(--green-soft);color:var(--green);font-size:22px}.workspace-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:18px;align-items:start}.agent-rail{position:static}.surface-card{border:1px solid var(--border);border-radius:18px;background:var(--surface);box-shadow:var(--shadow)}.surface-card .ant-card-head{min-height:44px;border-bottom-color:var(--border)}.surface-card .ant-card-body,.sidebar-card .ant-card-body,.summary-card .ant-card-body,.tabs-card .ant-card-body,.surface-card .ant-list,.surface-card .ant-list-item,.surface-card .ant-empty,.surface-card .ant-table,.surface-card .ant-table-container,.surface-card .ant-table-content,.surface-card .ant-tabs-content-holder,.surface-card .ant-descriptions-view,.surface-card .ant-descriptions-item-content{background:transparent}.surface-card .ant-table-thead>tr>th{background:#f8fafc!important}.surface-card .ant-table-tbody>tr>td{background:#fff!important;border-bottom-color:var(--border)!important}.surface-card .ant-table-tbody>tr:hover>td{background:#f8fbff!important}.alert-card{overflow:hidden;border-color:var(--border);background:transparent}.alert-card .ant-alert{border-radius:10px}.topology-entry-card .ant-card-body{background:transparent}.topology-entry{display:flex;justify-content:space-between;gap:16px;align-items:center}.topology-entry .ant-typography{margin-bottom:0}.import-url-qr{display:grid;justify-content:center;padding:16px;border:1px solid color-mix(in srgb,var(--border) 72%,transparent);border-radius:14px;background:color-mix(in srgb,var(--surface) 72%,transparent)}.agent-list-item{height:100%;padding:0!important;border:0!important}.agent-list-card .ant-list-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,360px),1fr));gap:12px;align-items:stretch}.agent-list-list .ant-list-items{display:grid;grid-template-columns:1fr;gap:10px}.agent-button{display:flex;flex-direction:column;gap:10px;width:100%;height:100%;min-height:214px;padding:12px 14px;text-align:left;border:1px solid var(--border);border-radius:16px;background:#fff;box-shadow:0 8px 22px #0f172a0a;transition:background .15s ease,border-color .15s ease,transform .15s ease;cursor:pointer}.agent-button:hover{border-color:#bfdbfe;background:#f8fbff;transform:translateY(-1px)}.agent-button.active{border-color:#60a5fa;background:#eff6ff;box-shadow:inset 4px 0 0 var(--blue),0 10px 26px #2563eb1f}.agent-button-list{display:grid;grid-template-columns:minmax(210px,.95fr) minmax(280px,1fr) minmax(300px,1.12fr);min-height:0;padding:14px 16px;align-items:center}.agent-list-main{display:grid;min-width:0;gap:6px}.agent-list-main .agent-card-head{gap:8px}.agent-list-main .agent-name{font-size:13px}.agent-list-location{justify-content:flex-start}.agent-list-tags{gap:4px}.agent-list-tags .agent-tag-chip{padding:2px 7px;font-size:10.5px}.agent-list-metrics,.agent-list-flow{display:grid;min-width:0;gap:6px}.agent-list-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.agent-button-list .mini-progress{padding:5px 7px;border-radius:10px}.agent-button-list .mini-progress-track{height:4px;margin-top:4px}.agent-button-list .mini-progress-head{font-size:10.5px}.agent-rail-toolbar{justify-content:flex-end}.agent-view-mode-button.ant-btn{width:34px;height:34px;border-color:color-mix(in srgb,var(--border) 82%,transparent);background:color-mix(in srgb,var(--surface-strong) 72%,transparent);color:var(--blue);box-shadow:0 8px 20px #0284c71f}.agent-view-mode-button.ant-btn:hover,.agent-view-mode-button.ant-btn:focus-visible{border-color:color-mix(in srgb,var(--blue) 35%,var(--border));background:color-mix(in srgb,var(--surface-strong) 88%,transparent);color:var(--blue)}.agent-view-mode-button.ant-btn.active{border-color:color-mix(in srgb,var(--blue) 26%,transparent);background:color-mix(in srgb,var(--blue-soft) 42%,var(--surface-strong));color:var(--blue);box-shadow:0 0 0 3px color-mix(in srgb,var(--blue-soft) 55%,transparent),0 10px 24px #0284c729}.agent-view-mode-button .anticon{font-size:16px}.agent-card-head{display:flex;justify-content:space-between;gap:10px;align-items:center}.agent-title-line{display:flex;min-width:0;align-items:center;gap:8px}.agent-state-dot{width:10px;height:10px;flex:0 0 auto;border-radius:999px;background:#94a3b8;box-shadow:0 0 0 4px #94a3b829}.agent-state-ok{background:#16a34a;box-shadow:0 0 0 5px #dcfce7}.agent-state-warn{background:#f59e0b;box-shadow:0 0 0 5px #fef3c7}.agent-state-bad{background:#ef4444;box-shadow:0 0 0 5px #fee2e2}.agent-order-chip{flex:0 0 auto;padding:2px 6px;border:1px solid #bfdbfe;border-radius:999px;background:#eff6ff;color:var(--blue);font-size:11px;font-weight:800;line-height:1.2}.agent-flag{display:grid;width:26px;height:26px;flex:0 0 auto;place-items:center;border:1px solid #e5e7eb;border-radius:999px;background:#fff;font-size:17px;line-height:1}.agent-name{overflow:hidden;color:var(--text);font-size:15px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.agent-status-pill{flex:0 0 auto;padding:3px 8px;border:1px solid #d1d5db;border-radius:999px;background:#f9fafb;color:var(--muted-strong);font-size:11px;font-weight:400;line-height:1.3}.agent-status-ok{border-color:#bbf7d0;background:#f0fdf4;color:#15803d}.agent-status-warn{border-color:#fde68a;background:#fffbeb;color:#b45309}.agent-status-bad{border-color:#fecaca;background:#fef2f2;color:#b91c1c}.agent-meta,.muted-line{color:var(--muted);font-size:12px;line-height:1.5}.agent-location{display:flex;flex-wrap:wrap;justify-content:space-between;gap:4px 10px;min-height:18px;word-break:break-word}.agent-tag-row{display:flex;flex-wrap:wrap;gap:6px}.agent-tag-chip{padding:3px 8px;border:1px solid #e5e7eb;border-radius:999px;background:#f8fafc;color:#334155;font-size:11px;font-weight:700;line-height:1.35}.agent-meter-grid,.agent-traffic-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.agent-traffic-grid .agent-wide-progress{grid-column:1 / -1}.client-traffic-cell{display:grid;gap:2px;color:var(--text);font-size:12px;line-height:1.45}.client-traffic-cell span+span{color:var(--muted)}.mini-progress{min-width:0;padding:7px 8px;border:1px solid #edf2f7;border-radius:12px;background:#fbfdff}.mini-progress-head{display:flex;justify-content:space-between;gap:8px;color:var(--muted);font-size:11px;line-height:1.35}.mini-progress-head span:last-child{overflow:hidden;color:var(--muted-strong);font-weight:400;text-align:right;text-overflow:ellipsis;white-space:nowrap}.mini-progress-track{height:6px;margin-top:6px;overflow:hidden;border-radius:999px;background:#e5e7eb}.mini-progress-fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#22c55e,#14b8a6)}.mini-progress-warn .mini-progress-fill{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.mini-progress-bad .mini-progress-fill{background:linear-gradient(90deg,#ef4444,#fb7185)}.mini-progress-neutral .mini-progress-head span:last-child{color:var(--blue)}.agent-wide-progress .mini-progress-head span:first-child{flex:0 0 auto}.agent-footer-line{margin-top:auto}.renewal-ok,.traffic-ok{color:var(--green)}.renewal-warn,.traffic-warn{color:var(--amber)}.renewal-bad,.traffic-bad{color:var(--red)}.main-stage{display:flex;flex-direction:column;gap:18px;min-width:0}.overview-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.overview-stat-card{position:relative;display:grid;grid-template-rows:auto 42px auto;min-height:120px;align-content:start;gap:16px;overflow:hidden;padding:22px 24px;border:1px solid var(--border);border-radius:18px;background:#fff;box-shadow:var(--shadow)}.overview-stat-card:after{display:none}.overview-stat-title{position:relative;z-index:1;color:var(--text);font-size:18px;font-weight:800;letter-spacing:.02em}.overview-stat-value{position:relative;z-index:1;display:inline-flex;height:42px;align-items:center;gap:12px;color:var(--text);font-size:24px;line-height:1}.overview-cost-title{display:flex;align-items:center;justify-content:space-between;gap:10px}.overview-currency-select{min-width:92px}.overview-currency-select .ant-select-selection-item{padding-inline-end:18px}.overview-cost-value{position:relative;z-index:1;color:var(--green);font-size:28px;font-weight:900;line-height:1}.overview-stat-value strong{font-size:28px;font-weight:900}.overview-stat-dot{width:10px;height:10px;border-radius:999px;background:var(--blue);box-shadow:0 0 0 5px #dbeafe}.overview-stat-green .overview-stat-dot{background:var(--green);box-shadow:0 0 0 5px #dcfce7}.overview-stat-red .overview-stat-dot{background:var(--red);box-shadow:0 0 0 5px #fee2e2}.overview-stat-foot{position:relative;z-index:1;color:var(--muted-strong);font-size:12px;line-height:1.5}.overview-network-card{gap:8px}.overview-network-total,.overview-network-speed{position:relative;z-index:1;display:flex;flex-wrap:wrap;gap:8px 12px;color:var(--text);font-weight:700}.overview-network-total{font-size:16px}.overview-network-speed{font-size:13px}.network-up{color:#1d4ed8}.network-down{color:#7c3aed}.overview-summary-strip{display:flex;flex-wrap:wrap;gap:8px 10px;margin-top:14px;color:var(--muted-strong);font-size:12px}.overview-summary-strip span{padding:5px 9px;border:1px solid var(--border);border-radius:999px;background:#fff}.compact-alert{margin-bottom:12px}.empty-stage{display:flex;align-items:center;justify-content:center;min-height:220px}.route-link,.route-rule-link{padding:0!important;height:auto!important;color:var(--blue)!important;font-weight:600}.route-anchor{display:inline-flex;min-width:46px;align-items:center;justify-content:center;padding:5px 9px;border:1px solid color-mix(in srgb,var(--green) 25%,transparent);border-radius:999px;background:var(--green-soft);color:var(--green);font-weight:700}.route-anchor.active{border-color:color-mix(in srgb,var(--amber) 42%,transparent);background:var(--amber-soft);color:var(--amber)}.route-row-selected td{background:var(--amber-soft)!important}.node-row-selected td{background:var(--green-soft)!important}.outbound-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:12px}.outbound-card{display:flex;flex-direction:column;gap:12px;padding:14px;border:1px solid var(--border);border-radius:8px;background:color-mix(in srgb,var(--surface) 62%,transparent);scroll-margin-top:90px;transition:background .15s ease,border-color .15s ease}.outbound-card:hover{border-color:var(--border-strong);background:var(--surface-soft)}.outbound-card.linked{cursor:pointer}.outbound-card.linked:hover,.outbound-card.linked:focus-visible{border-color:color-mix(in srgb,var(--blue) 55%,var(--border));background:color-mix(in srgb,var(--blue-soft) 72%,transparent);outline:none}.outbound-card.selected{border-color:color-mix(in srgb,var(--amber) 55%,var(--border));background:var(--amber-soft)}.outbound-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.outbound-tag{color:var(--text);font-size:15px;font-weight:700}.outbound-target{color:var(--muted-strong);font-size:13px;line-height:1.6;word-break:break-word}.outbound-metrics{display:flex;flex-wrap:wrap;gap:8px;color:var(--muted);font-size:12px}.config-section-card{border:1px solid var(--border);border-radius:8px;background:var(--surface-soft)}.ant-input,.ant-input-affix-wrapper,.ant-input-number,.ant-input-number-input,.ant-select-selector,.ant-picker,.ant-input-search .ant-input{background:color-mix(in srgb,var(--surface-strong) 58%,transparent)!important;border-color:color-mix(in srgb,var(--border) 86%,transparent)!important}.ant-input::placeholder,.ant-input-number-input::placeholder{color:color-mix(in srgb,var(--muted) 72%,transparent)!important}.ant-modal .ant-modal-content,.ant-modal .ant-modal-header,.ant-select-dropdown,.ant-dropdown-menu,.ant-popover .ant-popover-inner,.ant-picker-dropdown .ant-picker-panel-container{border:1px solid var(--border);background:var(--surface-strong)!important;box-shadow:var(--shadow)}.ant-modal .ant-modal-body,.ant-modal .ant-modal-footer,.ant-modal .ant-modal-title,.ant-select-item,.ant-dropdown-menu-item,.ant-popover .ant-popover-inner-content{background:transparent!important}.ant-modal-root:not(:has(.ant-modal-wrap)) .ant-modal-mask,.ant-modal-root:not(:has(.ant-modal)) .ant-modal-mask{display:none!important;pointer-events:none!important}.config-section-card .ant-card-body{padding:16px;background:transparent}.switch-row{display:flex;justify-content:space-between;align-items:center;min-height:32px;color:var(--muted-strong);font-size:14px}.section-title-row{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.section-title-row .ant-typography{margin-bottom:0}.entry-mapping-list{width:100%;margin-top:14px}.entry-mapping-row{display:grid;grid-template-columns:minmax(180px,1.4fr) 120px 120px 120px minmax(140px,1fr) auto;gap:8px;align-items:center;width:100%;padding:10px;border:1px solid color-mix(in srgb,var(--border) 70%,transparent);border-radius:12px;background:color-mix(in srgb,var(--surface-soft) 74%,transparent)}.entry-mapping-row .ant-input-number,.entry-mapping-row .ant-select{width:100%}.telegram-bot-list-item{gap:12px}.telegram-bot-main{min-width:0}.tag-filter-chip{margin-inline-end:0;padding:4px 10px;border-color:#e5e7eb;border-radius:999px;background:#fff;color:#374151;font-weight:700;-webkit-user-select:none;user-select:none}.tag-filter-chip.ant-tag-green{border-color:#86efac;background:#f0fdf4;color:#15803d}.cn-flow-card{--flow-client-col: 170px;--flow-arrow-col: 34px;--flow-hop-col: 328px;--flow-country-col: 250px;overflow:hidden;border:1px solid var(--border)!important;background:radial-gradient(circle at 12% 18%,rgba(255,255,255,.24),transparent 30%),radial-gradient(circle at 88% 18%,rgba(255,255,255,.18),transparent 28%),var(--surface)!important;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.cn-flow-card-cn{--flow-hop-col: 552px}.cn-flow-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:16px}.cn-flow-header .ant-typography{margin-bottom:0!important}.cn-flow-header-actions{display:flex;align-items:flex-end;flex-direction:column;gap:10px}.cn-flow-copy{max-width:820px;margin-top:8px;color:var(--muted)}.cn-flow-toolbar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.cn-flow-agent-filter{padding:7px 12px;border:1px solid var(--border);border-radius:999px;background:var(--surface-soft);color:var(--muted-strong);transition:border-color .16s ease,background .16s ease,color .16s ease}.cn-flow-agent-filter:hover,.cn-flow-agent-filter.active{border-color:#fb923c9e;background:#fb923c1f;color:var(--text)}.cn-flow-map{display:grid;grid-template-columns:150px minmax(0,1fr);gap:18px;align-items:stretch;max-height:min(62vh,560px);overflow-y:auto;padding-right:8px;scrollbar-color:rgba(14,165,233,.52) rgba(255,255,255,.18);scrollbar-width:thin}.cn-flow-map::-webkit-scrollbar{width:10px}.cn-flow-map::-webkit-scrollbar-track{border-radius:999px;background:#ffffff2e}.cn-flow-map::-webkit-scrollbar-thumb{border:2px solid rgba(255,255,255,.18);border-radius:999px;background:#0ea5e985}.cn-flow-source{position:sticky;top:12px;display:flex;min-height:240px;flex-direction:column;align-items:center;justify-content:center;gap:8px;border:1px solid rgba(248,113,113,.28);border-radius:24px;background:var(--surface-soft)}.cn-source-orb{display:grid;width:78px;height:78px;place-items:center;border:1px solid rgba(254,202,202,.42);border-radius:999px;background:linear-gradient(135deg,#ef4444,#f97316);box-shadow:0 10px 28px #f8717138;color:#fff7ed;font-size:26px;font-weight:900;letter-spacing:.08em}.client-orb,.tag-orb{background:linear-gradient(135deg,#0ea5e9,#14b8a6);box-shadow:0 10px 28px #0ea5e92e;font-size:18px}.tag-orb{background:linear-gradient(135deg,#f59e0b,#22c55e)}.cn-flow-source small{color:var(--muted);font-size:12px}.cn-flow-lanes{display:flex;flex-direction:column;gap:14px;overflow-x:auto;padding-bottom:4px}.cn-flow-lane{position:relative;display:grid;min-width:calc(var(--flow-client-col) + var(--flow-arrow-col) + var(--flow-hop-col) + var(--flow-arrow-col) + var(--flow-country-col) + 40px);grid-template-columns:var(--flow-client-col) var(--flow-arrow-col) var(--flow-hop-col) var(--flow-arrow-col) var(--flow-country-col);align-items:stretch;column-gap:10px;padding:8px 0;border:0;border-radius:0;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}.cn-flow-lane.loop{border:0}.cn-flow-agent-cluster{display:flex;min-width:980px;align-items:stretch;gap:10px}.cn-flow-agent-cluster>.agent-node{min-height:auto}.cluster-arrow{align-self:stretch}.cn-flow-agent-cluster-rows{display:flex;min-width:max-content;flex:1 0 auto;flex-direction:column;gap:14px}.cn-flow-agent-cluster-rows .cn-flow-lane{min-width:0;padding:0}.cn-flow-entry-cluster{display:flex;min-width:max-content;align-items:stretch;gap:10px}.cn-flow-entry-cluster>.entry-node{min-height:auto}.cn-flow-entry-cluster-rows{display:flex;min-width:max-content;flex-direction:column;gap:14px}.cn-flow-entry-cluster-rows .cn-flow-lane{min-width:0;padding:0}.cn-flow-node{display:flex;width:170px;min-height:104px;flex:0 0 auto;flex-direction:column;justify-content:center;gap:5px;padding:12px;border:1px solid var(--border);border-radius:16px;background:#ffffff4d;color:var(--text);text-align:left}button.cn-flow-node:hover{border-color:#2dd4bf9e;background:#ffffff7a}.client-node{border-color:#f8717159}.agent-node{border-color:#0ea5e961;background:#eff6ff57}.entry-node,.target-node{border-color:#38bdf857}.rule-node{width:250px;border-color:#facc1557;background:#fffbeb5c}.forward-node{width:250px;border-color:#2dd4bf70;background:linear-gradient(135deg,#fffbeb5c,#eff6ff6b)}.country-node{width:100%;border-color:#2dd4bf66;background:#ecfdf561}.country-block{border-color:#f8717185;background:#fef2f26b}.node-kicker{color:var(--muted);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}.cn-flow-node strong{overflow:hidden;color:var(--text);font-size:14px;text-overflow:ellipsis;white-space:nowrap}.cn-flow-node small{color:var(--muted);font-size:12px;line-height:1.45}.cn-flow-hop-group{position:relative;display:flex;width:100%;min-width:0;flex:0 0 auto;align-items:center;padding:0;border:0;border-radius:0;background:transparent}.cn-flow-hop-label{position:absolute;top:-28px;left:0;right:0;display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--muted);font-size:11px}.cn-flow-hop-label b{color:var(--text);font-size:12px}.cn-flow-hop-label span{color:var(--muted);white-space:nowrap}.cn-flow-hop-body{display:flex;width:100%;align-items:center;gap:10px}.cn-flow-hop-column{display:flex;width:var(--flow-hop-col);min-width:0;align-items:center;gap:10px}.compact-hop{justify-content:center}.compact-target-node{border-style:dashed}.cn-flow-arrow{display:flex;width:var(--flow-arrow-col);min-width:var(--flow-arrow-col);align-items:center;justify-content:center;color:#5eead4;font-size:22px;font-weight:900}.rule-arrow{width:68px;min-width:68px;flex-direction:column;gap:4px;color:#facc15;font-size:18px}.rule-arrow span{padding:3px 8px;border-radius:999px;background:#facc1521;font-size:12px}.rule-arrow em{color:var(--muted);font-size:10px;font-style:normal}.final-arrow{color:#fb923c}.cn-flow-warning{position:absolute;right:12px;bottom:8px;margin-inline-end:0}.overview-agent-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.overview-agent-card{display:flex;flex-direction:column;gap:8px;padding:14px;text-align:left;border:1px solid var(--border);border-radius:10px;background:color-mix(in srgb,var(--surface) 58%,transparent);transition:background .15s ease,border-color .15s ease,transform .15s ease}.overview-agent-card:hover{border-color:var(--border-strong);background:var(--surface-soft);transform:translateY(-1px)}.overview-agent-card.selected{border-color:color-mix(in srgb,var(--green) 50%,var(--border));background:var(--green-soft)}.overview-agent-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.overview-agent-tags{display:flex;flex-wrap:wrap;gap:6px}.overview-agent-stats{display:flex;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:12px}.topology-link-list{display:flex;flex-direction:column;gap:12px}.topology-link-card{padding:14px;border:1px solid var(--border);border-radius:10px;background:color-mix(in srgb,var(--surface) 54%,transparent)}.topology-link-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px}.topology-arrow{color:var(--blue);font-weight:700}.ant-table-wrapper .ant-table{border-radius:8px}.ant-table-thead>tr>th{color:var(--muted-strong)!important;font-size:12px;font-weight:700!important}.ant-tabs-nav{margin-bottom:14px!important}button,a,[role=button],.ant-btn,.ant-tabs-tab,.ant-select-selector,.ant-select-item,.ant-dropdown-menu-item,.ant-switch,.ant-checkbox-wrapper,.ant-radio-wrapper,.agent-button,.route-link,.route-rule-link,.outbound-card{cursor:pointer!important}input,textarea,.ant-input,.ant-input-affix-wrapper input,.ant-input-number-input,.ant-select-selection-search-input{cursor:text!important}@media (max-width: 1120px){.overview-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cn-flow-map{grid-template-columns:1fr}.cn-flow-source{position:static;min-height:160px}}@media (max-width: 980px){.agent-button-list{grid-template-columns:1fr;align-items:stretch}}@media (max-width: 768px){.app-shell{width:min(100% - 20px,1120px);padding-top:12px}.hero-panel{flex-direction:column;padding:16px}.hero-actions,.hero-actions .ant-btn{width:100%}.overview-stat-grid{grid-template-columns:1fr}.overview-stat-card{min-height:112px;padding:18px 20px}.agent-list-card .ant-list-items{grid-template-columns:1fr}.agent-rail-toolbar{width:100%}.topology-entry{align-items:flex-start;flex-direction:column}.topology-entry .ant-space,.topology-entry .ant-btn{width:100%}.outbound-grid,.entry-mapping-row{grid-template-columns:1fr}.section-title-row{align-items:flex-start;flex-direction:column}.cn-flow-header{flex-direction:column}.cn-flow-header-actions{align-items:flex-start}.cn-flow-lane{min-width:860px}.cn-flow-node{width:145px}.cn-source-orb{width:76px;height:76px;font-size:24px}}.agent-tag-warn{color:#9a3412;background:#fb923c33;border-color:#fb923c59}.selected-agent-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px}.selected-agent-toolbar .ant-typography{margin:0}@media (max-width: 720px){.selected-agent-toolbar{align-items:flex-start;flex-direction:column}}.client-expiry-cell{min-width:320px}
