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}body,html{font-family:Segoe UI,sans-serif;margin:0;padding:0}.login-bg{align-items:center;animation:fadeIn 1s ease-in-out;background:linear-gradient(135deg,#031b2e,#00c4b3);display:flex;height:100vh;justify-content:center}.login-card{animation:slideUp .7s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#f0faffd9;border-radius:16px;box-shadow:inset 0 0 .5px #fff9,0 15px 30px #00000026;max-width:400px;padding:2.5rem;text-align:center;width:100%}.login-logo{margin-bottom:-1rem;width:200px}.subtext{color:#666;font-size:.9rem;margin-bottom:1.5rem}.input-wrapper{margin-bottom:1.5rem;position:relative;width:100%}.input-wrapper input{background:#fff;border:1px solid #ccc;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:.75rem 2.5rem;transition:border-color .3s;width:100%}.input-wrapper input:focus{border-color:#00c4b3;outline:none}.input-icon{color:#888;font-size:1.1rem;left:.9rem}.eye-icon,.input-icon{position:absolute;top:50%;transform:translateY(-50%)}.eye-icon{color:#666;cursor:pointer;font-size:1.2rem;right:.75rem}.eye-icon:hover{color:#00c4b3}.login-card button{background-color:#00c4b3;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:.75rem;transition:background-color .3s;width:100%}.login-card button:hover{background-color:#029f93}.login-error{color:red;margin-top:.75rem}footer{color:#aaa;font-size:.8rem;margin-top:1.5rem}@keyframes shake{0%{transform:translateX(0)}20%{transform:translateX(-8px)}40%{transform:translateX(8px)}60%{transform:translateX(-6px)}80%{transform:translateX(6px)}to{transform:translateX(0)}}.shake{animation:shake .4s ease-in-out}.navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#031b2ed9;box-shadow:0 8px 24px #00000040;color:#fff;font-family:Segoe UI,sans-serif;justify-content:space-between;padding:.75rem 2rem;position:-webkit-sticky;position:sticky;top:0;transition:background-color .3s ease;z-index:999}.navbar,.navbar-left{align-items:center;display:flex}.navbar-left{gap:1rem}.logo{height:44px}.title{font-size:1.2rem;font-weight:700;letter-spacing:.5px}.tech{color:#00c4b3}.hamburger{background:none;border:none;cursor:pointer;display:none}.navbar-links{align-items:center;display:flex;gap:1.25rem;transition:max-height .4s ease,opacity .4s ease}.navlink{color:#cfd8dc;font-weight:500;padding:.5rem 0;position:relative;text-decoration:none;transition:color .3s ease}.navlink:after{background-color:#00c4b3;border-radius:2px;bottom:-2px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.navlink.active,.navlink:hover{color:#00c4b3}.navlink.active:after,.navlink:hover:after{width:100%}.navbar-right{align-items:center;display:flex;gap:1rem}.logout-btn{background-color:#00c4b3;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:700;padding:.5rem 1rem;transition:background-color .3s ease}.logout-btn:hover{background-color:#029f93}@media (max-width:768px){.hamburger{color:#fff;display:block;font-size:1.4rem;margin-left:auto}.navbar-links{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#031b2ef2;border-top:1px solid #ffffff1a;flex-direction:column;left:0;max-height:0;opacity:0;overflow:hidden;position:absolute;top:100%;width:100%}.navbar-links.activo{max-height:500px;opacity:1;padding:1rem 2rem}.desktop-only{display:none}.mobile-user{border-top:1px solid #444;color:#aaa;margin-top:1rem;padding-top:.5rem}}.glass-card{animation:fadeIn 1s ease,slideUp .7s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#f0faffd9;border-radius:16px;box-shadow:inset 0 0 .5px #fff9,0 15px 30px #00000026;max-width:700px;padding:2rem 3rem;width:100%}.usuario-info{color:#444;font-size:.95rem;line-height:1.5;margin-bottom:1.5rem}.usuario-info p{margin:.3rem 0}.dashboard-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-top:2rem}.dashboard-card{background:#ffffffb3;border-radius:16px;box-shadow:0 8px 24px #00000026;color:#031b2e;padding:1.5rem;text-align:center;transition:transform .3s ease}.dashboard-card:hover{transform:translateY(-5px)}.dashboard-card h3{color:#666;font-size:1rem;margin:0}.dashboard-value{font-size:1.8rem;font-weight:700;margin-top:.5rem}.dashboard-card.alert{background:#ff50501a;border-left:4px solid #ff4d4d;color:#b30000}.dashboard-card.warning{background:#ffc80026;border-left:4px solid #ffc107;color:#856404}.dashboard-card.neutral{background:#00c4b31a;border-left:4px solid #00c4b3;color:#00796b}.panel-container{align-items:center;background:linear-gradient(135deg,#031b2e,#00c4b3);display:flex;font-family:Segoe UI,Tahoma,sans-serif;justify-content:center;min-height:100vh;overflow:hidden;padding:2rem;position:relative;z-index:1}.volver-panel{padding:1rem 0}.btn-volver{background-color:#00c4b3;border-radius:6px;color:#fff;font-weight:700;padding:8px 16px;text-decoration:none;transition:background-color .2s}.btn-volver:hover{background-color:#029c94}.sensor-page{background:linear-gradient(135deg,#031b2e,#00c4b3);display:flex;justify-content:center;min-height:100vh;padding:3rem 1.5rem}.sensor-container{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#f0faffd9;border-radius:16px;box-shadow:inset 0 0 .5px #fff9,0 15px 30px #00000026;max-width:1200px;padding:2rem 3rem;width:100%}.sensor-container h2{color:#031b2e;margin-bottom:.3rem}.sensor-container p{color:#666;font-size:.95rem;margin-bottom:1.5rem}.filtros select{box-shadow:0 3px 6px #0000001a;font-size:.95rem}.cards-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));padding-bottom:2rem}.sensor-card{align-items:flex-start;background:#ffffffb3;border-radius:16px;box-shadow:0 12px 25px #00000026;color:#031b2e;display:flex;gap:1rem;padding:1.5rem;transition:transform .3s ease}.sensor-card:hover{transform:translateY(-5px)}.icono-sensor{align-items:center;background:#00c4b3;border-radius:50%;box-shadow:0 4px 10px #0003;color:#fff;display:flex;font-size:2rem;height:45px;justify-content:center;min-width:45px;padding:.5rem}.info-sensor h3{font-size:1.1rem;margin:0 0 .5rem}.info-sensor p{font-size:.9rem;margin:.2rem 0}.sin-resultados{color:#666;font-style:italic;margin-top:2rem;text-align:center}.fadeIn{animation:fadeIn 1s ease}.slideUp{animation:slideUp .7s ease}.btn-exportar-wrapper{display:flex;justify-content:center;margin-bottom:1.5rem}.btn-exportar{background-color:#00c4b3;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:700;padding:10px 16px;transition:background-color .3s}.btn-exportar:hover{background-color:#029c94}.tiempo-container{animation:fadeIn 1s ease,slideUp .7s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#f0faffd9;border-radius:16px;box-shadow:inset 0 0 .5px #fff9,0 15px 30px #00000026;font-family:Segoe UI,sans-serif;margin:2rem auto;max-width:1400px;padding:2rem}.titulo{color:#031b2e;font-weight:700;margin-bottom:.5rem;text-align:center}.filtros{flex-wrap:wrap;justify-content:center;margin:1.5rem 0 2rem}.filtros select{background-color:#fff;border:1px solid #ccc;border-radius:8px;box-shadow:0 2px 6px #0000000d;color:#031b2e;font-size:1rem;min-width:180px;padding:10px 14px;transition:border-color .3s ease}.filtros select:focus{border-color:#00c4b3;outline:none}.filtros select[multiple]{height:140px}.graficas-row{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.grafica-card{background:#fff;border:1px solid #ddd;border-radius:12px;box-shadow:0 8px 20px #0000000d;display:flex;flex-direction:column;justify-content:space-between;max-width:420px;min-height:420px;padding:1rem;width:100%}.grafica-card h4{color:#00c4b3;margin-bottom:1rem;text-align:center}@keyframes slideUp{0%{transform:translateY(20px)}to{transform:translateY(0)}}.select-multiple{flex-grow:1;font-size:1rem;min-width:250px;z-index:10}.historial-container{background-color:#f7f9fa;font-family:Segoe UI,sans-serif;padding:2rem}.filtros{display:flex;gap:1rem;margin-bottom:2rem}.filtros button,.filtros input{font-size:1rem;padding:8px}.graficas-historicas{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}.grafica-historica-card{background:#fff;border-radius:6px;box-shadow:0 2px 8px #00000014;flex:1 1;min-width:300px;padding:1rem}.pagina-alarmas{background:linear-gradient(135deg,#031b2e,#00c4b3);color:#fff;font-family:Segoe UI,Tahoma,sans-serif;min-height:100vh;padding:2rem}.pagina-alarmas h2{font-size:1.8rem;margin-bottom:.5rem}.pagina-alarmas p{font-size:1rem;margin-bottom:2rem}.btn-crear{background-color:#00c4b3;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;margin-bottom:1rem;padding:.6rem 1.2rem;transition:background-color .2s ease}.btn-crear:hover{background-color:#029c94}.seccion{background:#fffc;border-radius:12px;box-shadow:0 8px 20px #00000026;color:#031b2e;margin-bottom:2rem;padding:1.5rem}.seccion h3{font-size:1.2rem;margin-bottom:1rem}.seccion ul{list-style:none;padding-left:1rem}.seccion li{margin-bottom:.5rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#031b2e99;height:100%;left:0;top:0;width:100%}.modal{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:16px;box-shadow:0 8px 20px #0003;color:#031b2e;width:400px}.modal h3{font-size:1.4rem}.modal label{display:block;font-weight:700;margin:.6rem 0 .3rem}.modal input,.modal select{border:1px solid #ccc;border-radius:8px;font-size:.95rem;margin-bottom:1rem;padding:.5rem;width:100%}.btn-confirmar{background-color:#00c4b3;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:.6rem 1.2rem;width:100%}.btn-confirmar:hover{background-color:#029c94}:root{--font-small:0.85rem;--font-base:1rem;--font-large:1.2rem}.pagina-historicas{background:linear-gradient(135deg,#031b2e,#00c4b3);color:#031b2e;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh;padding:2rem}.top-bar{align-items:center;background:#fffffff2;border-radius:12px;box-shadow:0 6px 16px #0000001f;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.2rem 1.5rem}.top-bar h2{color:#031b2e;font-size:1.2rem;font-size:var(--font-large);margin:0}.top-bar button{background-color:#00c4b3;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-size:var(--font-base);font-weight:700;padding:.6rem 1.2rem;transition:background-color .3s ease}.top-bar button:hover{background-color:#029c94}.contenedor-graficos{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.grafico-box{background:#fff;border-radius:12px;box-shadow:0 6px 16px #0000001f;padding:1rem 1.2rem}.grafico-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.grafico-header h4{color:#031b2e;font-size:1rem;font-size:var(--font-base);margin:0}.grafico-header button{background:none;border:none;color:#b30000;cursor:pointer;font-size:1.2rem}canvas{max-height:350px;width:100%!important}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background-color:#0006;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.modal{animation:fadeIn .3s ease-in-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffc;border-radius:14px;box-shadow:0 10px 30px #00000040;max-width:420px;padding:2rem;width:90%}.modal h3{color:#031b2e;margin-top:0}.modal h3,.modal input[type=datetime-local],.modal select{font-size:1rem;font-size:var(--font-base);margin-bottom:1rem}.modal input[type=datetime-local],.modal select{border:1px solid #ccc;border-radius:8px;padding:.5rem;width:100%}.modal-buttons{display:flex;justify-content:space-between}.modal-buttons button{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-size:var(--font-base);font-weight:700;padding:.5rem 1rem}.modal-buttons button:first-child{background-color:#00c4b3;color:#fff}.modal-buttons button:last-child{background-color:#ccc;color:#031b2e}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-presets{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:flex-start;margin-bottom:1rem;margin-top:.5rem;row-gap:.4rem}.modal-presets button{background-color:#00c4b3;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.85rem;font-size:var(--font-small);font-weight:700;padding:.4rem .9rem;transition:background-color .2s ease}.modal-presets button:hover{background-color:#029c94}
/*# sourceMappingURL=main.4d2558fd.css.map*/