*{box-sizing:border-box;margin:0;padding:0}:root{color:#1f2937;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans SC,PingFang SC,Microsoft YaHei,sans-serif;font-weight:400;line-height:1.5}body{min-width:320px;min-height:100vh;margin:0}#root{width:100%;min-height:100vh}.feature-compact-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;display:grid}.feature-compact-item{cursor:pointer;border:1px solid;border-radius:4px;align-items:center;padding:8px 12px;transition:all .3s;display:flex}.feature-compact-item:hover{transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.feature-compact-item.status-g{background:#f6ffed;border-color:#b7eb8f}.feature-compact-item.status-g:hover{border-color:#52c41a}.feature-compact-item.status-y{background:#fffbe6;border-color:#ffe58f}.feature-compact-item.status-y:hover{border-color:#faad14}.feature-compact-item.status-r{background:#fff1f0;border-color:#ffccc7}.feature-compact-item.status-r:hover{border-color:#ff4d4f}.feature-compact-icon{margin-right:10px;font-size:18px}.feature-compact-content{flex:1;min-width:0}.feature-compact-name{color:#595959;white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:12px;font-weight:500;overflow:hidden}.feature-compact-value{align-items:baseline;gap:4px;display:flex}.feature-compact-value .value{color:#262626;font-size:16px;font-weight:600}.feature-compact-value .unit{color:#8c8c8c;font-size:11px}@media (max-width:1400px){.feature-compact-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media (max-width:1200px){.feature-compact-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}@media (max-width:768px){.feature-compact-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.feature-compact-item{padding:6px 8px}.feature-compact-icon{margin-right:8px;font-size:16px}.feature-compact-name{font-size:11px}.feature-compact-value .value{font-size:14px}.feature-compact-value .unit{font-size:10px}}.process-diagram-card{border-radius:12px;box-shadow:0 2px 8px #0000000d}.process-diagram-container{background:#fff;border:1px solid #e8e8e8;border-radius:8px;width:100%;height:500px;overflow:hidden}.process-diagram-svg{width:100%;height:100%}.device-point{transition:opacity .2s;cursor:pointer!important}.device-point:hover{opacity:.9}.device-point:hover .device-label-box{stroke-width:2px;stroke:#1890ff;fill:#1890fff2}.device-point circle{transition:fill .2s}.device-point:hover circle{fill:#1890ff}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.device-point.alert circle{animation:1.5s ease-in-out infinite pulse}.device-detail-modal .feature-grid{grid-template-columns:repeat(6,1fr);gap:12px;display:grid}.device-detail-modal .feature-ball{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#ffffff1a,#ffffff0d);border:2px solid;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;height:100px;transition:all .3s;display:flex;position:relative}.device-detail-modal .feature-ball:hover{transform:scale(1.05)!important}.device-detail-modal .feature-ball.state-g{background-color:#52c41a14;border-color:#52c41a}.device-detail-modal .feature-ball.state-y{background-color:#faad141a;border-color:#faad14}.device-detail-modal .feature-ball.state-r{background-color:#ff4d4f1a;border-color:#ff4d4f;animation:2s infinite pulse}.device-detail-modal .feature-name{color:#595959;font-size:11px;font-weight:600;position:absolute;top:6px}.device-detail-modal .feature-value{color:#262626;margin-top:8px;font-size:20px;font-weight:700}.device-detail-modal .feature-unit{color:#8c8c8c;margin-top:2px;font-size:10px}.device-detail-modal .feature-threshold{color:#bfbfbf;font-size:9px;position:absolute;bottom:6px}@media (max-width:1024px){.device-detail-modal .feature-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width:768px){.device-detail-modal .feature-grid{grid-template-columns:repeat(3,1fr)}}.device-grid{grid-template-columns:repeat(10,1fr);gap:12px;display:grid}.device-ball{background:radial-gradient(circle at 30% 30%,#ffffff4d,#0000);border:3px solid;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;height:90px;transition:transform .2s,box-shadow .2s;display:flex;position:relative}.device-ball:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.device-ball.state-g{background-color:#10b9810d;border-color:#10b981}.device-ball.state-y{background-color:#f59e0b1a;border-color:#f59e0b}.device-ball.state-r{background-color:#ef44441a;border-color:#ef4444}.device-label{color:#fff;font-size:10px;position:absolute;top:4px}.device-value{color:#fff;font-size:16px;font-weight:700}.device-threshold{color:#e5e7eb;font-size:9px;position:absolute;bottom:4px}@media (max-width:1024px){.device-grid{grid-template-columns:repeat(5,1fr)}}@media (max-width:768px){.device-grid{grid-template-columns:repeat(2,1fr)}}.page-container{background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);min-height:calc(100vh - 64px);padding:24px}.kg-canvas{transition:all .3s;position:relative}.kg-canvas:hover{box-shadow:0 8px 24px #00000014,0 4px 8px #0000001f!important}.kg-canvas:before{content:"";pointer-events:none;z-index:0;background:linear-gradient(135deg,#3b82f608 0%,#10b98105 50%,#f9731608 100%);border-radius:10px;position:absolute;inset:0}.ant-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000014!important}.ant-card-head-title{color:#1e40af!important;font-weight:600!important}.ant-btn-primary:hover{transform:translateY(-1px)!important;box-shadow:0 4px 12px #3b82f666!important}.ant-btn:not(.ant-btn-primary){color:#374151!important;border-color:#d1d5db!important}.ant-btn:not(.ant-btn-primary):hover{color:#3b82f6!important;border-color:#3b82f6!important;transform:translateY(-1px)!important}.ant-input,.ant-select-selector{border-color:#d1d5db!important;border-radius:8px!important;transition:all .3s!important}.ant-input:focus,.ant-select-focused .ant-select-selector{border-color:#3b82f6!important;box-shadow:0 0 0 2px #3b82f61a!important}.ant-upload-wrapper{display:inline-block}.triple-item{border-bottom:1px solid #f0f0f0;border-radius:8px;margin:4px 0;padding:12px;transition:all .2s}.triple-item:hover{background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);border-color:#3b82f6;transform:translate(4px)}.ant-space{flex-wrap:wrap!important}.ant-space-item{margin-bottom:8px!important}@media (max-width:768px){.page-container{padding:16px}.kg-canvas{height:400px!important}}@media (max-width:576px){.kg-canvas{height:300px!important}}.ant-spin-container{position:relative}.ant-spin-blur{opacity:.5;transition:opacity .3s}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#94a3b8 0%,#64748b 100%);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#64748b 0%,#475569 100%)}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;line-height:1.5}#root{min-height:100vh}.page-container{max-width:1400px;margin:0 auto}.page-header{border-bottom:1px solid #f0f0f0;margin-bottom:24px;padding:20px 0}.page-header h3{color:#1a1a1a;margin-bottom:4px;font-weight:600}.ant-card{border:1px solid #0000000f;border-radius:12px;transition:all .3s;box-shadow:0 2px 8px #0000000f}.ant-card:hover{box-shadow:0 4px 16px #0000001a}.ant-card-head{background:linear-gradient(135deg,#fafafa 0%,#fff 100%);border-bottom:1px solid #f0f0f0}.ant-btn{border-radius:8px;font-weight:500;transition:all .2s}.ant-btn-primary{background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);border:none;box-shadow:0 2px 4px #3b82f64d}.ant-btn-primary:hover{background:linear-gradient(135deg,#2563eb 0%,#1e40af 100%);transform:translateY(-1px);box-shadow:0 4px 8px #3b82f666}.ant-table{border-radius:8px;overflow:hidden}.ant-table-thead>tr>th{background:linear-gradient(135deg,#fafafa 0%,#f5f5f5 100%);border-bottom:1px solid #e5e5e5;font-weight:600}.ant-tag{border:none;border-radius:6px;font-weight:500}.loading-spinner{border:2px solid #f3f3f3;border-top-color:#3b82f6;border-radius:50%;width:20px;height:20px;animation:1s linear infinite spin;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.device-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;padding:16px 0;display:grid}.device-ball{cursor:pointer;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;width:100%;height:80px;font-size:12px;transition:all .3s;display:flex;position:relative;overflow:hidden}.device-ball:before{content:"";background:linear-gradient(90deg,#0000,#ffffff4d,#0000);width:100%;height:100%;transition:left .6s;position:absolute;top:0;left:-100%}.device-ball:hover:before{left:100%}.device-ball.state-g{color:#fff;background:linear-gradient(135deg,#10b981 0%,#059669 100%);box-shadow:0 2px 8px #10b9814d}.device-ball.state-y{color:#fff;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);box-shadow:0 2px 8px #f59e0b4d}.device-ball.state-r{color:#fff;background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);animation:2s infinite pulse;box-shadow:0 2px 8px #ef44444d}.device-ball:hover{transform:translateY(-2px)scale(1.02)}.device-label{margin-bottom:2px;font-weight:600}.device-value{font-size:11px;font-weight:500}.device-threshold{opacity:.8;margin-top:1px;font-size:9px}.predict-page-compact .ant-card{margin-bottom:8px!important}.predict-page-compact .ant-space-item,.predict-page-compact .ant-row,.predict-page-compact .ant-col{margin-bottom:0!important}.predict-page-compact .ant-statistic-title{margin-bottom:4px!important;font-size:12px!important}.predict-page-compact .ant-card-small>.ant-card-body{padding:12px!important}.predict-page-compact .ant-timeline-item-content{padding-bottom:8px!important}@media (max-width:768px){.page-container{padding:0 12px}.page-header{padding:16px 0}.device-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}.device-ball{height:70px;font-size:11px}}
