@import url(https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700&family=Roboto:wght@400;500;700&display=swap);.login-container{align-items:center;background:linear-gradient(135deg,#667eea99,#764ba299),url(/static/media/conny-schneider-xuTJZ7uD7PI-unsplash.adbd1710e78f29a10723.jpg) 50%/cover no-repeat;display:flex;font-family:Lato,sans-serif;justify-content:center;min-height:100vh}.login-box{background-color:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;max-width:400px;padding:40px;text-align:center;width:100%}.login-logo{margin-bottom:20px;width:250px}.login-box h1{color:#333;font-size:28px;font-weight:700;margin:0 0 10px}.login-box h2{color:#333;font-size:24px;font-weight:400;margin-bottom:30px}.login-box h2,.login-error{font-family:Lato,sans-serif}.login-error{background-color:#f8e8e8;border:1px solid #e0b0b0;border-radius:4px;color:#8c2222;margin-bottom:20px;padding:12px}.login-form{gap:20px}.form-group,.login-form{display:flex;flex-direction:column}.form-group{position:relative}.form-group label{background-color:#fff;color:#474747;font-family:Roboto,sans-serif;font-size:14px;font-weight:500;left:12px;padding:0 6px;position:absolute;top:-10px;z-index:1}.required{color:#8c2222;margin-left:2px}.required-hint{color:#8c2222;font-size:12px;margin-bottom:2px;margin-top:-10px;text-align:left}.form-group input:not(.password-input):invalid:not(:placeholder-shown),.password-input:invalid:not(:placeholder-shown){border-color:#8c2222!important}.form-group input:not(.password-input):invalid:not(:placeholder-shown):focus,.password-input:invalid:not(:placeholder-shown):focus{border-color:#8c2222!important;box-shadow:0 0 0 3px #8c22221a!important}.form-group input:not(.password-input){border:2px solid #1b1c3b;border-radius:6px;box-sizing:border-box;font-family:Lato,sans-serif;font-size:16px;padding:14px 12px;transition:border-color .3s,box-shadow .3s;width:100%}.form-group input:not(.password-input):focus{border-color:#cbe8fb;box-shadow:0 0 0 3px #cbe8fb33;outline:none}.form-group input:not(.password-input):disabled{background-color:#f5f5f5;border-color:#999;cursor:not-allowed}.password-input-wrapper{position:relative;width:100%}.password-input{border:2px solid #1b1c3b!important;border-radius:6px!important;box-sizing:border-box!important;font-family:Lato,sans-serif!important;font-size:16px!important;padding:14px 12px!important;transition:border-color .3s,box-shadow .3s!important;width:100%!important}.password-input:focus{border-color:#cbe8fb!important;box-shadow:0 0 0 3px #cbe8fb33!important;outline:none!important}.password-input:disabled{background-color:#f5f5f5!important;border-color:#999!important;cursor:not-allowed!important}.password-toggle{align-items:center;background:none;border:none;color:#1b1c3b;cursor:pointer;display:flex;font-size:18px;height:auto;justify-content:center;padding:6px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:color .3s;width:auto;z-index:10}.password-toggle:hover:not(:disabled){color:#667eea}.password-toggle:focus{border-radius:4px;outline:2px solid #cbe8fb;outline-offset:2px}.password-toggle:disabled{cursor:not-allowed;opacity:.6}.login-form button:not(.password-toggle){background-color:#1b1c3b;border:none;border-radius:6px;box-shadow:0 2px 8px #1b1c3b26;color:#fff;cursor:pointer;font-family:Roboto,sans-serif;font-size:16px;font-weight:600;padding:12px;transition:background-color .3s;width:100%}.login-form button:not(.password-toggle):focus{outline:3px solid #cbe8fb;outline-offset:2px}.login-form button:not(.password-toggle):hover:not(:disabled){background-color:#cbe8fb;box-shadow:0 4px 12px #1b1c3b40;color:#1b1c3b}.login-form button:not(.password-toggle):disabled{background-color:#999;cursor:not-allowed}.login-links{display:flex;gap:10px;justify-content:space-between;margin-top:20px}.link-button{background:none;border:2px solid #1b1c3b;border-radius:6px;box-shadow:0 2px 8px #1b1c3b1a;color:#1b1c3b;cursor:pointer;flex:1 1;font-family:Roboto,sans-serif;font-size:14px;font-weight:500;padding:10px;transition:all .3s}.link-button:focus{outline:3px solid #cbe8fb;outline-offset:2px}.link-button:hover:not(:disabled){background-color:#1b1c3b;border-color:#1b1c3b;box-shadow:0 4px 12px #1b1c3b40;color:#fff}.link-button:disabled{border-color:#999;color:#999;cursor:not-allowed}.device-toolbar{align-items:flex-end;display:flex;justify-content:space-between;margin:24px 40px 16px;padding-bottom:0;padding-top:10px}.device-toolbar-left{align-items:center;display:flex;gap:16px}.device-title{margin:0}.export-button,.sort-button{align-items:center;background-color:#1b1c3b;border:none;border-radius:24px;box-shadow:0 2px 6px #00000026;color:#fff;cursor:pointer;display:flex;gap:1px;padding:6px 12px}.sort-button:hover{background-color:#cbe8fb;color:#1b1c3b}.sort-icon{font-size:14px}.export-button{flex-direction:column;height:50px;text-align:center;width:150px}.export-button:hover{background-color:#cbe8fb;color:#1b1c3b}.export-icon{font-size:14px;line-height:1;margin-bottom:4px}.device-toolbar-right{align-items:center;display:flex;gap:12px}.search-wrapper{align-items:center;display:flex;position:relative}.search-label{background:#fff;color:#474747;font-family:Roboto,sans-serif;font-size:12px;font-weight:400;left:12px;padding:0 4px;position:absolute;top:-10px}.search-input{border:2px solid #1b1c3b;border-radius:4px;font-size:14px;height:45px;outline:none;padding:0 32px}.search-icon-left{left:10px;pointer-events:none}.search-clear,.search-icon-left{color:#1b1c3b;font-size:14px;position:absolute}.search-clear{cursor:pointer;right:10px}.device-list{display:flex;flex-direction:column;gap:10px;margin:0 40px}.device-row{align-items:center;display:grid;grid-template-columns:1.5fr 2.5fr 1.4fr 1fr .6fr .6fr;padding:10px 20px}.device-row>div{text-align:center}.device-row>div:first-child{text-align:left}.device-header{color:#474747;font-family:Roboto,sans-serif;font-size:14px;font-weight:600;padding-left:18px}.device-item{background:#e6e6e6;border-radius:999px;box-shadow:0 2px 6px #0000001a;font-size:14px}.clickable-row{cursor:pointer}.clickable-row:hover{background:#d9d9d9}.clickable-row:focus-visible{outline:2px solid #1b1c3b;outline-offset:-2px}.clickable-row .group-badge,.clickable-row .status-badge{cursor:default}.status-badge{border-radius:999px;display:inline-block;font-size:14px;font-weight:600;padding:4px 20px}.status-badge.active{background:#185226;color:#fff}.status-badge.inactive{background:#8c2222;color:#fff}.icon-button.delete,.icon-button.open{color:#1b1c3b}.group-badges{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.group-badge{background:#fff;border-radius:999px;font-size:14px;padding:4px 10px;white-space:nowrap}.search-suggestions{background:#cbe8fb;border-radius:4px;box-shadow:0 4px 10px #00000026;left:0;max-height:200px;overflow-y:auto;position:absolute;right:0;top:52px;z-index:10}.search-suggestion{border-radius:6px;cursor:pointer;padding:8px 12px}.search-suggestion:hover{background:#1b1c3b;color:#fff}.sort-dropdown{background:#cbe8fb;border-radius:6px;box-shadow:0 4px 10px #00000026;left:0;min-width:160px;position:absolute;top:calc(100% + 6px);z-index:50}.sort-option{border-radius:6px;cursor:pointer;padding:8px 12px}.sort-option.active,.sort-option:hover{background:#1b1c3b;color:#fff}.sort-option.active{font-weight:600}.sort-wrapper{display:inline-block;position:relative}.sort-option:focus-visible,button:focus-visible{outline:2px solid #1b1c3b;outline-offset:2px}.error-message{align-items:center;background-color:#e6e6e6;border-left:4px solid #8c2222;border-radius:6px;color:#8c2222;display:flex;font-size:14px;font-weight:600;gap:10px;line-height:1.4;margin:16px 40px;padding:12px}.error-message:before{content:"⚠️";font-size:18px;line-height:1}.status-bar{border-radius:6px;color:#185226;font-size:14px;margin:0 40px;padding-bottom:5px}@media (max-width:1024px){.device-row{grid-template-columns:1.5fr 2fr 1fr .5fr .5fr}.device-row>div:nth-child(3){display:none}}@media (max-width:768px){.device-toolbar{align-items:stretch;flex-direction:column;gap:12px;margin:16px 16px 12px}.device-toolbar-left{justify-content:space-between}.device-toolbar-right,.search-input{width:100%}.device-list{margin:0 16px}.device-header{display:none}.device-row{gap:8px;grid-template-columns:1fr auto auto;padding:10px 14px}.device-row>div:nth-child(2),.device-row>div:nth-child(3){display:none}.device-item{border-radius:12px}.error-message{margin:12px 16px}.status-bar{margin:0 16px}.pagination-controls{margin-right:16px}.export-button{flex-direction:row;height:auto;padding:6px 12px;width:auto}}@media (max-width:480px){.device-toolbar{margin:12px 10px 8px}.device-list{margin:0 10px}.device-row{font-size:13px;padding:8px 10px}.pagination-controls{gap:4px;margin-right:10px}}.device-detail-page{font-family:Roboto,sans-serif;margin:24px 40px;padding-top:10px}.device-detail-header{align-items:flex-end;display:flex;justify-content:space-between;margin-bottom:10px}.device-title{align-items:center;display:flex;font-size:20px;font-weight:700;gap:12px}.device-detail-page .status-badge{font-weight:500;padding:4px 12px}.back-button{background-color:#1b1c3b;border:none;border-radius:24px;box-shadow:0 2px 6px #00000026;color:#fff;cursor:pointer;gap:1px;padding:6px 12px}.back-button,.header-left{align-items:center;display:flex}.header-left{gap:12px}.device-actions{display:flex;gap:10px}.action-buttons{flex-direction:column;height:50px;text-align:center;width:150px}action-button-icon{font-size:14px;line-height:1;margin-bottom:4px}.device-actions button{align-items:center;background-color:#1b1c3b;border:none;border-radius:24px;box-shadow:0 2px 6px #00000026;color:#fff;cursor:pointer;display:flex;gap:1px;padding:6px 12px}.device-actions button:hover{background:#cbe8fb;color:#1b1c3b}.device-actions button.danger{background:#8c2222}.device-actions button.danger:hover{background:#f5d6d6;color:#8c2222}.device-detail-grid{grid-gap:24px;align-items:stretch;display:grid;gap:24px;grid-template-columns:1fr 1fr}.card{background:#d6ecff;border-radius:16px;padding:20px 24px;position:relative}.card-title{color:#1b1c3b;font-family:Lato,sans-serif;font-size:16px;font-weight:700;margin-bottom:8px}.card dl{grid-row-gap:14px;grid-column-gap:12px;column-gap:12px;display:grid;font-size:14px;grid-template-columns:120px 1fr;row-gap:14px}.card dt{font-weight:600}.card dd,.card dt{color:#1b1c3b;font-family:Lato,sans-serif}.card dd{margin:0}.card .edit{align-items:center;background:#1b1c3b;border:none;border-radius:24px;bottom:16px;box-shadow:0 2px 6px #00000026;color:#fff;cursor:pointer;display:flex;font-family:Roboto,sans-serif;font-size:14px;gap:1px;padding:6px 12px;position:absolute;right:16px}.card .edit:hover{background:#fff;color:#1b1c3b;font-weight:600}.card table{border-collapse:collapse;font-size:14px;width:100%}.card thead th{font-weight:500;padding-bottom:10px;text-align:left}.card tbody td{border-top:1px solid #0000001a;font-family:Lato,sans-serif;padding:10px}.card-details,.telemetry-card{height:320px}.telemetry-scroll{flex:1 1;min-height:0;overflow-y:auto;padding-right:4px}.list-item{align-items:center;background:#fff;border-radius:999px;display:flex;font-size:14px;justify-content:space-between;margin-bottom:10px;padding:8px 16px}.list-item.clickable-row{cursor:pointer}.list-item.clickable-row:hover{background:#ececec}.list-item.clickable-row:focus-visible{outline:2px solid #1b1c3b;outline-offset:-2px}.list-item button{background:none;border:none;cursor:pointer;font-size:14px}.list-item .actions{display:flex;gap:25px}.alarm-name{color:#000;font-family:Lato,sans-serif;font-weight:500;margin-right:10px;white-space:nowrap}.alarm-main{align-items:center;display:flex;gap:4px}.add-alarm{align-self:flex-start;margin-top:12px}.severity-badge{background:#d9d9d9;border-radius:999px;font-size:12px;font-weight:400;padding:3px 12px}.alarm-status,.sort-button.alarm-status-button{font-family:Roboto,sans-serif;font-size:12px;padding:4px 10px}.alarm-status{background:#fff;border-radius:999px;box-shadow:0 2px 6px #00000026;font-weight:400}.alarm-status-dropdown{font-family:Lato,sans-serif;font-size:14px;font-weight:400;line-height:1.4}.alarm-status-button:not(:disabled).status-ACTIVE_ACK,.alarm-status-button:not(:disabled).status-ACTIVE_UNACK{background-color:#8c2222;color:#fff}.alarm-status-button.status-CLEARED_ACK{background-color:#185226;color:#fff}.alarm-status-button:disabled{box-shadow:none;cursor:default}.alarm-card-header{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;margin-bottom:8px}.alarm-card-header .card-title{margin-bottom:0}.alarm-tabs{display:flex;gap:4px}.alarm-tab-btn{background:#e8e8e8;border:none;border-radius:999px;color:#1b1c3b;cursor:pointer;font-family:Roboto,sans-serif;font-size:13px;padding:4px 14px;transition:background .15s}.alarm-tab-btn:hover{background:#cbe8fb}.alarm-tab-btn.active{background:#1b1c3b;color:#fff}.alarm-tab-btn:focus-visible{outline:2px solid #1b1c3b;outline-offset:2px}.card .add{background:#fff;border:1px solid #1b1c3b;border-radius:999px;cursor:pointer;font-size:13px;margin-top:12px;padding:6px 14px}.card .add:hover{background:#1b1c3b;color:#fff}@media (max-width:1100px){.device-detail-grid{grid-template-columns:1fr}}@media (max-width:768px){.device-detail-page{margin:16px;padding-top:6px}.device-detail-header{align-items:flex-start;flex-direction:column;gap:12px}.device-actions{flex-wrap:wrap;width:100%}.action-buttons{flex-direction:row;height:auto;width:auto}.device-detail-grid{gap:16px}.card{padding:16px}.card dl{font-size:13px;grid-template-columns:100px 1fr;row-gap:10px}.card-details,.telemetry-card{height:auto;min-height:200px}.list-item{border-radius:12px;flex-wrap:wrap;gap:6px;padding:8px 12px}.list-item .actions{gap:12px}.alarm-card-header{align-items:flex-start;flex-direction:column}.alarm-tabs{flex-wrap:wrap}}@media (max-width:480px){.device-detail-page{margin:10px}.device-title{font-size:16px}.card dl{grid-template-columns:1fr}.card dt{font-weight:700;margin-bottom:-8px}}.groups-toolbar{align-items:flex-end;display:flex;justify-content:space-between;margin:24px 40px 16px;padding-top:10px}.groups-toolbar-left{align-items:center;display:flex;gap:16px}.groups-title{font-size:20px;font-weight:700;margin:0}.groups-sort-wrapper{display:inline-block;position:relative}.groups-sort-button{align-items:center;background-color:#1b1c3b;border:none;border-radius:24px;box-shadow:0 2px 6px #00000026;color:#fff;cursor:pointer;display:flex;gap:1px;padding:6px 12px}.groups-sort-button:hover{background-color:#cbe8fb;color:#1b1c3b}.groups-sort-dropdown{background:#cbe8fb;border-radius:6px;box-shadow:0 4px 10px #00000026;left:0;min-width:160px;position:absolute;top:calc(100% + 6px);z-index:50}.groups-sort-option{border-radius:6px;cursor:pointer;padding:8px 12px}.groups-sort-option.active,.groups-sort-option:hover{background:#1b1c3b;color:#fff}.groups-sort-option.active{font-weight:600}.groups-toolbar-right{align-items:center;display:flex;gap:12px}.groups-search-wrapper{align-items:center;display:flex;position:relative}.groups-search-label{background:#fff;color:#474747;font-family:Roboto,sans-serif;font-size:12px;font-weight:400;left:12px;padding:0 4px;position:absolute;top:-10px}.groups-search-input{border:2px solid #1b1c3b;border-radius:4px;font-size:14px;height:45px;outline:none;padding:0 32px}.groups-search-icon{color:#1b1c3b;font-size:14px;left:10px;pointer-events:none;position:absolute}.groups-search-suggestions{background:#cbe8fb;border-radius:4px;box-shadow:0 4px 10px #00000026;left:0;max-height:200px;overflow-y:auto;position:absolute;right:0;top:52px;z-index:10}.groups-search-suggestion{background:#cbe8fb;border-radius:6px;cursor:pointer;padding:8px 12px}.groups-search-suggestion.highlighted,.groups-search-suggestion:hover{background:#1b1c3b;color:#fff}.groups-list{display:flex;flex-direction:column;gap:10px;margin:0 40px}.groups-row{align-items:center;display:grid;grid-template-columns:1.5fr 2fr 1.8fr .6fr .6fr;padding:10px 20px}.groups-row>div{text-align:center}.groups-row>div:first-child{text-align:left}.groups-header{color:#474747;font-family:Roboto,sans-serif;font-size:14px;font-weight:600;padding-left:18px}.groups-item{background:#e6e6e6;border-radius:999px;box-shadow:0 2px 6px #0000001a;font-size:14px}.groups-item.clickable-row:hover{background:#d9d9d9}.groups-item.clickable-row:focus-visible{outline:2px solid #1b1c3b;outline-offset:-2px}.icon-button{background:none;border:none;color:#1b1c3b;cursor:pointer;font-size:16px}.pagination{display:flex;justify-content:flex-end;margin-top:12px}.pagination-right{width:100%}.pagination-controls{align-items:center;display:flex;gap:10px;margin-right:40px}.pagination-info{margin-right:8px}.pagination-info,.pagination-page{color:#474747;font-size:14px;font-weight:200}.pagination-controls button{cursor:pointer;padding:4px 8px}.pagination-controls button:disabled{cursor:default;opacity:.4}.groups-sort-option:focus-visible,button:focus-visible{outline:2px solid #1b1c3b;outline-offset:2px}.groups-error-message{align-items:center;background-color:#e6e6e6;border-left:4px solid #8c2222;border-radius:6px;color:#8c2222;display:flex;font-size:14px;font-weight:600;gap:10px;line-height:1.4;margin:16px 40px;padding:12px}.groups-error-message:before{content:"⚠️";font-size:18px}.groups-search-clear{background:none;border:none;color:#1b1c3b;cursor:pointer;font-size:14px;position:absolute;right:10px}.groups-search-clear:focus-visible{outline:2px solid #1b1c3b;outline-offset:2px}.modal-device-search-wrapper{align-items:center;display:flex;margin-top:16px;position:relative}.modal-device-search-label{background:#cbe8fb;color:#474747;font-family:Roboto,sans-serif;font-size:12px;font-weight:400;left:12px;padding:0 4px;position:absolute;top:-10px}.modal-device-search-input{background:#fff;border:1px solid #1b1c3b;border-radius:4px;font-size:14px;height:45px;outline:none;padding:0 32px;width:100%}.modal-device-search-input:focus{border-color:#1b1c3b;box-shadow:0 0 0 2px #1b1c3b1a}.modal-device-search-icon{color:#1b1c3b;font-size:14px;left:10px;pointer-events:none;position:absolute}.modal-device-search-suggestions{background:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 4px 10px #0000001a;left:0;max-height:200px;overflow-y:auto;position:absolute;right:0;top:52px;z-index:10}.modal-device-search-suggestion{background:#fff;border-radius:4px;cursor:pointer;font-size:14px;padding:8px 12px}.modal-device-search-suggestion.highlighted,.modal-device-search-suggestion:hover{background:#1b1c3b;color:#fff}.modal-device-search-clear{background:none;border:none;color:#1b1c3b;cursor:pointer;font-size:14px;position:absolute;right:10px}.modal-device-search-clear:focus-visible{outline:2px solid #1b1c3b;outline-offset:2px}.step-title{font-family:Roboto,sans-serif;font-size:18px;font-weight:500;margin-bottom:20px;text-align:left}.modal.large p{color:#8c2222;font-size:12px;margin-bottom:-5px;margin-top:4px}@media (max-width:1024px){.groups-row{grid-template-columns:1.5fr 1.5fr .6fr .6fr}.groups-row>div:nth-child(3){display:none}}@media (max-width:768px){.groups-toolbar{align-items:stretch;flex-direction:column;gap:12px;margin:16px 16px 12px}.groups-toolbar-left{justify-content:space-between}.groups-search-input,.groups-toolbar-right{width:100%}.groups-list{margin:0 16px}.groups-header{display:none}.groups-row{gap:8px;grid-template-columns:1fr auto auto;padding:10px 14px}.groups-row>div:nth-child(2),.groups-row>div:nth-child(3){display:none}.groups-item{border-radius:12px}.groups-error-message{margin:12px 16px}.pagination-controls{margin-right:16px}.modal{margin:0 16px;max-width:90vw;padding:1.5rem}.modal h2{font-size:1.3rem}.modal-actions{flex-direction:column;gap:.75rem}.modal-primary,.modal-primary-positive,.modal-secondary{justify-content:center;width:100%}}@media (max-width:480px){.groups-toolbar{margin:12px 10px 8px}.groups-list{margin:0 10px}.groups-row{font-size:13px;padding:8px 10px}.pagination-controls{gap:4px;margin-right:10px}}.group-detail-page{font-family:Roboto,sans-serif;margin:24px 40px;padding-top:10px}.group-detail-page .device-detail-grid{grid-gap:24px;align-items:stretch;display:grid;gap:24px;grid-auto-rows:minmax(400px,1fr);grid-template-columns:1fr 1fr}.group-detail-page .card-wrapper{display:flex;flex-direction:column;min-height:0}.group-detail-page .card{display:flex;flex:1 1;flex-direction:column;min-height:0;position:relative}.group-detail-page .devices-list-area{display:flex;flex:1 1;flex-direction:column;min-height:0;padding-bottom:50px}.group-detail-page .devices-list-scroll{flex:1 1;min-height:0;overflow-y:auto}.group-detail-page .pagination{display:flex;flex-shrink:0;justify-content:flex-end;margin-top:8px}.group-detail-page .pagination-controls{align-items:center;display:flex;gap:10px;margin-right:16px}.group-detail-page .card .edit.add-alarm{bottom:16px;margin:0;position:absolute;right:16px}.group-detail-page .telemetry-card{display:flex;flex-direction:column}.group-detail-page .telemetry-scroll{flex:1 1;min-height:0;overflow-y:auto}.modal-backdrop{align-items:center;background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.modal{background:#cbe8fb;border-radius:16px;box-shadow:0 20px 40px #00000040;font-family:Lato,sans-serif;max-width:500px;min-height:200px;padding:2.5rem 3rem;position:relative;text-align:center;width:100%}.modal h2{color:#1b1c3b;font-size:1.6rem;font-weight:700;margin-bottom:2rem}.modal p{color:#1b1c3b;font-size:1rem;line-height:1.5;margin-bottom:2.5rem}.modal-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.modal-primary,.modal-primary-positive{align-items:center;background:#1b1c3b;border:none;border-radius:999px;box-shadow:0 2px 6px #00000026;color:#fff;cursor:pointer;display:flex;font-family:Roboto,sans-serif;font-size:1rem;font-weight:400;gap:.5rem;padding:.75rem 1.75rem}.modal-primary-positive:disabled{background:#474747;box-shadow:none;cursor:not-allowed}.modal-primary-positive:disabled:hover{background:#474747}.modal-primary:hover{background:#8c2222}.modal-primary-positive:hover{background:#185226}.modal-secondary{align-items:center;background:#fff;border:none;border-radius:999px;box-shadow:0 2px 6px #00000026;color:#1b2a4e;cursor:pointer;display:flex;font-family:Roboto,sans-serif;font-size:.95rem;gap:.4rem;padding:.6rem 1.5rem}.modal-secondary:hover{background:#f2f6fb}@media (max-width:900px){.group-detail-page .device-detail-grid{grid-template-columns:1fr}}@media (max-width:768px){.group-detail-page{margin:16px;padding-top:6px}.modal{margin:0 16px;max-width:90vw;padding:1.5rem}.modal h2{font-size:1.3rem}.modal-actions{flex-direction:column;gap:.75rem}.modal-primary,.modal-primary-positive,.modal-secondary{justify-content:center;width:100%}.custom-tooltip{max-width:90vw;width:auto}.group-detail-page .card{padding:16px}.group-detail-page .device-detail-grid{gap:16px}}@media (max-width:480px){.group-detail-page{margin:10px}}.selected-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.selected-badge{align-items:center;background:#fff;border-radius:999px;display:inline-flex;font-size:.9rem;gap:6px;padding:4px 10px}.badge-remove{background:none;border:none;cursor:pointer;font-size:.85em}.group-detail-page .groups-search-input{width:100%}.group-detail-page .groups-search-label{background:#cbe8fb}.groups-search-suggestions,.modal-backdrop .groups-search-suggestion{background:#fff}.modal-backdrop .groups-search-suggestion.highlighted,.modal-backdrop .groups-search-suggestion:hover{background:#1b1c3b;color:#fff}.add-devices-actions{align-items:center;display:flex;gap:10px;position:relative}.tooltip-icon-button{background:none;border:none;cursor:pointer;font-size:1.1rem;margin-left:4px;padding:4px}.tooltip-icon-button.active{background:#1b1c3b;border-left:3px solid #078ac1;border-radius:30%;border-right:3px solid #078ac1;color:#fff;padding:3px 4px}.tooltip-icon-button:focus{border-radius:6px;outline:2px solid #1b1c3b}.custom-tooltip{background:#1b1c3b;border-left:4px solid #078ac1;border-radius:8px;border-right:4px solid #078ac1;color:#fff;font-size:.9rem;font-weight:200;margin-bottom:30px;padding:10px 14px;text-align:left;width:462px}.notifications-page .device-list{display:flex;flex-direction:column;gap:6px;margin:0 40px}.notifications-page .device-row{grid-column-gap:24px;align-items:center;column-gap:24px;display:grid;grid-template-columns:2fr 2fr 1fr .6fr .6fr;padding:10px 20px}.notifications-page .device-row>div{text-align:center}.notifications-page .device-row>div:first-child{text-align:left}.notifications-page .device-item{grid-column-gap:24px;align-items:center;column-gap:24px;display:grid;grid-template-columns:2fr 2fr 1fr .6fr .6fr;padding:10px 20px}.notifications-page .alarm-item{background:#e6e6e6;border-radius:999px;box-shadow:0 2px 6px #0000001a;color:#000;font-size:14px}.notifications-page .device-item>div{text-align:center}.notifications-page .device-item>div:first-child{text-align:left}.notifications-page .severity-badge{background:#fff;border-radius:999px;color:#1b1c3b;display:inline-block;font-weight:600;padding:6px 12px}.notifications-page .device-item .actions{align-items:center;display:flex;justify-content:center}.notifications-page .device-table-container h2{color:#474747;font-family:Lato,sans-serif;font-size:18px;font-weight:600;margin:8px 0 8px 40px}.notifications-page .notification-list{display:flex;flex-direction:column;gap:6px;margin:12px 40px 24px}.notifications-page .notification-item{grid-column-gap:16px;align-items:center;background:#474747;border-radius:12px;color:#fff;column-gap:16px;display:grid;grid-template-columns:2fr 2fr 1fr .6fr;padding:10px 20px}.notifications-page .notification-time{text-align:center}.notifications-page .notification-status .sort-button.read{background:#e6e6e6;color:#1b1c3b}.notifications-page .notification-status .sort-button.unread{background:#1b1c3b;color:#fff}@media (max-width:1024px){.notifications-page .device-item,.notifications-page .device-row{column-gap:12px;grid-template-columns:2fr 1.5fr 1fr .6fr}.notifications-page .device-item>div:nth-child(5),.notifications-page .device-row>div:nth-child(5){display:none}}@media (max-width:768px){.notifications-page .device-list{margin:0 16px}.notifications-page .device-item,.notifications-page .device-row{column-gap:8px;grid-template-columns:1fr auto;padding:10px 14px}.notifications-page .device-header,.notifications-page .device-item>div:nth-child(2),.notifications-page .device-item>div:nth-child(3),.notifications-page .device-item>div:nth-child(5),.notifications-page .device-row>div:nth-child(2),.notifications-page .device-row>div:nth-child(3),.notifications-page .device-row>div:nth-child(5){display:none}.notifications-page .alarm-item{border-radius:12px}.notifications-page .device-table-container h2{margin-left:16px}.notifications-page .notification-list{margin:12px 16px 24px}.notifications-page .notification-item{column-gap:8px;grid-template-columns:1fr auto}.notifications-page .notification-item>div:nth-child(2){display:none}}@media (max-width:480px){.notifications-page .device-list{margin:0 10px}.notifications-page .notification-list{margin:12px 10px 24px}}.all-alarms-page .device-list{display:flex;flex-direction:column;gap:6px;margin:0 40px}.all-alarms-page .device-row{grid-column-gap:24px;align-items:center;column-gap:24px;display:grid;grid-template-columns:2fr 2fr 1fr .6fr .6fr;padding:10px 20px}.all-alarms-page .device-row>div{text-align:center}.all-alarms-page .device-row>div:first-child{text-align:left}.all-alarms-page .device-item{grid-column-gap:24px;align-items:center;column-gap:24px;display:grid;grid-template-columns:2fr 2fr 1fr .6fr .6fr;padding:10px 20px}.all-alarms-page .alarm-item{background:#e6e6e6;border-radius:999px;box-shadow:0 2px 6px #0000001a;color:#000;font-size:14px}.all-alarms-page .device-item>div{text-align:center}.all-alarms-page .device-item>div:first-child{text-align:left}.all-alarms-page .severity-badge{background:#fff;border-radius:999px;color:#1b1c3b;display:inline-block;font-weight:600;padding:6px 12px}.all-alarms-page .originator-link{background-color:#e0e0e0;border:none;border-radius:24px;box-shadow:0 1px 3px #0000001a;color:#1b1c3b;cursor:pointer;display:inline-block;font-family:inherit;font-size:1em;padding:2px 9px;text-decoration:none;white-space:nowrap}.all-alarms-page .originator-link:hover{background-color:#cbe8fb;color:#1b1c3b}.all-alarms-page .originator-link:focus-visible{outline:2px solid #1b1c3b;outline-offset:2px}.all-alarms-page .device-item .actions{align-items:center;display:flex;justify-content:center}.all-alarms-page .device-table-container h2{color:#474747;font-family:Lato,sans-serif;font-size:18px;font-weight:600;margin:8px 0 8px 40px}.all-alarms-page .notification-list{display:flex;flex-direction:column;gap:6px;margin:12px 40px 24px}.all-alarms-page .notification-item{grid-column-gap:16px;align-items:center;background:#474747;border-radius:12px;color:#fff;column-gap:16px;display:grid;grid-template-columns:2fr 2fr 1fr .6fr;padding:10px 20px}.all-alarms-page .notification-time{text-align:center}.all-alarms-page .notification-status .sort-button.read{background:#e6e6e6;color:#1b1c3b}.all-alarms-page .notification-status .sort-button.unread{background:#1b1c3b;color:#fff}@media (max-width:1024px){.all-alarms-page .device-item,.all-alarms-page .device-row{column-gap:12px;grid-template-columns:2fr 1.5fr 1fr .6fr}.all-alarms-page .device-item>div:nth-child(5),.all-alarms-page .device-row>div:nth-child(5){display:none}}@media (max-width:768px){.all-alarms-page .device-list{margin:0 16px}.all-alarms-page .device-item,.all-alarms-page .device-row{column-gap:8px;grid-template-columns:1fr auto;padding:10px 14px}.all-alarms-page .device-header,.all-alarms-page .device-item>div:nth-child(2),.all-alarms-page .device-item>div:nth-child(3),.all-alarms-page .device-item>div:nth-child(5),.all-alarms-page .device-row>div:nth-child(2),.all-alarms-page .device-row>div:nth-child(3),.all-alarms-page .device-row>div:nth-child(5){display:none}.all-alarms-page .alarm-item{border-radius:12px}.all-alarms-page .device-table-container h2{margin-left:16px}.all-alarms-page .notification-list{margin:12px 16px 24px}.all-alarms-page .notification-item{column-gap:8px;grid-template-columns:1fr auto}.all-alarms-page .notification-item>div:nth-child(2){display:none}}@media (max-width:480px){.all-alarms-page .device-list{margin:0 10px}.all-alarms-page .notification-list{margin:12px 10px 24px}}.all-alarms-page .alarmrules-list .device-row{grid-template-columns:2fr 1fr 1.5fr 1.2fr .6fr .6fr}@media (max-width:1024px){.all-alarms-page .alarmrules-list .device-row{grid-template-columns:2fr 1fr 1.5fr .6fr}.all-alarms-page .alarmrules-list .device-row>div:nth-child(4),.all-alarms-page .alarmrules-list .device-row>div:nth-child(6){display:none}}@media (max-width:768px){.all-alarms-page .alarmrules-list .device-row{grid-template-columns:1fr auto}.all-alarms-page .alarmrules-list .device-row>div:nth-child(2),.all-alarms-page .alarmrules-list .device-row>div:nth-child(3),.all-alarms-page .alarmrules-list .device-row>div:nth-child(4),.all-alarms-page .alarmrules-list .device-row>div:nth-child(6){display:none}}.dashboard-toolbar{align-items:flex-end;display:flex;justify-content:space-between;margin:24px 40px 16px;padding-bottom:0;padding-top:10px}.dashboard-toolbar-left{align-items:center;display:flex;gap:16px}.dashboard-title{font-size:20px;font-weight:700;margin:0}.dashboard-toolbar-right{align-items:center;display:flex;gap:12px}.dashboard-list{display:flex;flex-direction:column;gap:10px;margin:0 40px}.dashboard-row{align-items:center;display:grid;grid-template-columns:1.5fr 2.5fr 1.4fr .6fr .6fr;padding:10px 20px}.dashboard-row>div{text-align:center}.dashboard-row>div:first-child{text-align:left}.dashboard-header{color:#474747;font-family:Roboto,sans-serif;font-size:14px;font-weight:600;padding-left:18px}.dashboard-item{background:#e6e6e6;border-radius:999px;box-shadow:0 2px 6px #0000001a;font-size:14px}.group-detail-page .dashboard-row{grid-template-columns:2fr 1.4fr .6fr .6fr}.group-detail-page .dashboard-list{margin:0}.navbar{background-color:#cbe8fb;border-bottom:1px solid #b8dff5;box-shadow:0 2px 8px #0000001a;justify-content:space-between;padding:5px 40px;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.navbar,.navbar-left,.navbar-logo-link{align-items:center;display:flex}.navbar-logo-link{text-decoration:none}.navbar-logo{cursor:pointer;height:50px;transition:transform .2s}.navbar-logo:hover{transform:scale(1.05)}.navbar-logo-link:focus{border-radius:8px;outline:2px solid #1b1c3b;outline-offset:4px}.navbar-center{flex:1 1;justify-content:flex-end}.nav-items,.navbar-center{align-items:center;display:flex}.nav-items{gap:70px}.nav-item{align-items:center;display:flex;position:relative}.nav-item.active .nav-button{color:#1b1c3b}.nav-item.active .nav-icon{background-color:#1b1c3b;color:#cbe8fb}.nav-button{align-items:center;background:none;border:none;color:#1b1c3b;cursor:pointer;display:flex;flex-direction:column;font-family:Roboto,sans-serif;font-size:16px;font-weight:800;gap:8px;padding:8px 0;position:relative;transition:all .2s}.nav-button:hover .nav-icon{background-color:#1b1c3b}.nav-button:focus{border-radius:8px;outline:2px solid #1b1c3b;outline-offset:4px}.nav-icon{border-radius:20px;font-size:22px;line-height:1;padding:6px 15px;transition:all .2s}.nav-label{color:#1b1c3b;font-family:Roboto,sans-serif;font-size:14px;font-weight:500;text-align:center;white-space:nowrap}.profile-item .nav-button{margin-left:10px}.profile-dropdown{position:relative}.dropdown-menu{border:1px solid #ddd;box-shadow:0 4px 12px #00000026;margin-top:8px;min-width:150px;top:100%;z-index:1001}.dropdown-item{background:none;border:none;color:#1b1c3b;cursor:pointer;display:block;font-family:Roboto,sans-serif;font-size:12px;padding:12px 16px;text-align:left;transition:background-color .2s;width:100%}.dropdown-item:first-child{border-radius:6px 6px 0 0}.dropdown-item:last-child{border-radius:0 0 6px 6px}.dropdown-item:hover{background-color:#f0f4ff;color:#667eea}.dropdown-item:focus{background-color:#f0f4ff;outline:2px solid #667eea;outline-offset:-2px}.sidebar-toggle{background:none;border:none;border-radius:6px;color:#1b1c3b;cursor:pointer;display:none;font-size:24px;margin-right:8px;padding:4px 8px}.sidebar-toggle:hover{background:#1b1c3b1a}.sidebar-toggle:focus-visible{outline:2px solid #1b1c3b;outline-offset:2px}@media (max-width:1024px){.nav-items{gap:20px}.navbar{padding:12px 20px}}@media (max-width:768px){.sidebar-toggle{display:block}.nav-items{gap:10px}.nav-button{padding:4px 6px}.nav-icon{font-size:16px;padding:4px 8px}.nav-label{display:none}.navbar{padding:8px 12px}.navbar-logo{height:36px}}@media (max-width:480px){.nav-items{gap:4px}.nav-icon{font-size:14px;padding:4px 6px}.navbar{padding:6px 8px}.navbar-logo{height:30px}}.dropdown-menu{background-color:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 4px 10px #0000001a;color:#000;min-width:120px;padding:8px 0;position:absolute;right:0;top:40px;z-index:1000}.dropdown-menu button{background:none;border:none;cursor:pointer;font-size:14px;line-height:1.4;padding:10px 16px;text-align:left;width:100%}.profile-button:hover{background-color:#07c}.dropdown-menu button:hover{background-color:#e4e4e4}.sidebar{background-color:#cbe8fb;box-shadow:none;flex-shrink:0;padding-top:20px;width:220px}.sidebar ul{list-style-type:none;margin:0;padding:0}.sidebar li{margin-bottom:16px}.sidebar a{border-radius:12px;color:#1b1c3b;font-family:Lato,sans-serif;font-size:14px;font-weight:600;padding:8px 12px;text-decoration:none}.sidebar a:hover,.sidebar li.active a{background-color:#1b1c3b;color:#fff;margin-right:16px}.sidebar li.active a{font-weight:600}.sidebar-section{padding-left:20px}.sidebar-title{align-items:center;color:#474747;display:block;font-family:Lato,sans-serif;font-size:20px;font-weight:300;gap:0;margin:0 0 16px;padding-left:12px;padding-top:40px}.sidebar-menu{list-style-type:none;margin:0;padding:0}.sidebar-menu li{margin-bottom:12px;padding:5px 0 0}.sidebar-item{align-items:center;border-radius:12px;color:#1b1c3b;display:flex;flex-direction:row;font-family:Roboto,sans-serif;font-size:14px;font-weight:500;gap:20px;padding-left:0;text-decoration:none}.sidebar-item:hover{background-color:#1b1c3b1a;margin-right:16px}.sidebar-item:focus{border-radius:8px;outline:2px solid #1b1c3b;outline-offset:4px}.sidebar-icon{align-items:center;display:flex;flex-shrink:0;font-size:16px;height:20px;justify-content:center;min-height:20px;min-width:20px;width:20px}.sidebar-label{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;flex:1 1;overflow:hidden;white-space:normal}@media (max-width:768px){.sidebar{height:100vh;left:-260px;padding-top:70px;position:fixed;top:0;transition:left .3s ease;width:240px;z-index:950}.sidebar.sidebar-open{left:0}}.home-container{display:flex;flex-direction:column;margin:0;max-width:100%;padding:30px}.home-container h1{color:#333;font-family:Lato,sans-serif;font-size:28px;font-weight:700;margin-bottom:30px;margin-top:15px;text-align:left}.cards-container{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr);margin-bottom:40px}.card-wrapper{display:flex;flex-direction:column}.card-label{color:#1b1c3b;font-family:Lato,sans-serif;font-size:16px;font-weight:600;margin:0 0 8px;padding:0}.card{background-color:#cbe8fb;border-radius:8px;display:flex;flex-direction:column;min-height:250px;padding:20px;transition:none}.card,.card:hover{box-shadow:none}.card h3{color:#1b1c3b;font-family:Roboto,sans-serif;font-size:16px;font-weight:500;margin:0 0 12px}.card-content{align-items:center;border:2px dashed #1b1c3b;border-radius:4px;color:#999;display:flex;flex:1 1;font-family:Lato,sans-serif;font-size:14px;justify-content:center;text-align:center}.cards-container-large{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}.card-wrapper-large{display:flex;flex-direction:column}.card-label-large{color:#1b1c3b;font-family:Lato,sans-serif;font-size:16px;font-weight:600;margin:0 0 8px;padding:0}.card-large{background-color:#cbe8fb;border-radius:8px;box-shadow:none;display:flex;flex-direction:column;min-height:200px;padding:20px;transition:none}.card-large h3{color:#1b1c3b;font-family:Roboto,sans-serif;font-size:16px;font-weight:500;margin:0 0 12px}.card-large-content{align-items:center;border:2px dashed #1b1c3b;border-radius:4px;color:#999;display:flex;flex:1 1;font-family:Lato,sans-serif;font-size:14px;justify-content:center;text-align:center}@media (max-width:1024px){.cards-container{grid-template-columns:repeat(2,1fr)}.cards-container-large{grid-template-columns:1fr}}@media (max-width:768px){.cards-container,.cards-container-large{grid-template-columns:1fr}.home-container h1{font-size:24px}.home-container{padding:20px}}.footer{background-color:#cbe8fb;border-top:1px solid #b8dff5;margin-top:auto;padding:20px}.footer-content{align-items:center;display:flex;justify-content:space-between;padding:0 20px}.footer-left p{color:#1b1c3b;font-family:Roboto,sans-serif;font-size:14px;font-weight:400;margin:0}.footer-right{align-items:center;display:flex;gap:20px}.footer-link{border-radius:15px;color:#1b1c3b;font-family:Roboto,sans-serif;font-size:14px;font-weight:500;padding:8px;text-decoration:none}.footer-link:hover{background-color:#1b1c3b;color:#fff}.footer-link:focus{border-radius:15px;outline:2px solid #1b1c3b;outline-offset:4px}.footer-divider{color:#1b1c3b;font-weight:300}@media (max-width:768px){.footer-content{flex-direction:column;gap:15px;text-align:center}.footer-left p{font-size:12px}.footer-right{justify-content:center}.footer-link{font-size:12px}}#root,body,html{height:100%;margin:0}body{background-color:#f4f4f4;font-family:Lato,sans-serif;margin:0}#root{display:flex;flex-direction:column;min-height:100vh}.app-body{display:flex;flex:1 1;overflow:hidden}.main-content{background-color:#fff;display:flex;flex:1 1;flex-direction:column;overflow-y:auto}.app-container{padding:20px}h1{color:#333;text-align:center}.dashboard-container{margin-top:40px}.dashboard-iframe{border:1px solid #ccc;border-radius:8px;height:600px;width:100%}.error{color:#8c2222}.sidebar-overlay{display:none}@media (max-width:768px){.app-container{padding:12px}.sidebar-overlay{background:#00000080;display:block;inset:0;position:fixed;z-index:900}}
/*# sourceMappingURL=main.5b7a05ca.css.map*/