:root{color-scheme:dark;font-family:Microsoft YaHei,PingFang SC,Segoe UI,sans-serif;--bg: #0a3270;--bg-2: #0d438b;--surface: #123f82;--surface-2: #15509f;--surface-3: #1b63bf;--ink: #f2f8ff;--text: #d5e8ff;--muted: #a8c2e5;--line: rgba(118, 191, 255, .32);--line-strong: rgba(100, 218, 255, .58);--blue: #2f8cff;--blue-2: #63b8ff;--blue-soft: rgba(47, 140, 255, .2);--cyan: #59e4ff;--cyan-soft: rgba(89, 228, 255, .16);--amber: #ffd06a;--amber-soft: rgba(255, 208, 106, .13);--violet: #7e94ff;--violet-soft: rgba(126, 148, 255, .14);--danger: #ff6b6b;--danger-soft: rgba(255, 107, 107, .14);--shadow: 0 18px 48px rgba(0, 32, 82, .32);--glow-blue: 0 0 26px rgba(47, 140, 255, .24);--radius: 8px}*{box-sizing:border-box}html,body,#app{min-height:100%;margin:0}body{background:radial-gradient(circle at 50% -12%,rgba(101,191,255,.34),transparent 38%),linear-gradient(180deg,#0b3c82,#0e56aa 48%,#082d69);color:var(--text);overflow-x:hidden}button,input{font:inherit}button{appearance:none;-webkit-appearance:none;cursor:pointer}.iconfont-svg{display:inline-flex;width:1em;height:1em;fill:currentColor;line-height:1;vertical-align:-.15em}.app-shell{position:relative;display:grid;min-height:100vh;grid-template-columns:220px minmax(0,1fr);isolation:isolate;background:linear-gradient(rgba(134,208,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(134,208,255,.045) 1px,transparent 1px),linear-gradient(135deg,#083478f0,#0a4b96eb 46%,#082a63f5);background-size:40px 40px,40px 40px,auto}.app-shell:before{position:fixed;inset:0;z-index:-1;background:linear-gradient(115deg,transparent 0%,rgba(89,228,255,.1) 42%,transparent 66%),linear-gradient(rgba(89,228,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(99,184,255,.05) 1px,transparent 1px);background-size:auto,56px 56px,56px 56px;opacity:.65;pointer-events:none;content:"";animation:tech-grid-pan 24s linear infinite}.app-shell:after{position:fixed;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(89,228,255,.08),transparent 18%,transparent 82%,rgba(47,140,255,.1)),radial-gradient(circle at 80% 16%,rgba(118,172,255,.16),transparent 30%);pointer-events:none;content:""}@keyframes tech-grid-pan{0%{background-position:0 0,0 0,0 0}to{background-position:0 0,56px 56px,-56px 56px}}@keyframes soft-pulse{0%,to{box-shadow:0 0 18px #48ddff29,inset 0 0 14px #1f7bff24}50%{box-shadow:0 0 28px #48ddff47,inset 0 0 18px #1f7bff33}}@keyframes soft-sheen{0%,62%,to{opacity:0;transform:translate(-70%)}72%{opacity:1}88%{opacity:0;transform:translate(125%)}}@keyframes panel-scan{0%,55%,to{transform:translate(0);opacity:0}68%{opacity:.9}86%{transform:translate(320%);opacity:0}}@keyframes soft-panel-breathe{0%,to{opacity:.46}50%{opacity:.82}}@keyframes video-corner-line{0%,to{opacity:.45;transform:translate(-8px)}50%{opacity:1;transform:translate(0)}}@keyframes range-active-pop{0%{transform:scale(.96);filter:brightness(.92)}to{transform:scale(1);filter:brightness(1)}}@keyframes range-number-glow{0%{color:#58e1ffeb;text-shadow:none}40%{color:#fff;text-shadow:0 0 14px rgba(72,221,255,.54),0 0 26px rgba(31,123,255,.28)}to{text-shadow:none}}@keyframes range-line-pop{0%{opacity:0;stroke-dasharray:1;stroke-dashoffset:1}to{opacity:1;stroke-dasharray:1;stroke-dashoffset:0}}@keyframes range-area-reveal{0%,20%{opacity:0}to{opacity:1}}@keyframes range-marker-reveal{0%,55%{opacity:0;transform:scale(.35)}to{opacity:1;transform:scale(1)}}@keyframes range-bar-fill{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.app-shell.nav-collapsed{grid-template-columns:70px minmax(0,1fr)}.sidebar{z-index:2;position:sticky;top:0;display:flex;height:100vh;flex-direction:column;gap:18px;border-right:1px solid rgba(88,225,255,.16);background:linear-gradient(180deg,#0d4289f5,#082a63fa),#0b3d86;box-shadow:14px 0 42px #00225847,inset -1px 0 #59e4ff1f;padding:18px 12px;color:var(--text)}.brand{display:flex;align-items:center;gap:11px;min-height:44px;padding:0 4px}.brand-mark{display:grid;width:38px;height:38px;flex:0 0 38px;place-items:center;border:1px solid rgba(88,225,255,.38);border-radius:8px;background:var(--cyan-soft);color:var(--cyan);box-shadow:0 0 18px #48ddff2e,inset 0 0 14px #1f7bff29;animation:soft-pulse 4.8s ease-in-out infinite}.brand-logo{display:block;width:29px;height:29px;object-fit:cover;object-position:center top;filter:drop-shadow(0 0 7px rgba(255,255,255,.34))}.brand-text,.site-card div{display:flex;min-width:0;flex-direction:column}.brand-text strong{overflow:hidden;color:var(--ink);font-size:16px;text-overflow:ellipsis;white-space:nowrap}.brand-text span,.muted{color:var(--muted);font-size:12px;white-space:nowrap}.nav-list{display:flex;flex-direction:column;gap:5px}.nav-item,.icon-btn,.text-btn{display:inline-flex;align-items:center;border:0}.nav-item{position:relative;gap:10px;width:100%;min-height:39px;border-radius:7px;background:transparent;color:#9cabbc;padding:0 11px;text-align:left;transition:background .15s ease,color .15s ease,box-shadow .15s ease,transform .15s ease}.nav-item:before{position:absolute;left:0;width:3px;height:18px;border-radius:99px;background:transparent;content:""}.nav-item:hover{background:#1f7bff1a;color:var(--ink);transform:translate(2px)}.nav-item.active{background:linear-gradient(90deg,#1f7bff47,#48ddff21),#081934b8;box-shadow:inset 0 0 0 1px #48ddff3d,0 0 22px #1f7bff1a;color:var(--ink);font-weight:700}.nav-item.active:before{background:var(--cyan);box-shadow:0 0 14px #48ddffbf}.nav-icon{display:grid;width:22px;height:22px;flex:0 0 22px;place-items:center;color:inherit}.nav-icon .iconfont-svg{font-size:16px}.site-card{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto;border:1px solid var(--line);border-radius:8px;background:linear-gradient(180deg,#63b8ff29,#ffffff0a),#0a3777cc;padding:10px;box-shadow:inset 0 0 18px #48ddff09}.site-card strong{overflow:hidden;color:var(--ink);font-size:13px;text-overflow:ellipsis;white-space:nowrap}.nav-collapsed .brand-text,.nav-collapsed .nav-item>span:not(.nav-icon),.nav-collapsed .site-card div,.nav-collapsed .site-card .iconfont-svg{display:none}.nav-collapsed .sidebar{align-items:center;padding-inline:12px}.nav-collapsed .nav-item{justify-content:center;padding:0}.nav-collapsed .site-card{width:38px;height:38px;padding:0}.main-panel{position:relative;z-index:1;display:flex;min-width:0;flex-direction:column;padding:12px 8px 10px;background:linear-gradient(rgba(132,213,255,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(99,184,255,.045) 1px,transparent 1px),var(--bg);background-size:36px 36px}.main-panel.range-motion .ops-item strong,.main-panel.range-motion .kpi-body strong,.main-panel.range-motion .status-pill,.main-panel.range-motion .carbon-stats strong,.main-panel.range-motion .strategy-item strong,.main-panel.range-motion .metric-item strong,.main-panel.range-motion .bar-item strong,.main-panel.range-motion .snapshot-item strong,.main-panel.range-motion .table-row strong,.main-panel.range-motion .alarm-item strong{animation:range-number-glow .98s ease-out both}.topbar{display:grid;align-items:center;grid-template-columns:80px minmax(360px,1fr) 220px;gap:14px;min-height:58px;margin-bottom:10px}.topbar-left,.topbar-actions{display:flex;align-items:center;gap:10px}.topbar-left{justify-content:flex-start}.topbar-actions{justify-content:flex-end}.system-title{position:relative;display:grid;justify-self:center;min-width:0;place-items:center;padding:0 34px;color:var(--ink);text-align:center;pointer-events:none}.system-title:before,.system-title:after{position:absolute;top:50%;width:88px;height:1px;border-radius:99px;background:linear-gradient(90deg,transparent,rgba(89,228,255,.82));box-shadow:0 0 14px #59e4ff61;content:""}.system-title:before{left:-74px}.system-title:after{right:-74px;transform:rotate(180deg)}.system-title-main{position:relative;display:block;overflow:hidden;max-width:100%;text-overflow:ellipsis;white-space:nowrap}.system-title-main{background:linear-gradient(180deg,#fff,#bfeeff 52%,#59e4ff);background-clip:text;-webkit-background-clip:text;color:transparent;font-family:YouSheBiaoTiHei,Alibaba PuHuiTi,Microsoft YaHei,PingFang SC,sans-serif;font-size:26px;font-weight:900;letter-spacing:0;line-height:1.12;text-shadow:0 0 18px rgba(89,228,255,.35),0 0 34px rgba(47,140,255,.24)}.system-title-main:after{position:absolute;right:10%;bottom:-7px;left:10%;height:2px;border-radius:99px;background:linear-gradient(90deg,transparent,rgba(89,228,255,.86),transparent);box-shadow:0 0 14px #59e4ff70;content:""}.eyebrow{margin:0 0 3px;color:var(--cyan);font-size:11px;font-weight:800;letter-spacing:0}h1,h2,p{margin:0}h1{color:var(--ink);font-size:22px;font-weight:760;line-height:1.25;letter-spacing:0;text-shadow:0 0 20px rgba(72,221,255,.22)}h2{color:var(--ink);font-size:15px;line-height:1.3}.panel-header p{margin-top:3px;color:var(--muted);font-size:12px}.panel-header>.iconfont-svg{color:var(--cyan);font-size:17px}.icon-btn{justify-content:center;width:36px;height:36px;flex:0 0 36px;border:1px solid var(--line);border-radius:7px;background:linear-gradient(180deg,#63b8ff2e,#ffffff0a),#0c3e85d1;color:var(--text);transition:border-color .15s ease,color .15s ease,background .15s ease,box-shadow .15s ease}.icon-btn:hover,.text-btn:hover{border-color:var(--line-strong);background:#1f7bff24;color:var(--ink);box-shadow:0 0 22px #1f7bff2e}.icon-btn .iconfont-svg{font-size:16px}.range-switch{display:flex;border:1px solid var(--line);border-radius:7px;background:linear-gradient(180deg,#63b8ff29,#ffffff08),#0c3e85d1;padding:2px;box-shadow:inset 0 0 16px #1f7bff0f}.range-switch button{position:relative;min-width:54px;height:30px;border:0;border-radius:5px;background:transparent;color:var(--muted);transition:background .16s ease,color .16s ease,transform .12s ease,box-shadow .16s ease}.range-switch button:hover{color:var(--ink);background:#1f7bff1f}.range-switch button:active{transform:scale(.96)}.range-switch button.active{background:linear-gradient(90deg,var(--cyan),var(--blue-2),var(--violet));color:#061017;font-weight:800;box-shadow:0 0 18px #48ddff47,inset 0 0 10px #ffffff38;animation:range-active-pop .22s ease-out}.ops-strip{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:1px;overflow:hidden;margin-bottom:12px;border:1px solid var(--line);border-radius:var(--radius);background:#76bfff3d;box-shadow:var(--shadow),0 0 28px #1f7bff14}.ops-item{position:relative;overflow:hidden;display:grid;align-items:center;grid-template-columns:20px minmax(0,1fr) auto;gap:8px;min-height:38px;background:linear-gradient(180deg,#63b8ff29,#ffffff09),#0c3a7ee0;padding:0 10px;color:var(--muted);font-size:12px}.ops-item:after{position:absolute;inset:0;background:linear-gradient(110deg,transparent 0%,rgba(72,221,255,.08) 45%,transparent 72%);opacity:0;pointer-events:none;content:"";animation:soft-sheen 9s ease-in-out infinite}.ops-item .iconfont-svg{color:var(--cyan);font-size:15px}.ops-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ops-item strong{color:var(--ink);font-size:13px;white-space:nowrap}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:8px}.kpi-card,.panel{border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(180deg,#63b8ff2e,#ffffff09),#0c3a7edb;box-shadow:var(--shadow),inset 0 0 24px #59e4ff0e}.kpi-card{position:relative;display:grid;min-width:0;grid-template-columns:38px minmax(0,1fr);gap:11px;overflow:hidden;padding:13px;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.kpi-card:hover{border-color:var(--line-strong);box-shadow:0 20px 48px #00225857,0 0 26px #63b8ff33,inset 0 0 26px #59e4ff14;transform:translateY(-2px)}.kpi-card:before{position:absolute;top:0;bottom:0;left:-70%;width:52%;background:linear-gradient(110deg,transparent,rgba(72,221,255,.12),transparent);pointer-events:none;content:"";animation:panel-scan 7.5s ease-in-out infinite}.kpi-card:after{position:absolute;inset:0;border-top:1px solid rgba(72,221,255,.2);pointer-events:none;content:""}.kpi-icon{display:grid;width:38px;height:38px;place-items:center;border:1px solid rgba(72,221,255,.16);border-radius:7px}.kpi-icon .iconfont-svg{font-size:20px}.kpi-card.electric .kpi-icon{background:linear-gradient(180deg,var(--cyan-soft),var(--blue-soft));color:var(--cyan);box-shadow:0 0 18px #48ddff24}.kpi-card.solar .kpi-icon{background:var(--amber-soft);color:var(--amber)}.kpi-card.carbon .kpi-icon{background:#bccbe01c;color:#bccbe0}.kpi-card.load .kpi-icon{background:linear-gradient(180deg,var(--blue-soft),var(--violet-soft));color:#9fb3ff}.kpi-body{min-width:0}.kpi-body span{color:var(--muted);font-size:12px}.kpi-body strong{display:block;margin:4px 0;color:var(--ink);font-size:25px;line-height:1;white-space:nowrap}.kpi-body em{color:var(--muted);font-size:12px;font-style:normal;font-weight:700}.kpi-body small{display:block;overflow:hidden;color:var(--cyan);font-size:12px;text-overflow:ellipsis;white-space:nowrap}.content-grid{display:grid;align-items:stretch;grid-template-columns:minmax(380px,1.05fr) minmax(330px,1.05fr) minmax(250px,.68fr);gap:8px}.page-grid{display:grid;align-items:stretch;grid-template-columns:minmax(0,1.45fr) minmax(300px,.72fr);gap:8px}.panel{position:relative;min-width:0;overflow:hidden;padding:12px}.panel:before{position:absolute;inset:0;z-index:0;background:linear-gradient(110deg,transparent 0%,rgba(72,221,255,.055) 48%,transparent 72%),linear-gradient(180deg,rgba(72,221,255,.04),transparent 26%);opacity:.72;pointer-events:none;content:"";animation:soft-panel-breathe 6s ease-in-out infinite}.panel>*{position:relative;z-index:1}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.status-pill{display:inline-flex;align-items:center;min-height:24px;border:1px solid rgba(88,225,255,.28);border-radius:99px;background:linear-gradient(180deg,#59e4ff33,#63b8ff1a),#0d3e84b8;color:var(--cyan);padding:0 9px;font-size:12px;font-weight:800;white-space:nowrap;box-shadow:inset 0 0 14px #48ddff14,0 0 16px #1f7bff14}.text-btn{gap:6px;min-height:30px;border:1px solid var(--line);border-radius:7px;background:linear-gradient(180deg,#63b8ff29,#ffffff08),#0c3e85cc;color:var(--text);padding:0 9px}.text-btn .iconfont-svg{font-size:14px}.map-panel{display:flex;flex-direction:column;grid-row:span 2}.campus-map{position:relative;flex:1;min-height:620px;overflow:hidden;border:1px solid rgba(72,221,255,.24);border-radius:8px;background:radial-gradient(circle at 50% 46%,rgba(88,225,255,.16),transparent 38%),radial-gradient(circle at 22% 18%,rgba(88,225,255,.12),transparent 17%),radial-gradient(circle at 78% 18%,rgba(255,255,255,.08),transparent 16%),linear-gradient(rgba(88,225,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(88,225,255,.035) 1px,transparent 1px),#07111a;background-size:auto,auto,auto,32px 32px,32px 32px,auto}.energy-asset-defs{position:absolute;width:0;height:0;overflow:hidden}.energy-pipes{position:absolute;inset:18px 20px;z-index:1;width:calc(100% - 40px);height:calc(100% - 36px)}.pipe-base{fill:none;stroke:#3b4852eb;stroke-linecap:round;stroke-linejoin:round;stroke-width:14}.pipe-flow{fill:none;filter:url(#pipe-glow);stroke-dasharray:1 13;stroke-linecap:round;stroke-linejoin:round;stroke-width:5;animation:pipe-flow 2.2s linear infinite}.pipe-flow-yellow{stroke:url(#pipe-yellow)}.pipe-flow-blue{stroke:url(#pipe-blue)}.pipe-flow-muted{opacity:.22;stroke:#94a3b8;stroke-dasharray:0}.pipe-label{fill:#24a7ff;font-size:28px;font-weight:700;paint-order:stroke;stroke:#050a12eb;stroke-width:4px}.pipe-label-pv,.pipe-label-battery{fill:#20a5ff}.pipe-label-grid,.pipe-label-load{fill:#d3dae4}@keyframes pipe-flow{to{stroke-dashoffset:-64}}.iso-node,.energy-device{position:absolute;z-index:3;display:grid;justify-items:center;width:166px;color:var(--ink);text-align:center}.iso-node strong,.energy-device strong{margin-top:9px;font-size:16px;line-height:1.2}.iso-node span,.energy-device span{margin-top:3px;color:#9aa8b7;font-size:11px;font-weight:700}.iso-node em,.energy-device em{margin-top:5px;color:var(--cyan);font-size:14px;font-style:normal;font-weight:800}.iso-platform{position:relative;display:grid;width:112px;height:78px;place-items:center;transform:perspective(520px) rotateX(58deg) rotate(-45deg)}.iso-platform:before,.iso-platform:after{position:absolute;inset:13px 7px;border-radius:16px;content:""}.iso-platform:before{background:linear-gradient(145deg,#e8f6fff0,#556976c2);box-shadow:0 14px 30px #0000006b,inset 0 1px 8px #ffffff8c}.iso-platform:after{inset:20px 18px;background:#fffffff5;filter:drop-shadow(0 0 16px rgba(88,225,255,.55))}.iso-shadow{position:absolute;inset:8px 4px;border-radius:18px;background:#58e1ff2e;filter:blur(16px);transform:translateY(-20px)}.asset-svg{position:relative;z-index:2;width:54px;height:54px;color:var(--cyan);filter:drop-shadow(0 0 12px rgba(88,225,255,.58));transform:rotate(45deg) rotateX(-58deg) translateY(-15px)}.node-solar{left:18%;top:18px}.node-grid{right:18%;top:18px}.node-battery{left:18%;bottom:22px}.node-load{right:18%;bottom:22px}.node-solar .asset-svg,.node-solar em{color:var(--amber)}.node-solar .iso-shadow{background:#ffd36b33}.node-grid{opacity:.82}.node-grid .asset-svg{color:#e6edf7}.node-battery .asset-svg,.node-battery em{color:var(--violet)}.node-battery .iso-shadow{background:#9b8cff33}.node-load{opacity:.72}.node-load .asset-svg{color:#8fa1b5}.energy-device{left:50%;top:50%;width:180px;transform:translate(-50%,-48%)}.device-platform{width:128px;height:92px}.device-platform:before{background:linear-gradient(145deg,#c6effff2,#3a5969cc)}.device-platform:after{background:linear-gradient(180deg,#5ee8ff,#2d9dff)}.energy-device .asset-svg{width:58px;height:58px;color:#f5fbff}.energy-device strong{margin-top:13px}.energy-device em{color:var(--ink);font-size:18px;text-shadow:0 0 16px rgba(88,225,255,.34)}.flow-lines{position:absolute;inset:14px;z-index:1;width:calc(100% - 28px);height:calc(100% - 28px);fill:none}.flow-backbone{stroke:#ffffff2e;stroke-width:16;stroke-linecap:round}.flow-link{filter:url(#flow-glow);stroke:url(#flow-primary);stroke-dasharray:12 12;stroke-linecap:round;stroke-width:4;animation:flow 2.4s linear infinite}.flow-pv{stroke:url(#flow-warm)}.flow-storage{stroke:var(--violet)}.core-ring{fill:#58e1ff0f;stroke:#58e1ff59;stroke-dasharray:8 7;stroke-width:2;transform-origin:center;animation:spin 18s linear infinite}.core-dot{fill:var(--cyan);filter:url(#flow-glow)}@keyframes flow{to{stroke-dashoffset:-48}}@keyframes spin{to{transform:rotate(360deg)}}.energy-core{position:absolute;left:50%;top:50%;z-index:3;display:grid;width:170px;height:118px;place-items:center;border:1px solid rgba(88,225,255,.45);border-radius:14px;background:linear-gradient(180deg,#58e1ff2b,#9b8cff14),#0d3879db;box-shadow:0 0 42px #58e1ff38,inset 0 0 28px #58e1ff14;color:var(--ink);transform:translate(-50%,-50%)}.energy-core span{color:var(--cyan);font-size:11px;font-weight:800}.energy-core strong{font-size:26px}.energy-core small{color:var(--muted);font-size:12px}.zone,.grid-node{position:absolute;z-index:2;display:flex;width:148px;min-height:92px;flex-direction:column;justify-content:center;gap:5px;border:1px solid rgba(88,225,255,.26);border-radius:10px;background:#0c1420e6;padding:11px;box-shadow:inset 0 0 22px #58e1ff0a,0 10px 30px #00000047}.zone:after,.grid-node:after{position:absolute;inset:0;border-radius:inherit;border-left:3px solid var(--cyan);pointer-events:none;content:""}.zone-head{display:flex;align-items:center;gap:7px;color:var(--muted);font-size:11px}.zone-head .iconfont-svg{color:var(--cyan);font-size:17px}.zone strong,.grid-node strong{color:var(--ink);font-size:14px}.zone em,.grid-node em{color:var(--cyan);font-size:12px;font-style:normal;font-weight:700}.zone-office{left:24px;top:138px}.zone-workshop{right:24px;top:138px}.zone-pv{left:calc(50% - 74px);top:28px}.zone-pv:after{border-left-color:var(--amber)}.zone-pv em,.zone-pv .zone-head .iconfont-svg{color:var(--amber)}.zone-storage{left:calc(50% - 74px);bottom:34px}.zone-storage:after{border-left-color:var(--violet)}.zone-storage em,.zone-storage .zone-head .iconfont-svg{color:var(--violet)}.zone-charge{right:24px;bottom:34px}.grid-node{left:24px;bottom:34px}.carbon-flow-map{min-height:650px;isolation:isolate;background:radial-gradient(circle at 50% 55%,rgba(88,225,255,.2),transparent 28%),linear-gradient(rgba(132,213,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(132,213,255,.045) 1px,transparent 1px),linear-gradient(145deg,#0a397bf0,#082b62f2 48%,#0c418beb);background-size:auto,32px 32px,32px 32px,auto}.energy-video-map{min-height:650px;isolation:isolate;background:linear-gradient(180deg,#63b8ff2e,#ffffff08),#0b3472;box-shadow:inset 0 0 54px #63b8ff1f,0 0 28px #63b8ff1f}.energy-video-map:before{position:absolute;inset:0;z-index:2;border:1px solid rgba(72,221,255,.18);border-radius:inherit;background:repeating-linear-gradient(180deg,rgba(132,213,255,.045) 0 1px,transparent 1px 5px),linear-gradient(180deg,rgba(9,44,98,.06),transparent 28%,rgba(9,44,98,.12)),linear-gradient(90deg,rgba(8,38,88,.2),transparent 18%,transparent 82%,rgba(8,38,88,.2));box-shadow:inset 0 0 54px #48ddff0f,inset 0 0 0 1px #ffffff09;pointer-events:none;content:""}.energy-video-map:after{position:absolute;right:14px;bottom:12px;z-index:3;width:96px;height:2px;border-radius:99px;background:linear-gradient(90deg,transparent,rgba(72,221,255,.9));box-shadow:0 0 16px #48ddff61;pointer-events:none;content:"";animation:video-corner-line 3.8s ease-in-out infinite}.energy-flow-video{position:absolute;inset:0;z-index:1;display:block;width:100%;height:100%;object-fit:cover;object-position:center;background:#0b3472;filter:saturate(1.14) contrast(1.02) brightness(1.08)}.carbon-flow-map:before{position:absolute;inset:18px;z-index:0;border:1px solid rgba(88,225,255,.13);border-radius:10px;background:linear-gradient(180deg,rgba(255,255,255,.026),transparent 36%),linear-gradient(90deg,transparent 0%,rgba(88,225,255,.055) 50%,transparent 100%);box-shadow:inset 0 0 54px #58e1ff09;pointer-events:none;content:""}.carbon-flow-map:after{position:absolute;left:50%;top:54%;z-index:0;width:320px;height:220px;border-radius:999px;background:#58e1ff17;filter:blur(46px);pointer-events:none;transform:translate(-50%,-50%);content:""}.map-panel .status-pill{border-color:#58e1ff5c;background:linear-gradient(180deg,#58e1ff29,#58e1ff0f),#0d3e84c7;box-shadow:inset 0 0 16px #58e1ff0f,0 0 18px #58e1ff14}.park-flow-lines{position:absolute;inset:22px 18px 18px;z-index:1;width:calc(100% - 36px);height:calc(100% - 40px);overflow:visible}.flow-base,.flow-bus{fill:none;stroke-linecap:round;stroke-linejoin:round}.flow-base{opacity:.72;stroke:#39485694;stroke-width:12}.flow-bus{filter:url(#park-flow-glow);stroke-dasharray:8 14;stroke-width:3.6;animation:park-flow 4s linear infinite}.source-bus{stroke:url(#flow-source)}.grid-bus{stroke:url(#flow-grid)}.storage-bus,.charge-bus{stroke:url(#flow-flex)}.office-bus,.workshop-bus{stroke:url(#flow-load)}.flow-dot{filter:url(#park-dot-glow);opacity:.95}.source-dot{fill:var(--amber)}.grid-dot,.load-dot{fill:var(--cyan)}.storage-dot,.flex-dot{fill:var(--violet)}@keyframes park-flow{to{stroke-dashoffset:-44}}.energy-center-card{position:absolute;left:50%;top:54%;z-index:4;display:grid;width:218px;min-height:178px;place-items:center;border:1px solid rgba(88,225,255,.58);border-radius:8px;background:linear-gradient(155deg,#58e1ff57,#58e1ff14 42%,#9b8cff29),#08121fe6;box-shadow:0 22px 50px #0000006b,0 0 42px #58e1ff38,inset 0 0 34px #58e1ff1f;padding:16px;text-align:center;transform:translate(-50%,-50%);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.energy-center-card:before{position:absolute;inset:-10px;z-index:-1;border:1px solid rgba(88,225,255,.18);border-radius:14px;box-shadow:0 0 36px #58e1ff1a;content:""}.energy-center-card:after{position:absolute;inset:7px;border:1px solid rgba(255,255,255,.08);border-radius:6px;pointer-events:none;content:""}.energy-center-icon{display:grid;width:50px;height:50px;place-items:center;border:1px solid rgba(88,225,255,.48);border-radius:8px;background:linear-gradient(180deg,#58e1ff42,#58e1ff14),#050d15b3;color:var(--cyan);box-shadow:inset 0 0 20px #58e1ff1f,0 0 24px #58e1ff2e}.energy-center-icon .iconfont-svg{font-size:25px}.energy-center-card>span{margin-top:10px;color:var(--cyan);font-size:12px;font-weight:800}.energy-center-card>strong{margin-top:4px;color:var(--ink);font-size:30px;line-height:1;text-shadow:0 0 22px rgba(88,225,255,.32)}.energy-center-card>small{margin-top:6px;color:var(--muted);font-size:11px}.center-stats{display:flex;width:100%;justify-content:center;gap:6px;margin-top:13px}.center-stats div{min-width:0;border:1px solid rgba(88,225,255,.18);border-radius:999px;background:#050c148c;padding:5px 7px;box-shadow:inset 0 0 14px #58e1ff0a}.center-stats em,.center-stats span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.center-stats em{color:var(--ink);font-size:10px;font-style:normal;font-weight:800}.center-stats span{margin-top:3px;color:var(--muted);font-size:9px}.flow-node{position:absolute;z-index:3;display:grid;grid-template-columns:40px minmax(0,1fr);gap:9px;width:164px;min-height:88px;align-items:center;border:1px solid var(--node-border, rgba(88, 225, 255, .27));border-radius:8px;background:linear-gradient(180deg,#ffffff14,#ffffff05),#0d3e84b3;box-shadow:0 16px 36px #00000047,0 0 22px var(--node-glow, rgba(88, 225, 255, .08)),inset 0 0 24px #58e1ff09;padding:10px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.flow-node:hover{border-color:var(--node-accent, var(--cyan));box-shadow:0 18px 40px #00000052,0 0 28px var(--node-glow, rgba(88, 225, 255, .16)),inset 0 0 26px #58e1ff0e;transform:translateY(-2px)}.node-charge:hover{transform:translate(-50%) translateY(-2px)}.flow-node:after{position:absolute;inset:0;border-radius:inherit;border-left:3px solid var(--node-accent, var(--cyan));pointer-events:none;content:""}.flow-node-icon{display:grid;width:38px;height:38px;place-items:center;border:1px solid color-mix(in srgb,var(--node-accent, var(--cyan)) 50%,transparent);border-radius:8px;background:linear-gradient(180deg,color-mix(in srgb,var(--node-accent, var(--cyan)) 20%,transparent),transparent),#ffffff09;color:var(--node-accent, var(--cyan));box-shadow:inset 0 0 14px color-mix(in srgb,var(--node-accent, var(--cyan)) 16%,transparent)}.flow-node-icon .iconfont-svg{font-size:21px}.flow-node-body{min-width:0}.flow-node span,.flow-node strong,.flow-node em,.flow-node small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flow-node span{color:var(--muted);font-size:11px;font-weight:700}.flow-node strong{margin-top:4px;color:var(--ink);font-size:14px;line-height:1.2}.flow-node em{margin-top:6px;color:var(--node-accent, var(--cyan));font-size:12px;font-style:normal;font-weight:800}.flow-node small{margin-top:4px;color:#8190a3;font-size:10px}.flow-node.source{--node-accent: var(--amber);--node-border: rgba(255, 211, 107, .42);--node-glow: rgba(255, 211, 107, .2);box-shadow:0 16px 36px #00000047,0 0 30px #ffd36b1f,inset 0 0 24px #ffd36b0b}.flow-node.grid{--node-accent: #bfeeff;--node-border: rgba(88, 225, 255, .36);--node-glow: rgba(88, 225, 255, .14)}.flow-node.storage,.flow-node.flex{--node-accent: var(--violet);--node-border: rgba(155, 140, 255, .42);--node-glow: rgba(155, 140, 255, .16)}.node-pv{left:32px;top:38px}.node-grid{right:24px;top:38px}.node-office{right:24px;top:244px}.node-workshop{right:24px;bottom:46px}.node-storage{left:32px;bottom:46px}.node-charge{left:50%;bottom:34px;transform:translate(-50%)}.chart-panel{grid-column:span 2}.chart-wrap{min-height:0}.chart-wrap svg{display:block;width:100%;height:auto;aspect-ratio:680 / 250;border:1px solid rgba(72,221,255,.24);border-radius:8px;background:linear-gradient(rgba(132,213,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(99,184,255,.05) 1px,transparent 1px),#092c62d1;background-size:100% 36px,36px 100%,auto;box-shadow:inset 0 0 28px #1f7bff0e,0 0 22px #1f7bff0e}.grid-line{stroke:#a2d7ff3d}.axis-line{stroke:#cae8ff57}.axis-label,.tick-label{fill:var(--muted);font-size:11px}.load-area{fill:url(#load-area);opacity:.82}.pv-area{fill:url(#pv-area);opacity:.74}.load-line,.pv-line{fill:none;filter:url(#chart-glow);stroke-linecap:round;stroke-linejoin:round;stroke-width:2.15;vector-effect:non-scaling-stroke}.load-line{stroke:var(--cyan)}.pv-line{stroke:var(--amber)}.main-panel.range-motion .load-line,.main-panel.range-motion .pv-line{animation:range-line-pop .98s ease-out both}.main-panel.range-motion .load-area,.main-panel.range-motion .pv-area{animation:range-area-reveal .98s ease-out both}.load-marker,.pv-marker{stroke:#08224ef5;stroke-width:1.4;transform-box:fill-box;transform-origin:center;vector-effect:non-scaling-stroke}.main-panel.range-motion .load-marker,.main-panel.range-motion .pv-marker{animation:range-marker-reveal .98s ease-out both}.load-marker{fill:var(--cyan)}.pv-marker{fill:var(--amber)}.chart-legend{display:flex;gap:18px;margin-top:8px;color:var(--muted);font-size:12px}.legend-dot{display:inline-block;width:8px;height:8px;margin-right:6px;border-radius:50%}.legend-dot.load{background:var(--cyan);box-shadow:0 0 12px #58e1ff80}.legend-dot.pv{background:var(--amber);box-shadow:0 0 12px #ffd36b66}.carbon-panel,.strategy-panel{min-height:206px}.carbon-ring{position:relative;display:grid;width:146px;height:146px;margin:0 auto 8px;place-items:center}.carbon-ring svg{position:absolute;inset:0;transform:rotate(-90deg)}.ring-bg,.ring-value{fill:none;stroke-width:13}.ring-bg{stroke:#9ba8ba33}.ring-value{stroke:var(--cyan);stroke-linecap:round;filter:drop-shadow(0 0 7px rgba(88,225,255,.5))}.carbon-ring div{display:grid;place-items:center}.carbon-ring strong{color:var(--ink);font-size:29px}.carbon-ring span,.carbon-stats span{color:var(--muted);font-size:12px}.carbon-stats{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding-top:11px}.carbon-stats strong{color:var(--ink)}.strategy-list,.metric-list,.bar-list,.alarm-list{display:grid;gap:8px}.strategy-item,.metric-item,.alarm-item,.snapshot-item,.strategy-card{border:1px solid var(--line);border-radius:7px;background:#0d3e84b8}.strategy-item{display:grid;align-items:center;grid-template-columns:28px 1fr auto;min-height:40px;padding:0 10px}.strategy-item .iconfont-svg{color:var(--violet);font-size:17px}.strategy-item span{color:var(--text);font-size:13px}.strategy-item strong{color:var(--ink);font-size:13px}.metric-item{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:50px;padding:0 11px}.metric-item span{color:var(--muted);font-size:13px}.metric-item strong{color:var(--ink);font-size:20px;white-space:nowrap}.metric-item em{color:var(--muted);font-size:12px;font-style:normal}.bar-item{display:grid;grid-template-columns:minmax(120px,.7fr) minmax(120px,auto);gap:8px 14px;align-items:center}.bar-item span{color:var(--text);font-size:13px}.bar-item strong{justify-self:end;color:var(--ink);font-size:13px}.bar-track{grid-column:1 / -1;height:8px;overflow:hidden;border-radius:99px;background:#8faac72e}.bar-track i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--cyan),var(--violet),var(--amber));transform-origin:left center;transition:width .3s ease}.main-panel.range-motion .bar-track i{animation:range-bar-fill .98s ease-out both}.strategy-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px}.strategy-card{min-height:112px;padding:13px}.strategy-card strong{display:block;margin-bottom:7px;color:var(--ink);font-size:14px}.strategy-card p{color:var(--muted);font-size:13px;line-height:1.65}.snapshot-panel{grid-column:span 3}.snapshot-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px}.snapshot-grid.single{grid-template-columns:1fr}.snapshot-item{min-width:0;padding:10px}.snapshot-item span{display:block;color:var(--muted);font-size:12px}.snapshot-item strong{display:block;overflow:hidden;margin:5px 0 4px;color:var(--ink);font-size:14px;text-overflow:ellipsis;white-space:nowrap}.snapshot-item small{color:#9fb0c5;font-size:12px}.device-panel{grid-column:span 2}.device-table{display:grid;gap:1px;overflow:hidden;border:1px solid var(--line);border-radius:7px;background:#76bfff47}.table-row{display:grid;align-items:center;grid-template-columns:minmax(170px,1.5fr) minmax(90px,.7fr) minmax(76px,.55fr) minmax(100px,.78fr);min-height:47px;background:#0b3777d1;padding:0 11px;column-gap:12px;font-size:13px}.table-head{min-height:32px;background:#84d5ff24;color:var(--muted);font-size:12px;font-weight:700}.table-row strong,.alarm-item strong{display:block;color:var(--ink);font-size:13px}.table-row small{display:block;margin-top:2px;color:var(--muted);font-size:12px}.status-dot{display:inline-block;width:8px;height:8px;margin-right:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px #58e1ff7a}.status-dot.warn{background:var(--danger);box-shadow:0 0 10px #ff6b6b73}.alarm-list.expanded{grid-template-columns:repeat(2,minmax(0,1fr))}.alarm-item{display:grid;align-items:center;grid-template-columns:30px minmax(0,1fr) 44px;min-height:62px;padding:9px;gap:9px}.alarm-level{display:grid;width:27px;height:27px;place-items:center;border-radius:5px;color:#07090f;font-size:12px;font-weight:800}.level-高{background:var(--danger)}.level-中{background:var(--amber)}.level-低{background:var(--violet)}.alarm-item p{overflow:hidden;margin-top:3px;color:var(--muted);font-size:12px;text-overflow:ellipsis;white-space:nowrap}.alarm-item time{color:var(--muted);font-size:12px;text-align:right}.statusbar{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;color:var(--muted);font-size:12px}.statusbar span{display:inline-flex;align-items:center;gap:6px;min-height:26px;border:1px solid var(--line);border-radius:99px;background:#0d3e84b8;padding:0 9px}.statusbar .iconfont-svg{color:var(--cyan);font-size:14px}@media(max-width:1180px){.app-shell,.app-shell.nav-collapsed{grid-template-columns:1fr}.sidebar{position:sticky;z-index:10;height:auto;flex-direction:row;align-items:center;overflow-x:auto;border-right:0;border-bottom:1px solid rgba(88,225,255,.16);scrollbar-width:none}.sidebar::-webkit-scrollbar{display:none}.nav-list{flex-direction:row}.nav-item{width:auto;white-space:nowrap}.site-card{min-width:180px;margin-top:0}.nav-collapsed .brand-text,.nav-collapsed .nav-item>span:not(.nav-icon),.nav-collapsed .site-card div,.nav-collapsed .site-card .iconfont-svg{display:flex}.ops-strip{grid-template-columns:repeat(3,minmax(0,1fr))}.content-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.page-grid{grid-template-columns:1fr}.map-panel,.chart-panel,.snapshot-panel,.device-panel{grid-column:span 2}.snapshot-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.strategy-cards,.alarm-list.expanded{grid-template-columns:1fr}}@media(max-width:820px){.main-panel{padding:12px}.topbar{grid-template-columns:40px minmax(0,1fr) 40px;gap:8px;min-height:auto}.topbar-left{grid-column:1;grid-row:1;width:auto;justify-content:flex-start}.system-title{grid-column:1 / -1;grid-row:1;width:100%;padding:0 48px}.system-title-main{font-size:18px}.topbar-actions{display:grid;align-items:center;grid-column:1 / -1;grid-row:2;grid-template-columns:minmax(0,1fr) 36px;gap:8px;width:100%}.range-switch{grid-column:1 / 2;grid-row:1;width:auto;min-width:0}.alert-btn{grid-column:2 / 3;grid-row:1;justify-self:end}.range-switch button{flex:1;min-width:0}.ops-strip,.kpi-grid,.content-grid{grid-template-columns:1fr}.ops-item{grid-template-columns:20px minmax(0,1fr);min-height:48px;gap:3px 8px;padding:6px 10px}.ops-item .iconfont-svg{grid-row:1 / span 2}.ops-item strong{grid-column:2;justify-self:start;font-size:14px}.map-panel,.chart-panel,.snapshot-panel,.device-panel{grid-column:auto}.snapshot-grid,.bar-item{grid-template-columns:1fr}.bar-item strong{justify-self:start}.metric-item{align-items:flex-start;flex-direction:column;justify-content:center;padding:11px}.campus-map{height:620px}.carbon-flow-map{height:auto;min-height:760px}.energy-video-map{height:620px;min-height:620px}.park-flow-lines{inset:74px 10px 102px;width:calc(100% - 20px);height:calc(100% - 176px);opacity:.58}.energy-center-card{top:51%;width:180px;min-height:162px;padding:13px}.energy-center-card>strong{font-size:23px}.center-stats{flex-wrap:wrap}.center-stats div{flex:1 1 52px}.flow-node{width:156px;min-height:86px;grid-template-columns:38px minmax(0,1fr);gap:8px;padding:10px}.flow-node-icon{width:36px;height:36px}.flow-node strong{font-size:13px}.flow-node small{display:none}.node-pv{left:14px;top:18px}.node-grid{right:14px;top:18px}.node-office{right:14px;left:auto;top:150px}.node-workshop{right:14px;top:auto;bottom:108px}.node-storage{left:14px;bottom:108px}.node-charge{left:50%;right:auto;bottom:20px;transform:translate(-50%)}.node-charge:hover{transform:translate(-50%) translateY(-2px)}.energy-core{top:47%;width:154px;height:108px}.zone,.grid-node{width:calc(50% - 24px);min-height:96px}.zone-pv{left:16px;top:18px}.zone-office{left:16px;top:148px}.zone-workshop{right:16px;top:148px}.zone-storage{left:16px;bottom:132px}.zone-charge{right:16px;bottom:132px}.grid-node{left:16px;bottom:18px}.flow-lines{opacity:.55}.pipe-label{display:none}.chart-wrap svg{height:240px;aspect-ratio:auto}.table-row{grid-template-columns:1fr;gap:5px;min-height:auto;padding:10px}.table-head{display:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}
