.react-grid-layout{transition:height .2s;position:relative}.react-grid-item{transition:left .2s,top .2s,width .2s,height .2s}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{z-index:1;will-change:width, height;transition:none}.react-grid-item.react-draggable-dragging{z-index:3;will-change:transform;transition:none}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{opacity:.2;z-index:2;-webkit-user-select:none;user-select:none;background:red;transition-duration:.1s}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{opacity:0;width:20px;height:20px;position:absolute}.react-grid-item:hover>.react-resizable-handle{opacity:1}.react-grid-item>.react-resizable-handle:after{content:"";border-bottom:2px solid #0006;border-right:2px solid #0006;width:5px;height:5px;position:absolute;bottom:3px;right:3px}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{cursor:sw-resize;bottom:0;left:0;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{cursor:se-resize;bottom:0;right:0}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{cursor:nw-resize;top:0;left:0;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{cursor:ne-resize;top:0;right:0;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{cursor:ew-resize;margin-top:-10px;top:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{cursor:ns-resize;margin-left:-10px;left:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}:root{--bg-app:#0c0f14;--bg-sidebar:#12161d;--bg-card:#181d26;--bg-elevated:#1e2430;--bg-input:#0f131a;--border:#ffffff14;--border-strong:#ffffff1f;--text-primary:#eef1f6;--text-secondary:#8b93a7;--text-muted:#6b7280;--accent:#5b9cf5;--accent-hover:#4a8ae8;--accent-soft:#5b9cf51f;--success:#4ade80;--danger:#f87171;--warning:#fbbf24;--sidebar-width:248px;--radius:12px;--radius-sm:8px;--shadow:0 8px 32px #00000059;--font:"Inter", "Segoe UI", system-ui, sans-serif}*{box-sizing:border-box}body{font-family:var(--font);background:var(--bg-app);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;margin:0}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}input,textarea,select{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);border-radius:6px;width:100%;padding:.55rem .75rem;font-family:inherit}input:focus,textarea:focus,select:focus{outline:2px solid var(--accent);border-color:var(--accent)}.btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-primary);align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.875rem;transition:background .15s,border-color .15s;display:inline-flex}.btn:hover:not(:disabled){border-color:var(--border-strong);background:#ffffff0f}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-danger{border-color:var(--danger);color:var(--danger)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;box-shadow:inset 0 1px #ffffff0a}.status-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.status-dot.online{background:var(--success);box-shadow:0 0 8px #4ade8073}.status-dot.offline{background:var(--danger)}.layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;padding:1.25rem 0;display:flex}.sidebar-brand{letter-spacing:-.02em;align-items:center;gap:.6rem;padding:0 1.25rem 1.75rem;font-size:1rem;font-weight:600;display:flex}.sidebar-brand-mark{background:linear-gradient(135deg, var(--accent), #818cf8);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:700;display:flex}.sidebar-nav a{color:var(--text-secondary);border-radius:var(--radius-sm);margin:0 .75rem .25rem;padding:.6rem 1rem;font-size:.9rem;text-decoration:none;transition:background .15s,color .15s;display:block}.sidebar-nav a.active,.sidebar-nav a:hover{color:var(--text-primary);background:var(--accent-soft);text-decoration:none}.sidebar-nav a.active{color:var(--accent);font-weight:500}.sidebar-footer{color:var(--text-muted);margin-top:auto;padding:1rem 1.25rem;font-size:.72rem}.topbar-title{color:var(--text-secondary);font-size:.875rem}.topbar-actions{align-items:center;gap:1rem;display:flex}.topbar-user{color:var(--text-secondary);font-size:.875rem}.main{flex-direction:column;flex:1;display:flex}.topbar{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#12161dd9;justify-content:space-between;align-items:center;height:60px;padding:0 1.75rem;display:flex}.content{flex:1;max-width:1600px;padding:1.75rem}.page-title{letter-spacing:-.03em;margin:0 0 1.25rem;font-size:1.625rem;font-weight:600}.toolbar-sub{color:var(--text-secondary);font-size:.875rem}.tabs{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;gap:.35rem;width:fit-content;margin-bottom:1.5rem;padding:.25rem;display:flex}.tab{color:var(--text-secondary);border-radius:var(--radius-sm);background:0 0;border:none;padding:.5rem 1rem;font-size:.875rem;transition:background .15s,color .15s}.tab:hover{color:var(--text-primary);background:#ffffff0a}.tab.active{color:var(--text-primary);background:var(--accent-soft);font-weight:500}.table{border-collapse:collapse;width:100%}.table th,.table td{text-align:left;border-bottom:1px solid var(--border);padding:.75rem 1rem}.table th{color:var(--text-secondary);text-transform:uppercase;font-size:.8rem;font-weight:500}.table tr:hover td{background:#ffffff05}.widget-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.widget-card{min-height:160px}.widget-title{color:var(--text-secondary);margin-bottom:.5rem;font-size:.85rem}.widget-value{font-variant-numeric:tabular-nums;font-size:2rem;font-weight:500}.login-page{justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{width:100%;max-width:400px}.form-group{margin-bottom:1rem}.form-group label{color:var(--text-secondary);margin-bottom:.35rem;font-size:.875rem;display:block}.error{color:var(--danger);margin-top:.5rem;font-size:.875rem}.honeypot{opacity:0;width:0;height:0;position:absolute;left:-9999px;overflow:hidden}.stat-row{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card .stat-value{font-size:2rem;font-weight:600}.stat-card .stat-label{color:var(--text-secondary);font-size:.85rem}.modal-overlay{z-index:100;background:#0009;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;width:100%;max-width:520px;max-height:90vh;padding:1.5rem;overflow-y:auto}.code-block{background:var(--bg-input);border:1px solid var(--border);white-space:pre-wrap;word-break:break-all;border-radius:6px;padding:.75rem;font-family:Consolas,monospace;font-size:.8rem}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.badge{color:#90caf9;background:#1976d233;border-radius:999px;padding:.15rem .5rem;font-size:.75rem;display:inline-block}.gauge-wrap{flex-direction:column;justify-content:center;align-items:center;height:120px;display:flex}.chart-wrap{height:180px}.source-badge{letter-spacing:.03em;text-transform:uppercase;border-radius:4px;padding:.2rem .55rem;font-size:.7rem;font-weight:600;display:inline-block}.source-badge.http{color:#90caf9;background:#1976d240}.source-badge.mqtt{color:#3fb950;background:#3fb95033}.status-pill{text-transform:capitalize;border-radius:999px;padding:.15rem .45rem;font-size:.75rem;display:inline-block}.status-pill.success{color:var(--success);background:#3fb95026}.status-pill.failed{color:var(--danger);background:#f8514926}.modal-wide{max-width:820px}.builder-grid{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}@media (width<=768px){.builder-grid{grid-template-columns:1fr}}.builder-form{flex-direction:column;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.preset-row{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.preset-btn{font-size:.8rem}.builder-preview{min-height:200px}.preview-meta{color:var(--text-secondary);margin-top:.75rem;font-size:.85rem}.builder-actions{justify-content:flex-end;gap:.5rem;margin-top:.5rem;display:flex}.widget-columns-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.25rem;display:flex}.widget-column-list{flex-direction:column;gap:.5rem;display:flex}.widget-column-row{grid-template-columns:1fr 1fr auto;align-items:center;gap:.5rem;display:grid}.widget-column-row-head{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;font-size:.75rem}.widget-column-row-head span:last-child{width:2.25rem}.widget-column-row .btn-danger{min-width:2.25rem;padding:.35rem .55rem}.section-title{margin:0 0 .75rem;font-size:.95rem;font-weight:500}.ingest-summary{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.json-mapper{flex-direction:column;gap:1rem;display:flex}.mapper-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.mapper-json-input label{color:var(--text-secondary);margin-bottom:.35rem;font-size:.875rem;display:block}.mapper-canvas{min-height:360px;position:relative;overflow:hidden}.mapper-lines{pointer-events:none;z-index:1;width:100%;height:100%;position:absolute;inset:0}.mapper-columns{z-index:2;grid-template-columns:1fr 1fr;gap:2rem;display:grid;position:relative}@media (width<=900px){.mapper-columns{grid-template-columns:1fr}.mapper-lines{display:none}}.mapper-tree-col,.mapper-bindings-col{min-height:280px}.col-header{text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);margin-bottom:.75rem;font-size:.8rem;font-weight:600}.mapper-hint{color:var(--accent);margin-top:1rem;font-size:.8rem}.tree-row{cursor:default;border-radius:4px;align-items:center;gap:.35rem;padding:.25rem .5rem;font-family:Consolas,monospace;font-size:.8rem;display:flex}.tree-row.leaf{cursor:pointer}.tree-row.leaf:hover{background:#1976d21f}.tree-row.selected{outline:1px solid var(--accent);background:#1976d233}.tree-row.mapped{border-left:3px solid var(--success)}.tree-toggle{width:14px;color:var(--text-secondary)}.tree-key{color:var(--text-primary);font-weight:500}.tree-type{font-size:.7rem}.tree-value{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:120px;margin-left:auto;overflow:hidden}.tree-mapped-dot{background:var(--success);border-radius:50%;width:8px;height:8px;margin-left:.25rem}.binding-card{background:var(--bg-input);border:1px solid var(--border);border-radius:6px;grid-template-columns:1fr auto 100px auto;align-items:center;gap:.5rem;margin-bottom:.5rem;padding:.6rem .75rem;display:grid}.binding-source{flex-direction:column;gap:.25rem;min-width:0;display:flex}.binding-source code{word-break:break-all;color:#79c0ff;font-size:.75rem}.binding-arrow{color:var(--accent);font-weight:700}.mapper-bottom-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (width<=768px){.mapper-bottom-grid{grid-template-columns:1fr}}.script-preview{max-height:220px;overflow:auto}.mapper-apply{flex-wrap:wrap;align-items:center;gap:1.25rem;display:flex}.mapper-apply label{color:var(--text-secondary);font-size:.875rem}.loading-block{color:var(--text-secondary);align-items:center;gap:.75rem;padding:1rem 0;display:flex}.page-loader{justify-content:center;padding:3rem 1rem;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:22px;height:22px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.alert-banner{border:1px solid;border-radius:8px;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding:.85rem 1rem;display:flex}.alert-banner.error{color:#ffb4af;background:#f851491f;border-color:#f8514959}.alert-banner.warning{color:#f0c674;background:#d299221f;border-color:#d2992259}.alert-banner.info{color:#90caf9;background:#1976d21f;border-color:#1976d259}.alert-banner.success{color:#8dde9b;background:#3fb9501f;border-color:#3fb95059}.alert-banner-text{flex:1;font-size:.9rem;line-height:1.45}.alert-banner-actions{flex-shrink:0;gap:.5rem;display:flex}.dashboard-grid-wrap{width:100%}.dashboard-edit-hint{color:var(--text-muted);background:var(--accent-soft);border-radius:var(--radius-sm);border:1px solid #5b9cf533;margin-bottom:.75rem;padding:.5rem .75rem;font-size:.8rem}.dashboard-grid-item{height:100%;position:relative;overflow:visible}.dashboard-grid-item>.widget-panel{min-height:100%}.widget-grid-chrome{z-index:5;opacity:0;gap:.35rem;transition:opacity .15s;display:flex;position:absolute;top:8px;right:8px}.dashboard-grid-item:hover .widget-grid-chrome{opacity:1}.widget-drag-handle{cursor:grab;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);-webkit-user-select:none;user-select:none;border-radius:6px;padding:.2rem .45rem;font-size:.85rem}.widget-drag-handle:active{cursor:grabbing}.widget-edit-btn{color:var(--accent);background:#60a5fa26;border:1px solid #60a5fa59;border-radius:6px;padding:.15rem .45rem;font-size:.85rem;line-height:1}.widget-remove-btn{color:var(--danger);background:#f8717126;border:1px solid #f8717159;border-radius:6px;padding:.15rem .45rem;font-size:1rem;line-height:1}.widget-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);height:100%;box-shadow:var(--shadow);flex-direction:column;display:flex;overflow:hidden}.widget-panel-head{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.widget-panel-title{letter-spacing:-.01em;font-size:.9rem;font-weight:600}.widget-type-chip{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:#ffffff0a;border-radius:4px;padding:.2rem .45rem;font-size:.65rem}.widget-panel-body{flex:1;min-height:0;padding:.75rem 1rem 1rem;overflow:auto}.widget-panel-body-table{flex-direction:column;padding-bottom:.5rem;display:flex}.widget-table-hint{color:var(--warning);margin:0 0 .5rem;font-size:.75rem;line-height:1.35}.chart-wrap{height:100%;min-height:140px}.gauge-wrap{flex-direction:column;justify-content:center;align-items:center;gap:.5rem;height:100%;display:flex}.gauge-arc{border:8px solid #ffffff14;border-bottom:0;border-top-left-radius:120px;border-top-right-radius:120px;width:120px;height:60px;position:relative;overflow:hidden}.gauge-fill{opacity:.85;border-top-left-radius:inherit;border-top-right-radius:inherit;height:100%;position:absolute;bottom:0;left:0}.gauge-value{font-size:1.35rem;font-weight:600}.value-display{text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;display:flex}.value-big{letter-spacing:-.03em;font-size:2rem;font-weight:700}.value-unit{color:var(--text-secondary);margin-left:.25rem;font-size:1rem}.value-meta{color:var(--text-muted);margin-top:.35rem;font-size:.8rem}.widget-table-wrap{flex-direction:column;flex:1;gap:.5rem;height:100%;min-height:0;display:flex}.widget-table-toolbar{align-items:center;gap:.5rem;display:flex}.widget-filter-input{border-radius:var(--radius-sm);flex:1;padding:.4rem .65rem;font-size:.8rem}.widget-mode-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);background:#ffffff0f;border-radius:999px;flex-shrink:0;padding:.25rem .5rem;font-size:.65rem;font-weight:600}.widget-mode-badge.live{color:var(--success);background:#4ade801f}.widget-table-scroll{flex:1;max-height:100%;overflow:auto}.table-compact th,.table-compact td{padding:.45rem .65rem;font-size:.85rem}.cell-muted{color:var(--text-muted);font-size:.8rem}.cell-value{font-variant-numeric:tabular-nums;font-weight:500}.empty-state{text-align:center;color:var(--text-secondary);padding:2.5rem 1.5rem}.empty-state p{margin-bottom:1rem}.login-page{background:radial-gradient(ellipse 80% 60% at 50% -10%, #5b9cf526, transparent), var(--bg-app);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.login-card{width:100%;max-width:400px;padding:2rem}.stat-card{text-align:center;padding:1.25rem}.stat-value{letter-spacing:-.03em;font-size:2rem;font-weight:700}.stat-label{color:var(--text-secondary);margin-top:.25rem;font-size:.8rem}.react-grid-item.react-grid-placeholder{border-radius:var(--radius);background:var(--accent-soft)!important;opacity:.6!important}.react-resizable-handle:after{border-color:var(--text-muted)!important}.credentials-panel-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.credentials-demo-note{color:var(--text-secondary);margin:.35rem 0 0;font-size:.875rem;line-height:1.5}.credentials-hint{color:var(--text-muted);margin:.5rem 0 0;font-size:.8rem}.copy-field-head{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.35rem;display:flex}.copy-field-head label{margin:0}.btn-copy{padding:.25rem .6rem;font-size:.75rem}.code-block-wrap{white-space:pre-wrap;word-break:break-all}.script-tab-grid{grid-template-columns:1fr 1fr;align-items:start;gap:1rem;display:grid}@media (width<=960px){.script-tab-grid{grid-template-columns:1fr}}.script-docs-section{border-top:1px solid var(--border);margin-top:1.25rem;padding-top:1rem}.script-docs-section:first-of-type{border-top:none;margin-top:.75rem;padding-top:0}.script-docs-section h4{color:var(--text-primary);margin:0 0 .5rem;font-size:.95rem}.script-docs-p,.script-docs-list{color:var(--text-secondary);margin:0 0 .65rem;font-size:.875rem;line-height:1.55}.script-docs-list{padding-left:1.25rem}.script-docs-code{margin:.5rem 0;font-size:.8rem}.script-docs-embedded{border-top:1px solid var(--border);margin-top:1rem;padding-top:1rem}.script-docs-embedded .script-docs-section:first-of-type{margin-top:0}
