:root{background:radial-gradient(circle at top left,#f7fbff,#eef4ff 40%,#f8fafc);color:#12263a}body{margin:0;min-height:100vh;font-family:Avenir Next,PingFang SC,Segoe UI,Helvetica Neue,Arial,sans-serif;background:radial-gradient(circle at top left,#f7fbff,#eef4ff 40%,#f8fafc)}#root{min-height:100vh}.login-root{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(1200px 500px at 15% -10%,rgba(38,132,255,.16),transparent 55%),radial-gradient(900px 400px at 100% 0%,rgba(22,184,134,.12),transparent 60%),linear-gradient(135deg,#f4f8ff,#f9fcff 60%,#f4f9ff)}.login-card{width:min(460px,100%);box-shadow:0 24px 56px #203f691f}.maintenance-root{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(1200px 500px at 15% -10%,rgba(210,80,80,.13),transparent 55%),radial-gradient(900px 400px at 100% 0%,rgba(245,158,11,.12),transparent 60%),linear-gradient(135deg,#fef4f4,#fff8f2 55%,#fffdf8)}.maintenance-card{width:min(560px,100%);box-shadow:0 24px 56px #8535351f}.node-row-highlight>td{background:linear-gradient(90deg,#fadb1438,#fadb1414)!important;animation:node-highlight-fade 2s ease-out}.rule-row-highlight>td{background:linear-gradient(90deg,#16a34a2e,#16a34a0f)!important;animation:rule-highlight-fade 2s ease-out}.upgrade-node-row-disabled>td{color:#94a3b8!important;background:#94a3b80f}.multi-hop-editor{display:grid;gap:10px;padding:12px;border:1px solid #dbe4f0;border-radius:12px;background:linear-gradient(180deg,#f8fbff,#f5f9ff);overflow-x:hidden}.multi-hop-editor-list{display:grid;gap:8px}.multi-hop-editor-row{display:flex;align-items:center;gap:10px;width:100%;min-width:0;padding:10px 12px;border:1px solid #d9e5f3;border-radius:10px;background:#fff;box-sizing:border-box}.multi-hop-editor-row--dragging{box-shadow:0 10px 24px #23487829;border-color:#91caff}.multi-hop-step-index{width:22px;height:22px;line-height:22px;text-align:center;border-radius:999px;font-size:12px;color:#24589a;background:#e3efff}.multi-hop-drag-handle{color:#6484ad}.multi-hop-flow-indicator{margin:4px 0 2px;text-align:center;color:#6f8db3;font-size:12px}.multi-hop-role-cell{flex:0 0 112px;min-width:112px}.multi-hop-group-select{flex:1 1 260px;min-width:180px}.multi-hop-port-input{flex:0 0 140px;min-width:120px}.multi-hop-port-input .ant-input-number{width:100%}.multi-hop-online-text{flex:0 0 80px;min-width:74px;text-align:right}.multi-hop-actions{flex:0 0 auto}.rule-chain-topology{display:flex;align-items:stretch;overflow-x:auto;padding:4px 0 10px}.rule-chain-hop-wrap{display:flex;align-items:center}.rule-chain-hop-card{width:250px;min-width:250px;border:1px solid #d6e3f2;border-radius:12px;padding:12px;background:#fefefe;box-shadow:inset 0 1px #ffffffd9}.rule-chain-hop-card--bypassed{opacity:.52;filter:grayscale(.12)}.rule-chain-instance-list{margin-top:10px;display:grid;gap:6px}.rule-chain-instance-item{padding:7px 9px;border:1px solid #e6edf6;border-radius:8px;background:#fff}.rule-chain-link{width:52px;min-width:52px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.rule-chain-link-line{width:36px;border-top:2px solid transparent}.rule-chain-link-arrow{font-size:14px}.rule-chain-link--healthy .rule-chain-link-line{border-top-color:#16a34a}.rule-chain-link--healthy .rule-chain-link-arrow{color:#16a34a}.rule-chain-link--degraded .rule-chain-link-line{border-top-color:#d97706;border-top-style:dashed}.rule-chain-link--degraded .rule-chain-link-arrow{color:#d97706}.rule-chain-link--down .rule-chain-link-line{border-top-color:#dc2626;border-top-style:dashed}.rule-chain-link--down .rule-chain-link-arrow{color:#dc2626}.rule-target-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid #d9e5f3;border-radius:8px;background:#fff}.rule-target-list{display:grid;gap:8px}.rule-target-row .ant-input,.rule-target-row .ant-input-number{flex:1 1 auto}.rule-target-handle{color:#6b7f99;font-size:16px;line-height:1;cursor:grab;-webkit-user-select:none;user-select:none}.rule-target-row--dragging .rule-target-row{box-shadow:0 10px 24px #23487829;border-color:#91caff}.plan-card-grid{display:grid;gap:14px;grid-template-columns:repeat(3,minmax(0,1fr))}.plan-card{min-height:250px}.plan-card-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 10px;font-size:12px;color:#466489}.ant-table-wrapper{width:100%}.ant-table-wrapper .ant-table-container{overflow-x:auto}.ant-table-wrapper .ant-table-content>table,.ant-table-wrapper .ant-table-header>table{width:max-content;min-width:100%}.ant-table-wrapper .ant-table-thead>tr>th,.ant-table-wrapper .ant-table-tbody>tr>td{padding:10px 8px!important;line-height:1.35;white-space:nowrap;word-break:keep-all}.ant-card .ant-card-body{padding:16px}@media(max-width:992px){.plan-card-grid{grid-template-columns:repeat(1,minmax(0,1fr))}.multi-hop-editor-row{flex-wrap:wrap;row-gap:8px}.rule-target-row{flex-wrap:wrap}.multi-hop-role-cell{flex:0 0 100px;min-width:100px}.multi-hop-group-select{flex:1 1 220px;min-width:160px}.multi-hop-port-input{flex:1 1 120px;min-width:110px}.multi-hop-online-text{flex:0 0 auto;min-width:0}.ant-table-wrapper .ant-table-thead>tr>th,.ant-table-wrapper .ant-table-tbody>tr>td{padding:8px 6px!important}.ant-layout .ant-layout-content{padding:12px!important}.ant-modal{max-width:calc(100vw - 24px)!important;margin:12px auto}}@keyframes node-highlight-fade{0%{background:#fadb1459}to{background:#fadb1414}}@keyframes rule-highlight-fade{0%{background:#16a34a47}to{background:#16a34a0f}}
