@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/ba9851c3c22cd980-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/21350d82a1f187e9-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Inter_Fallback_f367f3;src:local("Arial");ascent-override:90.49%;descent-override:22.56%;line-gap-override:0.00%;size-adjust:107.06%}.__className_f367f3{font-family:__Inter_f367f3,__Inter_Fallback_f367f3;font-style:normal}.__variable_f367f3{--font-sans:"__Inter_f367f3","__Inter_Fallback_f367f3"}@font-face{font-family:__JetBrains_Mono_3c557b;font-style:normal;font-weight:100 800;font-display:swap;src:url(/_next/static/media/886030b0b59bc5a7-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__JetBrains_Mono_3c557b;font-style:normal;font-weight:100 800;font-display:swap;src:url(/_next/static/media/0aa834ed78bf6d07-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__JetBrains_Mono_3c557b;font-style:normal;font-weight:100 800;font-display:swap;src:url(/_next/static/media/67957d42bae0796d-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:__JetBrains_Mono_3c557b;font-style:normal;font-weight:100 800;font-display:swap;src:url(/_next/static/media/f911b923c6adde36-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__JetBrains_Mono_3c557b;font-style:normal;font-weight:100 800;font-display:swap;src:url(/_next/static/media/939c4f875ee75fbb-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__JetBrains_Mono_3c557b;font-style:normal;font-weight:100 800;font-display:swap;src:url(/_next/static/media/bb3ef058b751a6ad-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__JetBrains_Mono_Fallback_3c557b;src:local("Arial");ascent-override:75.79%;descent-override:22.29%;line-gap-override:0.00%;size-adjust:134.59%}.__className_3c557b{font-family:__JetBrains_Mono_3c557b,__JetBrains_Mono_Fallback_3c557b;font-style:normal}.__variable_3c557b{--font-mono:"__JetBrains_Mono_3c557b","__JetBrains_Mono_Fallback_3c557b"}:root{--bg:oklch(98.5% 0.004 240);--surface:oklch(100% 0 0);--surface-2:oklch(97% 0.005 240);--surface-3:oklch(94% 0.007 240);--border:oklch(91% 0.008 240);--border-strong:oklch(85% 0.01 240);--text:oklch(22% 0.02 250);--text-2:oklch(45% 0.015 250);--text-3:oklch(60% 0.012 250);--text-muted:oklch(72% 0.01 250);--brand:oklch(52% 0.16 252);--brand-2:oklch(45% 0.18 252);--brand-soft:oklch(95% 0.03 252);--brand-ink:oklch(28% 0.1 252);--ok:oklch(62% 0.15 152);--ok-soft:oklch(95% 0.04 152);--warn:oklch(72% 0.16 75);--warn-soft:oklch(96% 0.05 75);--danger:oklch(58% 0.21 27);--danger-soft:oklch(96% 0.04 27);--info:oklch(60% 0.13 230);--info-soft:oklch(96% 0.03 230);--shadow-sm:0 1px 2px oklch(20% 0.02 250/0.04),0 1px 1px oklch(20% 0.02 250/0.03);--shadow:0 1px 3px oklch(20% 0.02 250/0.06),0 4px 12px oklch(20% 0.02 250/0.05);--shadow-lg:0 4px 8px oklch(20% 0.02 250/0.08),0 16px 40px oklch(20% 0.02 250/0.1);--radius:10px;--radius-sm:6px;--radius-lg:14px;--sidebar-w:240px;--topbar-h:60px;--font-sans:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono","SF Mono",Consolas,monospace}*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;font-feature-settings:"cv11","ss01"}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;padding:0}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}.sidebar{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:-webkit-sticky;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:10px;padding:18px 18px 16px;border-bottom:1px solid var(--border)}.brand-mark{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--brand) 0,var(--brand-2) 100%);display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px;letter-spacing:.02em;box-shadow:inset 0 1px 0 hsla(0,0%,100%,.2)}.brand-text{display:flex;flex-direction:column;line-height:1.15}.brand-name{font-weight:600;font-size:13.5px;color:var(--text)}.brand-sub{font-size:11px;color:var(--text-3)}.nav{padding:12px 10px;flex:1 1}.nav-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:12px 10px 6px;font-weight:600}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);font-size:13px;color:var(--text-2);width:100%;text-align:left;font-weight:500;transition:background .12s,color .12s}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:var(--brand-soft);color:var(--brand-ink)}.nav-item.active .nav-icon{color:var(--brand)}.nav-icon{width:16px;height:16px;color:var(--text-3);flex-shrink:0}.nav-badge{margin-left:auto;background:var(--danger);color:#fff;font-size:10px;font-weight:600;padding:1px 6px;border-radius:10px;font-family:var(--font-mono)}.sidebar-foot{padding:12px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px}.avatar{width:30px;height:30px;border-radius:50%;background:var(--surface-3);display:grid;place-items:center;font-size:11px;font-weight:600;color:var(--text-2)}.user-meta{display:flex;flex-direction:column;line-height:1.2}.user-name{font-size:12.5px;font-weight:500}.user-role{font-size:11px;color:var(--text-3)}.main{display:flex;flex-direction:column;min-width:0}.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 28px;gap:16px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.page-title{font-size:18px;font-weight:600;letter-spacing:-.01em}.page-sub{font-size:12.5px;color:var(--text-3);margin-top:2px}.topbar-spacer{flex:1 1}.live-pill{display:inline-flex;align-items:center;gap:7px;padding:5px 11px 5px 9px;background:var(--ok-soft);color:oklch(35% .12 152);border-radius:999px;font-size:11.5px;font-weight:600;font-family:var(--font-mono)}.live-dot{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 0 oklch(62% .15 152/.6);animation:pulse 1.8s infinite}@keyframes pulse{0%{box-shadow:0 0 0 0 oklch(62% .15 152/.5)}70%{box-shadow:0 0 0 6px oklch(62% .15 152/0)}to{box-shadow:0 0 0 0 oklch(62% .15 152/0)}}.fetch-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-left:8px;color:var(--text-3);opacity:0;transition:opacity .15s ease}.fetch-icon.active{opacity:.8}.fetch-icon.active svg{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.icon-btn{width:34px;height:34px;border-radius:var(--radius-sm);display:grid;place-items:center;color:var(--text-2);position:relative}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.icon-btn .dot{position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--danger);border:2px solid var(--surface)}.content{padding:24px 28px 48px;max-width:1600px;width:100%;margin:0 auto}.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:14px;gap:14px;margin-bottom:18px}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;flex-direction:column;gap:4px}.kpi-label{font-size:11.5px;color:var(--text-3);font-weight:500;text-transform:uppercase;letter-spacing:.04em}.kpi-value{font-family:var(--font-mono);font-size:22px;font-weight:500;letter-spacing:-.01em;color:var(--text)}.kpi-meta{font-size:12px;color:var(--text-3);display:flex;align-items:center;gap:6px}.kpi-meta .delta{color:var(--ok);font-weight:600}.kpi-meta .delta.down{color:var(--danger)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.card-title{font-size:13.5px;font-weight:600;color:var(--text)}.card-sub{font-size:11.5px;color:var(--text-3);margin-top:2px}.card-body{padding:16px 18px}.machines-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:14px;gap:14px;margin-bottom:18px}.machine{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s}.machine:hover{border-color:var(--border-strong);box-shadow:var(--shadow)}.machine-head{padding:14px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.machine-icon{width:38px;height:38px;border-radius:9px;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-2);flex-shrink:0}.machine-titlewrap{flex:1 1;min-width:0}.machine-name{font-size:14px;font-weight:600;letter-spacing:-.005em}.machine-meta{font-size:11.5px;color:var(--text-3);margin-top:1px}.machine-meta,.status-badge{font-family:var(--font-mono)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 8px 4px 7px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.status-badge .sb-dot{width:6px;height:6px;border-radius:50%}.status-badge.running{background:var(--ok-soft);color:oklch(35% .12 152)}.status-badge.running .sb-dot{background:var(--ok)}.status-badge.warn{background:var(--warn-soft);color:oklch(45% .13 75)}.status-badge.warn .sb-dot{background:var(--warn)}.status-badge.alert{background:var(--danger-soft);color:oklch(40% .18 27)}.status-badge.alert .sb-dot{background:var(--danger);animation:pulse 1.5s infinite}.status-badge.idle{background:var(--surface-3);color:var(--text-3)}.status-badge.idle .sb-dot{background:var(--text-3)}.machine-body{padding:16px;display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px}.sensor{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}.sensor.alert{background:var(--danger-soft);border-color:oklch(85% .08 27)}.sensor-head{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.sensor-icon{width:13px;height:13px}.sensor-value{font-family:var(--font-mono);font-size:26px;font-weight:500;letter-spacing:-.02em;color:var(--text);display:flex;align-items:baseline;gap:4px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.sensor-unit{font-size:13px;color:var(--text-3);font-weight:400}.sensor.alert .sensor-value{color:oklch(40% .18 27)}.spark{display:flex;align-items:flex-end;gap:2px;height:22px}.spark .bar{flex:1 1;background:var(--brand);border-radius:1px;min-height:2px;opacity:.7}.sensor.alert .spark .bar{background:var(--danger)}.sensor-range{font-size:10.5px;color:var(--text-muted);font-family:var(--font-mono);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.machine-foot,.sensor-range{display:flex;justify-content:space-between}.machine-foot{padding:12px 16px;border-top:1px solid var(--border);background:var(--surface-2);align-items:center;gap:12px}.runtime{font-size:11.5px;color:var(--text-3);font-family:var(--font-mono);display:flex;gap:6px}.btn,.runtime{align-items:center}.btn{display:inline-flex;gap:7px;padding:7px 13px;border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;border:1px solid var(--border);background:var(--surface);color:var(--text);transition:background .12s,border-color .12s,transform .05s}.btn:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn:active{transform:translateY(.5px)}.btn.primary{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:0 1px 0 oklch(40% .18 252/.25)}.btn.primary:hover{background:var(--brand-2);border-color:var(--brand-2)}.btn.danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn.danger:hover{background:oklch(50% .21 27);border-color:oklch(50% .21 27)}.btn.ghost{background:transparent}.btn.sm{padding:5px 10px;font-size:12px}.btn.icon-only{padding:7px}.btn.pump-active{background:var(--ok);border-color:var(--ok);color:#fff}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);padding:0 18px;background:var(--surface);border-radius:var(--radius) var(--radius) 0 0}.tab{padding:12px 14px;font-size:13px;font-weight:500;color:var(--text-3);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s,border-color .12s}.tab:hover{color:var(--text)}.tab.active{color:var(--brand);border-bottom-color:var(--brand)}.chart-wrap{position:relative;width:100%;height:280px}.chart-wrap.lg{height:360px}.chart-wrap svg{width:100%;height:100%;display:block}.chart-legend{display:flex;gap:14px;padding:10px 18px 0;font-size:12px;color:var(--text-2)}.legend-item{display:flex;align-items:center;gap:6px}.legend-swatch{width:10px;height:10px;border-radius:2px}.range-pills{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:7px;padding:2px}.range-pill{padding:4px 10px;font-size:11.5px;font-weight:500;color:var(--text-3);border-radius:5px;font-family:var(--font-mono)}.range-pill.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.alerts-grid{display:grid;grid-template-columns:1fr 320px;grid-gap:14px;gap:14px}.alert-row{display:grid;grid-template-columns:24px 1fr auto auto;grid-gap:14px;gap:14px;padding:12px 18px;border-bottom:1px solid var(--border);align-items:center;font-size:13px}.alert-row:last-child{border-bottom:none}.alert-row:hover{background:var(--surface-2)}.alert-icon{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:11px;flex-shrink:0}.alert-icon.crit{background:var(--danger-soft);color:var(--danger)}.alert-icon.warn{background:var(--warn-soft);color:oklch(50% .16 75)}.alert-icon.info{background:var(--info-soft);color:var(--info)}.alert-icon.ok{background:var(--ok-soft);color:var(--ok)}.alert-msg{color:var(--text);font-weight:500}.alert-meta{margin-top:2px}.alert-meta,.alert-time{font-size:11.5px;color:var(--text-3);font-family:var(--font-mono)}.toast-stack{position:fixed;top:20px;right:20px;display:flex;flex-direction:column;gap:10px;z-index:100;pointer-events:none}.toast{pointer-events:auto;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--danger);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:12px 14px;width:340px;display:grid;grid-template-columns:28px 1fr auto;grid-gap:10px;gap:10px;align-items:start;animation:toast-in .3s cubic-bezier(.2,.9,.25,1)}.toast.warn{border-left-color:var(--warn)}.toast.info{border-left-color:var(--info)}.toast.ok{border-left-color:var(--ok)}.toast.leaving{animation:toast-out .25s forwards}@keyframes toast-in{0%{opacity:0;transform:translateX(20px) scale(.96)}to{opacity:1;transform:translateX(0) scale(1)}}@keyframes toast-out{to{opacity:0;transform:translateX(20px) scale(.96)}}.toast-title{font-size:12.5px;font-weight:600;color:var(--text)}.toast-body{font-size:12px;color:var(--text-2);margin-top:2px}.toast-time{font-size:11px;font-family:var(--font-mono);color:var(--text-3);margin-top:4px}.toast-close{color:var(--text-muted);padding:2px}.toast-close:hover{color:var(--text)}.divider{height:1px;background:var(--border);margin:16px 0}.row{display:flex;align-items:center;gap:10px}.gap-sm{gap:6px}.spacer{flex:1 1}.empty{padding:60px 20px;text-align:center;color:var(--text-3);font-size:13px}.section-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin:4px 0 12px}.scroll-area{max-height:480px;overflow-y:auto}.scroll-area::-webkit-scrollbar{width:8px}.scroll-area::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}.history-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px}.history-grid.full{grid-template-columns:1fr}.machine-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}.mtab{padding:8px 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface);font-size:12.5px;font-weight:500;color:var(--text-2);display:inline-flex;align-items:center;gap:8px}.mtab:hover{border-color:var(--border-strong)}.mtab.active{background:var(--brand-soft);border-color:oklch(85% .06 252);color:var(--brand-ink)}.mtab .mtab-dot{width:8px;height:8px;border-radius:50%;background:var(--ok)}.mtab .mtab-dot.warn{background:var(--warn)}.mtab .mtab-dot.alert{background:var(--danger)}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:14px;gap:14px;margin-bottom:14px}table.alert-table{width:100%;border-collapse:collapse}table.alert-table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);font-weight:600;padding:10px 18px;border-bottom:1px solid var(--border);background:var(--surface-2)}table.alert-table td{padding:12px 18px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:top}table.alert-table tr:hover{background:var(--surface-2)}table.alert-table tr:last-child td{border-bottom:none}.filter-bar{padding:12px 18px;border-bottom:1px solid var(--border)}.filter-bar,.search{display:flex;gap:8px;align-items:center}.search{padding:6px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);flex:1 1;max-width:280px}.search input{border:none;background:none;outline:none;font-family:inherit;font-size:12.5px;color:var(--text);width:100%}.search input::placeholder{color:var(--text-muted)}.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600;font-family:var(--font-mono);background:var(--surface-3);color:var(--text-2)}.chip.crit{background:var(--danger-soft);color:oklch(40% .18 27)}.chip.warn{background:var(--warn-soft);color:oklch(45% .14 75)}.chip.info{background:var(--info-soft);color:oklch(35% .12 230)}.chip.ok{background:var(--ok-soft);color:oklch(35% .12 152)}