:root{--industrial-bg: #f2f5f9;--industrial-bg-secondary: #ffffff;--industrial-bg-card: #ffffff;--metal-dark: #e8edf3;--metal-mid: #d9e1ea;--metal-light: #c8d2de;--metal-bright: #8b99aa;--industrial-yellow: #f59e0b;--industrial-yellow-glow: rgba(245, 158, 11, .28);--industrial-orange: #f97316;--industrial-red: #dc2626;--industrial-green: #16a34a;--industrial-green-glow: rgba(22, 163, 74, .3);--industrial-blue: #0ea5e9;--industrial-blue-glow: rgba(14, 165, 233, .28);--text-primary: #0f172a;--text-secondary: #334155;--text-muted: #64748b;--border-color: #d9e1ea;--border-bright: #b8c4d3;--font-display: "JetBrains Mono", "Consolas", "Monaco", monospace;--font-body: "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);color:var(--text-primary);background:radial-gradient(circle at 10% 10%,rgba(14,165,233,.1),transparent 40%),radial-gradient(circle at 90% 10%,rgba(245,158,11,.12),transparent 45%),linear-gradient(180deg,#f8fafc,#eef3f8);min-height:100vh}.app-shell{min-height:100vh;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:100;background:#ffffffd1;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid rgba(185,197,212,.7)}.topbar-inner{max-width:1440px;margin:0 auto;padding:12px 24px;display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:12px;align-items:center}.brand{display:flex;align-items:center;gap:12px}.brand-mark{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,#0ea5e9,#0369a1);box-shadow:0 10px 24px #0ea5e94d}.brand-mark svg{width:24px;height:24px}.brand-text{display:flex;flex-direction:column;gap:2px}.brand-title{font-size:16px;font-weight:700;letter-spacing:.2px}.brand-sub{font-size:11px;color:var(--text-muted);font-family:var(--font-display)}.primary-nav{display:flex;justify-content:center;gap:8px}.nav-chip{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;text-decoration:none;color:var(--text-secondary);border:1px solid transparent;transition:.22s ease}.nav-chip:hover{background:#0ea5e91a;color:#0369a1}.nav-chip.active{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;border-color:transparent;box-shadow:0 10px 20px #0284c740}.chip-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center}.chip-icon svg{width:100%;height:100%}.chip-label{font-size:13px;font-weight:600}.account-panel{display:flex;justify-content:flex-end;align-items:center;gap:10px}.role-badge{border-radius:999px;padding:3px 9px;font-size:11px;font-weight:700;letter-spacing:.6px}.role-badge.admin{background:#f59e0b24;color:#92400e}.role-badge.maintenance{background:#0ea5e91f;color:#075985}.role-badge.operator{background:#16a34a1f;color:#166534}.role-badge.machine{background:#3341551f;color:#334155}.account-name{font-size:13px;font-weight:600;color:var(--text-secondary)}.icon-btn{width:34px;height:34px;border-radius:10px;border:1px solid var(--border-color);background:#fff;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.24s ease;box-shadow:0 6px 14px #0f172a0f;color:#1f2937}.icon-btn:hover{border-color:#7dd3fc;color:#0369a1;transform:translateY(-2px) scale(1.02);box-shadow:0 12px 22px #0ea5e933}.icon-btn.danger:hover{border-color:#fca5a5;color:#b91c1c;box-shadow:0 12px 20px #dc26262e}.icon-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;position:relative;z-index:1;opacity:.35}.switch-btn:after,.logout-btn:after{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;line-height:1;z-index:2;pointer-events:none}.switch-btn:after{content:"⇄";color:#0f172a}.logout-btn:after{content:"⎋";color:#b91c1c}.icon-btn.danger{border-color:#fecaca;color:#b91c1c;background:linear-gradient(180deg,#fff,#fff5f5)}.icon-btn.danger:hover{background:linear-gradient(180deg,#fff,#ffe8e8)}.app-main{flex:1;width:100%;max-width:1440px;margin:0 auto;padding:24px}.status-footer{border-top:1px solid rgba(185,197,212,.7);background:#ffffffbf;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.status-inner{max-width:1440px;margin:0 auto;padding:10px 24px;display:flex;justify-content:space-between;align-items:center;color:var(--text-muted);font-family:var(--font-display);font-size:11px}.status-left{display:flex;align-items:center;gap:8px;color:#166534}.status-pulse{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 #22c55e66;animation:pulse 1.8s infinite}@keyframes pulse{0%{box-shadow:0 0 #22c55e59}70%{box-shadow:0 0 0 10px #22c55e00}to{box-shadow:0 0 #22c55e00}}.card{background:linear-gradient(180deg,#fffffff2,#ffffffe6);border:1px solid rgba(185,197,212,.72);border-radius:18px;padding:22px;box-shadow:0 18px 40px #0f172a12;position:relative;transition:transform .26s ease,box-shadow .26s ease}.card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:18px;padding:1px;background:linear-gradient(135deg,#0ea5e92e,#f59e0b2e);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.card h3{margin-bottom:14px;font-size:14px;font-weight:700;letter-spacing:.6px;color:#0f172a;text-transform:uppercase}.card:hover{transform:translateY(-3px);box-shadow:0 22px 42px #0f172a1a}.form-item label{color:#475569;font-size:12px;font-weight:600;margin-bottom:7px}.form-item input,.form-item select{width:100%;background:#fff;border:1px solid #d7e0ea;border-radius:12px;color:#0f172a;padding:11px 12px;transition:.2s ease}.form-item input:focus,.form-item select:focus{outline:none;border-color:#38bdf8;box-shadow:0 0 0 4px #38bdf82e}button{border-radius:12px;border:1px solid #d7e0ea;background:#fff;color:#1e293b;font-weight:600;padding:10px 16px;transition:transform .22s ease,box-shadow .22s ease,filter .22s ease;position:relative;overflow:hidden}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 18px #0f172a17;filter:saturate(1.08)}button:active:not(:disabled){transform:translateY(0)}button:focus-visible{outline:0;box-shadow:0 0 0 4px #0ea5e933}.btn-primary{border:0;color:#fff;background:linear-gradient(135deg,#0ea5e9,#0284c7)}.btn-primary:hover:not(:disabled){box-shadow:0 12px 26px #0ea5e959}.btn-primary:before,.btn-danger:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(112deg,transparent 0%,rgba(255,255,255,.34) 50%,transparent 100%);transform:translate(-130%);transition:transform .45s ease}.btn-primary:hover:before,.btn-danger:hover:before{transform:translate(130%)}.btn-danger{background:#fff;border-color:#fecaca;color:#b91c1c}.btn-icon{display:inline-flex;align-items:center;justify-content:center}.btn-icon svg,.title-icon svg,.chip-icon svg{stroke-linecap:round;stroke-linejoin:round}.tag{border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700}@media (max-width: 1200px){.topbar-inner{grid-template-columns:1fr;gap:10px}.primary-nav{justify-content:flex-start;flex-wrap:wrap}.account-panel{justify-content:flex-start}}@media (max-width: 768px){.app-main{padding:16px}.chip-label,.account-name,.status-center{display:none}.primary-nav{gap:6px}.nav-chip{padding:8px}.status-inner{justify-content:space-between}}.dashboard[data-v-628dfe60]{max-width:1400px;margin:0 auto}.page-header[data-v-628dfe60]{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.page-title[data-v-628dfe60]{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.title-icon[data-v-628dfe60]{width:32px;height:32px;background:linear-gradient(135deg,var(--industrial-yellow) 0%,#e09400 100%);border-radius:4px;display:flex;align-items:center;justify-content:center;color:#000}.title-icon svg[data-v-628dfe60]{width:20px;height:20px}.page-subtitle[data-v-628dfe60]{font-family:var(--font-display);font-size:12px;color:var(--text-muted);letter-spacing:2px}.container[data-v-628dfe60]{display:grid;grid-template-columns:1fr 1fr;gap:24px}.input-card[data-v-628dfe60]:after{content:"INPUT";position:absolute;top:20px;right:20px;font-family:var(--font-display);font-size:10px;color:var(--text-muted);letter-spacing:2px;opacity:.5}.form-row[data-v-628dfe60]{display:grid;grid-template-columns:1fr 1fr;gap:16px}.label-icon[data-v-628dfe60]{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--metal-dark);border-radius:3px;margin-right:6px;font-size:10px;color:var(--industrial-yellow)}.input-with-unit[data-v-628dfe60]{position:relative;display:flex;align-items:center}.input-with-unit input[data-v-628dfe60]{padding-right:45px}.unit[data-v-628dfe60]{position:absolute;right:12px;font-family:var(--font-display);font-size:12px;color:var(--text-muted);pointer-events:none}.digital-input[data-v-628dfe60]{font-family:var(--font-display);font-variant-numeric:tabular-nums;font-size:16px;letter-spacing:.5px}.form-actions[data-v-628dfe60]{display:flex;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color)}.btn-secondary[data-v-628dfe60]{display:flex;align-items:center;gap:6px;background:var(--metal-dark)}.btn-icon[data-v-628dfe60]{font-size:14px}.result-card[data-v-628dfe60]:after{content:"OUTPUT";position:absolute;top:20px;right:20px;font-family:var(--font-display);font-size:10px;color:var(--text-muted);letter-spacing:2px;opacity:.5}.empty-state[data-v-628dfe60]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-icon[data-v-628dfe60]{width:64px;height:64px;color:var(--text-muted);margin-bottom:16px;opacity:.5}.empty-icon svg[data-v-628dfe60]{width:100%;height:100%}.empty-state p[data-v-628dfe60]{color:var(--text-secondary);font-size:14px;margin-bottom:8px}.empty-hint[data-v-628dfe60]{font-family:var(--font-display);font-size:11px;color:var(--text-muted);letter-spacing:1px}.result-content[data-v-628dfe60]{display:flex;flex-direction:column;gap:16px}.result-highlight[data-v-628dfe60]{background:linear-gradient(135deg,#00d4ff1a,#00d4ff0d);border:1px solid var(--industrial-blue);border-radius:4px;padding:24px;text-align:center;position:relative;overflow:hidden}.result-highlight[data-v-628dfe60]:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--industrial-blue);box-shadow:0 0 20px var(--industrial-blue-glow)}.highlight-label[data-v-628dfe60]{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.highlight-value[data-v-628dfe60]{font-size:48px;font-weight:600;color:var(--industrial-blue);text-shadow:0 0 30px var(--industrial-blue-glow);line-height:1.2}.compensation-badge[data-v-628dfe60]{display:inline-flex;align-items:center;gap:4px;margin-top:12px;padding:6px 14px;border-radius:4px;font-family:var(--font-display);font-size:13px;font-weight:600}.compensation-badge.positive[data-v-628dfe60]{background:#22c55e1a;border:1px solid var(--industrial-green);color:var(--industrial-green)}.compensation-badge.negative[data-v-628dfe60]{background:#f5a6231a;border:1px solid var(--industrial-yellow);color:var(--industrial-yellow)}.explanation-box[data-v-628dfe60]{background:var(--industrial-bg);border:1px solid var(--border-color);border-radius:4px;padding:16px}.box-header[data-v-628dfe60]{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:600;color:var(--industrial-yellow);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.box-icon[data-v-628dfe60]{width:16px;height:16px;background:#f5a6231a;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px}.explanation-box p[data-v-628dfe60]{font-size:13px;color:var(--text-secondary);line-height:1.6;margin:0}.params-panel[data-v-628dfe60]{background:var(--industrial-bg);border:1px solid var(--border-color);border-radius:4px;padding:16px}.panel-header[data-v-628dfe60]{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.panel-grid[data-v-628dfe60]{display:grid;grid-template-columns:1fr 1fr;gap:12px}.panel-item[data-v-628dfe60]{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--industrial-bg-secondary);border-radius:3px}.item-label[data-v-628dfe60]{font-size:11px;color:var(--text-muted);text-transform:uppercase}.item-value[data-v-628dfe60]{font-size:13px;font-weight:500;color:var(--text-primary)}.btn-submit[data-v-628dfe60]{width:100%;padding:14px;font-size:14px}.warning-hint[data-v-628dfe60]{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:#f5a6230d;border:1px dashed var(--industrial-yellow);border-radius:4px;font-size:12px;color:var(--industrial-yellow)}.warning-icon[data-v-628dfe60]{font-size:14px}@media (max-width: 768px){.container[data-v-628dfe60],.form-row[data-v-628dfe60]{grid-template-columns:1fr}.highlight-value[data-v-628dfe60]{font-size:36px}.panel-grid[data-v-628dfe60]{grid-template-columns:1fr}}.dashboard .card[data-v-628dfe60]{border-radius:18px}.label-icon[data-v-628dfe60],.box-icon[data-v-628dfe60],.panel-icon[data-v-628dfe60],.warning-icon[data-v-628dfe60],.btn-icon[data-v-628dfe60]{display:inline-flex;align-items:center;justify-content:center;font-weight:700}.form-actions button[data-v-628dfe60],.btn-submit[data-v-628dfe60]{border-radius:12px;position:relative;overflow:hidden}.form-actions button[data-v-628dfe60]:before,.btn-submit[data-v-628dfe60]:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);transform:translate(-125%);transition:transform .45s ease}.form-actions button[data-v-628dfe60]:hover:before,.btn-submit[data-v-628dfe60]:hover:before{transform:translate(125%)}.result-highlight[data-v-628dfe60]{box-shadow:0 16px 30px #0ea5e929}.device[data-v-4ad747b3]{max-width:1400px;margin:0 auto}.page-header[data-v-4ad747b3]{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.page-title[data-v-4ad747b3]{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.title-icon[data-v-4ad747b3]{width:32px;height:32px;background:linear-gradient(135deg,var(--industrial-yellow) 0%,#e09400 100%);border-radius:4px;display:flex;align-items:center;justify-content:center;color:#000}.title-icon svg[data-v-4ad747b3]{width:20px;height:20px}.page-subtitle[data-v-4ad747b3]{font-family:var(--font-display);font-size:12px;color:var(--text-muted);letter-spacing:2px}.container[data-v-4ad747b3]{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:24px}.status-card[data-v-4ad747b3]:after{content:"STATUS";position:absolute;top:20px;right:20px;font-family:var(--font-display);font-size:10px;color:var(--text-muted);letter-spacing:2px;opacity:.5}.status-display[data-v-4ad747b3]{display:flex;flex-direction:column;align-items:center;padding:20px 0}.status-indicator[data-v-4ad747b3]{display:flex;flex-direction:column;align-items:center;gap:16px}.indicator-ring[data-v-4ad747b3]{width:100px;height:100px;border-radius:50%;background:conic-gradient(from 0deg,var(--metal-dark),var(--metal-mid),var(--metal-dark));display:flex;align-items:center;justify-content:center;position:relative}.indicator-core[data-v-4ad747b3]{width:84px;height:84px;border-radius:50%;background:var(--industrial-bg);display:flex;align-items:center;justify-content:center}.status-icon[data-v-4ad747b3]{width:40px;height:40px;display:flex;align-items:center;justify-content:center}.status-icon svg[data-v-4ad747b3]{width:100%;height:100%}.status-icon.online[data-v-4ad747b3]{color:var(--industrial-green);filter:drop-shadow(0 0 10px var(--industrial-green-glow))}.status-icon.offline[data-v-4ad747b3]{color:var(--industrial-red);opacity:.6}.status-label[data-v-4ad747b3]{font-size:14px;font-weight:600;padding:8px 20px;border-radius:4px;text-transform:uppercase;letter-spacing:1px}.status-label.online[data-v-4ad747b3],.status-label.idle[data-v-4ad747b3]{background:#22c55e1a;border:1px solid var(--industrial-green);color:var(--industrial-green)}.status-label.running[data-v-4ad747b3]{background:#00d4ff1a;border:1px solid var(--industrial-blue);color:var(--industrial-blue);animation:pulse-glow-4ad747b3 1.5s infinite}@keyframes pulse-glow-4ad747b3{0%,to{box-shadow:0 0 10px #00d4ff33}50%{box-shadow:0 0 20px #00d4ff66}}.status-label.completed[data-v-4ad747b3]{background:#22c55e1a;border:1px solid var(--industrial-green);color:var(--industrial-green)}.status-label.error[data-v-4ad747b3]{background:#ef44441a;border:1px solid var(--industrial-red);color:var(--industrial-red)}.connection-status[data-v-4ad747b3]{display:flex;align-items:center;gap:8px;font-size:12px;font-family:var(--font-display)}.connection-status.online[data-v-4ad747b3]{color:var(--industrial-green)}.connection-status.offline[data-v-4ad747b3]{color:var(--text-muted)}.connection-dot[data-v-4ad747b3]{width:8px;height:8px;border-radius:50%;background:currentColor}.connection-status.online .connection-dot[data-v-4ad747b3]{box-shadow:0 0 10px currentColor;animation:blink-4ad747b3 1s infinite}@keyframes blink-4ad747b3{0%,to{opacity:1}50%{opacity:.4}}.info-panel[data-v-4ad747b3]{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color)}.info-row[data-v-4ad747b3]{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-color)}.info-row[data-v-4ad747b3]:last-child{border-bottom:none}.info-label[data-v-4ad747b3]{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.info-value[data-v-4ad747b3]{font-size:13px;font-weight:500;color:var(--text-primary)}.angle-card[data-v-4ad747b3]:after{content:"MONITOR";position:absolute;top:20px;right:20px;font-family:var(--font-display);font-size:10px;color:var(--text-muted);letter-spacing:2px;opacity:.5}.angle-grid[data-v-4ad747b3]{display:flex;flex-direction:column;gap:16px}.angle-box[data-v-4ad747b3]{background:var(--industrial-bg);border:1px solid var(--border-color);border-radius:4px;padding:16px;position:relative;overflow:hidden}.angle-box[data-v-4ad747b3]:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--industrial-blue)}.angle-header[data-v-4ad747b3]{display:flex;align-items:center;gap:8px;margin-bottom:12px}.angle-title[data-v-4ad747b3]{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.angle-value[data-v-4ad747b3]{font-size:32px;font-weight:600;color:var(--text-secondary);margin-bottom:12px}.angle-value.has-value[data-v-4ad747b3]{color:var(--industrial-blue);text-shadow:0 0 20px var(--industrial-blue-glow)}.angle-value.good[data-v-4ad747b3]{color:var(--industrial-green);text-shadow:0 0 20px var(--industrial-green-glow)}.angle-value.warning[data-v-4ad747b3]{color:var(--industrial-yellow)}.angle-value.error[data-v-4ad747b3]{color:var(--industrial-red)}.angle-bar[data-v-4ad747b3]{height:4px;background:var(--metal-dark);border-radius:2px;overflow:hidden}.bar-fill[data-v-4ad747b3]{height:100%;background:linear-gradient(90deg,var(--industrial-blue),#4ddbff);border-radius:2px;transition:width .5s ease}.bar-fill.actual[data-v-4ad747b3]{background:linear-gradient(90deg,var(--industrial-green),#4ade80)}.deviation-box[data-v-4ad747b3]:before{background:var(--industrial-yellow)}.deviation-indicator[data-v-4ad747b3]{padding:8px 0}.indicator-scale[data-v-4ad747b3]{height:6px;background:linear-gradient(90deg,var(--industrial-red) 0%,var(--industrial-yellow) 50%,var(--industrial-red) 100%);border-radius:3px;position:relative}.scale-marker[data-v-4ad747b3]{position:absolute;top:-3px;width:12px;height:12px;background:#fff;border-radius:50%;transform:translate(-50%);box-shadow:0 0 10px #ffffff80}.control-card[data-v-4ad747b3]:after{content:"CONTROL";position:absolute;top:20px;right:20px;font-family:var(--font-display);font-size:10px;color:var(--text-muted);letter-spacing:2px;opacity:.5}.control-grid[data-v-4ad747b3]{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.control-btn[data-v-4ad747b3]{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--industrial-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);text-align:left;transition:all .3s ease}.control-btn[data-v-4ad747b3]:hover:not(:disabled){background:var(--metal-dark);border-color:var(--border-bright)}.control-btn[data-v-4ad747b3]:disabled{opacity:.4;cursor:not-allowed}.control-btn.start[data-v-4ad747b3]:hover:not(:disabled){border-color:var(--industrial-green);box-shadow:0 0 20px #22c55e1a}.control-btn.complete[data-v-4ad747b3]:hover:not(:disabled){border-color:var(--industrial-blue);box-shadow:0 0 20px #00d4ff1a}.control-btn.reset[data-v-4ad747b3]:hover:not(:disabled){border-color:var(--industrial-red);box-shadow:0 0 20px #ef44441a}.btn-icon[data-v-4ad747b3]{width:36px;height:36px;background:var(--metal-dark);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-icon svg[data-v-4ad747b3]{width:20px;height:20px}.btn-text[data-v-4ad747b3]{display:flex;flex-direction:column}.text-main[data-v-4ad747b3]{font-size:14px;font-weight:500}.text-sub[data-v-4ad747b3]{font-size:10px;color:var(--text-muted);font-family:var(--font-display);letter-spacing:.5px}.auto-refresh[data-v-4ad747b3]{padding-top:16px;border-top:1px solid var(--border-color)}.toggle-label[data-v-4ad747b3]{display:flex;align-items:center;gap:12px;cursor:pointer}.toggle-label input[data-v-4ad747b3]{display:none}.toggle-slider[data-v-4ad747b3]{width:48px;height:24px;background:var(--metal-dark);border-radius:12px;position:relative;transition:all .3s ease;border:1px solid var(--border-color)}.toggle-slider[data-v-4ad747b3]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:var(--text-muted);border-radius:50%;transition:all .3s ease}.toggle-label input:checked+.toggle-slider[data-v-4ad747b3]{background:#22c55e33;border-color:var(--industrial-green)}.toggle-label input:checked+.toggle-slider[data-v-4ad747b3]:after{left:26px;background:var(--industrial-green);box-shadow:0 0 10px var(--industrial-green-glow)}.toggle-text[data-v-4ad747b3]{display:flex;flex-direction:column}.toggle-main[data-v-4ad747b3]{font-size:13px;font-weight:500}.toggle-sub[data-v-4ad747b3]{font-size:10px;color:var(--text-muted);font-family:var(--font-display);letter-spacing:.5px}.flow-card[data-v-4ad747b3]:after{content:"WORKFLOW";position:absolute;top:20px;right:20px;font-family:var(--font-display);font-size:10px;color:var(--text-muted);letter-spacing:2px;opacity:.5}.status-flow[data-v-4ad747b3]{display:flex;align-items:center;justify-content:center;gap:60px;padding:30px}.flow-step[data-v-4ad747b3]{display:flex;align-items:center;position:relative}.step-connector[data-v-4ad747b3]{position:absolute;left:-50px;width:40px;height:2px}.connector-line[data-v-4ad747b3]{width:100%;height:100%;background:var(--metal-dark)}.flow-step.completed .connector-line[data-v-4ad747b3]{background:var(--industrial-green)}.step-node[data-v-4ad747b3]{display:flex;flex-direction:column;align-items:center;gap:12px}.node-ring[data-v-4ad747b3]{width:64px;height:64px;border-radius:50%;background:var(--metal-dark);display:flex;align-items:center;justify-content:center;position:relative}.flow-step.active .node-ring[data-v-4ad747b3]{background:var(--industrial-blue);box-shadow:0 0 30px var(--industrial-blue-glow);animation:pulse-ring-4ad747b3 2s infinite}@keyframes pulse-ring-4ad747b3{0%,to{box-shadow:0 0 20px var(--industrial-blue-glow)}50%{box-shadow:0 0 40px var(--industrial-blue-glow)}}.flow-step.completed .node-ring[data-v-4ad747b3]{background:var(--industrial-green)}.node-core[data-v-4ad747b3]{width:52px;height:52px;border-radius:50%;background:var(--industrial-bg-card);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.node-core svg[data-v-4ad747b3]{width:24px;height:24px}.flow-step.active .node-core[data-v-4ad747b3]{color:var(--industrial-blue)}.flow-step.completed .node-core[data-v-4ad747b3]{color:var(--industrial-green)}.step-info[data-v-4ad747b3]{display:flex;flex-direction:column;align-items:center;gap:4px}.step-number[data-v-4ad747b3]{font-size:10px;color:var(--text-muted);font-family:var(--font-display);letter-spacing:1px}.step-label[data-v-4ad747b3]{font-size:13px;font-weight:500;color:var(--text-secondary)}.flow-step.active .step-label[data-v-4ad747b3]{color:var(--industrial-blue)}.flow-step.completed .step-label[data-v-4ad747b3]{color:var(--industrial-green)}@media (max-width: 1024px){.container[data-v-4ad747b3]{grid-template-columns:1fr 1fr}.status-flow[data-v-4ad747b3]{flex-direction:column;gap:30px}.step-connector[data-v-4ad747b3]{display:none}}@media (max-width: 768px){.container[data-v-4ad747b3]{grid-template-columns:1fr}}.device .card[data-v-4ad747b3]{border-radius:18px}.control-btn[data-v-4ad747b3]{border-radius:14px;position:relative;overflow:hidden}.control-btn[data-v-4ad747b3]:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(112deg,transparent 0%,rgba(255,255,255,.24) 50%,transparent 100%);transform:translate(-125%);transition:transform .45s ease}.control-btn[data-v-4ad747b3]:hover:not(:disabled):before{transform:translate(125%)}.btn-icon svg[data-v-4ad747b3],.title-icon svg[data-v-4ad747b3],.node-core svg[data-v-4ad747b3],.status-icon svg[data-v-4ad747b3]{stroke-linecap:round;stroke-linejoin:round}.indicator-ring[data-v-4ad747b3]{box-shadow:inset 0 0 0 2px #ffffff6b,0 10px 28px #0f172a1f}.history[data-v-382da066]{max-width:1400px;margin:0 auto}.page-header[data-v-382da066]{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.page-title[data-v-382da066]{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.title-icon[data-v-382da066]{width:32px;height:32px;background:linear-gradient(135deg,var(--industrial-yellow) 0%,#e09400 100%);border-radius:4px;display:flex;align-items:center;justify-content:center;color:#000}.title-icon svg[data-v-382da066]{width:20px;height:20px}.page-subtitle[data-v-382da066]{font-family:var(--font-display);font-size:12px;color:var(--text-muted);letter-spacing:2px}.toolbar[data-v-382da066]{margin-bottom:20px;display:flex;gap:12px}.toolbar button[data-v-382da066]{display:flex;align-items:center;gap:8px;padding:10px 18px;background:var(--industrial-bg-card);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:13px;transition:all .3s ease}.toolbar button[data-v-382da066]:hover:not(:disabled){background:var(--metal-dark);border-color:var(--border-bright)}.toolbar button[data-v-382da066]:disabled{opacity:.5;cursor:not-allowed}.btn-icon[data-v-382da066]{width:16px;height:16px;display:flex;align-items:center;justify-content:center}.btn-icon svg[data-v-382da066]{width:100%;height:100%}.btn-refresh[data-v-382da066]:hover:not(:disabled){border-color:var(--industrial-blue);color:var(--industrial-blue)}.btn-clear[data-v-382da066]:hover:not(:disabled){border-color:var(--industrial-red);color:var(--industrial-red)}.table-container[data-v-382da066]{background:var(--industrial-bg-card);border:1px solid var(--border-color);border-radius:4px;overflow:hidden;box-shadow:0 4px 20px #0000004d}.table-container[data-v-382da066]:before{content:"";display:block;height:2px;background:linear-gradient(90deg,var(--industrial-yellow) 0%,var(--industrial-blue) 100%)}.data-table[data-v-382da066]{width:100%;border-collapse:collapse;font-size:13px}.data-table th[data-v-382da066],.data-table td[data-v-382da066]{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border-color)}.data-table th[data-v-382da066]{background:var(--industrial-bg-secondary);font-weight:600;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.5px}.data-table tbody tr[data-v-382da066]{transition:background .2s ease}.data-table tbody tr[data-v-382da066]:hover{background:#00d4ff08}.row-alt[data-v-382da066]{background:#ffffff05}.cell-id[data-v-382da066]{font-family:var(--font-display)}.id-badge[data-v-382da066]{display:inline-block;padding:4px 10px;background:var(--metal-dark);border-radius:3px;font-size:12px;color:var(--text-primary)}.material-tag[data-v-382da066]{display:inline-block;padding:4px 10px;background:#00d4ff1a;border:1px solid var(--industrial-blue);border-radius:3px;font-size:11px;color:var(--industrial-blue)}.highlight[data-v-382da066]{color:var(--industrial-yellow);font-weight:500}.deviation-badge[data-v-382da066]{display:inline-flex;align-items:center;padding:4px 10px;border-radius:3px;font-family:var(--font-display);font-size:12px;font-weight:500}.deviation-badge.success[data-v-382da066]{background:#22c55e1a;color:var(--industrial-green)}.deviation-badge.warning[data-v-382da066]{background:#f5a6231a;color:var(--industrial-yellow)}.deviation-badge.error[data-v-382da066]{background:#ef44441a;color:var(--industrial-red)}.deviation-badge.default[data-v-382da066]{background:var(--metal-dark);color:var(--text-muted)}.status-badge[data-v-382da066]{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:3px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge .status-dot[data-v-382da066]{width:6px;height:6px;border-radius:50%}.status-badge.success[data-v-382da066]{background:#22c55e1a;color:var(--industrial-green)}.status-badge.success .status-dot[data-v-382da066]{background:var(--industrial-green);box-shadow:0 0 6px var(--industrial-green-glow)}.status-badge.running[data-v-382da066]{background:#00d4ff1a;color:var(--industrial-blue)}.status-badge.running .status-dot[data-v-382da066]{background:var(--industrial-blue);box-shadow:0 0 6px var(--industrial-blue-glow);animation:blink 1s infinite}.status-badge.error[data-v-382da066]{background:#ef44441a;color:var(--industrial-red)}.status-badge.error .status-dot[data-v-382da066]{background:var(--industrial-red)}.status-badge.offline[data-v-382da066]{background:var(--metal-dark);color:var(--text-muted)}.status-badge.pending[data-v-382da066]{background:#f5a6231a;color:var(--industrial-yellow)}.status-badge.pending .status-dot[data-v-382da066]{background:var(--industrial-yellow);animation:blink 1.5s infinite}.cell-time[data-v-382da066]{color:var(--text-secondary);font-size:12px}.btn-detail[data-v-382da066]{padding:6px;background:transparent;border:1px solid var(--border-color);border-radius:3px;color:var(--text-muted);cursor:pointer;transition:all .2s ease}.btn-detail[data-v-382da066]:hover{background:var(--metal-dark);border-color:var(--industrial-blue);color:var(--industrial-blue)}.btn-detail svg[data-v-382da066]{width:16px;height:16px;display:block}.empty-cell[data-v-382da066]{padding:60px 20px}.empty-content[data-v-382da066]{display:flex;flex-direction:column;align-items:center;color:var(--text-muted)}.empty-icon[data-v-382da066]{width:48px;height:48px;margin-bottom:16px;opacity:.4}.empty-icon svg[data-v-382da066]{width:100%;height:100%}.empty-content p[data-v-382da066]{font-size:14px;margin-bottom:8px}.empty-hint[data-v-382da066]{font-family:var(--font-display);font-size:11px;letter-spacing:1px}.modal-overlay[data-v-382da066]{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal[data-v-382da066]{background:var(--industrial-bg-card);border:1px solid var(--border-color);border-radius:4px;width:90%;max-width:600px;max-height:80vh;overflow:auto;box-shadow:0 20px 60px #00000080}.modal-header[data-v-382da066]{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color);background:var(--industrial-bg-secondary)}.modal-title[data-v-382da066]{display:flex;align-items:center;gap:12px}.modal-title .title-icon[data-v-382da066]{width:36px;height:36px;background:var(--metal-dark);border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--industrial-yellow)}.modal-title .title-icon svg[data-v-382da066]{width:20px;height:20px}.title-text[data-v-382da066]{display:flex;flex-direction:column}.title-text .main[data-v-382da066]{font-size:16px;font-weight:600;color:var(--text-primary)}.title-text .sub[data-v-382da066]{font-size:10px;color:var(--text-muted);font-family:var(--font-display);letter-spacing:1px}.close-btn[data-v-382da066]{width:32px;height:32px;background:transparent;border:1px solid var(--border-color);border-radius:4px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0}.close-btn[data-v-382da066]:hover{background:var(--metal-dark);border-color:var(--industrial-red);color:var(--industrial-red)}.close-btn svg[data-v-382da066]{width:16px;height:16px}.modal-body[data-v-382da066]{padding:24px}.detail-section[data-v-382da066]{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border-color)}.detail-section[data-v-382da066]:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.section-header[data-v-382da066]{display:flex;align-items:center;gap:8px;margin-bottom:16px}.section-icon[data-v-382da066]{font-size:16px}.section-title[data-v-382da066]{font-size:13px;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.detail-grid[data-v-382da066]{display:grid;grid-template-columns:1fr 1fr;gap:12px}.detail-item[data-v-382da066]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--industrial-bg);border:1px solid var(--border-color);border-radius:4px}.detail-item.full-width[data-v-382da066]{grid-column:1 / -1;flex-direction:column;align-items:flex-start;gap:8px}.detail-item.highlight[data-v-382da066]{border-color:var(--industrial-yellow);background:#f5a6230d}.item-label[data-v-382da066]{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.item-value[data-v-382da066]{font-size:13px;font-weight:500;color:var(--text-primary)}.item-value.accent[data-v-382da066]{color:var(--industrial-yellow);font-size:16px}.item-value.explanation[data-v-382da066]{font-size:12px;line-height:1.6;color:var(--text-secondary)}.item-value.success[data-v-382da066]{color:var(--industrial-green)}.item-value.warning[data-v-382da066]{color:var(--industrial-yellow)}.item-value.error[data-v-382da066]{color:var(--industrial-red)}@media (max-width: 1024px){.data-table[data-v-382da066]{font-size:12px}.data-table th[data-v-382da066],.data-table td[data-v-382da066]{padding:10px 12px}}@media (max-width: 768px){.table-container[data-v-382da066]{overflow-x:auto}.data-table[data-v-382da066]{min-width:800px}.detail-grid[data-v-382da066]{grid-template-columns:1fr}}.table-container[data-v-382da066],.modal[data-v-382da066]{border-radius:16px}.toolbar button[data-v-382da066],.btn-detail[data-v-382da066],.close-btn[data-v-382da066]{border-radius:10px;position:relative;overflow:hidden}.toolbar button[data-v-382da066]:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(112deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);transform:translate(-125%);transition:transform .45s ease}.toolbar button[data-v-382da066]:hover:before{transform:translate(125%)}.status-badge .status-dot[data-v-382da066]{box-shadow:0 0 0 4px #ffffff73}.login-page[data-v-8b5932b4]{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(0,212,255,.05) 0%,transparent 50%),linear-gradient(225deg,rgba(245,166,35,.05) 0%,transparent 50%),var(--industrial-bg);padding:20px}.login-container[data-v-8b5932b4]{width:100%;max-width:420px;background:var(--industrial-bg-card);border:1px solid var(--border-color);border-radius:20px;padding:40px;box-shadow:0 24px 56px #0f172a2e,inset 0 1px #ffffffb3;position:relative;overflow:hidden}.login-container[data-v-8b5932b4]:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--industrial-yellow) 0%,var(--industrial-blue) 50%,var(--industrial-yellow) 100%)}.login-header[data-v-8b5932b4]{text-align:center;margin-bottom:32px}.logo[data-v-8b5932b4]{width:64px;height:64px;margin:0 auto 16px;background:linear-gradient(135deg,var(--metal-dark) 0%,var(--metal-mid) 100%);border:1px solid var(--border-bright);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--industrial-yellow);box-shadow:inset 0 1px #ffffff1a,0 4px 12px #0000004d}.logo svg[data-v-8b5932b4]{width:32px;height:32px}.login-header h1[data-v-8b5932b4]{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:4px;letter-spacing:.5px}.subtitle[data-v-8b5932b4]{font-size:11px;color:var(--text-muted);font-family:var(--font-display);letter-spacing:1px}.login-tabs[data-v-8b5932b4]{display:flex;gap:8px;margin-bottom:24px;padding:4px;background:var(--industrial-bg);border-radius:6px;border:1px solid var(--border-color)}.tab-btn[data-v-8b5932b4]{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:transparent;border:1px solid transparent;border-radius:10px;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.tab-btn[data-v-8b5932b4]:hover{color:var(--text-primary)}.tab-btn.active[data-v-8b5932b4]{background:linear-gradient(135deg,#0ea5e929,#0ea5e914);border-color:var(--industrial-blue);color:#075985;box-shadow:0 8px 22px #0ea5e933}.tab-icon[data-v-8b5932b4]{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center}.tab-icon svg[data-v-8b5932b4]{width:16px;height:16px}.login-form[data-v-8b5932b4]{margin-bottom:24px}.form-group[data-v-8b5932b4]{margin-bottom:16px}.form-group label[data-v-8b5932b4]{display:block;margin-bottom:6px;font-size:12px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.form-group input[data-v-8b5932b4]{width:100%;padding:12px 16px;background:var(--industrial-bg);border:1px solid var(--border-color);border-radius:6px;font-size:14px;color:var(--text-primary);font-family:var(--font-display);transition:all .3s ease}.form-group input[data-v-8b5932b4]:focus{outline:none;border-color:var(--industrial-yellow);box-shadow:0 0 0 3px #f5a6231a}.form-group input[data-v-8b5932b4]::placeholder{color:var(--text-muted)}.form-hint[data-v-8b5932b4]{display:flex;align-items:center;gap:8px;padding:12px;background:#00d4ff0d;border:1px solid rgba(0,212,255,.2);border-radius:6px;font-size:12px;color:var(--text-secondary);margin-bottom:16px}.hint-icon[data-v-8b5932b4]{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center}.hint-icon svg[data-v-8b5932b4]{width:16px;height:16px}.role-hints[data-v-8b5932b4]{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.role-hint[data-v-8b5932b4]{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--text-secondary)}.role-tag[data-v-8b5932b4]{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.role-tag.admin[data-v-8b5932b4]{background:#f5a6231a;border:1px solid var(--industrial-yellow);color:var(--industrial-yellow)}.role-tag.maintenance[data-v-8b5932b4]{background:#00d4ff1a;border:1px solid var(--industrial-blue);color:var(--industrial-blue)}.role-tag.operator[data-v-8b5932b4]{background:#22c55e1a;border:1px solid var(--industrial-green);color:var(--industrial-green)}.error-message[data-v-8b5932b4]{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#ef44441a;border:1px solid var(--industrial-red);border-radius:6px;color:var(--industrial-red);font-size:13px;margin-bottom:16px}.error-icon[data-v-8b5932b4]{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center}.error-icon svg[data-v-8b5932b4]{width:16px;height:16px}.login-btn[data-v-8b5932b4]{width:100%;padding:14px 24px;background:linear-gradient(135deg,var(--industrial-yellow) 0%,#e09400 100%);border:1px solid var(--industrial-yellow);border-radius:12px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .28s ease;position:relative;overflow:hidden;text-transform:uppercase;letter-spacing:1px;display:flex;align-items:center;justify-content:center;gap:8px}.login-btn[data-v-8b5932b4]:hover:not(:disabled){box-shadow:0 16px 28px #0ea5e959;transform:translateY(-2px)}.login-btn[data-v-8b5932b4]:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.32) 48%,transparent 100%);transform:translate(-130%);transition:transform .45s ease}.login-btn[data-v-8b5932b4]:hover:before{transform:translate(130%)}.login-btn[data-v-8b5932b4]:disabled{opacity:.6;cursor:not-allowed}.loading-spinner[data-v-8b5932b4]{width:16px;height:16px;border:2px solid rgba(0,0,0,.3);border-top-color:#000;border-radius:50%;animation:spin-8b5932b4 1s linear infinite}@keyframes spin-8b5932b4{to{transform:rotate(360deg)}}.demo-accounts[data-v-8b5932b4]{padding-top:24px;border-top:1px solid var(--border-color)}.demo-title[data-v-8b5932b4]{text-align:center;font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}.demo-list[data-v-8b5932b4]{display:flex;flex-direction:column;gap:8px}.demo-item[data-v-8b5932b4]{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--industrial-bg);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .3s ease}.demo-item[data-v-8b5932b4]:hover{border-color:var(--border-bright);background:var(--metal-dark)}.demo-type[data-v-8b5932b4]{font-size:11px;font-weight:600;color:var(--industrial-yellow);text-transform:uppercase;letter-spacing:.5px}.demo-cred[data-v-8b5932b4]{font-size:12px;color:var(--text-secondary);font-family:var(--font-display)}@media (max-width: 480px){.login-container[data-v-8b5932b4]{padding:24px}.login-header h1[data-v-8b5932b4]{font-size:18px}.tab-btn[data-v-8b5932b4]{padding:10px;font-size:13px}}.machine-select-page[data-v-efcc2be2]{max-width:1200px;margin:0 auto;padding:32px 24px}.page-header[data-v-efcc2be2]{display:flex;flex-direction:column;gap:8px;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border-color)}.page-header h1[data-v-efcc2be2]{font-size:24px;font-weight:600;color:var(--text-primary);letter-spacing:.5px}.page-header .subtitle[data-v-efcc2be2]{color:var(--text-secondary);font-size:14px}.user-info[data-v-efcc2be2]{display:flex;align-items:center;gap:16px;margin-top:8px}.role-badge[data-v-efcc2be2]{display:inline-block;padding:4px 12px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.role-badge.admin[data-v-efcc2be2]{background:#f5a6231a;border:1px solid var(--industrial-yellow);color:var(--industrial-yellow)}.role-badge.maintenance[data-v-efcc2be2]{background:#00d4ff1a;border:1px solid var(--industrial-blue);color:var(--industrial-blue)}.role-badge.operator[data-v-efcc2be2]{background:#22c55e1a;border:1px solid var(--industrial-green);color:var(--industrial-green)}.user-name[data-v-efcc2be2]{color:var(--text-primary);font-weight:500}.logout-btn[data-v-efcc2be2]{padding:6px 12px;background:transparent;border:1px solid var(--border-color);border-radius:10px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .3s ease;margin-left:auto}.logout-btn[data-v-efcc2be2]:hover{border-color:var(--industrial-red);color:var(--industrial-red);box-shadow:0 10px 20px #dc262624}.loading-state[data-v-efcc2be2],.error-state[data-v-efcc2be2]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px 24px;color:var(--text-secondary)}.loading-spinner[data-v-efcc2be2]{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--industrial-yellow);border-radius:50%;animation:spin-efcc2be2 1s linear infinite}@keyframes spin-efcc2be2{to{transform:rotate(360deg)}}.error-state .error-icon[data-v-efcc2be2]{width:48px;height:48px;color:var(--industrial-red)}.error-state .error-icon svg[data-v-efcc2be2]{width:100%;height:100%}.error-state button[data-v-efcc2be2]{padding:8px 24px;background:var(--metal-dark);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);cursor:pointer;transition:all .3s ease}.error-state button[data-v-efcc2be2]:hover{border-color:var(--industrial-yellow);color:var(--industrial-yellow)}.machines-grid[data-v-efcc2be2]{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.machine-card[data-v-efcc2be2]{background:var(--industrial-bg-card);border:1px solid var(--border-color);border-radius:18px;padding:24px;cursor:pointer;transition:all .28s ease;position:relative;overflow:hidden}.machine-card[data-v-efcc2be2]:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;transition:all .3s ease}.machine-card.online[data-v-efcc2be2]:before{background:var(--industrial-green)}.machine-card.offline[data-v-efcc2be2]:before{background:var(--industrial-red)}.machine-card.maintenance[data-v-efcc2be2]:before{background:var(--industrial-yellow)}.machine-card[data-v-efcc2be2]:hover{border-color:var(--border-bright);box-shadow:0 18px 32px #0f172a24;transform:translateY(-4px)}.machine-card.online[data-v-efcc2be2]:hover{box-shadow:0 8px 24px #22c55e1a}.status-indicator[data-v-efcc2be2]{display:flex;align-items:center;gap:8px;margin-bottom:16px}.status-dot[data-v-efcc2be2]{width:8px;height:8px;border-radius:50%;animation:pulse-efcc2be2 2s infinite}.machine-card.online .status-dot[data-v-efcc2be2]{background:var(--industrial-green);box-shadow:0 0 10px var(--industrial-green-glow)}.machine-card.offline .status-dot[data-v-efcc2be2]{background:var(--industrial-red)}.machine-card.maintenance .status-dot[data-v-efcc2be2]{background:var(--industrial-yellow);box-shadow:0 0 10px var(--industrial-yellow-glow)}@keyframes pulse-efcc2be2{0%,to{opacity:1}50%{opacity:.5}}.status-text[data-v-efcc2be2]{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.machine-card.online .status-text[data-v-efcc2be2]{color:var(--industrial-green)}.machine-card.offline .status-text[data-v-efcc2be2]{color:var(--industrial-red)}.machine-card.maintenance .status-text[data-v-efcc2be2]{color:var(--industrial-yellow)}.machine-info[data-v-efcc2be2]{margin-bottom:16px}.machine-name[data-v-efcc2be2]{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.machine-id[data-v-efcc2be2]{font-size:12px;color:var(--text-muted);font-family:var(--font-display);margin-bottom:8px}.machine-location[data-v-efcc2be2]{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.location-icon[data-v-efcc2be2]{width:14px;height:14px;display:inline-flex;align-items:center;justify-content:center}.location-icon svg[data-v-efcc2be2]{width:14px;height:14px}.machine-meta[data-v-efcc2be2]{margin-bottom:16px}.last-active[data-v-efcc2be2]{font-size:11px;color:var(--text-muted);font-family:var(--font-display)}.machine-action[data-v-efcc2be2]{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid var(--border-color);font-size:13px;color:var(--text-secondary);transition:all .3s ease}.machine-card:hover .machine-action[data-v-efcc2be2]{color:var(--industrial-yellow)}.action-arrow[data-v-efcc2be2]{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;transition:transform .3s ease}.action-arrow svg[data-v-efcc2be2]{width:16px;height:16px}.machine-card:hover .action-arrow[data-v-efcc2be2]{transform:translate(4px)}.machine-card.add-machine[data-v-efcc2be2]{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;border-style:dashed;background:transparent}.machine-card.add-machine[data-v-efcc2be2]:before{display:none}.machine-card.add-machine[data-v-efcc2be2]:hover{border-color:var(--industrial-yellow);background:#f5a6230d}.add-icon[data-v-efcc2be2]{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--metal-dark);border:2px solid var(--border-color);font-size:24px;color:var(--industrial-yellow);margin-bottom:12px;transition:all .3s ease}.machine-card.add-machine:hover .add-icon[data-v-efcc2be2]{border-color:var(--industrial-yellow);background:#f5a6231a}.add-text[data-v-efcc2be2]{font-size:14px;color:var(--text-secondary);font-weight:500}.modal-overlay[data-v-efcc2be2]{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal-content[data-v-efcc2be2]{background:var(--industrial-bg-card);border:1px solid var(--border-color);border-radius:16px;padding:32px;width:100%;max-width:400px;box-shadow:0 20px 60px #00000080}.modal-content h3[data-v-efcc2be2]{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:24px;text-align:center}.form-group[data-v-efcc2be2]{margin-bottom:16px}.form-group label[data-v-efcc2be2]{display:block;margin-bottom:6px;font-size:12px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.form-group input[data-v-efcc2be2]{width:100%;padding:12px 16px;background:var(--industrial-bg);border:1px solid var(--border-color);border-radius:6px;font-size:14px;color:var(--text-primary);transition:all .3s ease}.form-group input[data-v-efcc2be2]:focus{outline:none;border-color:var(--industrial-yellow)}.modal-actions[data-v-efcc2be2]{display:flex;gap:12px;margin-top:24px}.modal-actions button[data-v-efcc2be2]{flex:1;padding:12px 24px;border-radius:12px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.btn-cancel[data-v-efcc2be2]{background:var(--metal-dark);border:1px solid var(--border-color);color:var(--text-secondary)}.btn-cancel[data-v-efcc2be2]:hover{border-color:var(--border-bright);color:var(--text-primary);box-shadow:0 10px 18px #0f172a14}.btn-confirm[data-v-efcc2be2]{background:linear-gradient(135deg,var(--industrial-blue) 0%,#0284c7 100%);border:1px solid var(--industrial-blue);color:#fff;font-weight:600;position:relative;overflow:hidden}.btn-confirm[data-v-efcc2be2]:hover:not(:disabled){box-shadow:0 14px 28px #0ea5e94d;transform:translateY(-1px)}.btn-confirm[data-v-efcc2be2]:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.34) 50%,transparent 100%);transform:translate(-125%);transition:transform .45s ease}.btn-confirm[data-v-efcc2be2]:hover:before{transform:translate(125%)}.btn-confirm[data-v-efcc2be2]:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.machines-grid[data-v-efcc2be2]{grid-template-columns:1fr}.page-header[data-v-efcc2be2]{flex-direction:column;align-items:flex-start}}
