body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{background-color:#f5f5f5;min-height:100vh}.header{background-color:#fff;box-shadow:0 2px 8px #0000001a;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-content{justify-content:space-between;margin:0 auto;max-width:1920px;padding:1rem 2rem}.header-content,.logo{align-items:center;display:flex}.logo-text{color:#1a1a1a;font-size:1.25rem;font-weight:700;letter-spacing:1px}.header-actions{align-items:center;display:flex;gap:1.5rem}.connection-status{align-items:center;background-color:#f8f9fa;border-radius:20px;display:flex;gap:.5rem;padding:.5rem 1rem}.status-dot{animation:pulse 2s infinite;border-radius:50%;height:10px;width:10px}.status-dot.connected{background-color:#28a745}.status-dot.disconnected{animation:none;background-color:#dc3545}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-label{color:#495057;font-size:.875rem;font-weight:600}.main-container{display:flex;margin:0 auto;max-width:1920px;min-height:calc(100vh - 80px)}.sidebar{background-color:#fff;box-shadow:2px 0 8px #0000000d;height:calc(100vh - 80px);overflow-y:auto;padding:1rem;position:-webkit-sticky;position:sticky;top:80px;width:320px}.search-section{margin-bottom:1rem;position:relative}.search-input{border:1px solid #dee2e6;border-radius:6px;font-size:.85rem;outline:none;padding:.5rem .75rem;transition:border-color .2s;width:100%}.search-input:focus{border-color:#6c757d}.clear-search{background:none;border:none;color:#6c757d;cursor:pointer;font-size:1.3rem;padding:0 .4rem;position:absolute;right:8px;top:50%;transform:translateY(-50%)}.clear-search:hover{color:#dc3545}.filter-section{background-color:#fff;border:1px solid #e9ecef;border-radius:6px;margin-bottom:.75rem;overflow:hidden}.filter-header{align-items:center;background-color:#f8f9fa;cursor:pointer;display:flex;justify-content:space-between;padding:.6rem .75rem;transition:background-color .2s;-webkit-user-select:none;user-select:none}.filter-header:hover{background-color:#e9ecef}.filter-title{color:#212529;font-size:.85rem;font-weight:600}.filter-toggle{color:#495057;font-size:1.1rem;font-weight:600;transition:transform .3s}.filter-section.collapsed .filter-toggle{transform:rotate(180deg)}.filter-section.collapsed .filter-content{display:none}.filter-content{padding:.6rem .75rem}.filter-checkbox{align-items:center;cursor:pointer;display:flex;gap:.4rem;padding:.3rem 0}.filter-checkbox input[type=checkbox]{accent-color:#6c757d;cursor:pointer;height:16px;width:16px}.checkbox-label{color:#495057;font-size:.85rem}.filter-section.active-filter{background-color:#fff5f5;border-color:#ff6b6b}.active-asset-badge{align-items:center;background-color:#ff6b6b;border-radius:6px;color:#fff;display:flex;font-size:.85rem;font-weight:600;justify-content:space-between;padding:.5rem .75rem}.asset-badge-text{flex:1 1}.remove-filter{background:none;border:none;color:#fff;cursor:pointer;font-size:1.5rem;line-height:1;padding:0 .25rem;transition:opacity .2s}.remove-filter:hover{opacity:.8}.range-inputs{display:flex;gap:.6rem;margin-bottom:.6rem}.range-input-group{flex:1 1}.range-input-group label{color:#6c757d;display:block;font-size:.75rem;margin-bottom:.2rem}.range-input-group input[type=number]{border:1px solid #dee2e6;border-radius:4px;font-size:.85rem;padding:.4rem;width:100%}.range-slider input[type=range]{accent-color:#6c757d;border-radius:3px;height:6px;outline:none;width:100%}.clear-filters-btn{background-color:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;margin-bottom:.75rem;padding:.5rem;transition:background-color .2s;width:100%}.clear-filters-btn:hover{background-color:#c82333}.equipment-count{background-color:#f99;border-radius:6px;color:#fff;font-size:.85rem;padding:.6rem .75rem;text-align:center}.equipment-count strong{color:#fff;font-size:1rem}.content{flex:1 1;overflow-y:auto;padding:2rem}.content-header{margin-bottom:2rem}.page-title{color:#212529;font-size:2rem;font-weight:700;margin-bottom:.5rem}.page-subtitle{color:#6c757d;font-size:1rem}.assets-section{border-bottom:2px solid #e9ecef;margin-bottom:3rem;padding-bottom:2rem}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.section-title-main{color:#212529;font-size:1.5rem;font-weight:700;margin:0}.clear-asset-btn{background-color:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:background-color .2s}.clear-asset-btn:hover{background-color:#5a6268}.assets-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.asset-card{background-color:#fff;border:3px solid #0000;border-radius:12px;box-shadow:0 2px 8px #0000001a;cursor:pointer;padding:1.5rem;position:relative;transition:transform .2s,box-shadow .2s,border-color .2s}.asset-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-4px)}.asset-card.selected{border-color:#ff6b6b;box-shadow:0 4px 16px #ff6b6b4d}.asset-card-header{align-items:flex-start;border-bottom:1px solid #e9ecef;display:flex;margin-bottom:1rem;padding-bottom:1rem}.asset-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.asset-name{color:#212529;font-size:1.25rem;font-weight:700;line-height:1.3;margin:0}.asset-id{background-color:#f8f9fa;border-radius:4px;color:#6c757d;font-family:monospace;font-size:.75rem;font-weight:500;padding:.125rem .5rem;width:-webkit-fit-content;width:fit-content}.asset-description{border-bottom:1px solid #e9ecef;margin-bottom:1rem;padding-bottom:1rem}.asset-description p{color:#495057;font-size:.875rem;line-height:1.5;margin:0}.asset-stats{display:flex;flex-direction:column;gap:.5rem}.stat-item{align-items:center;display:flex;justify-content:space-between}.stat-divider{border:none;border-top:1px solid #e9ecef;margin:0}.stat-label{color:#6c757d;font-size:.875rem;font-weight:500}.stat-value{color:#212529;font-size:1rem;font-weight:700}.asset-card-footer{border-top:1px solid #e9ecef;display:flex;justify-content:flex-end;margin-top:1rem;padding-top:1rem}.asset-details-btn{background-color:#ff6b6b;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:background-color .2s}.asset-details-btn:hover{background-color:#ee5a52}.selected-badge{background-color:#ff6b6b;border-radius:12px;color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.5px;padding:.25rem .75rem;position:absolute;right:.75rem;top:.75rem}.equipment-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.equipment-count-badge{background-color:#ff6b6b;border-radius:20px;color:#fff;font-size:.875rem;font-weight:600;padding:.5rem 1rem}.equipment-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-bottom:2rem}.equipment-card{background-color:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;cursor:pointer;overflow:hidden;transition:transform .2s,box-shadow .2s}.equipment-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-4px)}.card-timestamp{align-items:center;background-color:#f8f9fa;color:#6c757d;display:flex;font-size:.8rem;padding:.5rem 1rem}.timestamp-text{font-weight:500}.card-title{padding:.75rem 1rem}.card-title h3{color:#212529;font-size:1.25rem;font-weight:700}.equipment-description{border-bottom:1px solid #f1f3f5;padding:0 1rem .75rem}.equipment-description p{color:#6c757d;font-size:.85rem;line-height:1.5;margin:0}.equipment-details{background-color:#fff;padding:.5rem 1rem}.detail-row{align-items:center;border-bottom:1px solid #f1f3f5;display:flex;justify-content:space-between;padding:.5rem 0}.detail-row:last-child{border-bottom:none}.detail-label{color:#6c757d;font-size:.85rem;font-weight:500}.detail-value{color:#212529;font-size:.9rem;font-weight:600}.detail-value.highlight{color:#495057;font-size:1rem}.tag-badge{border-radius:20px;color:#fff;font-size:.85rem;font-weight:700;letter-spacing:.5px;padding:.25rem .75rem}.card-footer{align-items:center;background-color:#fff;border-top:1px solid #e9ecef;display:flex;justify-content:flex-end;padding:1rem}.details-btn{background-color:#ff6b6b;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.75rem 1.5rem;transition:background-color .2s}.details-btn:hover{background-color:#ee5a52}.no-results{background-color:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:4rem 2rem;text-align:center}.no-results p{color:#6c757d;font-size:1.25rem;margin-bottom:1.5rem}.reset-btn{background-color:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:background-color .2s}.reset-btn:hover{background-color:#5a6268}@media (max-width:1200px){.equipment-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.assets-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}}@media (max-width:992px){.main-container{flex-direction:column}.sidebar{height:auto;position:relative;top:0;width:100%}.content{padding:1.5rem}.equipment-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.assets-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.equipment-section-header,.section-header{align-items:flex-start;flex-direction:column;gap:1rem}}@media (max-width:768px){.header-content{padding:1rem}.logo-text{font-size:1rem}.content,.sidebar{padding:1rem}.page-title{font-size:1.5rem}.section-title-main{font-size:1.25rem}.assets-grid,.equipment-grid{gap:1rem;grid-template-columns:1fr}}@media (max-width:576px){.header-actions{gap:.5rem}.connection-status{padding:.5rem}.status-label{display:none}.range-inputs{flex-direction:column;gap:.75rem}}.modal-overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:2rem;position:fixed;right:0;top:0;z-index:2000}.modal-content{animation:modalSlideIn .3s ease-out;background-color:#fff;border-radius:16px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:1200px;overflow-y:auto;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;background-color:#f8f9fa;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;padding:1.5rem 2rem}.modal-header h2{color:#212529;font-size:1.5rem;font-weight:700;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:50%;color:#6c757d;cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;padding:0;transition:background-color .2s,color .2s;width:32px}.modal-close:hover{background-color:#e9ecef;color:#dc3545}.modal-body{padding:2rem}.modal-section{margin-bottom:2rem}.modal-section:last-child{margin-bottom:0}.section-title{border-bottom:2px solid #ff6b6b;color:#212529;display:inline-block;font-size:1.25rem;font-weight:700;margin-bottom:1rem;padding-bottom:.5rem}.loading-indicator{color:#6c757d;font-size:.9rem;font-style:italic;font-weight:400}.websocket-badge{animation:pulse 2s infinite;background-color:#28a7451a;border:1px solid #28a745;border-radius:12px;color:#28a745;font-size:.75rem;font-weight:600;margin-left:1rem;padding:.25rem .75rem}.endpoints-list{display:flex;flex-direction:column;gap:1rem}.endpoint-item{background-color:#f8f9fa;border-left:4px solid #ff6b6b;border-radius:8px;display:flex;gap:1rem;padding:1rem}.endpoint-method{align-items:center;border-radius:4px;display:inline-flex;font-size:.75rem;font-weight:700;height:-webkit-fit-content;height:fit-content;justify-content:center;min-width:50px;padding:.25rem .75rem}.endpoint-method.get{background-color:#28a745;color:#fff}.endpoint-method.ws{background-color:#6c757d;color:#fff}.endpoint-details{flex:1 1}.endpoint-path{background-color:#212529;border-radius:4px;color:#0f0;display:block;font-family:Courier New,monospace;font-size:.85rem;margin-bottom:.5rem;padding:.5rem .75rem;word-break:break-all}.endpoint-description{color:#495057;font-size:.9rem;margin:.5rem 0 0}.endpoint-example{color:#6c757d;font-size:.85rem;font-style:italic;margin:.5rem 0 0}.endpoint-example code{background-color:#e9ecef;border-radius:3px;font-size:.8rem;padding:.25rem .5rem}.asset-info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.info-item{background-color:#f8f9fa;border-radius:6px;display:flex;flex-direction:column;gap:.5rem;padding:.75rem}.info-item.full-width{grid-column:1/-1}.info-label{color:#6c757d;font-size:.875rem;font-weight:600}.info-value{color:#212529;font-size:1rem;font-weight:500}.info-value code{background-color:#212529;border-radius:4px;color:#0f0;font-family:Courier New,monospace;font-size:.875rem;padding:.25rem .5rem}.visualization-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.parameter-chart{background-color:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:1rem}.chart-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.chart-header h4{color:#212529;font-size:.95rem;font-weight:600;margin:0}.chart-live-value{align-items:center;color:#495057;display:flex;font-size:.9rem;font-weight:600;gap:.5rem}.live-indicator{animation:pulse 2s infinite;color:#28a745;font-size:1rem}.chart-container{height:auto}.chart,.chart-container{position:relative;width:100%}.chart{display:flex;flex-direction:column;height:100%}.chart svg{display:block}.chart-labels{color:#6c757d;display:flex;font-size:.75rem;justify-content:space-between;margin-top:.5rem;padding-top:.5rem}.chart-label-max,.chart-label-min{font-family:Courier New,monospace}.no-data{align-items:center;border:1px dashed #dee2e6;border-radius:4px;color:#6c757d;font-size:.9rem;font-style:italic;height:200px;justify-content:center}.modal-footer,.no-data{background-color:#f8f9fa;display:flex}.modal-footer{border-top:1px solid #e9ecef;gap:1rem;justify-content:flex-end;padding:1.5rem 2rem}.modal-btn{border:none;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:600;padding:.75rem 2rem;transition:all .2s}.modal-btn.secondary{background-color:#6c757d;color:#fff}.modal-btn.secondary:hover{background-color:#5a6268}@media (max-width:768px){.modal-overlay{padding:1rem}.modal-header{padding:1rem 1.5rem}.modal-header h2{font-size:1.25rem}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem}.asset-info-grid,.visualization-grid{grid-template-columns:1fr}.endpoint-item{flex-direction:column;gap:.75rem}.endpoint-method{width:-webkit-fit-content;width:fit-content}}@media (max-width:576px){.modal-overlay{padding:.5rem}.modal-content{border-radius:8px}.modal-body{padding:1rem}.section-title{font-size:1.1rem}}.error-container,.loading-container{align-items:center;color:#495057;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:60vh}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e0e0e0;border-radius:50%;border-top-color:#495057;height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.error-container button{background-color:#495057;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem}.error-container button:hover{background-color:#343a40}.card-title{display:flex;flex-direction:column;gap:.25rem}.instance-id{background-color:#f8f9fa;border-radius:4px;color:#6c757d;font-family:monospace;font-size:.75rem;font-weight:500;margin-top:.25rem;padding:.125rem .5rem;width:-webkit-fit-content;width:fit-content}
/*# sourceMappingURL=main.ace1f27b.css.map*/