@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap);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;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.device-status-card{background:#fff;border:1px solid #e1e8ed;border-radius:16px;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;margin-bottom:24px;padding:28px;transition:box-shadow .2s ease}.device-status-card:hover{box-shadow:0 4px 12px #00000014,0 2px 4px #0000000a}.device-header{border-bottom:1px solid #e1e8ed;justify-content:space-between;margin-bottom:24px;padding-bottom:20px}.device-header,.device-title{align-items:center;display:flex}.device-title{gap:12px}.device-icon{color:#6c5ce7;flex-shrink:0;height:28px;width:28px}.device-header h2{color:#2d3436;font-size:22px;font-weight:600;letter-spacing:-.3px;margin:0}.status-badge{align-items:center;border-radius:12px;display:flex;font-size:13px;font-weight:500;gap:8px;letter-spacing:.2px;padding:8px 16px}.status-dot{animation:pulse-dot 2s ease-in-out infinite;border-radius:50%;height:8px;width:8px}.status-badge.online{background:#d4edda;color:#155724}.status-badge.online .status-dot{background:#28a745}.status-badge.offline{background:#f8d7da;color:#721c24}.status-badge.offline .status-dot{background:#dc3545}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.9)}}.device-info{display:flex;flex-direction:column;gap:16px}.info-row{align-items:center;background:#fafbfc;border:1px solid #f1f3f5;border-radius:10px;display:flex;justify-content:space-between;padding:14px 16px;transition:background .2s ease}.info-row:hover{background:#f5f7fa;border-color:#e1e8ed}.info-label{align-items:center;color:#636e72;display:flex;font-size:14px;font-weight:500;gap:10px;letter-spacing:.1px}.info-icon{color:#95a5a6;flex-shrink:0;height:18px;width:18px}.info-value{color:#2d3436;font-family:SF Mono,Monaco,Courier New,monospace;font-size:14px;font-weight:500}.info-value-group{align-items:center;display:flex;gap:8px}.info-value.masked{background:#fff;border:1px solid #e1e8ed;border-radius:6px;font-size:13px;max-width:200px;overflow:hidden;padding:6px 12px;text-overflow:ellipsis;white-space:nowrap}.icon-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#95a5a6;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s ease}.icon-btn svg{height:18px;width:18px}.icon-btn:hover{background:#e1e8ed;color:#6c5ce7}.icon-btn:active{transform:scale(.95)}.icon-btn.copied{background:#d4edda;color:#28a745}.icon-btn.copied:hover{background:#c3e6cb}@media (max-width:768px){.device-status-card{padding:20px}.device-header h2{font-size:18px}.info-row{align-items:flex-start;flex-direction:column;gap:12px}.info-value-group{width:100%}.info-value.masked{flex:1 1;max-width:100%}}.device-map-card{background:#fff;border:1px solid #e1e8ed;border-radius:16px;box-shadow:0 2px 8px #0000000f;margin-bottom:24px;padding:28px;transition:all .3s ease}.device-map-card:hover{box-shadow:0 4px 12px #00000014}.map-header{border-bottom:1px solid #f1f3f5;justify-content:space-between;margin-bottom:28px;padding-bottom:20px}.map-header,.map-title{align-items:center;display:flex}.map-title{gap:12px}.map-icon{color:#6c5ce7;flex-shrink:0;height:28px;width:28px}.map-header h3{color:#2d3436;font-size:20px;font-weight:600;letter-spacing:-.3px;margin:0}.location-badge,.location-info{align-items:center;display:flex}.location-badge{background:#f5f3ff;border:1px solid #e5dff9;border-radius:20px;color:#6c5ce7;font-size:12px;font-weight:500;gap:6px;letter-spacing:.2px;padding:6px 14px}.badge-icon{flex-shrink:0;height:14px;width:14px}.map-wrapper{background:#fafbfc;border:1px solid #f1f3f5;border-radius:12px;padding:16px}.map-container{border-radius:10px;box-shadow:0 2px 8px #0000000f;overflow:hidden}.map-error-message{background:#fff5f5;border:1px solid #fed7d7;border-radius:12px;color:#c53030;display:flex;gap:16px;margin-bottom:20px;padding:20px}.error-icon{color:#e53e3e;flex-shrink:0;height:24px;width:24px}.map-error-message strong{display:block;font-size:14px;font-weight:600;margin-bottom:4px}.map-error-message p{font-size:13px;line-height:1.5;margin:4px 0}.help-text{color:#9b2c2c;font-size:12px;margin-top:8px}.map-popup{min-width:200px;padding:4px}.map-popup h4{color:#2d3436;font-size:15px;font-weight:600;margin:0 0 12px}.popup-details{display:flex;flex-direction:column;gap:8px}.popup-row{align-items:center;color:#636e72;display:flex;font-size:13px;gap:8px}.popup-icon{color:#6c5ce7;flex-shrink:0;height:16px;width:16px}.coordinates{font-family:Courier New,monospace;font-size:12px}@media (max-width:768px){.device-map-card{padding:20px}.map-header{align-items:flex-start;flex-direction:column;gap:12px}.map-wrapper{padding:12px}}.sensor-gauges-card{background:#fff;border:1px solid #e1e8ed;border-radius:16px;box-shadow:0 2px 8px #0000000f;margin-bottom:24px;padding:28px;transition:all .3s ease}.sensor-gauges-card:hover{box-shadow:0 4px 12px #00000014}.gauges-header{border-bottom:1px solid #f1f3f5;justify-content:space-between;margin-bottom:28px;padding-bottom:20px}.gauges-header,.gauges-title{align-items:center;display:flex}.gauges-title{gap:12px}.gauges-icon{color:#6c5ce7;flex-shrink:0;height:28px;width:28px}.gauges-header h3{color:#2d3436;font-size:20px;font-weight:600;letter-spacing:-.3px;margin:0}.simulated-badge{align-items:center;background:#f5f3ff;border:1px solid #e5dff9;border-radius:20px;color:#6c5ce7;display:flex;font-size:12px;font-weight:500;gap:6px;letter-spacing:.2px;padding:6px 14px}.simulated-badge svg{flex-shrink:0}.gauges-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.gauge-item{background:#fafbfc;border:1px solid #f1f3f5;border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:24px;transition:all .3s ease}.gauge-item:hover{background:#f8f7ff;border-color:#e5dff9;box-shadow:0 4px 12px #6c5ce714;transform:translateY(-2px)}.gauge-header-row{align-items:center;display:flex;gap:12px}.gauge-icon-svg{flex-shrink:0;height:32px;width:32px}.gauge-label{color:#636e72;font-size:14px;font-weight:500;letter-spacing:.2px}.gauge-value{color:#2d3436;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:36px;font-weight:700;letter-spacing:-1px;line-height:1}.aqi-label{font-size:13px;font-weight:600;letter-spacing:.5px;margin-top:-4px;text-transform:uppercase}.gauge-timestamp{border-top:1px solid #f1f3f5;color:#95a5a6;font-size:12px;font-weight:400;margin-top:auto;padding-top:8px}.no-sensor-data{align-items:center;color:#95a5a6;display:flex;flex-direction:column;gap:12px;padding:60px 20px;text-align:center}.no-sensor-data svg{margin-bottom:8px}.no-sensor-data p{color:#636e72;font-size:16px;font-weight:500;margin:0}.no-sensor-data small{color:#95a5a6;font-size:13px;font-weight:400}@media (max-width:768px){.sensor-gauges-card{padding:20px}.gauges-header{align-items:flex-start;flex-direction:column;gap:12px}.gauges-grid{grid-template-columns:1fr}.gauge-value{font-size:32px}}.notification{align-items:center;animation:slideIn .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;box-shadow:0 4px 12px #00000026;display:flex;gap:16px;max-width:500px;min-width:320px;overflow:hidden;padding:16px 20px;position:relative}@keyframes slideIn{0%{opacity:0;transform:translateX(400px)}to{opacity:1;transform:translateX(0)}}.notification:before{background:currentColor;bottom:0;content:"";left:0;position:absolute;top:0;width:4px}.notification-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center}.notification-content{flex:1 1;min-width:0}.notification-message{font-size:14px;font-weight:500;letter-spacing:.2px;line-height:1.5;margin:0}.notification-close{align-items:center;background:#0000;border:none;border-radius:6px;color:inherit;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;opacity:.6;padding:6px;transition:all .2s ease}.notification-close:hover{background:#0000001a;opacity:1}.notification-success{background:#e8f5e9;border:1px solid #c8e6c9;color:#27ae60}.notification-success .notification-message{color:#1b5e20}.notification-error{background:#ffebee;border:1px solid #ffcdd2;color:#e74c3c}.notification-error .notification-message{color:#c62828}.notification-warning{background:#fff3e0;border:1px solid #ffe0b2;color:#f39c12}.notification-warning .notification-message{color:#e65100}.notification-info{background:#f5f3ff;border:1px solid #e5dff9;color:#6c5ce7}.notification-info .notification-message{color:#5b4bc4}.notification-container{display:flex;flex-direction:column;gap:12px;pointer-events:none;position:fixed;right:24px;top:24px;z-index:9999}.notification-container .notification{pointer-events:all}@media (max-width:768px){.notification-container{left:16px;right:16px;top:16px}.notification{min-width:auto;width:100%}}.popup-backdrop{animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:9998}.popup{animation:popupSlideIn .4s cubic-bezier(.68,-.55,.265,1.55);background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;left:50%;max-width:500px;min-width:360px;padding:40px 32px 32px;position:fixed;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:9999}@keyframes popupSlideIn{0%{opacity:0;transform:translate(-50%,-60%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.popup-icon{align-items:center;animation:iconBounce .6s ease;display:flex;justify-content:center;margin:0 auto 24px}@keyframes iconBounce{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.popup-icon-svg{filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.popup-success .popup-icon-svg,.popup-success .popup-title{color:#27ae60}.popup-error .popup-icon-svg,.popup-error .popup-title{color:#e74c3c}.popup-warning .popup-icon-svg,.popup-warning .popup-title{color:#f39c12}.popup-info .popup-icon-svg,.popup-info .popup-title{color:#6c5ce7}.popup-title{font-size:24px;font-weight:700;letter-spacing:-.5px;margin:0 0 12px}.popup-message{color:#636e72;font-size:15px;font-weight:400;line-height:1.6;margin:0 0 28px}.popup-close-btn{background:linear-gradient(135deg,#6c5ce7,#5b4bc4);border:none;border-radius:12px;box-shadow:0 4px 12px #6c5ce74d;color:#fff;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:.5px;padding:14px 24px;transition:all .3s ease;width:100%}.popup-close-btn:hover{box-shadow:0 6px 16px #6c5ce766;transform:translateY(-2px)}.popup-close-btn:active{transform:translateY(0)}.popup-success .popup-close-btn{background:linear-gradient(135deg,#27ae60,#219a52);box-shadow:0 4px 12px #27ae604d}.popup-success .popup-close-btn:hover{box-shadow:0 6px 16px #27ae6066}.popup-error .popup-close-btn{background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 4px 12px #e74c3c4d}.popup-error .popup-close-btn:hover{box-shadow:0 6px 16px #e74c3c66}.popup-warning .popup-close-btn{background:linear-gradient(135deg,#f39c12,#e67e22);box-shadow:0 4px 12px #f39c124d}.popup-warning .popup-close-btn:hover{box-shadow:0 6px 16px #f39c1266}@media (max-width:768px){.popup{max-width:400px;min-width:auto;padding:32px 24px 24px;width:calc(100% - 40px)}.popup-title{font-size:20px}.popup-message{font-size:14px}.popup-icon-svg{height:56px;width:56px}}.settings-panel{background:#fff;border:1px solid #e1e8ed;border-radius:16px;box-shadow:0 2px 8px #0000000f;margin-bottom:24px;padding:28px;transition:all .3s ease}.settings-panel:hover{box-shadow:0 4px 12px #00000014}.settings-header{align-items:center;border-bottom:1px solid #f1f3f5;display:flex;justify-content:space-between;margin-bottom:28px;padding-bottom:20px}.settings-title{align-items:center;display:flex;gap:12px}.settings-icon{color:#6c5ce7;flex-shrink:0;height:28px;width:28px}.settings-header h3{color:#2d3436;font-size:20px;font-weight:600;letter-spacing:-.3px;margin:0}.btn-save{align-items:center;background:#6c5ce7;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;letter-spacing:.2px;padding:10px 20px;transition:all .3s ease}.btn-save:hover:not(:disabled){background:#5b4bc4;box-shadow:0 4px 12px #6c5ce74d;transform:translateY(-1px)}.btn-save:disabled{cursor:not-allowed;opacity:.6}.btn-icon{flex-shrink:0}.spinning{animation:spin 1s linear infinite}.settings-tabs{border-bottom:2px solid #f1f3f5;display:flex;gap:4px;margin-bottom:28px;overflow-x:auto;scrollbar-width:thin}.settings-tabs::-webkit-scrollbar{height:4px}.settings-tabs::-webkit-scrollbar-track{background:#f8f9fa}.settings-tabs::-webkit-scrollbar-thumb{background:#dfe6e9;border-radius:2px}.tab{align-items:center;background:#0000;border:none;border-bottom:3px solid #0000;color:#95a5a6;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;letter-spacing:.2px;padding:12px 18px;transition:all .3s ease;white-space:nowrap}.tab.active,.tab:hover{background:#f8f7ff;color:#6c5ce7}.tab.active{border-bottom-color:#6c5ce7}.tab-icon{flex-shrink:0}.settings-content{min-height:400px}.settings-section{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.settings-section h4{color:#2d3436;font-size:18px;font-weight:600;letter-spacing:-.2px;margin:0 0 24px}.section-header{align-items:center;display:flex;justify-content:space-between}.form-group,.section-header{margin-bottom:24px}.form-group label{color:#636e72;display:block;font-size:13px;font-weight:500;letter-spacing:.2px;margin-bottom:8px}.form-group input,.form-group select,.location-autocomplete-input{background:#fafbfc;border:1px solid #e1e8ed;border-radius:10px;box-sizing:border-box;color:#2d3436;font-family:inherit;font-size:14px;padding:12px 14px;transition:all .3s ease;width:100%}.form-group input:focus,.form-group select:focus,.location-autocomplete-input:focus{background:#fff;border-color:#6c5ce7;box-shadow:0 0 0 3px #6c5ce71a;outline:none}.form-group input::placeholder,.location-autocomplete-input::placeholder{color:#b2bec3}.form-group small{color:#95a5a6;display:block;font-size:12px;line-height:1.4;margin-top:6px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.checkbox-label{align-items:center;color:#2d3436!important;cursor:pointer;display:flex!important;font-size:14px!important;font-weight:500!important;letter-spacing:0!important}.checkbox-label input[type=checkbox]{accent-color:#6c5ce7;cursor:pointer;height:18px!important;margin-right:10px;width:18px!important}.btn-add{align-items:center;background:#e8f5e9;border:1px solid #27ae60;border-radius:10px;color:#27ae60;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;letter-spacing:.2px;padding:8px 16px;transition:all .3s ease}.btn-add:hover:not(:disabled){background:#27ae60;box-shadow:0 4px 12px #27ae6033;color:#fff;transform:translateY(-1px)}.btn-add:disabled{cursor:not-allowed;opacity:.5}.card-item,.route-item{background:#fafbfc;border:1px solid #e1e8ed;border-radius:12px;margin-bottom:16px;padding:20px;transition:all .3s ease}.card-item:hover,.route-item:hover{border-color:#dfe6e9;box-shadow:0 2px 8px #0000000a}.card-header,.route-header{align-items:center;border-bottom:1px solid #e1e8ed;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.card-header span,.route-header span{color:#6c5ce7;font-size:14px;font-weight:600;letter-spacing:.2px}.btn-remove{align-items:center;background:#0000;border:none;border-radius:6px;color:#e74c3c;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s ease}.btn-remove:hover{background:#ffe5e5;transform:scale(1.1)}.empty-message{color:#95a5a6;font-size:14px;line-height:1.6;padding:60px 20px;text-align:center}.btn-test-summary{align-items:center;background:#fff3e0;border:1px solid #f39c12;border-radius:10px;color:#f39c12;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;letter-spacing:.2px;margin-top:8px;padding:12px 20px;transition:all .3s ease}.btn-test-summary:hover:not(:disabled){background:#f39c12;box-shadow:0 4px 12px #f39c1233;color:#fff;transform:translateY(-1px)}.btn-test-summary:disabled{cursor:not-allowed;opacity:.5}.location-dropdown{background:#fff;border:1px solid #e1e8ed;border-radius:10px;box-shadow:0 4px 12px #0000001a;left:0;max-height:300px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 4px);z-index:1000}.location-dropdown-item{align-items:center;border-bottom:1px solid #f1f3f5;color:#2d3436;cursor:pointer;display:flex;font-size:14px;gap:12px;padding:12px 14px;transition:background .2s ease}.location-dropdown-item:last-child{border-bottom:none}.location-dropdown-item:hover{background:#f8f7ff}.location-dropdown-item svg{color:#6c5ce7}.location-dropdown-item span{flex:1 1}@media (max-width:768px){.settings-panel{padding:20px}.settings-header{align-items:flex-start;flex-direction:column;gap:16px}.form-row{grid-template-columns:1fr}.settings-tabs{gap:2px}.tab{font-size:13px;padding:10px 14px}.tab-icon{height:16px;width:16px}}*{box-sizing:border-box;margin:0;padding:0}body{background:#f5f7fa;color:#2d3436;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;overflow-x:hidden}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff;border-bottom:1px solid #e1e8ed;box-shadow:0 1px 3px #0000000a;padding:20px 0;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-content{justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 32px}.header-content,.logo{align-items:center;display:flex}.logo{gap:12px}.logo-icon{color:#6c5ce7;height:32px;transition:transform .3s ease;width:32px}.logo:hover .logo-icon{transform:rotate(5deg)}.logo h1{color:#2d3436;font-size:24px;font-weight:600;letter-spacing:-.5px;margin:0}.nav-buttons{display:flex;gap:8px}.nav-btn{background:#0000;border:none;border-radius:8px;color:#636e72;cursor:pointer;font-size:14px;font-weight:500;letter-spacing:.2px;padding:10px 20px;transition:all .2s ease}.nav-btn.active,.nav-btn:hover{background:#f5f3ff;color:#6c5ce7}.nav-btn.active{font-weight:600}.app-main{background:#f5f7fa;flex:1 1;padding:32px 0}.container{margin:0 auto;max-width:1400px;padding:0 24px}.grid-2-col{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}@media (max-width:1024px){.grid-2-col{grid-template-columns:1fr}}.app-footer{background:#fff;border-top:1px solid #e1e8ed;color:#95a5a6;font-size:13px;font-weight:400;padding:20px 0;text-align:center}.sync-indicator{animation:pulse 2s infinite;color:#6c5ce7;font-weight:500}.connection-indicator{align-items:center;display:inline-flex;font-weight:500}.connection-indicator.connected{color:#27ae60}.connection-indicator.reconnecting{animation:pulse 2s infinite;color:#f39c12}.connection-indicator.error{color:#e74c3c}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.app-loading{align-items:center;background:#f5f7fa;color:#6c5ce7;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loader{animation:spin 1s ease-in-out infinite;border:3px solid #e1e8ed;border-radius:50%;border-top-color:#6c5ce7;height:48px;margin-bottom:20px;width:48px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.app-loading p{color:#2d3436;font-size:16px;font-weight:500}.app-error{align-items:center;background:#f5f7fa;color:#2d3436;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:40px;text-align:center}.app-error h2{color:#e74c3c;font-size:24px;font-weight:600;margin-bottom:16px}.app-error p{color:#636e72;font-size:15px;margin-bottom:24px}.app-error button{background:#6c5ce7;border:none;border-radius:8px;box-shadow:0 2px 8px #6c5ce733;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:12px 28px;transition:all .2s ease}.app-error button:hover{background:#5f4dd4;box-shadow:0 4px 12px #6c5ce74d;transform:translateY(-1px)}.error-details{background:#fff;border:1px solid #e1e8ed;border-radius:12px;margin-top:32px;max-width:500px;padding:24px}.error-details p{color:#636e72;font-size:14px;margin-bottom:12px}.error-details code{background:#f8f9fa;border:1px solid #e1e8ed;border-radius:8px;color:#6c5ce7;display:block;font-family:SF Mono,Monaco,Courier New,monospace;font-size:13px;padding:12px 16px}@media (max-width:768px){.header-content{flex-direction:column;gap:16px}.logo h1{font-size:24px}.nav-buttons{width:100%}.nav-btn{flex:1 1;font-size:13px}.container{padding:0 16px}}
/*# sourceMappingURL=main.ff6e3370.css.map*/