th[data-v-cf3988c4],td[data-v-cf3988c4]{vertical-align:middle}th[data-v-cf3988c4]:nth-child(1),td[data-v-cf3988c4]:nth-child(1){width:170px}th[data-v-cf3988c4]:nth-child(2),td[data-v-cf3988c4]:nth-child(2){width:110px}th[data-v-cf3988c4]:nth-child(3),td[data-v-cf3988c4]:nth-child(3){width:130px}th[data-v-cf3988c4]:nth-child(4),td[data-v-cf3988c4]:nth-child(4){width:160px}th[data-v-cf3988c4]:nth-child(5),td[data-v-cf3988c4]:nth-child(5){width:120px}th[data-v-cf3988c4]:nth-child(6),td[data-v-cf3988c4]:nth-child(6){width:120px}th[data-v-cf3988c4]:nth-child(7),td[data-v-cf3988c4]:nth-child(7){width:80px}.detail-btn[data-v-cf3988c4]{display:inline-flex;align-items:center;height:32px;padding:0 12px;border:1px solid #346538;border-radius:5px;background:#f7faf5;color:#346538;font-size:13px;cursor:pointer;transition:background .2s ease,color .2s ease}.detail-btn[data-v-cf3988c4]:hover{background:#346538;color:#fff}.drawer-overlay[data-v-cf3988c4]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:rgba(31,37,40,.18);-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.drawer-fade-enter-active[data-v-cf3988c4],.drawer-fade-leave-active[data-v-cf3988c4]{transition:opacity .28s cubic-bezier(.16,1,.3,1)}.drawer-fade-enter-from[data-v-cf3988c4],.drawer-fade-leave-to[data-v-cf3988c4]{opacity:0}.detail-drawer[data-v-cf3988c4]{position:fixed;top:0;right:0;bottom:0;z-index:110;width:min(480px,92vw);display:flex;flex-direction:column;background:#fff;border-left:1px solid #e1e4dc;box-shadow:-8px 0 32px #1f25281f}.drawer-slide-enter-active[data-v-cf3988c4],.drawer-slide-leave-active[data-v-cf3988c4]{transition:transform .32s cubic-bezier(.16,1,.3,1)}.drawer-slide-enter-from[data-v-cf3988c4],.drawer-slide-leave-to[data-v-cf3988c4]{transform:translate(100%)}.drawer-header[data-v-cf3988c4]{display:flex;align-items:center;justify-content:space-between;padding:22px 24px 18px;border-bottom:1px solid #e8ebe3}.drawer-header h3[data-v-cf3988c4]{margin:0;font-size:20px;color:#1f2528}.drawer-close[data-v-cf3988c4]{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid #e1e4dc;border-radius:6px;background:#fbfbfa;color:#60695e;font-size:20px;line-height:1;cursor:pointer;transition:background .2s ease,color .2s ease}.drawer-close[data-v-cf3988c4]:hover{background:#f0f2ed;color:#1f2528}.drawer-body[data-v-cf3988c4]{flex:1;overflow-y:auto;padding:20px 24px 32px}.drawer-section[data-v-cf3988c4]{margin-bottom:28px}.drawer-section[data-v-cf3988c4]:last-child{margin-bottom:0}.drawer-section h4[data-v-cf3988c4]{margin:0 0 14px;font-size:15px;color:#495148;padding-bottom:8px;border-bottom:1px solid #eef0eb}.info-grid[data-v-cf3988c4]{display:grid;gap:12px;margin:0}.info-item[data-v-cf3988c4]{display:grid;grid-template-columns:100px 1fr;gap:12px;align-items:baseline}.info-item dt[data-v-cf3988c4]{color:#6f786d;font-size:13px}.info-item dd[data-v-cf3988c4]{margin:0;color:#1f2528;font-size:14px;word-break:break-all}.data-items-list[data-v-cf3988c4]{display:grid;gap:8px}.data-item-row[data-v-cf3988c4]{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border:1px solid #e8ebe3;border-radius:6px;background:#fbfbfa}.data-item-name[data-v-cf3988c4]{color:#495148;font-size:14px}.data-item-value[data-v-cf3988c4]{color:#1f2528;font-size:14px;font-weight:600}.empty-cell[data-v-cf3988c4]{color:#7b8378;text-align:center;padding:20px 0}:root{font-family:Microsoft YaHei,PingFang SC,Segoe UI,sans-serif;color:#1f2528;background:#f5f7f1;--bg: #edf7e8;--surface: rgba(255, 255, 255, .91);--surface-strong: #ffffff;--line: #b9d6a8;--line-soft: #d9ebcd;--text: #1f2528;--muted: #566352;--brand: #16a34a;--brand-deep: #087f35;--brand-soft: #c9f7d4;--blue: #1557ff;--blue-deep: #123ac8;--blue-soft: #dbe6ff;--orange: #ff5a00;--orange-soft: #ffdec2;--shadow: 0 20px 48px rgba(22, 163, 74, .18);--shadow-soft: 0 14px 34px rgba(21, 87, 255, .12);font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at 10% 6%,rgba(22,163,74,.24),transparent 29%),radial-gradient(circle at 82% 10%,rgba(21,87,255,.22),transparent 31%),radial-gradient(circle at 92% 76%,rgba(255,90,0,.18),transparent 29%),linear-gradient(145deg,rgba(221,255,222,.96) 0%,rgba(255,255,255,.9) 38%,rgba(219,230,255,.9) 100%)}button,input,select{font:inherit}button{cursor:pointer}.login-page{position:relative;display:grid;place-items:center;min-height:100vh;padding:28px}.login-footer{position:absolute;left:50%;bottom:20px;display:grid;gap:6px;color:#687466;font-size:13px;text-align:center;transform:translate(-50%)}.login-footer a{color:inherit;text-decoration:none;transition:color .2s ease}.login-footer a:hover{color:var(--brand)}.login-card{display:grid;gap:18px;width:min(430px,100%);padding:34px;border:1px solid rgba(221,229,214,.9);border-radius:12px;background:var(--surface);box-shadow:var(--shadow)}.login-logo{display:block;width:340px;max-width:100%;height:auto;margin:0 auto 6px}.login-card h1{margin:0;font-size:30px;text-align:center;color:var(--text)}.login-card .eyebrow{text-align:center}.login-card label{display:grid;gap:7px}.login-card label span{color:#60695e;font-size:13px}.login-button{width:100%;margin-top:4px}.login-error{margin:0;color:#9f2f2d;font-size:14px}.loading-page{position:relative;display:grid;place-items:center;min-height:100vh;padding:28px}.loading-card{display:grid;justify-items:center;gap:18px;width:min(420px,100%);padding:34px;border:1px solid rgba(221,229,214,.9);border-radius:12px;background:var(--surface);box-shadow:var(--shadow)}.loading-logo{width:340px;max-width:100%;height:auto}.loading-bar{width:240px;height:4px;overflow:hidden;border-radius:999px;background:#e8eee2}.loading-bar span{display:block;width:42%;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--brand),var(--blue),var(--orange));animation:loading-slide 2s cubic-bezier(.16,1,.3,1) infinite}.loading-card p{margin:0;color:#60695e}@keyframes loading-slide{0%{transform:translate(-110%)}to{transform:translate(250%)}}.app-shell{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;display:flex;flex-direction:column;justify-content:space-between;height:100vh;padding:28px;border-right:1px solid rgba(221,229,214,.9);background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(233,252,229,.92)),var(--surface);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:8px 0 28px #2f502d0d}.brand-logo{display:block;width:230px;max-width:100%;height:auto;margin:0 auto 28px}.brand-area{text-align:center}.sidebar h1,.topbar h2,.section-heading h3{margin:0}.sidebar h1{font-size:26px;letter-spacing:0;text-align:center;color:var(--text)}.sidebar .company-name{max-width:224px;margin:12px auto 0;padding-top:12px;border-top:1px solid var(--line-soft);color:#566352;font-size:14px;font-weight:600;line-height:1.65;text-align:center}.sidebar p{margin:8px 0 0;color:#6e756c;line-height:1.6}.nav-list{display:grid;gap:8px;width:230px;max-width:100%;margin:54px auto auto}.nav-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px;border:1px solid transparent;border-radius:8px;background:transparent;color:#394238;text-align:left;transition:background .2s ease,border-color .2s ease,color .2s ease,transform .2s ease,box-shadow .2s ease}.nav-item:hover{border-color:#16a34a75;background:linear-gradient(90deg,rgba(201,247,212,.95),rgba(219,230,255,.7));color:#102416}.nav-item.active{border-color:#16a34a94;background:linear-gradient(100deg,var(--brand) 0%,#24c45b 42%,var(--blue) 100%);color:#fff;box-shadow:inset 4px 0 #ffffff9e,0 10px 22px #16a34a3d}.nav-item.active .nav-icon{color:#fff}.nav-item:active,.button:active,.row-actions button:active{transform:translateY(1px)}.nav-icon{font-family:Consolas,SF Mono,monospace;color:var(--brand)}.connection-box{display:flex;align-items:center;gap:12px;padding:14px;border:1px solid rgba(22,163,74,.32);border-radius:8px;background:linear-gradient(180deg,#fff,#e8ffe9);box-shadow:var(--shadow-soft)}.logout-button{border:1px solid var(--line);border-radius:5px;background:#fff;color:#29302c;padding:6px 9px;transition:border-color .2s ease,background .2s ease,transform .2s ease}.logout-button:hover{border-color:#23863652;background:linear-gradient(90deg,var(--brand-soft),var(--blue-soft))}.top-logout{align-self:center;padding:9px 13px}.connection-box strong,.connection-box small{display:block}.connection-box small{margin-top:4px;color:#7a8178}.status-dot{width:10px;height:10px;border-radius:50%;background:#a8aaa5}.status-dot.online{background:#00c853;box-shadow:0 0 0 5px #00c85338}.status-dot.offline{background:#e53935;box-shadow:0 0 0 5px #e539352e}.content{min-width:0;padding:28px}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:24px}.eyebrow{margin:0 0 8px;color:var(--muted);font-family:Consolas,SF Mono,monospace;font-size:12px;letter-spacing:0}.topbar h2{font-size:34px;color:var(--text)}.topbar-actions,.form-actions,.inline-filter,.row-actions{display:flex;align-items:center;gap:10px}.search-input,input,select{height:40px;min-width:0;border:1px solid #bcd5b0;border-radius:6px;background:rgba(255,255,255,.96);color:#202622;outline:none;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}input,select{width:100%;padding:0 10px}.search-input{width:260px;padding:0 12px}input:focus,select:focus,.search-input:focus{border-color:var(--brand);background:#fff;box-shadow:0 0 0 4px #16a34a2e}.button{height:40px;padding:0 16px;border:1px solid #17351f;border-radius:6px;background:linear-gradient(135deg,var(--brand),var(--brand-deep) 45%,var(--blue-deep));color:#fff;box-shadow:0 12px 26px #16a34a4d;transition:background .2s ease,transform .2s ease,box-shadow .2s ease}.button:hover{background:linear-gradient(135deg,#20c95a,var(--brand-deep) 48%,var(--blue));box-shadow:0 14px 30px #16a34a57}.button.secondary{border-color:var(--line);background:#fff;color:#29302c;box-shadow:none}.button.secondary:hover{background:#f8fbf5}.panel-stack{display:grid;gap:18px}.page-fade-enter-active,.page-fade-leave-active{transition:opacity .34s cubic-bezier(.16,1,.3,1),transform .34s cubic-bezier(.16,1,.3,1);will-change:opacity,transform}.page-fade-enter-from{opacity:0;transform:translateY(10px)}.page-fade-leave-to{opacity:0;transform:translateY(-6px)}.metric-grid{display:grid;grid-template-columns:1fr 2fr;gap:14px}.metric-panel,.table-section,.editor-grid,.query-panel{border:1px solid rgba(185,214,168,.96);border-radius:8px;background:var(--surface);box-shadow:var(--shadow-soft)}.metric-panel{min-height:130px;padding:20px;position:relative;overflow:hidden}.metric-panel:before{content:"";position:absolute;inset:0 0 auto;height:5px;background:linear-gradient(90deg,var(--brand) 0%,var(--blue) 48%,var(--orange) 100%);opacity:.95}.metric-panel span,.metric-panel small{color:#6f786d}.metric-panel strong{display:block;margin:12px 0 8px;font-family:Consolas,SF Mono,monospace;font-size:34px;color:#17231b}.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.table-section{overflow:hidden}.chart-section{overflow:visible;border:1px solid rgba(185,214,168,.96);border-radius:8px;background:var(--surface);box-shadow:var(--shadow-soft)}.chart-wrap{position:relative;overflow:visible;padding:18px}.chart-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:16px}.chart-summary article{padding:14px;border:1px solid rgba(185,214,168,.72);border-radius:8px;background:linear-gradient(180deg,#fff,#edffe9)}.chart-summary span{display:block;color:#6f786d;font-size:13px}.chart-summary strong{display:block;margin-top:8px;font-family:Consolas,SF Mono,monospace;font-size:24px;color:#213627}.efficiency-chart-panel{padding:22px 24px 18px;border:1px solid rgba(185,214,168,.96);border-radius:8px;background:var(--surface);box-shadow:var(--shadow-soft);overflow:visible}.efficiency-chart-panel .efficiency-chart{overflow:visible}.efficiency-chart-heading{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px}.efficiency-chart-heading h3{position:relative;margin:0;padding-left:14px;font-size:18px;color:#1f2937}.efficiency-chart-heading h3:before{content:"";position:absolute;left:0;top:2px;width:5px;height:20px;border-radius:999px;background:var(--blue);box-shadow:0 0 0 5px #1557ff33}.efficiency-chart-heading.orange h3:before{background:var(--orange);box-shadow:0 0 0 5px #ff5a0033}.efficiency-chart-heading span,.efficiency-legend{color:#667085;font-size:14px}.efficiency-legend{display:flex;align-items:center;gap:18px}.efficiency-legend span{display:inline-flex;align-items:center;gap:8px}.legend-toggle{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border:1px solid #d8e0d1;border-radius:20px;background:#fff;color:#1f2937;font-size:14px;cursor:pointer;transition:background .2s ease,border-color .2s ease,opacity .2s ease,box-shadow .2s ease}.legend-toggle:hover{border-color:#b0b8aa;box-shadow:0 6px 14px #2f502d14}.legend-toggle.off{opacity:.45;background:#f5f5f2;border-color:#e1e4dc}.legend-toggle.off .legend-dot{opacity:.5}.legend-dot{display:inline-block;width:13px;height:13px;border-radius:50%}.legend-dot.baseline{background:#00d084}.legend-dot.actual{background:var(--blue)}.efficiency-chart{width:100%;height:330px}.efficiency-energy-echart{height:330px}.efficiency-energy-chart-layer{position:relative}.efficiency-energy-hover-card{position:absolute;top:0;left:0;z-index:30;width:300px;padding:14px 18px;border:1px solid rgba(223,227,218,.9);border-radius:8px;background:#fff;box-shadow:0 10px 26px #1f252829;color:#6b7280;pointer-events:none;will-change:transform}.efficiency-energy-hover-title{margin-bottom:8px;color:#6b7280;font-size:18px;font-weight:600;line-height:1.2}.efficiency-energy-hover-row{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-top:7px;font-size:17px;line-height:1.25}.efficiency-energy-hover-row span{display:inline-flex;align-items:center;min-width:0;gap:8px;font-weight:600}.efficiency-energy-hover-row b{color:#666;font-size:18px;font-weight:800}.efficiency-rate-echart{height:430px}.trend-chart{display:block;width:100%;height:320px}.empty-chart{padding:54px 18px;color:#7b8378;text-align:center;background:linear-gradient(180deg,rgba(201,247,212,.56),rgba(219,230,255,.28),rgba(255,255,255,0))}.empty-chart.compact{padding:96px 18px}.chart-tooltip-title{margin-bottom:6px;color:#60695e;font-family:Consolas,SF Mono,monospace}.trend-echarts-tooltip{pointer-events:none}.chart-hover-card{position:absolute;top:0;left:0;z-index:20;min-width:180px;max-width:220px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:0 12px 28px #1f252824;color:#1f2528;pointer-events:none;white-space:nowrap;will-change:transform}.chart-hover-card b{font-weight:800}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 18px 14px;border-bottom:1px solid var(--line-soft);background:linear-gradient(90deg,rgba(201,247,212,.92),rgba(219,230,255,.68),rgba(255,222,194,.28))}.section-heading h3{font-size:18px;color:var(--text)}.section-heading span{color:#737b71;font-size:14px}.editor-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;padding:18px}.query-panel{display:grid;grid-template-columns:minmax(180px,1fr) minmax(240px,1.6fr) minmax(160px,1fr) minmax(160px,1fr) auto;gap:14px;padding:18px}.message-query{grid-template-columns:minmax(180px,1fr) minmax(260px,1.6fr) minmax(180px,1fr) auto;align-items:end}.export-query{grid-template-columns:minmax(150px,.9fr) minmax(220px,1.4fr) minmax(130px,.75fr) minmax(150px,.9fr) minmax(150px,.9fr) auto;align-items:end}.export-query .multi-select-field{grid-column:span 2}.trend-query{grid-template-columns:minmax(150px,.9fr) minmax(260px,1.6fr) minmax(130px,.75fr) minmax(160px,.9fr)}.trend-query.range{grid-template-columns:minmax(140px,.85fr) minmax(240px,1.45fr) minmax(120px,.7fr) minmax(260px,1.2fr)}.efficiency-query{grid-template-columns:minmax(120px,.85fr) minmax(230px,1.45fr) minmax(110px,.75fr) minmax(150px,.9fr) minmax(130px,.8fr) auto;align-items:end}.efficiency-query.range{grid-template-columns:minmax(110px,.8fr) minmax(210px,1.35fr) minmax(100px,.65fr) minmax(260px,1.25fr) minmax(120px,.75fr)}.editor-grid.device-editor{grid-template-columns:repeat(4,minmax(0,1fr))}.editor-grid label,.query-panel label{display:grid;gap:7px}.multi-select-field,.date-range-field{position:relative;display:grid;gap:7px}.editor-grid label span,.query-panel label span,.multi-select-field>span,.date-range-field>span{color:#60695e;font-size:13px}.multi-select-trigger,.date-range-trigger{width:100%;height:40px;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 10px;border:1px solid #bcd5b0;border-radius:6px;background:#fff;color:#202622;cursor:pointer;text-align:left}.multi-select-trigger:focus,.date-range-trigger:focus{border-color:var(--brand);box-shadow:0 0 0 4px #16a34a2e;outline:none}.multi-select-trigger span:first-child,.date-range-trigger span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.multi-select-arrow{color:#697267;font-size:12px;line-height:1}.select-like-arrow{width:9px;height:9px;flex:0 0 auto;border-right:2px solid #1f2528;border-bottom:2px solid #1f2528;transform:rotate(45deg) translateY(-2px);opacity:.9}.multi-select-menu{position:absolute;z-index:30;top:calc(100% + 6px);left:0;right:0;max-height:260px;overflow:auto;padding:6px;border:1px solid var(--line);border-radius:6px;background:#fff;box-shadow:0 16px 34px #1f252824}.date-range-menu{position:absolute;z-index:30;top:calc(100% + 6px);left:0;width:340px;max-width:calc(100vw - 48px);padding:14px 16px 16px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:0 16px 34px #1f252824}.calendar-header{display:grid;grid-template-columns:36px 1fr 36px;align-items:center;gap:8px;margin-bottom:10px}.calendar-header strong,.calendar-title-button{color:#0f1f16;font-size:16px;text-align:left}.calendar-header button,.calendar-footer button{height:34px;border:0;border-radius:6px;background:transparent;color:#1557ff;font-size:16px;cursor:pointer}.calendar-header button{display:inline-flex;align-items:center;justify-content:center;color:#1f2528;font-size:24px;line-height:1}.calendar-header .calendar-title-button{justify-self:start;display:inline-flex;align-items:center;justify-content:flex-start;width:auto;max-width:100%;padding:0 8px;color:#0f1f16;font-size:16px;font-weight:800;line-height:1}.calendar-title-button:after{content:"";display:inline-block;margin-left:7px;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor}.calendar-header button:disabled{color:#b5bab4;cursor:not-allowed}.calendar-weekdays,.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}.calendar-weekdays{margin-bottom:6px}.calendar-weekdays span{height:30px;display:grid;place-items:center;color:#0f1f16;font-weight:700;font-size:14px}.calendar-grid{gap:2px}.month-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:8px 0 10px}.month-option{height:38px;border:0;border-radius:6px;background:#f4f8f1;color:#111827;font-size:15px;cursor:pointer}.month-option:hover:not(:disabled){background:var(--blue-soft);color:var(--blue)}.month-option.selected{background:var(--blue);color:#fff;font-weight:800;box-shadow:inset 0 0 0 2px #0b2e93}.month-option:disabled{color:#c4c9c6;background:#f4f5f3;cursor:not-allowed}.calendar-day{height:34px;border:0;border-radius:4px;background:transparent;color:#111827;font-size:15px;cursor:pointer}.calendar-day:hover:not(:disabled){background:var(--blue-soft);color:var(--blue)}.calendar-day.muted{color:#aab0ad}.calendar-day.in-range{background:#dbe6ff;color:#123ac8}.calendar-day.selected{background:var(--blue);color:#fff;font-weight:800;box-shadow:inset 0 0 0 2px #0b2e93}.calendar-day.today:not(.selected){box-shadow:inset 0 0 0 1px var(--blue)}.calendar-day:disabled{color:#c4c9c6;cursor:not-allowed}.calendar-footer{display:flex;align-items:center;justify-content:space-between;margin-top:12px}.query-panel label.multi-select-option,.multi-select-option{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:5px;color:#202622;font-size:14px;cursor:pointer}.query-panel label.multi-select-option:hover,.multi-select-option:hover{background:linear-gradient(90deg,var(--brand-soft),var(--blue-soft))}.multi-select-option input{width:16px;height:16px;flex:0 0 auto;accent-color:#346538}.multi-select-option span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.form-actions{align-self:end}.table-wrap{width:100%;overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}th,td{padding:13px 16px;border-bottom:1px solid var(--line-soft);text-align:left;vertical-align:top;white-space:nowrap}th{color:#687166;font-weight:600;background:linear-gradient(180deg,#f7fff6,#dff5df);color:#25451f}tbody tr:hover{background:#ddf8df}.mono{font-family:Consolas,SF Mono,monospace}.badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;font-size:12px;line-height:1}.badge.ok{background:linear-gradient(90deg,var(--brand-soft),#e7ffea);color:var(--brand)}.badge.muted{background:#f2f0ec;color:#766f65}.row-actions button{border:1px solid var(--line);border-radius:5px;background:#fff;color:#28302b;padding:6px 9px}.data-chip-row{display:flex;flex-wrap:wrap;gap:6px;min-width:360px;max-width:760px}.data-chip{padding:5px 8px;border:1px solid var(--line-soft);border-radius:6px;background:linear-gradient(180deg,#fff,#ecffe8);color:#495148;white-space:nowrap}.data-chip b{color:#1f2528}.empty-cell{color:#7b8378;text-align:center}.error-toast{position:fixed;right:24px;bottom:24px;max-width:420px;margin:0;padding:12px 14px;border:1px solid #f0c7c4;border-radius:8px;background:#fdebec;color:#9f2f2d;box-shadow:0 12px 32px #9f2f2d1f}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:grid;place-items:center;background:rgba(31,37,40,.24);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.confirm-card{width:min(400px,90vw);padding:28px 32px;border:1px solid var(--line);border-radius:10px;background:#fff;box-shadow:0 18px 48px #1f25282e}.confirm-card p{margin:0 0 22px;font-size:15px;color:#1f2528;line-height:1.6}.confirm-actions{display:flex;justify-content:flex-end;gap:12px}.button.danger{border-color:#c74a46;background:#c74a46;color:#fff}.button.danger:hover{background:#b03a36}.confirm-fade-enter-active,.confirm-fade-leave-active{transition:opacity .22s cubic-bezier(.16,1,.3,1)}.confirm-fade-enter-from,.confirm-fade-leave-to{opacity:0}@media (max-width: 1100px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto}.metric-grid,.chart-summary,.split-grid,.editor-grid,.editor-grid.device-editor,.query-panel{grid-template-columns:1fr}.topbar{flex-direction:column}.topbar-actions,.search-input,.date-range-menu{width:100%}}
