.mqtt-container[data-v-45ea9da8]{max-width:1200px;margin:0 auto;padding:20px}.mqtt-section[data-v-45ea9da8]{background:#fff;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 8px rgba(0,0,0,.1)}.mqtt-title[data-v-45ea9da8]{font-size:16px;font-weight:600;margin-bottom:15px;color:#333;position:relative}.live-indicator[data-v-45ea9da8]{display:inline-block;width:10px;height:10px;border-radius:50%;background:#ff4d4f;animation:blink-data-v-45ea9da8 1s infinite;margin-left:8px}@keyframes blink-data-v-45ea9da8{0%,to{opacity:1}50%{opacity:.3}}.form-row[data-v-45ea9da8]{display:flex;gap:15px;margin-bottom:15px;flex-wrap:wrap}.form-group[data-v-45ea9da8]{display:flex;flex-direction:column;gap:5px;min-width:150px}.form-group.full-width[data-v-45ea9da8]{flex:1;min-width:100%}.form-group label[data-v-45ea9da8]{font-size:12px;color:#666;font-weight:500}.form-group input[data-v-45ea9da8],.form-group select[data-v-45ea9da8],.form-group textarea[data-v-45ea9da8]{padding:8px 12px;border:1px solid #d9d9d9;border-radius:4px;font-size:14px;outline:none;transition:border-color .3s}.form-group input[data-v-45ea9da8]:focus,.form-group select[data-v-45ea9da8]:focus,.form-group textarea[data-v-45ea9da8]:focus{border-color:#1890ff}.form-group textarea[data-v-45ea9da8]{resize:vertical;min-height:100px}.btn[data-v-45ea9da8]{padding:8px 20px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.btn[data-v-45ea9da8]:disabled{opacity:.5;cursor:not-allowed}.btn-success[data-v-45ea9da8]{background:#52c41a;color:#fff}.btn-success[data-v-45ea9da8]:hover:not(:disabled){background:#389e0d}.btn-danger[data-v-45ea9da8]{background:#ff4d4f;color:#fff}.btn-danger[data-v-45ea9da8]:hover:not(:disabled){background:#cf1322}.btn-warning[data-v-45ea9da8]{background:#faad14;color:#fff}.btn-warning[data-v-45ea9da8]:hover:not(:disabled){background:#d48806}.btn-primary[data-v-45ea9da8]{background:#1890ff;color:#fff}.btn-primary[data-v-45ea9da8]:hover:not(:disabled){background:#096dd9}.connection-status[data-v-45ea9da8]{margin-top:10px;padding:8px 12px;border-radius:4px;font-size:13px;font-weight:500}.connection-status.disconnected[data-v-45ea9da8]{background:#fff2f0;color:#cf1322}.connection-status.connected[data-v-45ea9da8]{background:#f6ffed;color:#52c41a}.connection-error[data-v-45ea9da8]{margin-top:10px;padding:8px 12px;background:#fff2f0;color:#cf1322;border-radius:4px;font-size:13px}.realtime-panel[data-v-45ea9da8]{margin-top:15px}.panel-row[data-v-45ea9da8]{display:flex;gap:15px;margin-bottom:15px;flex-wrap:wrap}.panel-item[data-v-45ea9da8]{background:#f5f5f5;padding:12px 16px;border-radius:6px;min-width:140px;flex:1}.item-label[data-v-45ea9da8]{font-size:12px;color:#8c8c8c;margin-bottom:5px}.item-value[data-v-45ea9da8]{font-size:16px;font-weight:600;color:#333}.item-value.speed[data-v-45ea9da8]{color:#1890ff}.item-value.status-0[data-v-45ea9da8]{color:#52c41a}.item-value.status-1[data-v-45ea9da8]{color:#ff4d4f}.item-value.status-2[data-v-45ea9da8]{color:#faad14}.empty-message[data-v-45ea9da8]{padding:20px;text-align:center;color:#999;background:#fafafa;border-radius:4px}.receive-container[data-v-45ea9da8]{margin-top:15px}.receive-messages[data-v-45ea9da8]{max-height:400px;overflow-y:auto}.message-item[data-v-45ea9da8]{background:#f9f9f9;padding:12px;border-radius:6px;margin-bottom:10px;border-left:4px solid #1890ff}.msg-header[data-v-45ea9da8]{display:flex;justify-content:space-between;margin-bottom:10px;font-size:12px}.msg-time[data-v-45ea9da8]{color:#8c8c8c}.msg-topic[data-v-45ea9da8]{color:#1890ff;font-weight:500}.msg-parsed[data-v-45ea9da8]{font-size:13px}.msg-payload[data-v-45ea9da8]{font-family:monospace;font-size:13px;color:#333;word-break:break-all}.signal-table[data-v-45ea9da8]{width:100%;border-collapse:collapse;font-size:12px}.signal-table td[data-v-45ea9da8],.signal-table th[data-v-45ea9da8]{padding:6px 10px;text-align:left;border-bottom:1px solid #e8e8e8}.signal-table th[data-v-45ea9da8]{background:#f5f5f5;font-weight:600;color:#666}.signal-table .table-header[data-v-45ea9da8]{background:#1890ff;color:#fff;text-align:center}.signal-table .label[data-v-45ea9da8]{color:#8c8c8c;width:35%}.video-wrapper[data-v-2bb19c62]{position:relative;width:100%;height:186px}.loading-overlay[data-v-2bb19c62]{position:absolute;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.7);display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:10}.loading-spinner[data-v-2bb19c62]{width:40px;height:40px;border:4px solid hsla(0,0%,100%,.3);border-top-color:#00d4ff;border-radius:50%;animation:spin-data-v-2bb19c62 1s linear infinite}.loading-text[data-v-2bb19c62]{color:#fff;font-size:14px;margin-top:12px}@keyframes spin-data-v-2bb19c62{to{transform:rotate(1turn)}}.app-wrapper[data-v-0132107e]{width:100vw;height:100vh;overflow:hidden;background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);display:flex;flex-direction:column;box-sizing:border-box}.header[data-v-0132107e]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:hsla(0,0%,100%,.08);backdrop-filter:blur(10px);border-bottom:1px solid hsla(0,0%,100%,.1)}.header-center[data-v-0132107e],.header-left[data-v-0132107e],.header-right[data-v-0132107e]{flex:1}.header-center[data-v-0132107e]{text-align:center}.header-right[data-v-0132107e]{text-align:right}.school-badge[data-v-0132107e]{display:inline-flex;align-items:center;gap:6px;background:hsla(0,0%,100%,.1);border-radius:20px}.badge-icon[data-v-0132107e]{font-size:16px}.badge-text[data-v-0132107e]{font-size:12px;color:#fff;font-weight:500}.car-plate[data-v-0132107e]{display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:8px 20px;border-radius:8px;font-size:14px;font-weight:700;font-family:Courier New,monospace;letter-spacing:2px;box-shadow:0 4px 15px rgba(102,126,234,.4)}.student-info[data-v-0132107e]{display:inline-flex;align-items:center;gap:8px}.student-name[data-v-0132107e]{font-size:12px;color:#fff;font-weight:500}.car-type-badge[data-v-0132107e]{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:700}.player-section[data-v-0132107e]{background:#00c776;border:2px solid linear-gradient(235deg,#00d4ff,#09c);border-radius:12px;box-shadow:0 0 2px rgba(43,255,0,.3),inset 0 0 2px rgba(43,255,0,.1),0 4px 1px rgba(0,0,0,.5);margin:8px;padding:8px;position:relative}.player-section[data-v-0132107e]:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(135deg,#00d4ff,#09c,#00d4ff);border-radius:14px;z-index:-1;animation:borderGlow-data-v-0132107e 3s ease-in-out infinite}@keyframes borderGlow-data-v-0132107e{0%,to{opacity:.6;filter:blur(8px)}50%{opacity:1;filter:blur(12px)}}.map-section[data-v-0132107e]{flex:1;display:flex;justify-content:center;align-items:center;margin:8px;min-height:0}.canvas-wrapper[data-v-0132107e]{width:100%;height:100%;border-radius:12px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.3)}.track-canvas[data-v-0132107e]{width:100%;height:100%;background:#2d3436}.footer[data-v-0132107e]{position:fixed;top:50px;left:0;right:0;z-index:100;background:rgba(38,39,45,.8);border-radius:12px;backdrop-filter:none;padding:10px 16px;margin:16px}.status-title[data-v-0132107e]{color:#fff;padding:8px 0;font-size:14px;font-weight:700}.status-panel[data-v-0132107e]{display:flex;justify-content:space-between;align-items:center}.status-indicators[data-v-0132107e]{display:flex;gap:12px;flex-wrap:wrap}.indicator-item[data-v-0132107e]{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;min-width:48px;transition:all .3s ease;border:1px solid transparent}.indicator-item.active[data-v-0132107e]{transform:scale(1.05)}.indicator-icon[data-v-0132107e]{font-size:18px;filter:grayscale(100%);opacity:.5;color:#fff;transition:all .3s ease}.indicator-icon img[data-v-0132107e]{width:24px;height:24px}.indicator-icon .text[data-v-0132107e]{padding:3px}.indicator-item.active .indicator-icon[data-v-0132107e]{filter:grayscale(0);opacity:1;transform:scale(1.1)}.indicator-label[data-v-0132107e]{font-size:14px;color:hsla(0,0%,100%,.986);font-weight:500;transition:all .3s ease}.indicator-item.active .indicator-label[data-v-0132107e]{color:#4caf50;font-weight:700}.speed-display[data-v-0132107e]{position:fixed;top:310px;left:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#babdc2;width:62px;height:62px;border-radius:50%;transition:all .3s ease;z-index:101}.speed-display.warning[data-v-0132107e]{background:linear-gradient(135deg,#ff416c,#ff4b2b);box-shadow:0 2px 5px rgba(255,65,108,.5),0 0 5px rgba(255,65,108,.4);animation:speedPulse-data-v-0132107e 1s infinite}@keyframes speedPulse-data-v-0132107e{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.speed-value[data-v-0132107e]{font-size:18px;font-weight:700;color:#000;font-family:Courier New,monospace;line-height:1}.speed-unit[data-v-0132107e]{font-size:8px;color:#000;margin-top:2px}@media screen and (max-width:480px){.header[data-v-0132107e]{padding:8px 12px}.school-badge[data-v-0132107e]{padding:4px 8px}.badge-text[data-v-0132107e]{font-size:11px}.car-plate[data-v-0132107e]{padding:6px 14px;font-size:12px}.student-name[data-v-0132107e]{font-size:11px}.car-type-badge[data-v-0132107e]{padding:3px 8px;font-size:10px}.player-section[data-v-0132107e]{flex:0 0 160px}.status-indicators[data-v-0132107e]{gap:6px}.indicator-item[data-v-0132107e]{padding:6px 8px;min-width:40px}.indicator-icon[data-v-0132107e]{font-size:16px}.speed-value[data-v-0132107e]{font-size:22px;font-weight:700}.speed-unit[data-v-0132107e]{font-size:10px}}@media screen and (max-height:600px){.player-section[data-v-0132107e]{flex:0 0 140px}.footer[data-v-0132107e]{padding:8px 12px}.indicator-item[data-v-0132107e]{padding:6px 10px}}body,html{margin:0;padding:0;height:100%}#app,body,html{width:100%;overflow:hidden}#app{font-family:Avenir,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-align:center;color:#2c3e50;position:relative;height:100vh}