body,html{height:100%;margin:0;padding:0;width:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;overflow-x:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}html{font-size:1rem}@media screen and (max-width:767px){html{font-size:1rem}}@media screen and (min-width:1024px) and (max-width:1919px){html{font-size:.875rem}}@media screen and (min-width:1440px) and (max-width:1919px){html{font-size:1rem}}@media screen and (min-width:1920px){html{font-size:1.5rem}}h1,h2,h3,h4,h5,h6{margin-top:0}.App{display:flex;flex-direction:column;height:100vh;text-align:center}.auth-required{min-height:calc(90vh - 5rem)}.auth-card{border-radius:12px;box-shadow:0 4px 12px #0000001a;max-width:400px}.auth-card h2{margin-bottom:16px}.auth-card p{margin-bottom:24px}.modern-login-button{background-color:#4a5f8c;border-radius:20px;font-family:inherit;font-size:15px;font-weight:500;max-width:200px;padding:8px 48px;transition:all .3s ease}.modern-login-button:hover{background-color:#3a4f7c;box-shadow:0 2px 8px #4a5f8c4d;transform:translateY(-1px)}.modern-login-button:active{box-shadow:0 1px 4px #4a5f8c4d;transform:translateY(0)}.signup-link{color:#666;font-size:14px;margin-top:24px}.signup-link-button{color:#4a5f8c;cursor:pointer;font-weight:600;text-decoration:none}.signup-link-button:hover{text-decoration:underline}@media (max-width:48rem){.App{margin:0 auto;max-width:100%}.auth-card{margin:20px;padding:30px}}@media (max-width:479px){.auth-required{min-height:calc(90vh - 3.75rem)}}.toast{background-color:#c83232b3;border-radius:8px;bottom:80px;box-shadow:0 4px 12px #0000004d;color:#fff;left:50%;max-width:90%;padding:12px 24px;position:fixed;text-align:center;transform:translateX(-50%);transition:opacity .3s ease-in-out;z-index:10000}.toast-visible{opacity:1}.toast-hidden{opacity:0}.toast-message{font-size:14px;font-weight:500}:root{--input-border:#d1d1d1;--text-primary:#333;--text-secondary:#666;--error-bg:#fdecea;--error-border:#ebccd1;--error-text:#c9302c}.auth-required{align-items:center;background:#f5f5f5;background:var(--background-off-white);box-sizing:border-box;display:flex;justify-content:center;min-height:calc(100vh - 10rem);padding:2rem 1rem;width:100%}.auth-card{background:#fff;border:2px solid #d1d1d1;border-radius:8px;box-shadow:0 2px 4px #0000001a;box-sizing:border-box;max-width:450px;padding:40px;text-align:center;width:450px}.auth-card h2{color:#333;color:var(--text-primary);font-size:24px;font-weight:700;letter-spacing:.5px;margin:0 0 15px}.auth-card p{color:#666;color:var(--text-secondary);font-size:14px;margin:0 0 30px}.auth-toast-error{align-items:center;animation:slideDown .3s ease-out;background-color:#fdecea;background-color:var(--error-bg);border:1px solid #ebccd1;border:1px solid var(--error-border);border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;gap:12px;left:50%;max-width:500px;padding:16px 20px;position:fixed;top:7rem;transform:translateX(-50%);z-index:1000}@keyframes slideDown{0%{opacity:0;transform:translateX(-50%) translateY(-20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.auth-toast-icon{flex-shrink:0;font-size:20px}.auth-toast-message{color:#c9302c;color:var(--error-text);flex:1 1;font-size:14px;line-height:1.5}.auth-toast-close{align-items:center;background:none;border:none;color:#c9302c;color:var(--error-text);cursor:pointer;display:flex;flex-shrink:0;font-size:24px;height:24px;justify-content:center;line-height:1;opacity:.7;padding:0;transition:opacity .2s;width:24px}.auth-toast-close:hover{opacity:1}.modern-login-button{background-color:#4267b2;background-color:var(--fire-blue);border:none;border-radius:24px;box-sizing:border-box;color:#fff;cursor:pointer;font-size:16px;font-weight:600;height:35px;line-height:1;max-height:35px;min-height:35px;padding:8px 20px;transition:background-color .2s,transform .1s;width:100%}.modern-login-button:hover{background-color:#365899}.modern-login-button:active{transform:scale(.98)}.modern-login-button:disabled{background-color:#ccc;cursor:not-allowed}.auth-button{border:none;border-radius:8px;cursor:pointer;font-family:inherit;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}.auth-button:disabled{cursor:not-allowed;opacity:.6}.login-button{background-color:#4caf50;color:#fff}.login-button:hover:not(:disabled){background-color:#45a049;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.login-button:active:not(:disabled){box-shadow:0 2px 4px #0003;transform:translateY(0)}.logout-button{background-color:#f44336;color:#fff}.logout-button:hover{background-color:#da190b;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.logout-button:active{box-shadow:0 2px 4px #0003;transform:translateY(0)}.auth-loading{align-items:center;background-color:#f5f5f5;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.auth-loading p{color:#333;font-size:18px;font-weight:500;margin-top:20px}.auth-loading-spinner{animation:spin 1s linear infinite;border:6px solid #f3f3f3;border-radius:50%;border-top-color:#4caf50;height:60px;width:60px}@media (max-width:650px){.auth-card{max-width:85%!important;padding:30px 20px!important;width:85%!important}}@media (max-width:768px){.auth-button{font-size:14px;padding:10px 20px}.auth-loading-spinner{border-width:5px;height:50px;width:50px}.auth-loading p{font-size:16px}}@media (max-width:480px){.fire-defense-footer,.fire-defense-header{height:50px}.auth-required{min-height:calc(100vh - 100px);padding:1rem .5rem}.auth-toast-error{max-width:calc(100% - 2rem);padding:12px 16px;top:60px}.auth-toast-icon{font-size:18px}.auth-toast-message{font-size:13px}}.dashboard{padding-bottom:.25rem}.dashboard,.dashboard-container{display:flex;flex-direction:column;height:auto;width:100%}.dashboard-container{align-items:center;gap:0}.system-status-section{background-color:#fff;border-radius:.375rem;font-size:.875rem;padding:.25rem;width:100%}.system-status-section h3{font-size:.75rem}.status-indicators{display:flex;flex-wrap:wrap;gap:.125rem;justify-content:space-between}.status-indicator{align-items:center;border-radius:.25rem;display:flex;flex:1 1;flex-direction:column;min-width:2.25rem;padding:.1875rem .125rem}.indicator-icon{font-size:1.125rem}.indicator-label{font-size:.825rem;font-weight:500;text-align:center}.status-good{background-color:#e8f5e9;color:#2e7d32}.status-warning{background-color:#fff8e1;color:#f57f17}.status-error{background-color:#ffebee;color:#c62828}.status-unknown{background-color:#f5f5f5;color:#757575}.property-visualization{display:flex;flex-direction:column;gap:.25rem;max-width:30rem;width:100%}.property-image-container{align-items:center;aspect-ratio:16/9;background-color:#f5f5f5;display:flex;flex:1 1;justify-content:center;max-height:13rem;overflow:hidden;width:100%}.property-image{display:block;max-height:100%;max-width:100%;object-fit:contain;transition:all .3s ease}.system-status-display{align-items:center;background-color:#fff;border-radius:.375rem;display:flex;justify-content:center;text-align:center;width:100%}.status-text{color:#2e7d32;font-size:1rem;font-weight:700;letter-spacing:.03em}.control-buttons-container{align-items:center;display:flex;flex-direction:column;gap:1rem;max-width:30rem;padding-bottom:.125rem;width:100%}.activate-button-circular{align-items:center;background-color:#a20b00;border:none;border-radius:50%;box-shadow:0 .125rem .25rem #0003;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:700;height:9rem;justify-content:center;letter-spacing:.03em;margin-bottom:.75rem;margin-top:0;text-transform:uppercase;transition:all .3s ease;width:9rem}.activate-button-circular:hover:not(:disabled){box-shadow:0 .25rem .5rem #0000004d;transform:scale(1.05)}.activate-button-circular:active:not(:disabled){transform:scale(.98)}.presoak-button{background-color:#90caf9;border:none;border-radius:1.5rem;color:#0d47a1;cursor:pointer;font-size:1rem;font-weight:700;height:2rem;min-width:7rem;padding:.375rem .75rem;transition:background-color .3s}.presoak-button:hover:not(:disabled){background-color:#64b5f6}.presoak-button.active{color:#fff}.activate-button-circular.active,.presoak-button.active{animation:pulse 1.5s infinite;background-color:#4caf50}.cancel-button.test-mode,.confirm-button.test-mode,.presoak-button.test-mode{border:.125rem solid #2196f3!important}.activate-button-circular.test-mode{border:.25rem solid #2196f3!important}.presoak-button.active.test-mode{color:#fff}.activate-button-circular.active.test-mode,.presoak-button.active.test-mode{animation:pulse-blue 1.5s infinite;background-color:#2196f3}button:disabled{cursor:not-allowed;opacity:.7}.confirmation-popup{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.confirmation-content{animation:popup-appear .3s ease-out;background-color:#fff;border-radius:.375rem;box-shadow:0 .25rem .5rem #0003;max-width:18rem;padding:1rem;text-align:center;width:90%}@keyframes popup-appear{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes pulse-blue{0%{box-shadow:0 0 0 0 #2196f366}70%{box-shadow:0 0 0 .5rem #2196f300}to{box-shadow:0 0 0 0 #2196f300}}.confirmation-header{align-items:center;display:flex;margin-bottom:.5rem}.confirmation-icon{color:#f57f17;font-size:1rem;margin-right:.375rem}.confirmation-content h3{color:#333;font-size:.875rem;margin:0}.confirmation-content p{color:#555;font-size:.75rem;line-height:1.4;margin:0 0 .75rem}.confirmation-buttons{display:flex;gap:.75rem;justify-content:center;margin-top:.75rem}.cancel-button{background-color:red;border:none;border-radius:1.5rem;color:#fff;cursor:pointer;font-size:.75rem;font-weight:500;min-width:5rem;padding:.375rem 1rem;transition:background-color .2s}.cancel-button:hover{background-color:#d32f2f}.confirm-button{background-color:#90caf9;border:none;border-radius:1.5rem;color:#0d47a1;cursor:pointer;font-size:.75rem;font-weight:500;min-width:5rem;padding:.375rem 1rem;transition:background-color .2s}.confirm-button:hover{background-color:#64b5f6}@media (min-width:48rem){.dashboard-container{flex-direction:column}.property-image-container{max-height:10rem}.indicator-icon{font-size:1.325rem}.indicator-label{font-size:1.125rem}.status-text{font-size:1.5rem}.control-buttons-container{align-items:center;flex-direction:column;gap:1.5rem}.activate-button-circular{font-size:1.1rem;height:10rem;width:10rem}.presoak-button{font-size:1.125rem;height:2.5rem;min-width:8rem;padding:.5rem 1.25rem}.confirmation-content{padding:1.25rem}.confirmation-icon{font-size:1.25rem;margin-right:.5rem}.confirmation-content h3{font-size:1rem}.confirmation-buttons{gap:1rem}.cancel-button,.confirm-button{min-width:6rem;padding:.5rem 1.25rem}}@media (min-width:60rem){.indicator-icon{font-size:1.5rem}.indicator-label{font-size:1.25rem}.control-buttons-container{gap:1.75rem}.activate-button-circular{font-size:.95rem;height:8.5rem;width:8.5rem}.presoak-button{font-size:1.125rem;height:2.75rem;min-width:9rem;padding:.5625rem 1.375rem}.property-image-container{max-height:13rem}}@media (min-width:75rem){.property-image-container{max-height:12rem}.property-visualization{max-width:40rem}.control-buttons-container{gap:1rem}.activate-button-circular{font-size:1.05rem;height:9rem;margin-bottom:0;margin-top:1.5rem;width:9rem}.presoak-button{font-size:1.125rem;height:2.5rem;min-width:10rem;padding:.625rem 1.5rem}}@media (min-width:90rem){.property-visualization{max-width:40rem}.control-buttons-container{gap:1rem}.activate-button-circular{font-size:1.1rem;height:10rem;margin-bottom:0;margin-top:1.5rem;width:10rem}}@media (min-width:100rem){.property-image-container{max-height:20rem}.status-text{font-size:2rem}.control-buttons-container{gap:1.25rem}.activate-button-circular{font-size:1.2rem;height:11rem;margin-bottom:0;margin-top:2rem;width:11rem}.presoak-button{font-size:1.25rem;height:3rem;padding:.625rem 1.5rem}}.system-page{display:flex;flex-direction:column;gap:0;padding-bottom:.25rem;position:relative}.system-page>*+*{margin-top:.375rem}.connection-status-section{display:inline-block;max-height:-webkit-fit-content;max-height:fit-content;padding:.25rem}.connection-status-section,.relay-section,.sensor-section{background-color:#fff;border-radius:.375rem;box-shadow:0 .125rem .25rem #0000001a}.relay-section,.sensor-section{padding:.25rem .25rem .125rem}.connection-status-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.125rem}.connection-status-header h3{color:#444;font-size:.75rem;margin:0}.refresh-button{background:none;border:none;border-radius:.25rem;color:#666;cursor:pointer;padding:.25rem;transition:all .2s ease}.refresh-button:hover:not(:disabled){background-color:#f0f0f0;color:#333}.refresh-button:disabled{cursor:not-allowed;opacity:.6}.connection-status-display{display:flex;flex-direction:column;gap:.25rem}.connection-status-info{align-items:center;display:flex;gap:.5rem}.connection-icon{font-size:.875rem}.connection-text{font-size:.75rem;font-weight:600}.connection-ip{color:#666;font-size:.625rem;font-style:italic}.last-update{color:#888;font-size:.5rem}.connection-error{color:#f44336;font-size:.5rem;font-weight:500}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.relay-section,.sensor-section{max-height:-webkit-fit-content;max-height:fit-content}.relay-section h3,.sensor-section h3{color:#444;font-size:.75rem;margin-bottom:.125rem;margin-top:0;text-align:left}.sensor-grid{grid-gap:.25rem;display:grid;gap:.25rem;grid-template-columns:repeat(2,1fr)}.sensor-tile{align-items:center;background-color:#fff;border:.1875rem solid #e0e0e0;border-radius:.375rem;display:flex;flex-direction:column;padding:.375rem;text-align:center;transition:all .3s ease}.sensor-tile:hover{box-shadow:0 .125rem .25rem #0000001a;transform:translateY(-.0625rem)}.sensor-icon{font-size:1rem;margin-bottom:.25rem}.sensor-name{font-size:.95rem;font-weight:700;margin-bottom:.0625rem}.sensor-status{color:#555;font-size:.8rem}.sensor-status.status-ready{color:#4caf50;font-weight:600}.sensor-status.status-alert{color:#ff9800;font-weight:600}.sensor-status.status-error{color:#f44336;font-weight:600}.add-icon{color:#bdbdbd;font-size:1.25rem}.relay-grid{grid-gap:.25rem;display:grid;gap:.25rem;grid-template-columns:repeat(2,1fr)}.relay-tile{align-items:center;background-color:#fff;border:.1875rem solid #e0e0e0;border-radius:.375rem;display:flex;flex-direction:column;padding:.375rem;text-align:center;transition:all .3s ease}.relay-tile:hover{box-shadow:0 .125rem .25rem #0000001a;transform:translateY(-.0625rem)}.relay-icon{font-size:1rem;margin-bottom:.25rem}.relay-name{font-size:.95rem;font-weight:700;margin-bottom:.25rem}.relay-status{border-radius:.125rem;display:inline-block;font-size:.8rem;padding:.0625rem .25rem}.relay-status.on{background-color:#a5d6a7;color:#1b5e20}.relay-status.off{background-color:#ffcdd2;color:#b71c1c}.relay-status.open{background-color:#a5d6a7;color:#1b5e20}.relay-status.closed{background-color:#ffcdd2;color:#b71c1c}.relay-status.status-ready{color:#4caf50;font-weight:600}.relay-status.status-alert{color:#ff9800;font-weight:600}.relay-status.status-error{color:#f44336;font-weight:600}.status-connected{border-color:#4caf50!important}.status-disconnected{border-color:#f44336!important}.relay-tile.status-ready,.sensor-tile.status-ready{border-color:#4caf50!important}.relay-tile.status-alert,.sensor-tile.status-alert{border-color:#ff9800!important}.relay-tile.status-error,.sensor-tile.status-error{border-color:#f44336!important}.no-devices-message{align-items:center;background:#ffffff0d;border:2px dashed #fff3;border-radius:1rem;display:flex;flex-direction:column;grid-column:1/-1;justify-content:center;min-height:2.5rem;padding:1.5rem 1rem;text-align:center}.no-devices-icon{font-size:3rem;margin-bottom:1rem;opacity:.7}.no-devices-text{color:#fff9;font-size:.9rem;line-height:1.4;max-width:15rem}.connection-status{background:#ffffff0d;border:.0625rem solid #ffffff1a;border-radius:.5rem;display:flex;flex-direction:column;gap:.5rem;padding:.5rem}.last-update-info{align-items:center;color:#666;display:flex;font-size:.75rem;justify-content:space-between}.last-update-text{opacity:.8}.connection-indicator{align-items:center;display:flex;gap:.75rem}.connection-dot{animation:pulse 2s infinite;border-radius:50%;height:.75rem;width:.75rem}.connection-text{font-size:.9rem;font-weight:500}.connection-connected .connection-dot{background-color:#4caf50;box-shadow:0 0 0 0 #4caf50b3}.connection-connected .connection-text{color:#4caf50}.connection-connecting .connection-dot{background-color:#ff9800;box-shadow:0 0 0 0 #ff9800b3}.connection-connecting .connection-text{color:#ff9800}.connection-error .connection-dot{background-color:#f44336;box-shadow:0 0 0 0 #f44336b3}.connection-error .connection-text{color:#f44336}.connection-disconnected .connection-dot{animation:none;background-color:#9e9e9e}.connection-disconnected .connection-text{color:#9e9e9e}@keyframes pulse{0%{box-shadow:0 0 0 0 #4caf50b3;transform:scale(.95)}70%{box-shadow:0 0 0 .625rem #4caf5000;transform:scale(1)}to{box-shadow:0 0 0 0 #4caf5000;transform:scale(.95)}}@media (min-width:48rem){.system-page{grid-gap:0;display:grid;grid-template-areas:"connection connection" "sensors sensors" "relays relays";grid-template-columns:1fr 1fr}.connection-status-section{grid-area:connection;padding:.375rem}.sensor-section{grid-area:sensors;padding:.375rem .375rem .25rem}.relay-section{grid-area:relays;padding:.375rem .375rem .25rem}.relay-section h3,.sensor-section h3{font-size:.875rem}.relay-grid,.sensor-grid{gap:.375rem;grid-template-columns:repeat(3,1fr)}.sensor-icon{font-size:1.25rem}.relay-name,.sensor-name{font-size:1.4rem}.relay-status,.sensor-status{font-size:1.2rem}}@media (min-width:75rem){.relay-grid,.sensor-grid{grid-template-columns:repeat(4,1fr)}.sensor-icon{font-size:1.5rem}.relay-name,.sensor-name{font-size:1.125rem}.relay-status,.sensor-status{font-size:1rem}}@media (min-width:100rem){.system-page{margin:0 auto;max-width:1400px;padding:1rem}.relay-grid,.sensor-grid{gap:1rem;grid-template-columns:repeat(6,1fr)}.relay-tile,.sensor-tile{padding:1rem}.relay-icon,.sensor-icon{font-size:1.75rem}.relay-name,.sensor-name{font-size:1.25rem}.sensor-data{font-size:1.1rem}.relay-status,.sensor-status{font-size:1.125rem}}@media (min-width:120rem){.system-page{max-width:1600px;padding:1.5rem}.relay-grid,.sensor-grid{gap:1.25rem;grid-template-columns:repeat(8,1fr)}.relay-tile,.sensor-tile{padding:1.25rem}.relay-icon,.sensor-icon{font-size:2rem;margin-bottom:.75rem}.relay-name,.sensor-data,.sensor-name{font-size:1.375rem;margin-bottom:.5rem}.relay-status,.sensor-status{font-size:1.25rem}}.location-page{display:flex;flex:1 1;flex-direction:column;gap:.375rem;height:100%;position:relative}.page-title{font-size:.875rem;margin:0}.location-map{background-color:#fff;border-radius:.375rem;box-shadow:0 .0625rem .1875rem #0000001a;max-height:-webkit-fit-content;max-height:fit-content;overflow:hidden}.map-image{display:block;height:auto;width:100%}.map-placeholder{align-items:center;background-color:#e0e0e0;display:flex;flex-direction:column;height:0;justify-content:center;max-height:-webkit-fit-content;max-height:fit-content;padding-bottom:40%;position:relative}.map-placeholder-icon{color:#757575;font-size:2rem;opacity:.5}.map-marker-icon,.map-placeholder-icon{left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.map-marker-icon{color:#e53935;font-size:1.25rem;z-index:2}.map-placeholder-text{bottom:20%;color:#757575;font-size:.625rem;font-weight:700;left:50%;position:absolute;transform:translateX(-50%)}.location-info{background-color:#fff;border-radius:.375rem;box-shadow:0 .0625rem .1875rem #0000001a;max-height:-webkit-fit-content;max-height:fit-content;padding:.375rem}.info-item{border-bottom:.0625rem solid #eee;display:flex;justify-content:space-between;padding:.375rem 0}.info-item:last-child{border-bottom:none}.info-label{color:#555;font-size:.625rem;font-weight:700}.info-value{color:#333;font-size:.625rem}@media (min-width:48rem){.location-page{grid-gap:.5rem;display:grid;grid-template-areas:"title title" "map map" "info info" "note note";grid-template-columns:1fr 1fr}.page-title{font-size:1rem;grid-area:title}.location-info{grid-area:info;padding:.5rem}.info-label,.info-value{font-size:.75rem}.map-placeholder-icon{font-size:2.5rem}.map-marker-icon{font-size:1.5rem}.map-placeholder-text{font-size:.75rem}}@media (min-width:75rem){.location-page{grid-template-areas:"title title" "map info" "note note"}.map-placeholder{padding-bottom:60%}.page-title{font-size:1.125rem}.info-label,.info-value{font-size:.875rem}.map-placeholder-icon{font-size:3rem}.map-marker-icon{font-size:1.75rem}}.coming-soon-overlay{align-items:center;background-color:#808080cc;bottom:0;display:flex;justify-content:center;left:0;pointer-events:auto;position:fixed;right:0;top:0;z-index:1000}.coming-soon-content{text-align:center}.coming-soon-text{color:#fff;font-size:2.5rem;font-weight:700;margin:0;text-shadow:2px 2px 4px #00000080}.camera-page{display:flex;flex:1 1;flex-direction:column;gap:.75rem;height:100%;padding-bottom:.5rem;position:relative}.page-title{color:#333;font-size:1rem;margin-top:.5rem}.camera-list{display:flex;flex-direction:column;gap:.75rem}.camera-item{background-color:#fff;border-radius:.5rem;box-shadow:0 .125rem .25rem #0000001a;overflow:hidden}.camera-title{background-color:#444;color:#fff;font-size:.875rem;margin:0;padding:.5rem}.camera-feed,.camera-image{height:auto;width:100%}.camera-image{display:block}.camera-placeholder{align-items:center;background-color:#e0e0e0;display:flex;flex-direction:column;height:0;justify-content:center;padding-bottom:56.25%;position:relative}.camera-placeholder-icon{color:#757575;font-size:2rem;left:50%;position:absolute;top:50%;transform:translate(-50%,-70%)}.camera-placeholder-text{color:#757575;font-size:.75rem;font-weight:700;left:50%;position:absolute;top:60%;transform:translateX(-50%)}.camera-controls{background-color:#f5f5f5;display:flex;justify-content:space-between;padding:.5rem}.camera-button{align-items:center;background-color:#2196f3;border:none;border-radius:.25rem;color:#fff;cursor:pointer;display:flex;font-weight:700;gap:.375rem;padding:.375rem .75rem;transition:background-color .3s}.button-icon,.camera-button{font-size:.75rem}.camera-button:hover{background-color:#1976d2}@media (min-width:48rem){.camera-list{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr)}.page-title{font-size:1.125rem}.camera-title{font-size:1rem}.camera-controls,.camera-title{padding:.625rem}.camera-button{padding:.5rem 1rem}.button-icon,.camera-button{font-size:.875rem}.camera-placeholder-icon{font-size:2.5rem}.camera-placeholder-text{font-size:.875rem}}@media (min-width:75rem){.camera-list{gap:1rem;grid-template-columns:repeat(3,1fr)}.page-title{font-size:1.25rem}.camera-title{font-size:1.125rem}.camera-placeholder-icon{font-size:3rem}.camera-placeholder-text{font-size:1rem}}.sensor-detail-page{display:flex;flex-direction:column;min-height:calc(100vh - 130px);overflow:hidden;padding-bottom:1rem}.sensor-detail-header{align-items:center;display:flex;margin-bottom:1.5rem}.back-button{height:40px;width:40px}.sensor-detail-title{align-items:center;display:flex;height:36px}.sensor-detail-icon{color:#444;font-size:1.5rem;margin-right:.75rem}.sensor-detail-content{background-color:#fff;border-radius:.5rem;box-shadow:0 .125rem .25rem #0000001a;padding:1rem}@media (min-width:768px){.sensor-detail-content{margin:0 auto;max-width:18.75rem}}.relay-detail-page{display:flex;flex-direction:column;min-height:calc(100vh - 130px);overflow:hidden;padding-bottom:1rem}.relay-detail-header{align-items:center;display:flex;margin-bottom:1.5rem}.back-button{align-items:center;background:none;border:none;color:#444;cursor:pointer;display:flex;font-size:1.2rem;height:2.5rem;justify-content:center;margin-right:1rem;padding:.5rem;width:2.5rem}.relay-detail-title{align-items:center;display:flex;height:2.25rem}.relay-detail-icon{color:#444;font-size:1.5rem;margin-right:.75rem}.relay-detail-content{background-color:#fff;border-radius:.5rem;box-shadow:0 .125rem .25rem #0000001a;padding:1rem}.detail-item{border-bottom:.0625rem solid #eee;display:flex;justify-content:space-between;padding:.75rem 0}.detail-item:last-child{border-bottom:none}.detail-label{color:#555;font-weight:500}.detail-value{color:#333;font-weight:600}.detail-value.status-alert{color:#f44336;font-weight:700}.detail-value.status-ready{color:#4caf50;font-weight:700}.detail-value.status-error{color:#f44336;font-weight:700}@media (min-width:48rem){.relay-detail-content{margin:0 auto;max-width:18.75rem}}.privacy-policy-container{display:flex;flex-direction:column;height:100%;margin:0 auto;max-width:60rem;overflow:hidden;padding:.375rem}.privacy-policy-header{align-items:center;display:flex;flex-shrink:0;margin-bottom:.5rem}.privacy-policy-header .back-button{align-items:center;background:none;border:none;color:#444;cursor:pointer;display:flex;font-size:.875rem;height:2rem;justify-content:center;margin-right:.5rem;padding:.25rem;width:2rem}.privacy-policy-header h1{color:#333;font-size:1rem;margin:0}.privacy-policy-content{background-color:#fff;border-radius:.375rem;box-shadow:0 .0625rem .1875rem #0000001a;flex:1 1;overflow-x:hidden;overflow-y:auto;padding:.5rem}@media (min-width:48rem){.privacy-policy-container{padding:.75rem}.privacy-policy-content{padding:1rem}.privacy-policy-header h1{font-size:1.125rem}}@media (min-width:75rem){.privacy-policy-container{padding:1rem}.privacy-policy-content{padding:1.25rem}.privacy-policy-header h1{font-size:1.25rem}}.terms-and-conditions-container{display:flex;flex-direction:column;height:100%;margin:0 auto;max-width:60rem;overflow:hidden;padding:.375rem}.terms-and-conditions-header{align-items:center;display:flex;flex-shrink:0;margin-bottom:.5rem}.terms-and-conditions-header .back-button{align-items:center;background:none;border:none;color:#444;cursor:pointer;display:flex;font-size:.875rem;height:2rem;justify-content:center;margin-right:.5rem;padding:.25rem;width:2rem}.terms-and-conditions-header h1{color:#333;font-size:1rem;margin:0}.terms-and-conditions-content{background-color:#fff;border-radius:.375rem;box-shadow:0 .0625rem .1875rem #0000001a;flex:1 1;overflow-x:hidden;overflow-y:auto;padding:.5rem}@media (min-width:48rem){.terms-and-conditions-container{padding:.75rem}.terms-and-conditions-content{padding:1rem}.terms-and-conditions-header h1{font-size:1.125rem}}@media (min-width:75rem){.terms-and-conditions-container{padding:1rem}.terms-and-conditions-content{padding:1.25rem}.terms-and-conditions-header h1{font-size:1.25rem}}.cookie-policy-container{display:flex;flex-direction:column;height:100%;margin:0 auto;max-width:60rem;overflow:hidden;padding:.375rem}.cookie-policy-header{align-items:center;display:flex;flex-shrink:0;margin-bottom:.5rem}.cookie-policy-header .back-button{align-items:center;background:none;border:none;color:#444;cursor:pointer;display:flex;font-size:.875rem;height:2rem;justify-content:center;margin-right:.5rem;padding:.25rem;width:2rem}.cookie-policy-header h1{color:#333;font-size:1rem;margin:0}.cookie-policy-content{background-color:#fff;border-radius:.375rem;box-shadow:0 .0625rem .1875rem #0000001a;flex:1 1;overflow-x:hidden;overflow-y:auto;padding:.5rem}@media (min-width:48rem){.cookie-policy-container{padding:.75rem}.cookie-policy-content{padding:1rem}.cookie-policy-header h1{font-size:1.125rem}}@media (min-width:75rem){.cookie-policy-container{padding:1rem}.cookie-policy-content{padding:1.25rem}.cookie-policy-header h1{font-size:1.25rem}}.contact-us-container{display:flex;flex-direction:column;height:100%;margin:0 auto;max-width:60rem;overflow:hidden;padding:.375rem}.contact-us-header{align-items:center;display:flex;flex-shrink:0;margin-bottom:.5rem}.contact-us-header .back-button{align-items:center;background:none;border:none;color:#444;cursor:pointer;display:flex;font-size:.875rem;height:2rem;justify-content:center;margin-right:.5rem;padding:.25rem;width:2rem}.contact-us-header h1{color:#333;font-size:1rem;margin:0}.contact-us-content{background-color:#fff;border-radius:.375rem;box-shadow:0 .0625rem .1875rem #0000001a;flex:1 1;overflow-x:hidden;overflow-y:auto;padding:.5rem}.contact-info{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:2rem 1rem;text-align:center}.contact-info .email-icon{color:#e74c3c;font-size:3rem;margin-bottom:1rem}.contact-info p{color:#333;font-size:1rem;margin:0}.contact-info a{color:#e74c3c;font-weight:500;text-decoration:none}.contact-info a:hover{text-decoration:underline}@media (min-width:48rem){.contact-us-container{padding:.75rem}.contact-us-content{padding:1rem}.contact-us-header h1{font-size:1.125rem}.contact-info .email-icon{font-size:4rem}.contact-info p{font-size:1.125rem}}@media (min-width:75rem){.contact-us-container{padding:1rem}.contact-us-content{padding:1.25rem}.contact-us-header h1{font-size:1.25rem}.contact-info .email-icon{font-size:5rem}.contact-info p{font-size:1.25rem}}.header{align-items:center;background-color:#444;color:#fff;display:flex;flex-direction:column;height:5rem;left:0;position:fixed;top:0;width:100%;z-index:100}.header-logo-container{display:flex;justify-content:center;margin-bottom:.5rem;width:100%}.header-logo-container h2{color:#fff;font-size:1rem;margin:0}.header-bottom-row{align-items:center;display:flex;padding:.25rem 0;position:relative;width:100%}.property-selector{left:50%;position:absolute;transform:translateX(-50%)}.property-selector select{-webkit-appearance:none;appearance:none;background-color:initial;border:none;border-bottom:1px solid #ffffff4d;color:#fff;cursor:pointer;font-size:.75rem;min-width:10rem;outline:none;padding:.25rem 1rem;text-align:center;width:auto}.property-selector select:focus{border-bottom:1px solid #fffc}.property-selector select option{background-color:#444;padding:.5rem;text-align:center}.settings-button{align-items:center;background:none;border:none;border-radius:50%;cursor:pointer;display:flex;height:2rem;justify-content:center;padding:.25rem;position:absolute;right:0;transition:background-color .2s;width:2rem}.settings-button:hover{background-color:#ffffff1a}.settings-icon{color:#fff;font-size:1rem}.menu-dropdown{background-color:#555;border-radius:.25rem;box-shadow:0 2px 8px #0000004d;margin-top:.25rem;position:absolute;right:.5rem;top:100%;width:12rem;z-index:101}.menu-dropdown ul{list-style:none;margin:0;padding:0}.menu-dropdown li{align-items:center;border-bottom:1px solid #666;cursor:pointer;display:flex;font-size:.875rem;padding:.5rem .75rem;transition:all .2s ease}.menu-icon{color:#ddd;font-size:.875rem;margin-right:.5rem}.menu-dropdown li:hover{background-color:#666;padding-left:1rem}.menu-dropdown li:last-child{border-bottom:none}@media (max-width:479px){.header{height:3.75rem;padding:.25rem}.header-logo-container h2{font-size:1.5rem}.property-selector select{font-size:.75rem;min-width:8rem;padding:.2rem 1rem}.settings-icon{font-size:.875rem}.settings-button{height:1.5rem;width:1.5rem}}@media (min-width:480px) and (max-width:1023px){.header{padding:.5rem 1rem}.header-logo-container h2{font-size:1.25rem}.property-selector select{font-size:.875rem;min-width:12rem;padding:.3rem 1.25rem}.settings-icon{font-size:1.25rem}.menu-dropdown li{font-size:1rem;padding:.6rem 1rem}.menu-icon{font-size:1rem}}@media (min-width:768px) and (max-width:1439px){.header{padding:.75rem 1.5rem}.header-logo-container{margin-bottom:.75rem}.header-logo-container h2{font-size:1.5rem}.property-selector select{font-size:1rem;min-width:15rem;padding:.4rem 1.5rem}.settings-button{height:2.5rem;width:2.5rem}.settings-icon{font-size:1.5rem}.menu-dropdown{right:1rem;width:15rem}.menu-dropdown li{font-size:1.125rem;padding:.75rem 1rem}.menu-icon{font-size:1.125rem;margin-right:.75rem}}@media (min-width:1200px) and (max-width:1919px){.header-logo-container h2{font-size:1.75rem}.property-selector select{font-size:1.125rem;min-width:18rem;padding-top:1.25rem}}.footer{background-color:#444;bottom:0;box-shadow:0 -2px 5px #0000001a;color:#fff;display:flex;justify-content:space-around;position:fixed;width:100%}.footer-item{align-items:center;cursor:pointer;display:flex;flex:1 1;flex-direction:column;padding:.5rem;transition:all .2s ease}.footer-icon{font-size:1.25rem}.footer-text{font-size:1rem}.footer-item.active{background-color:#ffffff0d;color:#90caf9}.footer-item:hover{background-color:#ffffff1a}.footer-item.active .footer-icon{transform:scale(1.1)}@media (min-width:320px) and (max-width:1023px){.footer{padding:.25rem 0}.footer-item{padding:.25rem}.footer-icon{font-size:1.1rem;margin-bottom:.2rem}.footer-text{font-size:.85rem}}@media (min-width:768px){.footer-item{padding:.75rem .5rem}.footer-icon{font-size:1.5rem;margin-bottom:.3rem}.footer-text{font-size:.875rem}}@media (min-width:64rem){.footer{height:5rem;padding:.5rem 0}.footer-item{padding:.75rem 1rem}.footer-icon{font-size:1.75rem;margin-bottom:.4rem}.footer-text{font-size:1rem}}@media (min-width:90rem){.footer{height:4rem;padding:0}.footer-item{padding:.5rem}.footer-icon{font-size:2rem;margin-bottom:.1rem}.footer-text{font-size:1rem}}.warning-banner{align-items:center;box-shadow:0 2px 4px #0000001a;display:flex;font-size:.875rem;font-weight:700;gap:.5rem;justify-content:center;left:0;margin-bottom:0;margin-top:0;min-height:2.5rem;padding:.5rem;position:fixed;text-align:center;top:3.75rem;transition:background-color .3s ease;width:100%;z-index:99}.warning-banner.normal{animation:pulse-green 2s infinite;background-color:#4caf50;color:#fff}.warning-banner.active,.warning-banner.presoaking{animation:pulse-red 2s infinite;background-color:#ff5722;color:#fff}.warning-banner.sync_warning,.warning-banner.warning{animation:pulse-orange 2s infinite;background-color:#f80;color:#fff}.warning-banner.error{animation:pulse-error 2s infinite;background-color:#d32f2f;color:#fff}@keyframes pulse-green{0%{box-shadow:0 0 0 0 #4caf5066}70%{box-shadow:0 0 0 10px #4caf5000}to{box-shadow:0 0 0 0 #4caf5000}}@keyframes pulse-red{0%{box-shadow:0 0 0 0 #ff572266}70%{box-shadow:0 0 0 10px #ff572200}to{box-shadow:0 0 0 0 #ff572200}}@keyframes pulse-orange{0%{box-shadow:0 0 0 0 #ff980066}70%{box-shadow:0 0 0 10px #ff980000}to{box-shadow:0 0 0 0 #ff980000}}@keyframes pulse-error{0%{box-shadow:0 0 0 0 #d32f2f99}70%{box-shadow:0 0 0 15px #d32f2f00}to{box-shadow:0 0 0 0 #d32f2f00}}.active-icon,.error-icon,.normal-icon,.presoaking-icon{color:#fff;font-size:1rem}@media (min-width:480px){.warning-banner{font-size:.9375rem;gap:.6rem;padding:.6rem;top:5rem}.active-icon,.error-icon,.normal-icon,.presoaking-icon{font-size:1.125rem}}@media (min-width:768px){.warning-banner{font-size:1rem;gap:.75rem;padding:.75rem 1rem;top:4.5rem}.active-icon,.error-icon,.normal-icon,.presoaking-icon{font-size:1.25rem}}@media (min-width:1024px){.warning-banner{font-size:1.125rem;padding:.75rem 1.5rem;top:5rem}.active-icon,.error-icon,.normal-icon,.presoaking-icon{font-size:1.5rem}}.layout{flex-direction:column;max-height:100vh;min-height:100vh;position:relative}.content,.layout{display:flex;overflow:hidden}.content{bottom:3.5rem;flex:1 1;flex-direction:column;left:0;position:fixed;right:0;top:7rem}.content-no-scroll{overflow:hidden}@media (min-width:30rem){.content{top:8rem}}@media (min-width:48rem){.content{top:7rem}}@media (min-width:64rem){.content{bottom:5rem;top:8rem}}@media (min-height:62.5rem){.layout{justify-content:space-between}.content{flex:1 0 auto}}:root{--fire-blue:#4267b2;--fire-red:#e31e24;--header-footer-bg:#444;--background-off-white:#f5f5f5}.public-layout{background-color:#f5f5f5;background-color:var(--background-off-white);display:flex;flex-direction:column;min-height:100vh}.fire-defense-header{background-color:#444;background-color:var(--header-footer-bg);color:#fff;height:5rem;left:0;padding:1rem 2rem;position:fixed;right:0;top:0;z-index:100}.fire-defense-header,.fire-defense-header-logo{align-items:center;display:flex;justify-content:center}.fire-defense-header-logo h2{color:#fff;font-size:1.5rem;font-weight:700;letter-spacing:.5px;margin:0}.fire-defense-footer{background-color:#444;background-color:var(--header-footer-bg);bottom:0;height:5rem;left:0;position:fixed;width:100%;z-index:100}.public-content{flex:1 1;margin:5rem auto 0;max-width:1200px;overflow-y:auto;padding:2rem;width:100%}@media (max-width:479px){.fire-defense-footer,.fire-defense-header{height:3.75rem}.fire-defense-header{padding:.25rem}.fire-defense-header-logo h2{font-size:1.25rem}.public-content{margin-top:3.75rem;padding:1rem}}@media (min-width:480px) and (max-width:1023px){.fire-defense-header{padding:.5rem 1rem}.fire-defense-header-logo h2{font-size:1.25rem}}@media (min-width:768px) and (max-width:1439px){.fire-defense-header{padding:.75rem 1.5rem}.fire-defense-header-logo h2{font-size:1.5rem}}@media (min-width:1200px) and (max-width:1919px){.fire-defense-header-logo h2{font-size:1.75rem}}.cookie-consent-overlay{animation:slideUp .4s ease-out;bottom:0;left:0;position:fixed;right:0;z-index:9999}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.cookie-consent-banner{align-items:center;background:#fff;border-top:3px solid #4a5f8c;box-shadow:0 -4px 20px #00000026;display:flex;gap:1.5rem;margin:0 auto;max-width:100%;padding:1.5rem}.cookie-consent-icon{align-items:center;color:#4a5f8c;display:flex;flex-shrink:0;font-size:2.5rem;justify-content:center}.cookie-consent-content{flex:1 1;min-width:0;text-align:left}.cookie-consent-content h3{color:#333;font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.cookie-consent-content p{color:#666;font-size:.875rem;line-height:1.5;margin:0}.cookie-consent-actions{display:flex;flex-shrink:0;flex-wrap:wrap;gap:.75rem;justify-content:flex-end}.cookie-consent-button{border:none;border-radius:6px;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;padding:.625rem 1.25rem;transition:all .2s ease;white-space:nowrap}.cookie-consent-accept{background-color:#4a5f8c;color:#fff}.cookie-consent-accept:hover{background-color:#3a4f7c;box-shadow:0 2px 8px #4a5f8c4d;transform:translateY(-1px)}.cookie-consent-necessary{background-color:#4caf50;color:#fff}.cookie-consent-necessary:hover{background-color:#45a049;box-shadow:0 2px 8px #4caf504d;transform:translateY(-1px)}.cookie-consent-decline{background-color:#f5f5f5;border:1px solid #ddd;color:#666}.cookie-consent-decline:hover{background-color:#e0e0e0;border-color:#ccc;color:#555}.cookie-consent-learn-more{background-color:initial;border:1px solid #4a5f8c;color:#4a5f8c}.cookie-consent-learn-more:hover{background-color:#4a5f8c;color:#fff}.cookie-consent-button:active{transform:translateY(0)}@media (max-width:64rem){.cookie-consent-banner{align-items:flex-start;flex-direction:column;gap:1rem;padding:1.25rem}.cookie-consent-icon{font-size:2rem}.cookie-consent-content{text-align:left}.cookie-consent-actions{justify-content:stretch;width:100%}.cookie-consent-button{flex:1 1;min-width:-webkit-fit-content;min-width:fit-content}}@media (max-width:48rem){.cookie-consent-banner{gap:.875rem;padding:1rem}.cookie-consent-icon{font-size:1.75rem}.cookie-consent-content h3{font-size:1rem}.cookie-consent-content p{font-size:.8125rem}.cookie-consent-actions{flex-direction:column;gap:.5rem}.cookie-consent-button{font-size:.8125rem;padding:.75rem 1rem;width:100%}}
/*# sourceMappingURL=main.fce6b5ed.css.map*/