.layout-shell{--page-padding-x: clamp(1rem, 4vw, 2.5rem);--nav-accent-height: 40px;--nav-bar-height: 60px;--header-total-height: calc(var(--nav-accent-height) + var(--nav-bar-height));display:flex;flex-direction:column;min-height:100vh;background-color:#fafcff}.page-header-shell{width:100%;background-color:#fff;border-bottom:1px solid var(--border-color);position:sticky;top:var(--header-total-height);z-index:999}.layout-body{flex:1;display:flex;align-items:stretch;min-height:0;margin-left:260px}.layout-content{flex:1;display:flex;flex-direction:column;background-color:#fafcff}.nav-accent{height:var(--nav-accent-height);background-color:var(--tritech-orange);width:100%;position:sticky;top:0;z-index:1001;display:flex;align-items:center}.nav-accent-content{max-width:100%;width:100%;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.nav-accent-left{flex:1}.nav-bar{background-color:var(--tritech-blue);color:var(--tritech-white);padding:0;box-shadow:0 2px 4px #0000001a;position:sticky;top:var(--nav-accent-height);z-index:1000}.nav-content{max-width:100%;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.nav-actions{display:flex;align-items:center;gap:1rem}.nav-logo{font-size:1.5rem;font-weight:600;letter-spacing:.5px}.nav-phone{font-size:1rem;font-weight:400;color:var(--tritech-white);display:flex;align-items:center;gap:.5rem}.nav-phone svg{width:16px;height:16px;flex-shrink:0}.nav-username{font-size:.95rem;font-weight:500;color:var(--tritech-white);padding:.35rem .75rem;background-color:#ffffff1a;border-radius:999px;border:1px solid rgba(255,255,255,.2)}.logout-button{background-color:#ffffff26;color:var(--tritech-white);border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:.35rem 1rem;cursor:pointer;transition:background-color .2s ease,transform .1s ease;font-size:.9rem}.logout-button:hover{background-color:#ffffff40}.logout-button:active{transform:translateY(1px)}.main-content{flex:1;padding:2rem var(--page-padding-x);max-width:100%}.footer{background-color:#fff;color:var(--text-secondary);text-align:center;padding:1rem 0;font-size:.9rem;border-top:1px solid var(--border-color)}@media (max-width: 768px){.layout-body{margin-left:0}.nav-accent-content{padding:0 1rem}.nav-content{padding:.75rem 1rem .75rem 3.75rem}.nav-logo{font-size:1.1rem}.nav-phone{font-size:.9rem}.main-content{padding:1.5rem var(--page-padding-x)}}@media (max-width: 1024px){.nav-logo{font-size:1.25rem}.nav-phone{font-size:.9rem}.main-content{padding:1.5rem var(--page-padding-x)}}@media (max-width: 640px){.main-content{padding:1rem var(--page-padding-x)}}.sidebar{width:260px;background-color:#fff;border-right:1px solid var(--border-color);max-height:calc(100vh - var(--header-total-height, 100px));height:calc(100vh - var(--header-total-height, 100px));display:flex;flex-direction:column;padding:1.5rem 1.25rem;gap:1.5rem;box-shadow:inset -1px 0 #00000008;position:fixed;left:0;top:var(--header-total-height, 100px);overflow:hidden;z-index:998}.sidebar-brand{display:flex;flex-direction:column;gap:.35rem;position:relative;flex-shrink:0}.sidebar-logo{font-weight:700;letter-spacing:1px;color:var(--tritech-blue);font-size:1.2rem}.sidebar-tagline{font-size:.85rem;color:var(--text-secondary);margin:0}.sidebar-nav{flex:1 1 0;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-right:.25rem;margin-right:-.25rem}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:#0000000d;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb{background-color:#0003;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background-color:#0000004d}.sidebar-nav ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.sidebar-link{display:flex;flex-direction:column;padding:.9rem 1rem;border-radius:10px;text-decoration:none;color:var(--text-dark);background-color:transparent;border:1px solid transparent;transition:background-color .2s ease,border-color .2s ease,transform .15s ease}.sidebar-link-content{display:flex;align-items:center;gap:.75rem}.sidebar-link-icon{display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0;transition:color .2s ease}.sidebar-link:hover .sidebar-link-icon,.sidebar-link-active .sidebar-link-icon{color:var(--tritech-blue)}.sidebar-link:hover{background-color:#1b5ba214;border-color:#1b5ba226;transform:translate(2px)}.sidebar-link-active{background-color:#1b5ba21f;border-color:#1b5ba266;box-shadow:inset 0 0 0 1px #1b5ba240}.sidebar-link-primary{font-weight:600;font-size:1rem}.sidebar-link-secondary{font-size:.78rem;color:var(--text-secondary);margin-top:.25rem}.sidebar-toggle{position:fixed;top:calc(4px + .75rem);left:.75rem;z-index:1002;background-color:var(--tritech-blue);border:none;border-radius:6px;padding:.5rem;cursor:pointer;display:none;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003;transition:background-color .2s;width:40px;height:40px}@media (max-width: 768px){.sidebar-toggle{left:.5rem;top:calc(4px + .5rem)}}.sidebar-toggle:hover{background-color:#1a5a9e}.hamburger{display:flex;flex-direction:column;gap:4px;width:24px;height:18px}.hamburger span{display:block;width:100%;height:2px;background-color:#fff;border-radius:2px;transition:all .3s ease}.hamburger-open span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.hamburger-open span:nth-child(2){opacity:0}.hamburger-open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:997;display:none}.sidebar-close-button{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s,color .2s}.sidebar-close-button:hover{background-color:#0000000d;color:var(--text-dark)}@media (max-width: 768px){.sidebar-toggle{display:flex}.sidebar-overlay{display:block}.sidebar{width:280px;transform:translate(-100%);transition:transform .3s ease;box-shadow:2px 0 8px #00000026}.sidebar-open{transform:translate(0)}.sidebar-closed{transform:translate(-100%)}.layout-body{margin-left:0}}@media (min-width: 769px){.sidebar-toggle,.sidebar-overlay{display:none!important}.sidebar-close-button{display:none}}.sensor-list-container{height:100%;display:flex;flex-direction:column}.sensor-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem}.sensor-list-title{font-size:1.25rem;font-weight:600;color:var(--text-dark);margin:0}.sensor-export-controls{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end;margin-bottom:1rem}.date-filter-group{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:200px}.date-filter-group label{font-size:.85rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.date-input{padding:.5rem;border:1px solid var(--border-color);border-radius:6px;font-size:.95rem;font-family:inherit;background-color:#fff;color:var(--text-dark);transition:border-color .2s}.date-input:focus{outline:none;border-color:var(--tritech-blue);box-shadow:0 0 0 3px #1b5ba21a}.date-input:disabled{background-color:var(--bg-light);cursor:not-allowed;opacity:.6}.reset-date-button{padding:.5rem 1rem;background-color:var(--bg-light);border:1px solid var(--border-color);border-radius:6px;font-size:.9rem;font-weight:500;color:var(--text-dark);cursor:pointer;transition:all .2s;white-space:nowrap;height:fit-content}.reset-date-button:hover:not(:disabled){background-color:var(--border-color);border-color:var(--text-secondary)}.reset-date-button:disabled{opacity:.6;cursor:not-allowed}.export-all-csv-button{background-color:var(--tritech-blue);color:#fff;border:none;border-radius:6px;padding:.5rem 1.5rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;height:fit-content;display:flex;align-items:center;gap:.5rem}.export-all-csv-button:hover:not(:disabled){background-color:#1a5a9e;transform:translateY(-1px);box-shadow:0 4px 8px #1b5ba233}.export-all-csv-button:active:not(:disabled){transform:translateY(0)}.export-all-csv-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.sensor-list-error{background-color:#d32f2f1a;border-left:4px solid var(--error-color);color:var(--error-color);padding:.75rem 1rem;margin-bottom:1rem;border-radius:4px;font-size:.875rem;font-weight:500}.sensor-list-wrapper{flex:1;overflow:auto}.sensor-table{width:100%;border-collapse:collapse;font-size:.9rem}.sensor-table thead{background-color:var(--bg-light);position:sticky;top:0}.sensor-table th{padding:.75rem;text-align:left;font-weight:600;color:var(--text-dark);border-bottom:2px solid var(--border-color);font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.sensor-table td{padding:.75rem;border-bottom:1px solid var(--border-color);color:var(--text-dark)}.sensor-table tbody tr{cursor:pointer;transition:background-color .2s ease}.sensor-table tbody tr:hover{background-color:var(--bg-light)}.sensor-table tbody tr.selected{background-color:#1b5ba21a;border-left:3px solid var(--tritech-blue)}.sensor-table tbody tr.selected:hover{background-color:#1b5ba226}.name-cell{font-weight:600;color:var(--tritech-blue);font-size:.9rem}.dev-eui-cell{font-family:Courier New,monospace;font-size:.85rem;color:var(--text-secondary)}.timestamp-cell{font-size:.85rem;color:var(--text-secondary);white-space:nowrap}.count-cell{text-align:center;font-weight:500}.value-cell{text-align:right;font-family:Courier New,monospace}.status-cell,.signal-cell{text-align:center;width:60px}.status-indicator{display:inline-block;width:12px;height:12px;border-radius:50%;position:relative;cursor:help}.status-dot{display:block;width:100%;height:100%;border-radius:50%;background-color:inherit}.signal-bars{display:inline-flex;align-items:flex-end;gap:2px;height:16px;cursor:help;justify-content:center}.signal-bar{width:4px;background-color:#e0e0e0;border-radius:2px;transition:background-color .2s ease}.signal-bar:nth-child(1){height:6px}.signal-bar:nth-child(2){height:10px}.signal-bar:nth-child(3){height:14px}.signal-bars[data-quality=good] .signal-bar.active{background-color:#4caf50}.signal-bars[data-quality=weak] .signal-bar.active{background-color:#ff9800}.signal-bars[data-quality=poor] .signal-bar.active{background-color:#f44336}.signal-bars:not([data-quality]) .signal-bar,.signal-bars[data-quality=""] .signal-bar{background-color:#9e9e9e}.empty-state{text-align:center;padding:2rem;color:var(--text-secondary);font-style:italic}@media (max-width: 768px){.sensor-list-container{padding:0}.sensor-list-header{flex-direction:column;align-items:stretch;margin-bottom:.75rem}.sensor-list-title{font-size:1.1rem;margin-bottom:0}.sensor-export-controls{flex-direction:column;gap:1rem}.date-filter-group{min-width:100%}.reset-date-button,.export-all-csv-button{width:100%;justify-content:center}.sensor-list-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.sensor-table{font-size:.75rem;min-width:600px}.sensor-table th,.sensor-table td{padding:.5rem .4rem;white-space:nowrap}.dev-eui-cell{font-size:.7rem}.name-cell{font-size:.85rem}}.sensor-details-container{height:100%;overflow-y:auto;display:flex;flex-direction:column;gap:2rem}.sensor-details-header{border-bottom:2px solid var(--border-color);padding-bottom:1rem}.sensor-title-row{display:flex;align-items:baseline;gap:1rem;margin-bottom:.5rem;flex-wrap:wrap}.sensor-status-badge{padding:.25rem .75rem;border-radius:999px;color:#fff;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.sensor-name{font-size:1.5rem;font-weight:600;color:var(--tritech-blue);margin:0}.sensor-dev-eui{font-size:1.25rem;font-weight:500;color:var(--text-secondary);font-family:Courier New,monospace;margin:0}.sensor-last-update{font-size:.9rem;color:var(--text-secondary)}.empty-details,.loading-state,.error-state{text-align:center;padding:3rem;color:var(--text-secondary);font-style:italic}.error-state{color:var(--error-color)}.current-values-card{background-color:#fff;border-radius:8px;padding:1.75rem;box-shadow:1px 1px #00000014,0 1px 3px #0000000d;border:1px solid rgb(0 0 0 / 14%)}.card-title{font-size:1.1rem;font-weight:600;color:var(--text-dark);margin-bottom:1rem}.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.value-item{display:flex;flex-direction:column;gap:.5rem}.value-label{font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:500;display:flex;align-items:center;gap:.5rem}.field-status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;cursor:help}.threshold-info{font-size:.75rem;color:var(--text-secondary);cursor:help;margin-left:.25rem}.value-data{font-size:1.5rem;font-weight:600;color:var(--tritech-blue);font-family:Courier New,monospace}.history-section{display:flex;flex-direction:column;gap:1.5rem}.history-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.history-actions{display:flex;gap:.75rem;align-items:center}.date-filter-container{display:flex;gap:1rem;align-items:center;padding:1rem;background-color:var(--bg-light);border-radius:8px;border:1px solid var(--border-color);flex-wrap:wrap}.date-filter-group{display:flex;align-items:center;gap:.5rem}.date-filter-group label{font-size:.9rem;font-weight:500;color:var(--text-dark);white-space:nowrap}.date-input{padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem;font-family:inherit;color:var(--text-dark);background-color:var(--tritech-white);cursor:pointer}.date-input:focus{outline:2px solid var(--tritech-blue);outline-offset:2px;border-color:var(--tritech-blue)}.reset-date-button{background-color:var(--tritech-orange);color:var(--tritech-white);border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .2s ease,transform .1s ease;white-space:nowrap}.reset-date-button:hover{background-color:#e09a2e;transform:translateY(-1px)}.reset-date-button:active{transform:translateY(0)}.export-csv-button{background-color:var(--tritech-blue);color:var(--tritech-white);border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .2s ease,transform .1s ease;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.export-csv-button:hover{background-color:#154a8a;transform:translateY(-1px)}.export-csv-button:active{transform:translateY(0)}.export-csv-button:focus{outline:2px solid var(--tritech-orange);outline-offset:2px}.chart-wrapper{display:flex;flex-direction:column;gap:.5rem}.chart-title{font-size:1rem;font-weight:600;color:var(--text-dark);margin:0;padding-left:.5rem}.chart-container{background-color:var(--bg-light);border-radius:8px;padding:1rem;border:1px solid var(--border-color)}.no-history{text-align:center;padding:2rem;color:var(--text-secondary);font-style:italic;background-color:var(--bg-light);border-radius:8px}.custom-tooltip{background-color:#fff;border:1px solid #E0E0E0;border-radius:6px;padding:.75rem;box-shadow:0 2px 8px #00000026;font-size:.85rem;min-width:200px}.tooltip-label{font-weight:600;color:var(--text-dark);margin:0 0 .5rem;font-size:.9rem}.tooltip-value{margin:.5rem 0;color:var(--text-dark)}.tooltip-value strong{color:var(--tritech-blue)}.tooltip-threshold{margin:.5rem 0;padding:.5rem;background-color:var(--bg-light);border-radius:4px;font-size:.8rem;color:var(--text-secondary);line-height:1.5}.tooltip-threshold strong{color:var(--text-dark)}.tooltip-status{margin:.5rem 0 0;padding:.5rem;border-radius:4px;font-size:.8rem;font-weight:500}.tooltip-status-normal{background-color:#e8f5e9;color:#2e7d32}.tooltip-status-warning{background-color:#fff3e0;color:#e65100}.tooltip-status-alert{background-color:#ffebee;color:#c62828}.tooltip-status-none{background-color:var(--bg-light);color:var(--text-secondary)}.history-table-container{display:flex;flex-direction:column;gap:.75rem}.table-title{font-size:1rem;font-weight:600;color:var(--text-dark)}.history-table-wrapper{max-height:400px;overflow-y:auto;border:1px solid var(--border-color);border-radius:8px}.history-table{width:100%;border-collapse:collapse;font-size:.85rem}.history-table thead{background-color:var(--bg-light);position:sticky;top:0;z-index:1}.history-table th{padding:.75rem;text-align:left;font-weight:600;color:var(--text-dark);border-bottom:2px solid var(--border-color);font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}.history-table td{padding:.75rem;border-bottom:1px solid var(--border-color);color:var(--text-dark)}.history-table tbody tr:hover{background-color:var(--bg-light)}.history-table .timestamp-cell{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.history-table .value-cell{text-align:right;font-family:Courier New,monospace}@media (max-width: 768px){.sensor-details-container{gap:1.5rem}.sensor-name{font-size:1.25rem}.sensor-dev-eui{font-size:1rem}.current-values-card{padding:1.25rem}.values-grid{grid-template-columns:1fr;gap:.75rem}.chart-container{padding:.5rem;min-height:200px}.chart-title{font-size:1rem;margin-bottom:.5rem}.history-header{flex-direction:column;align-items:stretch;gap:1rem}.history-actions{width:100%;flex-direction:column;gap:.75rem}.export-csv-button{width:100%;justify-content:center}.date-filter-container{flex-direction:column;align-items:stretch;gap:.75rem}.date-filter-group{width:100%;flex-direction:column;align-items:stretch}.date-input,.reset-date-button{width:100%}.history-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.history-table{font-size:.75rem;min-width:700px}.history-table th,.history-table td{padding:.5rem .4rem;white-space:nowrap}}.dashboard-statistics{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:1.5rem}.stat-card{background-color:#fff;border:1px solid rgb(0 0 0 / 14%);border-radius:8px;padding:1.5rem;box-shadow:1px 1px #00000014,0 1px 3px #0000000d;display:flex;flex-direction:column;gap:.75rem}.stat-label{font-size:.875rem;font-weight:500;color:#666;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:2rem;font-weight:700;color:#1a1a1a;line-height:1}.stat-value-container{display:flex;align-items:center;justify-content:space-between;gap:1rem}.stat-indicator{display:flex;align-items:center;gap:.5rem}.stat-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.stat-dot-online{background-color:#4caf50}.stat-dot-offline{background-color:#9e9e9e}.stat-percentage{font-size:.875rem;font-weight:500;color:#666}.stat-critical{font-size:.875rem;font-weight:600;color:#f44336;margin-top:.25rem}@media (max-width: 768px){.dashboard-statistics{grid-template-columns:repeat(2,1fr);gap:1rem}.stat-card{padding:1.25rem;border-radius:8px}.stat-value{font-size:1.75rem}.stat-label{font-size:.8rem}}@media (max-width: 480px){.dashboard-statistics{grid-template-columns:1fr}}.login-page{min-height:100vh;display:flex;flex-direction:column;background-color:#fafcff}.login-page .nav-accent{height:40px;background-color:var(--tritech-orange);width:100%;display:flex;align-items:center}.login-page .nav-accent-content{max-width:100%;width:100%;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.login-page .nav-accent-left{flex:1}.login-page .nav-phone{font-size:1rem;font-weight:400;color:var(--tritech-white);display:flex;align-items:center;gap:.5rem}.login-page .nav-phone svg{width:16px;height:16px;flex-shrink:0}.login-wrapper{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}.login-card{width:100%;max-width:420px;background-color:#fff;border:1px solid rgb(0 0 0 / 14%);border-radius:8px;padding:1.5rem;box-shadow:1px 1px #00000014,0 1px 3px #0000000d;display:flex;flex-direction:column;gap:1.5rem}.login-brand{text-align:center}.login-accent{width:60px;height:4px;background-color:var(--tritech-orange);margin:0 auto 1rem;border-radius:999px}.login-brand h1{margin:0;color:var(--tritech-orange)}.login-brand p{margin:.25rem 0 0;color:var(--text-secondary)}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-weight:600;color:var(--text-dark)}.form-group input{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;background-color:#fdfdfd}.form-group input:focus{outline:none;border-color:var(--tritech-blue);box-shadow:0 0 0 3px #1b5ba226}.login-button{background-color:var(--tritech-blue);color:var(--tritech-white);border:none;border-radius:8px;padding:.85rem 1rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s ease,transform .1s ease}.login-button:hover{background-color:#154a8a}.login-button:active{transform:translateY(1px)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-error{background-color:#fee;border:1px solid #fcc;color:#c33;padding:.75rem 1rem;border-radius:6px;font-size:.9rem;text-align:center}.login-hint{text-align:center;font-size:.85rem;color:var(--text-secondary);margin:0}@media (max-width: 480px){.login-page .nav-accent-content{padding:0 1rem}.login-page .nav-phone{font-size:.9rem}.login-card{padding:1.25rem}}.structure-view-container{width:100%;height:100%;display:flex;flex-direction:column;gap:1.5rem}.structure-view-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.structure-view-title{font-size:1.5rem;font-weight:600;color:var(--text-dark);margin:0}.structure-view-controls{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.image-upload-control{display:flex;align-items:center}.upload-image-button{padding:.625rem 1.25rem;border:1px solid var(--border-color);border-radius:6px;background-color:#fff;color:var(--text-dark);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;display:inline-block}.upload-image-button:hover{background-color:var(--bg-light);border-color:var(--tritech-blue)}.edit-mode-button,.save-layout-button{padding:.625rem 1.25rem;border:1px solid var(--border-color);border-radius:6px;background-color:#fff;color:var(--text-dark);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.edit-mode-button:hover{background-color:var(--bg-light);border-color:var(--tritech-blue)}.edit-mode-button.active,.save-layout-button{background-color:var(--tritech-blue);color:#fff;border-color:var(--tritech-blue)}.save-layout-button:hover:not(:disabled){background-color:#1a5a9e}.save-layout-button:disabled{opacity:.6;cursor:not-allowed}.edit-mode-notice{background-color:#fff3e0;border:1px solid #ffb74d;border-radius:6px;padding:.75rem 1rem;color:#e65100;font-size:.9rem}.structure-view-loading,.structure-view-error{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:1.1rem;color:var(--text-secondary)}.structure-view-error{color:var(--error-color)}.structure-view-map{position:relative;width:100%;min-height:600px;background-color:#fff;border:1px solid rgb(0 0 0 / 14%);border-radius:8px;overflow:hidden;box-shadow:1px 1px #00000014,0 1px 3px #0000000d}.floorplan-background{width:100%;height:100%;object-fit:contain;position:absolute;top:0;left:0;z-index:1;pointer-events:none}.sensor-marker{position:absolute;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transform:translate(-50%,-50%);box-shadow:0 2px 8px #0000004d;border:2px solid white;transition:transform .1s,box-shadow .1s}.sensor-marker:hover{transform:translate(-50%,-50%) scale(1.1);box-shadow:0 4px 12px #0006;z-index:20}.sensor-marker.editable{cursor:move}.sensor-marker.dragging{z-index:100;transform:translate(-50%,-50%) scale(1.2);box-shadow:0 6px 16px #00000080}.sensor-icon{display:flex;align-items:center;justify-content:center;width:100%;height:100%;pointer-events:none}.sensor-icon svg{width:24px;height:24px}.drag-handle{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:.8rem;color:var(--text-secondary);white-space:nowrap;pointer-events:none}.gateway-marker{position:absolute;width:50px;height:50px;background-color:#2196f3;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:5;transform:translate(-50%,-50%);box-shadow:0 2px 8px #0000004d;border:2px solid white}.gateway-icon{font-size:1.8rem;filter:brightness(0) invert(1)}.sensor-tooltip{position:absolute;background-color:#000000e6;color:#fff;padding:.75rem;border-radius:6px;font-size:.85rem;z-index:1000;pointer-events:none;min-width:200px;max-width:250px;box-shadow:0 4px 12px #0000004d;transform:translate(-50%)}.sensor-tooltip-top{transform:translate(-50%,-100%);margin-top:-10px}.sensor-tooltip-top:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid rgba(0,0,0,.9)}.sensor-tooltip-bottom{transform:translate(-50%);margin-top:10px}.sensor-tooltip-bottom:after{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid rgba(0,0,0,.9)}.tooltip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.2)}.tooltip-status{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.tooltip-status.normal{background-color:#4caf50}.tooltip-status.warning{background-color:#ff9800}.tooltip-status.alert{background-color:#f44336}.tooltip-status.offline{background-color:#9e9e9e}.tooltip-content{display:flex;flex-direction:column;gap:.25rem}.tooltip-row{display:flex;justify-content:space-between;gap:1rem}.tooltip-row span:first-child{color:#ffffffb3}.tooltip-row span:last-child{font-weight:500}@media (max-width: 768px){.structure-view-header{flex-direction:column;align-items:stretch}.structure-view-controls{flex-direction:column;width:100%}.edit-mode-button,.save-layout-button{width:100%}.structure-view-map{min-height:400px}.sensor-marker{width:32px;height:32px}.sensor-icon svg{width:18px;height:18px}.gateway-marker{width:40px;height:40px}.gateway-icon{font-size:1.5rem}}.sensors-page{display:flex;flex-direction:column;gap:1.5rem}.sensors-page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.sensors-page-header h1{margin:0;font-size:1.75rem;color:var(--text-dark)}.sensors-toast{padding:.85rem 1rem;border-radius:8px;font-weight:500}.sensors-toast-success{background:#388e3c1a;color:#1b5e20;border:1px solid rgba(56,142,60,.2)}.sensors-toast-error{background:#d32f2f1a;color:#b71c1c;border:1px solid rgba(211,47,47,.2)}.sensors-error{padding:1rem;border-radius:8px;border:1px solid rgba(211,47,47,.3);background:#d32f2f0d;color:#b71c1c}.sensors-table-card{background:#fff;border:1px solid rgb(0 0 0 / 14%);border-radius:8px;padding:2rem;box-shadow:1px 1px #00000014,0 1px 3px #0000000d}.sensors-loading,.sensors-empty{padding:1.5rem;text-align:center;color:var(--text-secondary)}.sensors-table{width:100%;border-collapse:collapse}.sensors-table th,.sensors-table td{padding:.85rem .75rem;border-bottom:1px solid var(--border-color);text-align:left}.sensors-table th{text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;color:var(--text-secondary)}.sensors-table input[type=text]{width:100%;padding:.5rem .65rem;border-radius:8px;border:1px solid var(--border-color);font-size:.95rem}.row-actions{display:flex;gap:.5rem}.save-button,.clear-button{border-radius:999px;padding:.35rem .9rem;border:none;cursor:pointer;font-size:.85rem}.save-button{background-color:var(--tritech-blue);color:var(--tritech-white)}.save-button:disabled{opacity:.5;cursor:not-allowed}.clear-button{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.mono{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.9rem}@media (max-width: 900px){.sensors-table{display:block;overflow-x:auto}}@media (max-width: 640px){.sensors-page-header{flex-direction:column;align-items:flex-start}.row-actions{flex-direction:column}}.thresholds-page{display:flex;flex-direction:column;gap:1.5rem}.thresholds-page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.page-eyebrow{text-transform:uppercase;letter-spacing:.08em;color:var(--tritech-blue);font-weight:600;margin:0 0 .25rem}.thresholds-page-header h1{margin:0;font-size:1.75rem;color:var(--text-dark)}.header-description{margin:.5rem 0 0;color:var(--text-secondary)}.refresh-button{border:1px solid var(--border-color);background:#fff;color:var(--text-dark);border-radius:999px;padding:.45rem 1.25rem;cursor:pointer;transition:background .2s ease,border-color .2s ease}.refresh-button:disabled{opacity:.6;cursor:not-allowed}.thresholds-toast{padding:.85rem 1rem;border-radius:8px;font-weight:500}.thresholds-toast-success{background:#388e3c1a;color:#1b5e20;border:1px solid rgba(56,142,60,.2)}.thresholds-toast-error{background:#d32f2f1a;color:#b71c1c;border:1px solid rgba(211,47,47,.2)}.thresholds-error{padding:1rem;border-radius:8px;border:1px solid rgba(211,47,47,.3);background:#d32f2f0d;color:#b71c1c}.thresholds-loading,.thresholds-empty{padding:1.5rem;text-align:center;color:var(--text-secondary)}.thresholds-sensor-selector{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border:1px solid rgb(0 0 0 / 14%);border-radius:8px;box-shadow:1px 1px #00000014,0 1px 3px #0000000d}.thresholds-sensor-selector label{font-weight:600;color:var(--text-dark)}.thresholds-sensor-selector select{flex:1;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:8px;font-size:.95rem;background:#fff;color:var(--text-dark);cursor:pointer}.thresholds-table-card{background:#fff;border:1px solid rgb(0 0 0 / 14%);border-radius:8px;padding:2rem;box-shadow:1px 1px #00000014,0 1px 3px #0000000d}.thresholds-card-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.thresholds-card-header h2{margin:0 0 .5rem;font-size:1.25rem;color:var(--text-dark)}.thresholds-card-description{margin:0;color:var(--text-secondary);font-size:.9rem}.thresholds-fields{display:flex;flex-direction:column;gap:1.5rem}.threshold-field{padding:1.5rem;border:1px solid rgb(0 0 0 / 14%);border-radius:8px;background:#fff;box-shadow:1px 1px #00000014,0 1px 3px #0000000d}.threshold-field-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.threshold-field-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-dark)}.delete-threshold-button{padding:.35rem .9rem;border:1px solid rgba(211,47,47,.3);background:transparent;color:#b71c1c;border-radius:999px;cursor:pointer;font-size:.85rem;transition:background .2s ease}.delete-threshold-button:hover:not(:disabled){background:#d32f2f1a}.delete-threshold-button:disabled{opacity:.5;cursor:not-allowed}.threshold-inputs{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;align-items:end}.threshold-input-group{display:flex;flex-direction:column;gap:.5rem}.threshold-input-group label{font-size:.85rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.threshold-input-group input{padding:.5rem .65rem;border:1px solid var(--border-color);border-radius:8px;font-size:.95rem;font-family:Courier New,monospace}.threshold-input-group input:focus{outline:none;border-color:var(--tritech-blue);box-shadow:0 0 0 3px #1b5ba21a}.threshold-actions{display:flex;align-items:flex-end}.save-threshold-button{padding:.5rem 1.25rem;border:none;background-color:var(--tritech-blue);color:var(--tritech-white);border-radius:999px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .2s ease}.save-threshold-button:hover:not(:disabled){background-color:#1a5a9f}.save-threshold-button:disabled{opacity:.5;cursor:not-allowed}.threshold-binary-note{padding:1rem;background:#1b5ba20d;border:1px solid rgba(27,91,162,.2);border-radius:8px;color:var(--text-dark)}.threshold-binary-note p{margin:0;font-size:.9rem;line-height:1.5}.threshold-binary-note strong{color:var(--tritech-blue)}@media (max-width: 768px){.thresholds-page-header{flex-direction:column;align-items:flex-start}.threshold-inputs{grid-template-columns:1fr}.threshold-field-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.alerts-log-page{display:flex;flex-direction:column;gap:1.5rem;padding:0}.alerts-log-header{margin-bottom:.5rem}.header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.page-title{font-size:1.75rem;font-weight:600;color:var(--text-dark);margin:0 0 .5rem}.page-description{font-size:.95rem;color:var(--text-secondary);margin:0}.clean-alerts-button{padding:.625rem 1.25rem;background-color:#f44336;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.clean-alerts-button:hover:not(:disabled){background-color:#d32f2f}.clean-alerts-button:disabled{opacity:.6;cursor:not-allowed}.alerts-filters{background-color:#fff;border:1px solid rgb(0 0 0 / 14%);border-radius:8px;padding:2rem;display:flex;flex-wrap:wrap;gap:1.5rem;align-items:flex-end;box-shadow:1px 1px #00000014,0 1px 3px #0000000d}.filter-group{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:150px}.filter-group label{font-size:.85rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.filter-select,.filter-input{padding:.5rem;border:1px solid var(--border-color);border-radius:6px;font-size:.95rem;font-family:inherit;background-color:var(--tritech-white);color:var(--text-dark);transition:border-color .2s}.filter-select:focus,.filter-input:focus{outline:none;border-color:var(--tritech-blue);box-shadow:0 0 0 3px #1b5ba21a}.filter-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.filter-button{padding:.5rem 1rem;background-color:var(--bg-light);border:1px solid var(--border-color);border-radius:6px;font-size:.9rem;font-weight:500;color:var(--text-dark);cursor:pointer;transition:all .2s;white-space:nowrap}.filter-button:hover:not(:disabled){background-color:var(--border-color);border-color:var(--text-secondary)}.filter-button.primary{background-color:var(--tritech-blue);color:#fff;border-color:var(--tritech-blue)}.filter-button.primary:hover:not(:disabled){background-color:#1a5a9e}.filter-button:disabled{opacity:.6;cursor:not-allowed}.auto-refresh-toggle{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-secondary);cursor:pointer}.auto-refresh-toggle input[type=checkbox]{cursor:pointer}.alerts-error{background-color:#fee;border:1px solid #fcc;border-radius:6px;padding:.75rem 1rem;color:var(--error-color);font-size:.9rem}.alerts-table-container{background-color:#fff;border:1px solid rgb(0 0 0 / 14%);border-radius:8px;overflow:hidden;box-shadow:1px 1px #00000014,0 1px 3px #0000000d}.alerts-loading,.alerts-empty{text-align:center;padding:3rem;color:var(--text-secondary);font-style:italic}.alerts-table-wrapper{max-height:600px;overflow-y:auto}.alerts-table{width:100%;border-collapse:collapse;font-size:.9rem}.alerts-table thead{background-color:var(--bg-light);position:sticky;top:0;z-index:1}.alerts-table th{padding:1rem .75rem;text-align:left;font-weight:600;color:var(--text-dark);text-transform:uppercase;font-size:.8rem;letter-spacing:.5px;border-bottom:2px solid var(--border-color)}.alerts-table td{padding:.75rem;border-bottom:1px solid var(--border-color);color:var(--text-dark)}.alerts-table tbody tr:hover{background-color:var(--bg-light)}.timestamp-cell{font-family:Courier New,monospace;font-size:.85rem;white-space:nowrap}.sensor-cell{min-width:200px}.sensor-name{font-weight:500;font-size:1rem;color:var(--text-dark)}.sensor-eui{font-size:.8rem;color:var(--text-secondary);font-family:Courier New,monospace;margin-top:.25rem}.alert-type-badge,.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:999px;color:#fff;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.message-cell{max-width:300px;word-wrap:break-word;color:var(--text-secondary);font-size:.85rem}.alerts-summary{text-align:right;font-size:.9rem;color:var(--text-secondary);padding:.5rem 0}@media (max-width: 768px){.alerts-filters{flex-direction:column}.filter-group{min-width:100%}.filter-actions{width:100%;justify-content:space-between}.alerts-table-wrapper{overflow-x:auto}.alerts-table{min-width:800px}}.users-page{width:100%;display:flex;flex-direction:column;gap:1.5rem}.users-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.users-title{font-size:1.5rem;font-weight:600;color:var(--text-dark);margin:0}.create-user-button{padding:.625rem 1.25rem;background-color:var(--tritech-blue);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .2s}.create-user-button:hover{background-color:#1a5a9e}.users-loading,.users-error{padding:1rem;border-radius:6px;text-align:center}.users-loading{background-color:var(--bg-light);color:var(--text-secondary)}.users-error{background-color:#fee;border:1px solid #fcc;color:#c33}.create-user-form-card{background-color:#fff;border:1px solid rgb(0 0 0 / 14%);border-radius:8px;padding:1.5rem;box-shadow:1px 1px #00000014,0 1px 3px #0000000d}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.form-header h3{margin:0;font-size:1.2rem;font-weight:600;color:var(--text-dark)}.close-button{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.close-button:hover{background-color:var(--bg-light)}.create-user-form-card form{display:flex;flex-direction:column;gap:1rem}.create-user-form-card .form-group{display:flex;flex-direction:column;gap:.5rem}.create-user-form-card .form-group label{font-weight:500;color:var(--text-dark);font-size:.9rem}.create-user-form-card .form-group input,.create-user-form-card .form-group select{padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:6px;font-size:.9rem;background-color:#fff}.create-user-form-card .form-group input:focus,.create-user-form-card .form-group select:focus{outline:none;border-color:var(--tritech-blue);box-shadow:0 0 0 3px #1b5ba21a}.form-error{background-color:#fee;border:1px solid #fcc;color:#c33;padding:.75rem;border-radius:6px;font-size:.9rem}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:.5rem}.form-actions button{padding:.625rem 1.25rem;border:1px solid var(--border-color);border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.form-actions button[type=button]{background-color:#fff;color:var(--text-dark)}.form-actions button[type=button]:hover{background-color:var(--bg-light)}.form-actions button[type=submit]{background-color:var(--tritech-blue);color:#fff;border-color:var(--tritech-blue)}.form-actions button[type=submit]:hover:not(:disabled){background-color:#1a5a9e}.form-actions button:disabled{opacity:.6;cursor:not-allowed}.users-table-card{background-color:#fff;border:1px solid rgb(0 0 0 / 14%);border-radius:8px;padding:1.5rem;box-shadow:1px 1px #00000014,0 1px 3px #0000000d;overflow-x:auto}.users-table{width:100%;border-collapse:collapse}.users-table thead{background-color:var(--bg-light)}.users-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--text-dark);font-size:.9rem;border-bottom:2px solid var(--border-color)}.users-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);color:var(--text-dark)}.users-table tbody tr:hover{background-color:var(--bg-light)}.empty-state{text-align:center;color:var(--text-secondary);padding:2rem}.username-cell{font-weight:500}.role-cell{min-width:120px}.role-select{padding:.375rem .625rem;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem;background-color:#fff;cursor:pointer}.role-select:focus{outline:none;border-color:var(--tritech-blue);box-shadow:0 0 0 3px #1b5ba21a}.date-cell{color:var(--text-secondary);font-size:.9rem;white-space:nowrap}.actions-cell{text-align:right}.action-buttons{display:flex;gap:.5rem;justify-content:flex-end}.edit-button{padding:.375rem .75rem;background-color:#e3f2fd;color:#1976d2;border:1px solid #90caf9;border-radius:4px;font-size:.85rem;cursor:pointer;transition:all .2s}.edit-button:hover{background-color:#bbdefb;border-color:#64b5f6}.delete-button{padding:.375rem .75rem;background-color:#fee;color:#c33;border:1px solid #fcc;border-radius:4px;font-size:.85rem;cursor:pointer;transition:all .2s}.delete-button:hover{background-color:#fcc;border-color:#f99}@media (max-width: 768px){.users-header{flex-direction:column;align-items:stretch}.create-user-button{width:100%}.users-table{font-size:.85rem}.users-table th,.users-table td{padding:.5rem}}.system-settings-page{display:flex;flex-direction:column;gap:1.5rem;padding:2rem}.system-settings-card{background:#fff;border:1px solid rgb(0 0 0 / 14%);border-radius:8px;padding:2rem;box-shadow:1px 1px #00000014,0 1px 3px #0000000d}.system-settings-card h1{margin:0;font-size:1.75rem;color:var(--text-dark);font-weight:600}.dashboard-header{width:100%;padding:1.5rem var(--page-padding-x);background:linear-gradient(135deg,#1b5ba214,#f9b04114)}.dashboard-title{font-size:1.75rem;font-weight:600;color:var(--text-dark);margin:0;letter-spacing:.5px}.app-container{display:flex;flex-direction:column;gap:1.5rem;width:100%;background-color:#fafcff;padding:1.5rem;min-height:100vh}.sensor-list-panel,.sensor-details-panel{width:100%}.sensor-list-panel,.sensor-details-panel{background-color:#fff;border:1px solid rgb(0 0 0 / 14%);border-radius:8px;padding:2rem;box-shadow:1px 1px #00000014,0 1px 3px #0000000d}.app-loading{text-align:center;padding:3rem;font-size:1.1rem;color:var(--text-secondary)}.error-banner{background-color:#d32f2f1a;border-left:4px solid var(--error-color);color:var(--error-color);padding:1rem 1.5rem;margin-bottom:1rem;border-radius:4px;font-weight:500}@media (max-width: 768px){.dashboard-header{padding:1rem var(--page-padding-x)}.dashboard-title{font-size:1.25rem}.app-container{gap:1rem}.sensor-list-panel,.sensor-details-panel{padding:1.25rem;border-radius:8px}.app-loading{padding:2rem 1rem;font-size:1rem}.error-banner{padding:.75rem 1rem;font-size:.9rem}}:root{--tritech-blue: #1B5BA2;--tritech-orange: #F9B041;--tritech-white: #FFFFFF;--bg-light: #F5F5F5;--text-dark: #222222;--border-color: #E0E0E0;--text-secondary: #666666;--error-color: #D32F2F;--success-color: #388E3C}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fafcff;color:var(--text-dark)}#root{min-height:100vh;display:flex;flex-direction:column}
