@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&display=swap";html,body{color:#f8fafc;background:#020617;height:100%;margin:0;padding:0;font-family:Inter,sans-serif;overflow:hidden}#app{flex-direction:column;height:100vh;display:flex}.app-container{box-sizing:border-box;flex-direction:column;flex:1;min-height:0;padding:2rem;display:flex}.layout-grid{flex:1;grid-template-columns:2fr 1fr;gap:2rem;width:100%;max-width:1600px;min-height:0;margin:0 auto;display:grid}.main-view,.side-panel{flex-direction:column;min-height:0;display:flex}.item-enter-active,.item-leave-active{transition:opacity .2s}.item-enter-from,.item-leave-to{opacity:0}.canvas-container[data-v-aabc7645]{box-sizing:border-box;background-color:#0f172a;flex-direction:column;width:100%;height:100%;padding:20px;display:flex;position:relative;overflow:auto}.reference-notice[data-v-aabc7645]{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172ad9;border:1px solid #3b82f666;border-radius:12px;flex-shrink:0;max-width:800px;margin-bottom:24px;padding:16px;animation:.8s ease-out fadeIn-aabc7645;box-shadow:0 10px 25px -5px #00000080}.notice-title[data-v-aabc7645]{color:#38bdf8;align-items:center;gap:6px;margin-bottom:8px;font-size:.9rem;font-weight:800;display:flex}.notice-desc[data-v-aabc7645]{color:#94a3b8;font-size:.75rem;font-weight:500;line-height:1.5}@keyframes fadeIn-aabc7645{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.conveyor-wrapper[data-v-aabc7645]{background:#1e293b;border:1px solid #334155;border-radius:8px;position:relative;overflow:hidden}.cell-bg[data-v-aabc7645]{box-sizing:border-box;background:#1e293bcc;border:1px dashed #94a3b833;position:absolute}.top-line-bg[data-v-aabc7645]{background-image:repeating-linear-gradient(45deg,#ffffff05 0 10px,#0000 10px 20px);animation:1.5s linear infinite moveStripesRight-aabc7645}.bottom-line-bg[data-v-aabc7645]{background-image:repeating-linear-gradient(-45deg,#ffffff05 0 10px,#0000 10px 20px);animation:1.5s linear infinite moveStripesLeft-aabc7645}@keyframes moveStripesRight-aabc7645{0%{background-position:0 0}to{background-position:28px 0}}@keyframes moveStripesLeft-aabc7645{0%{background-position:0 0}to{background-position:-28px 0}}.product-item[data-v-aabc7645]{box-sizing:border-box;z-index:10;padding:2px;transition:all .5s linear;position:absolute}.item-inner[data-v-aabc7645]{color:#fff;border-radius:2px;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:700;display:flex;position:relative;box-shadow:0 2px 4px #0006}.subtype-dot[data-v-aabc7645]{border:1px solid #fff;border-radius:50%;width:6px;height:6px;position:absolute;top:-2px;right:-2px}.subtype-export .subtype-dot[data-v-aabc7645]{background:#10b981}.subtype-domestic .subtype-dot[data-v-aabc7645]{background:#f59e0b}.product-A .item-inner[data-v-aabc7645]{background:#ef4444;border:1px solid #b91c1c}.product-B .item-inner[data-v-aabc7645]{background:#3b82f6;border:1px solid #1d4ed8}.product-C .item-inner[data-v-aabc7645]{background:#8b5cf6;border:1px solid #6d28d9}.product-D .item-inner[data-v-aabc7645]{background:#ec4899;border:1px solid #be185d}.product-E .item-inner[data-v-aabc7645]{background:#14b8a6;border:1px solid #0f766e}.product-F .item-inner[data-v-aabc7645]{background:#f97316;border:1px solid #c2410c}.end-pusher[data-v-aabc7645]{color:#fbbf24;z-index:5;background:#fbbf2433;border:1px solid #fbbf24;border-radius:4px;justify-content:center;align-items:center;font-weight:700;transition:background .1s;display:flex;position:absolute}.end-pusher.active[data-v-aabc7645]{background:#fbbf24cc}.pusher-piston[data-v-aabc7645]{transition:transform .1s}.end-pusher.active .pusher-piston[data-v-aabc7645]{transform:translateY(-24px)}.plc-indicator[data-v-aabc7645]{z-index:20;background:#0f172a;border:1px solid #475569;border-radius:4px;flex-direction:column;align-items:center;padding:2px 4px;display:flex;position:absolute;box-shadow:0 2px 4px #00000080}.plc-label[data-v-aabc7645]{color:#94a3b8;margin-bottom:2px;font-size:8px;font-weight:700}.plc-leds[data-v-aabc7645]{gap:4px;display:flex}.led-group[data-v-aabc7645]{flex-direction:column;align-items:center;gap:1px;display:flex}.led-label[data-v-aabc7645]{color:#64748b;font-size:7px}.led[data-v-aabc7645]{background:#334155;border-radius:50%;width:8px;height:8px;transition:all .1s;box-shadow:inset 0 1px 2px #00000080}.led.sensor-led.on[data-v-aabc7645]{background:#22c55e;box-shadow:0 0 4px #22c55e,inset 0 1px 2px #ffffff80}.led.pusher-led.on[data-v-aabc7645]{background:#ef4444;box-shadow:0 0 4px #ef4444,inset 0 1px 2px #ffffff80}.pusher-arm[data-v-aabc7645]{z-index:15;justify-content:center;align-items:flex-end;display:flex;position:absolute}.pusher-head[data-v-aabc7645]{background:#f59e0b;border-radius:2px;width:20px;height:4px;transition:transform .1s cubic-bezier(.4,0,.2,1);transform:translateY(-8px);box-shadow:0 1px 2px #00000080}.pusher-arm.active .pusher-head[data-v-aabc7645]{background:#fbbf24;transform:translateY(22px)}.supply-point[data-v-aabc7645]{color:#10b981;z-index:6;background:#10b98133;border:1px solid #10b981;justify-content:center;align-items:center;font-size:8px;display:flex;position:absolute}.return-marker[data-v-aabc7645]{color:#8b5cf6;z-index:6;background:#8b5cf633;border:1px solid #8b5cf6;justify-content:center;align-items:center;font-size:8px;display:flex;position:absolute}.supply-hopper[data-v-aabc7645]{background:#1e293bcc;border:1px solid #475569;border-radius:8px;width:140px;padding:8px;position:absolute}.hopper-title[data-v-aabc7645]{color:#94a3b8;text-align:center;margin-bottom:4px;font-size:10px}.hopper-items[data-v-aabc7645]{flex-wrap:wrap;gap:2px;display:flex}.station[data-v-aabc7645]{z-index:20;background:#0f172ae6;border:1px solid #475569;border-radius:8px;padding:8px;position:absolute;box-shadow:0 4px 6px #0000004d}.station-header[data-v-aabc7645]{color:#e2e8f0;text-align:center;margin-bottom:4px;font-size:12px;font-weight:700}.robot-arm[data-v-aabc7645]{background:#0003;border-top:2px solid #475569;border-radius:4px;justify-content:center;align-items:center;height:36px;margin-bottom:8px;display:flex;position:relative}.robot-gripper[data-v-aabc7645]{background:#cbd5e1;border-radius:0 0 2px 2px;width:12px;height:6px;position:absolute;top:0}.pallets-container[data-v-aabc7645]{justify-content:center;gap:8px;display:flex}.pallet[data-v-aabc7645]{background:#1e293b;border:2px dashed #475569;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;width:65px;height:60px;display:flex;position:relative;overflow:hidden}.pallet.active[data-v-aabc7645]{border-style:solid;border-color:#3b82f6}.pallet.waiting_replace[data-v-aabc7645]{border-style:solid;border-color:#ef4444;animation:1s infinite pulse-aabc7645}.pallet-label[data-v-aabc7645]{color:#cbd5e1;z-index:2;font-size:10px;font-weight:700}.pallet-status[data-v-aabc7645]{color:#94a3b8;z-index:2;margin-top:2px;font-size:9px}.progress-bar[data-v-aabc7645]{z-index:1;background:0 0;align-items:flex-end;width:100%;height:100%;display:flex;position:absolute;bottom:0;left:0}.progress-fill[data-v-aabc7645]{background:#3b82f633;width:100%;transition:height .3s}.pallet.waiting_replace .progress-fill[data-v-aabc7645]{background:#ef44444d}@keyframes pulse-aabc7645{0%{box-shadow:0 0 #ef444466}70%{box-shadow:0 0 0 6px #ef444400}to{box-shadow:0 0 #ef444400}}.vertical-conveyor[data-v-aabc7645]{z-index:5;background-color:#1e293b;background-image:repeating-linear-gradient(0deg,#ffffff05 0 10px,#0000 10px 20px);border-left:1px solid #334155;border-right:1px solid #334155;animation:1.5s linear infinite moveStripesVert-aabc7645;position:absolute}@keyframes moveStripesVert-aabc7645{0%{background-position:0 0}to{background-position:0 24px}}.pallet-track[data-v-aabc7645]{background:#334155;border-radius:2px;width:calc(100% - 220px);height:4px;position:absolute;left:20px}.animated-pallet[data-v-aabc7645]{color:#fff;z-index:30;border-radius:4px;justify-content:center;align-items:center;width:65px;height:30px;font-size:10px;font-weight:700;transition:all .1s linear;display:flex;position:absolute}.animated-pallet.empty[data-v-aabc7645]{background:#475569;border:2px dashed #94a3b8}.animated-pallet.full[data-v-aabc7645]{background:#3b82f6;border:2px solid #ef4444}.forklift[data-v-aabc7645]{color:#fff;z-index:25;background:#f59e0b;border-radius:8px;justify-content:center;align-items:center;width:80px;height:60px;font-size:14px;font-weight:700;transition:all .1s linear;display:flex;position:absolute;box-shadow:0 4px 6px #00000080}.forklift[data-v-aabc7645]:before{content:"";background:#cbd5e1;width:20px;height:6px;position:absolute;bottom:5px;left:-20px}.item-enter-active[data-v-aabc7645],.item-leave-active[data-v-aabc7645]{transition:opacity .5s}.item-enter-from[data-v-aabc7645],.item-leave-to[data-v-aabc7645]{opacity:0}.dashboard[data-v-9fe1e2f1]{box-sizing:border-box;color:#f8fafc;flex-direction:column;gap:24px;height:100%;padding:24px;display:flex}.header h1[data-v-9fe1e2f1]{letter-spacing:-.02em;background:linear-gradient(135deg,#38bdf8 0%,#818cf8 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0 0 16px;font-size:1.1rem;font-weight:800}.main-controls[data-v-9fe1e2f1]{flex-direction:column;gap:12px;display:flex}.btn-play[data-v-9fe1e2f1],.btn-pause[data-v-9fe1e2f1]{cursor:pointer;border:none;border-radius:8px;width:100%;padding:12px;font-weight:700;transition:all .2s}.btn-play[data-v-9fe1e2f1]{color:#fff;background:#10b981}.btn-pause[data-v-9fe1e2f1]{color:#fff;background:#f59e0b}.jog-section[data-v-9fe1e2f1]{flex-direction:column;gap:6px;display:flex}.jog-label[data-v-9fe1e2f1]{color:#64748b;font-size:.7rem;font-weight:700}.jog-group[data-v-9fe1e2f1]{background:#0f172a;border-radius:8px;gap:2px;padding:2px;display:flex}.jog-group button[data-v-9fe1e2f1]{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:6px;font-size:.75rem;font-weight:600;transition:all .2s}.jog-group button.active[data-v-9fe1e2f1]{color:#fff;background:#3b82f6;box-shadow:0 2px 4px #0000004d}.status-section[data-v-9fe1e2f1]{flex-direction:column;gap:12px;display:flex}.status-card[data-v-9fe1e2f1]{background:#0f172a;border:1px solid #334155;border-radius:10px;flex-direction:column;gap:4px;padding:12px 16px;display:flex}.card-tag[data-v-9fe1e2f1]{color:#64748b;letter-spacing:.05em;font-size:.65rem;font-weight:800}.status-content[data-v-9fe1e2f1]{align-items:center;gap:10px;display:flex;overflow:hidden}.status-indicator[data-v-9fe1e2f1]{background:#475569;border-radius:50%;width:8px;height:8px}.pc-card .status-indicator.pulse[data-v-9fe1e2f1]{background:#8b5cf6;animation:1s infinite led-pulse-9fe1e2f1}.plc-card .status-indicator.pulse[data-v-9fe1e2f1]{background:#10b981;animation:1s infinite led-pulse-9fe1e2f1}.status-value[data-v-9fe1e2f1]{color:#e2e8f0;white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.95rem;font-weight:700;overflow:hidden}.scrolling-container[data-v-9fe1e2f1]{position:relative;overflow:hidden}.scrolling-text[data-v-9fe1e2f1]{padding-left:0;display:inline-block}@keyframes led-pulse-9fe1e2f1{0%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.metrics-grid[data-v-9fe1e2f1]{grid-template-columns:1fr 1fr;gap:12px;display:grid}.metric-box[data-v-9fe1e2f1]{background:#0f172a;border:1px solid #334155;border-radius:10px;padding:12px}.metric-box.highlight[data-v-9fe1e2f1]{background:#3b82f60d;border-color:#3b82f6}.metric-label[data-v-9fe1e2f1]{color:#64748b;margin-bottom:4px;font-size:.6rem;font-weight:800}.metric-value[data-v-9fe1e2f1]{color:#f1f5f9;font-size:1.1rem;font-weight:800}.time-font[data-v-9fe1e2f1]{color:#38bdf8;font-family:monospace}.unit[data-v-9fe1e2f1]{color:#64748b;margin-left:2px;font-size:.65rem}.progress-container[data-v-9fe1e2f1]{margin-top:8px}.progress-label[data-v-9fe1e2f1]{color:#475569;margin-bottom:3px;font-size:.6rem}.progress-track[data-v-9fe1e2f1]{background:#1e293b;border-radius:2px;height:4px;overflow:hidden}.progress-fill[data-v-9fe1e2f1]{background:#3b82f6;height:100%;transition:width .3s}.hardware-section[data-v-9fe1e2f1]{flex-direction:column;gap:10px;display:flex}.section-title[data-v-9fe1e2f1]{color:#64748b;font-size:.7rem;font-weight:800}.hw-grid[data-v-9fe1e2f1]{flex-direction:column;gap:8px;display:flex}.hw-item[data-v-9fe1e2f1]{background:#0f172a80;border:1px solid #0000;border-radius:8px;align-items:center;gap:12px;padding:8px 12px;transition:all .2s;display:flex}.hw-item.active[data-v-9fe1e2f1]{background:#3b82f61a;border-color:#3b82f64d}.hw-icon[data-v-9fe1e2f1]{font-size:1.2rem}.hw-name[data-v-9fe1e2f1]{color:#94a3b8;font-size:.75rem;font-weight:700}.hw-status[data-v-9fe1e2f1]{color:#475569;font-size:.65rem;font-weight:800}.hw-item.active .hw-name[data-v-9fe1e2f1]{color:#f1f5f9}.hw-item.active .hw-status[data-v-9fe1e2f1]{color:#3b82f6}:root{--bg-dark:#0f172a;--panel-bg:#1e293b;--border-color:#334155;--accent-color:#3b82f6;--text-primary:#f8fafc;--text-secondary:#94a3b8}body{background-color:var(--bg-dark);color:var(--text-primary);margin:0;padding:0;font-family:Inter,system-ui,-apple-system,sans-serif;overflow:hidden}.app-container{flex-direction:column;width:100vw;height:100vh;display:flex}.layout-main{flex:1;min-height:0;display:flex}.canvas-area{background:radial-gradient(circle,#1e293b 0%,#0f172a 100%);flex:1;min-width:0;position:relative}.dashboard-area{border-left:1px solid var(--border-color);background:var(--panel-bg);width:420px;overflow-y:auto}.logs-footer{border-top:1px solid var(--border-color);background:#020617;flex-direction:column;height:180px;display:flex}.logs-header{border-bottom:1px solid var(--border-color);background:#0f172a;justify-content:space-between;align-items:center;padding:8px 16px;display:flex}.logs-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:700}.logs-count{color:var(--accent-color);font-size:.75rem}.logs-content{scroll-behavior:smooth;flex:1;padding:8px 16px;font-family:Fira Code,Cascadia Code,monospace;font-size:.85rem;overflow-y:auto}.log-entry{border-bottom:1px solid #3341554d;gap:12px;padding:4px 0;display:flex}.log-timestamp{color:var(--accent-color);flex-shrink:0}.log-message{color:#cbd5e1}.log-empty{color:var(--text-secondary);text-align:center;padding-top:20px;font-style:italic}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#475569}
