:root{color-scheme:light}:root{--ipx-tone-green: #10b981;--ipx-tone-blue: #1677ff;--ipx-tone-orange: #fa8c16;--ipx-tone-red: #ff4d4f;--ipx-tone-purple: #722ed1;--ipx-tone-gray: #64748b}body{margin:0;background:#f0f2f5}body[data-theme=dark]{background:#141414;color-scheme:dark}.ipx-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000f}body[data-theme=dark] .ipx-card{background:#1f1f1f;box-shadow:0 2px 8px #00000059}.ipx-kpi{transition:box-shadow .2s ease,transform .2s ease}.ipx-kpi:hover{box-shadow:0 8px 24px #0000001a;transform:translateY(-3px)}.ipx-spin{animation:ipxspin 14s linear infinite}@keyframes ipxspin{to{transform:rotate(360deg)}}.ipx-node-handle{opacity:0;transition:opacity .2s ease;cursor:grab}.ipx-node-card:hover .ipx-node-handle{opacity:.5}.ipx-metric-strip{margin-bottom:16px;width:100%}.ipx-metric-strip .ant-pro-card-col{min-width:0}.ipx-metric-item{height:92px;border-radius:8px;background:#fff;border:1px solid #eef2f7;box-shadow:0 6px 18px #0f172a0a}.ipx-metric-item .ant-pro-card-body{height:100%;padding:14px}.ipx-metric-item .ant-pro-statistic,.ipx-metric-item .ant-pro-statistic-wrapper{height:100%}.ipx-metric-item .ant-pro-statistic-title{color:#94a3b8;font-size:12px}.ipx-metric-item .ant-pro-statistic-content{min-width:0;font-size:22px;font-weight:800;line-height:1.15;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ipx-metric-item .ant-pro-statistic-icon{width:36px;height:36px;display:inline-grid;place-items:center;border-radius:8px;color:var(--metric-color, #1677ff);background:color-mix(in srgb,var(--metric-color, #1677ff) 10%,#fff)}.ipx-metric-item .ant-pro-statistic-suffix{color:#94a3b8;font-size:12px}.ipx-metric-item[data-tone=green]{--metric-color: #10b981}.ipx-metric-item[data-tone=blue]{--metric-color: #1677ff}.ipx-metric-item[data-tone=orange]{--metric-color: #fa8c16}.ipx-metric-item[data-tone=red]{--metric-color: #ff4d4f}.ipx-metric-item[data-tone=purple]{--metric-color: #722ed1}.ipx-metric-item[data-tone=gray]{--metric-color: #64748b}.ipx-settings-card{height:100%;border-radius:8px;border-color:#eef2f7}.ipx-settings-card .ant-pro-card-header{min-height:48px;border-bottom-color:#eef2f7}.ipx-relation-link{font-weight:600}.ipx-compact-section{border-radius:8px;background:#fff;border:1px solid #eef2f7}.ipx-compact-section .ant-pro-card-body{padding:14px}.ipx-filter-card,.ipx-bulk-card,.ipx-dashboard-panel,.ipx-live-card,.ipx-ops-health-card,.ipx-line-summary-tile,.ipx-line-card,.ipx-region-tree-card,.ipx-region-lines-card{border-radius:8px;border-color:#eef2f7;box-shadow:0 6px 18px #0f172a0a}.ipx-filter-card,.ipx-bulk-card,.ipx-dashboard-panel,.ipx-live-card,.ipx-dashboard-kpi,.ipx-node-card,.ipx-metric-item{transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.ipx-filter-card:hover,.ipx-bulk-card:hover,.ipx-dashboard-panel:hover,.ipx-live-card:hover,.ipx-dashboard-kpi:hover,.ipx-node-card:hover,.ipx-metric-item:hover{transform:translateY(-2px);box-shadow:0 12px 28px #0f172a14}.ipx-dashboard-kpi{height:100%;border-radius:8px;border:1px solid #eef2f7;box-shadow:0 6px 18px #0f172a0a}.ipx-dashboard-kpi .ant-pro-card-body{padding:18px 20px}.ipx-dashboard-kpi .ant-pro-statistic-icon{width:46px;height:46px;display:inline-grid;place-items:center;border-radius:8px;color:var(--ipx-kpi-color, #1677ff);background:color-mix(in srgb,var(--ipx-kpi-color, #1677ff) 10%,#fff)}.ipx-dashboard-kpi .ant-pro-statistic-title{color:#94a3b8;font-size:12px;font-weight:700}.ipx-dashboard-kpi .ant-pro-statistic-content{color:#172033;font-size:28px;font-weight:800}.ipx-line-summary-tile .ant-pro-card-body{padding:14px 16px}.ipx-line-summary-tile .ant-pro-statistic-title{color:#94a3b8;font-size:12px}.ipx-line-summary-tile .ant-pro-statistic-content{font-size:24px;font-weight:800}.ipx-pro-card-list .ant-pro-list-row-card{padding:0;border:none;background:transparent;box-shadow:none}.ipx-page-skeleton{padding:24px;animation:ipxFadeUp .28s ease both}.ipx-page-skeleton-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.ipx-page-skeleton-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:16px}.ipx-page-skeleton-card,.ipx-page-skeleton-panel{border-radius:8px;border:1px solid #eef2f7;background:#fff;box-shadow:0 6px 18px #0f172a0a}.ipx-page-skeleton-card{padding:16px;min-height:132px}.ipx-page-skeleton-panel{padding:20px;min-height:280px}@keyframes ipxFadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 960px){.ipx-page-skeleton-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 560px){.ipx-page-skeleton{padding:16px}.ipx-page-skeleton-head{align-items:stretch;flex-direction:column}.ipx-page-skeleton-grid{grid-template-columns:1fr}}.ipx-node-summary{display:grid;grid-template-columns:minmax(260px,.9fr) 2fr;gap:16px;margin-bottom:16px}.ipx-node-summary-copy{min-height:148px;border-radius:8px;padding:18px;color:#172033;background:linear-gradient(135deg,#1677ff1f,#10b98117),#fff;border:1px solid rgba(22,119,255,.16);box-shadow:0 10px 26px #0f172a0f}.ipx-node-summary-copy h2{margin:12px 0 6px;font-size:24px;line-height:1.15;letter-spacing:0}.ipx-node-summary-copy p{margin:0;color:#64748b;line-height:1.7}.ipx-node-summary-grid{align-content:stretch}.ipx-node-kpi{height:100%;min-height:96px;display:flex;gap:12px;align-items:center;padding:14px;border-radius:8px;background:#fff;border:1px solid #eef2f7;box-shadow:0 8px 24px #0f172a0d}.ipx-node-kpi-icon{flex:none;width:38px;height:38px;display:grid;place-items:center;color:var(--kpi-color);background:color-mix(in srgb,var(--kpi-color) 12%,#fff);border:1px solid color-mix(in srgb,var(--kpi-color) 22%,#fff);border-radius:8px;font-size:18px}.ipx-node-kpi span,.ipx-node-kpi em{display:block;font-style:normal;color:#94a3b8;font-size:12px}.ipx-node-kpi strong{display:block;margin:1px 0;color:var(--kpi-color);font-size:22px;line-height:1.1}.ipx-node-card{position:relative;overflow:hidden;height:100%;border-radius:8px;border:1px solid color-mix(in srgb,var(--node-color) 24%,#e2e8f0);background:linear-gradient(135deg,color-mix(in srgb,var(--node-color) 10%,#fff),#fff 56%),#fff}.ipx-node-card-glow{height:4px;background:linear-gradient(90deg,var(--node-color),color-mix(in srgb,var(--node-color) 35%,#fff))}.ipx-node-card-inner{padding:14px}.ipx-node-card-head{display:flex;align-items:center;gap:8px;min-width:0}.ipx-node-flag{flex:none;width:30px;height:30px;display:grid;place-items:center;border-radius:8px;background:#f8fafc;border:1px solid #eef2f7;font-size:18px}.ipx-node-name{flex:1;min-width:0;color:#172033;font-size:15px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ipx-node-address-row{min-height:24px;display:flex;align-items:center;gap:6px;margin:8px 0 12px;color:#94a3b8;font-size:12px}.ipx-node-address-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:SFMono-Regular,Consolas,monospace}.ipx-node-address-row em{flex:none;font-style:normal;color:#64748b;border-left:1px solid #e2e8f0;padding-left:8px}.ipx-node-note-row{display:flex;align-items:center;gap:6px;min-height:26px;margin:0 0 12px;padding:6px 8px;color:#64748b;background:#f8fafc;border:1px solid #eef2f7;border-radius:8px;font-size:12px}.ipx-node-note-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ipx-node-meter-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}.ipx-node-meter>div:first-child{display:flex;justify-content:space-between;color:#64748b;font-size:12px}.ipx-node-card-foot{display:flex;justify-content:space-between;align-items:center;gap:8px;padding-top:10px;border-top:1px solid #eef2f7;color:#475569;font-size:12px}.ipx-app-card{height:100%;border-radius:8px;border:1px solid #e2e8f0}.ipx-app-icon{width:36px;height:36px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;color:#1677ff;background:#e6f4ff;font-size:18px}.ipx-credential-box{display:grid;gap:10px;padding:12px;border-radius:8px;border:1px solid #e2e8f0;background:#f8fafc}.ipx-credential-label{margin-bottom:4px;color:#64748b;font-size:12px}.ipx-credential-value{max-width:100%;display:inline-flex}.ipx-enroll-modal .ant-modal-content{border-radius:12px;overflow:hidden}.ipx-enroll-modal .ant-modal-header{margin-bottom:0}.ipx-enroll-title-icon{width:42px;height:42px;display:inline-grid;place-items:center;border-radius:10px;color:#1677ff;background:#1677ff1a;border:1px solid rgba(22,119,255,.18);font-size:20px}.ipx-enroll-title{display:block;color:#172033;font-size:17px;font-weight:850}.ipx-enroll-subtitle{display:block;margin-top:2px;color:#94a3b8;font-size:12px;font-weight:400}.ipx-enroll-steps{margin:16px 0 18px;padding:12px 14px;border-radius:8px;background:#f8fafc;border:1px solid #eef2f7}.ipx-enroll-hero,.ipx-enroll-form,.ipx-enroll-status,.ipx-enroll-material-head,.ipx-code-panel{border-radius:8px;border:1px solid #eef2f7;background:#fff;box-shadow:0 8px 24px #0f172a0d}.ipx-enroll-hero{height:100%;padding:18px;background:linear-gradient(135deg,#1677ff1c,#fa8c1614),#fff}.ipx-enroll-hero h3,.ipx-enroll-status h3{margin:14px 0 8px;color:#172033;font-size:22px;line-height:1.18;letter-spacing:0}.ipx-enroll-hero p,.ipx-enroll-status p{margin:0;color:#64748b;line-height:1.72}.ipx-enroll-flow{display:grid;gap:10px;margin-top:18px}.ipx-enroll-flow div{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;background:#ffffffc2;border:1px solid rgba(226,232,240,.9);color:#334155;font-weight:650}.ipx-enroll-form{padding:18px}.ipx-enroll-status{height:100%;padding:18px;text-align:center;background:linear-gradient(180deg,#1677ff14,#fffc),#fff}.ipx-enroll-status.is-online{background:linear-gradient(180deg,#10b9811c,#ffffffd1),#fff}.ipx-enroll-status-orb{width:82px;height:82px;display:grid;place-items:center;margin:6px auto 0;border-radius:20px;color:#1677ff;background:#1677ff1a;border:1px solid rgba(22,119,255,.2);font-size:34px}.ipx-enroll-status.is-online .ipx-enroll-status-orb{color:#10b981;background:#10b9811f;border-color:#10b98138}.ipx-enroll-status-meta{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding:9px 10px;border-radius:8px;background:#f8fafcd1;border:1px solid #eef2f7;color:#64748b}.ipx-enroll-material-head{padding:12px;margin-bottom:12px}.ipx-enroll-spec{display:grid;grid-template-columns:28px 56px minmax(0,1fr);align-items:center;gap:8px;padding:10px;border-radius:8px;background:#f8fafc;border:1px solid #eef2f7}.ipx-enroll-spec-icon{color:#1677ff}.ipx-enroll-spec-label{color:#94a3b8;font-size:12px}.ipx-enroll-spec-value{min-width:0;font-family:SFMono-Regular,Consolas,monospace;color:#172033}.ipx-enroll-image-switch{display:flex;justify-content:flex-end;align-items:center;gap:10px;margin-top:12px}.ipx-code-panel{overflow:hidden;margin-bottom:12px}.ipx-code-panel-head{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:12px;background:#fbfdff;border-bottom:1px solid #eef2f7}.ipx-code-panel-desc{margin-top:2px;color:#94a3b8;font-size:12px}.ipx-code-block{margin:0;max-height:320px;overflow:auto;padding:14px;color:#dbeafe;background:#0f172a;font-family:SFMono-Regular,Consolas,monospace;font-size:12px;line-height:1.58;white-space:pre}body[data-theme=dark] .ipx-node-summary-copy,body[data-theme=dark] .ipx-node-kpi,body[data-theme=dark] .ipx-node-card,body[data-theme=dark] .ipx-metric-item,body[data-theme=dark] .ipx-settings-card,body[data-theme=dark] .ipx-compact-section,body[data-theme=dark] .ipx-app-card,body[data-theme=dark] .ipx-enroll-hero,body[data-theme=dark] .ipx-enroll-form,body[data-theme=dark] .ipx-enroll-status,body[data-theme=dark] .ipx-enroll-material-head,body[data-theme=dark] .ipx-code-panel{background-color:#1f1f1f;border-color:#303030}body[data-theme=dark] .ipx-node-summary-copy h2,body[data-theme=dark] .ipx-node-name,body[data-theme=dark] .ipx-enroll-title,body[data-theme=dark] .ipx-enroll-hero h3,body[data-theme=dark] .ipx-enroll-status h3,body[data-theme=dark] .ipx-metric-item strong,body[data-theme=dark] .ipx-enroll-spec-value{color:#ffffffe0}body[data-theme=dark] .ipx-credential-box{background:#111827;border-color:#303030}body[data-theme=dark] .ipx-app-icon{color:#91caff;background:#111a2c}@media (max-width: 980px){.ipx-node-summary{grid-template-columns:1fr}}@media (max-width: 720px){.ipx-node-card-foot{align-items:flex-start;flex-direction:column}}
