*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;background-color:#262322;overflow:hidden;font-family:Roboto Condensed,sans-serif}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#1a1817;border-radius:10px}::-webkit-scrollbar-thumb{background:#4a4a4a;border-radius:10px;border:2px solid #1a1817;transition:background .2s ease}::-webkit-scrollbar-thumb:hover{background:#d1060a}*{scrollbar-width:thin;scrollbar-color:#4a4a4a #1a1817}.main-panel{width:100%;height:100%;display:flex;flex-direction:column}.headbar{background-color:#000;height:80px;display:flex;align-items:center;justify-content:space-between;padding:0 4rem;flex-shrink:0;position:relative;z-index:1000;border-bottom:1px solid rgba(255,255,255,.08)}@media (max-width: 1024px){.headbar{padding:0 2rem}}.headbar-left-side{display:flex;align-items:center;gap:1rem}.headbar-right-side{display:flex;align-items:center;gap:3rem}.user-menu-wrapper{margin-left:1rem}@media (max-width: 768px){.desktop-only{display:none}}.headbar-right-side-content{display:flex;justify-content:space-between;align-items:center;width:100%}.headbar-logo{height:48px}.headbar-title{color:#fff;height:32px}.headbar-options{color:#fff;font-size:1.1rem;text-decoration:none;font-weight:500;letter-spacing:.8px;position:relative;padding:.5rem 0;transition:color .3s ease;opacity:.8}.headbar-options:hover{opacity:1;color:#fff}.headbar-options.active{color:#fff;opacity:1;font-weight:700}.headbar-options:after{content:"";position:absolute;bottom:0;left:0;width:0;height:3px;background-color:#d1060a;transition:width .3s ease;border-radius:4px}.headbar-options.active:after{width:100%}.headbar-options:hover:after{width:100%;background-color:#d1060a80}.mobile-menu-toggle{display:none;background:transparent;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:8px}@media (max-width: 768px){.mobile-menu-toggle{display:block}}.mobile-nav-overlay{position:fixed;top:10vh;left:0;width:100%;height:90vh;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:999;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s ease-in-out}.mobile-nav-overlay.open{transform:translate(0)}.mobile-nav-content{display:flex;flex-direction:column;align-items:center;padding-top:5vh;gap:2rem}.mobile-nav-link{color:#fff;font-size:1.5rem;text-decoration:none;font-weight:700;letter-spacing:1px}.mobile-nav-link.active{color:#d1060a}.mobile-user-menu{margin-top:2rem;border-top:1px solid rgba(255,255,255,.1);padding-top:2rem;width:70%;display:flex;justify-content:center}.headbar-icon{font-size:1.2vw;color:#fff}.content{background-color:#262322;flex-grow:1;overflow:auto;padding:10px;color:#fff}.vsd-user{position:relative}.vsd-user-btn{display:flex;align-items:center;gap:10px;height:38px;padding:0 12px;background:#2f2f2f;color:#fff;border:1px solid rgba(255,255,255,.12);border-radius:10px;cursor:pointer;font:500 .95rem Roboto Condensed,sans-serif;transition:background .15s ease,box-shadow .15s ease,filter .15s ease}.vsd-user-btn:hover{background:#343434}.vsd-user-btn.is-open{background:#373737}.vsd-user-icon{font-size:16px;opacity:.9}.vsd-user-email{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:.9}.vsd-user-caret{font-size:16px;opacity:.75}.vsd-user-btn.vsd-user-btn--icon{width:38px;padding:0;justify-content:center;box-shadow:inset 0 0 0 1px #ffffff14,0 2px 10px #00000059;background:#2f2f2f}.vsd-user-btn.vsd-user-btn--icon:hover{filter:brightness(1.06);box-shadow:inset 0 0 0 1px #ffffff1f,0 3px 12px #0000006b}.vsd-user-btn.vsd-user-btn--icon.is-open{background:#373737;box-shadow:inset 0 0 0 1px #ffffff24,0 3px 12px #00000075}.vsd-user-pop{position:absolute;right:0;top:calc(100% + 8px);min-width:240px;background:#2f2f2f;color:#eee;border:1px solid rgba(255,255,255,.12);border-radius:12px;box-shadow:0 10px 22px #00000059;padding:8px;z-index:50}.vsd-user-row{width:100%;display:flex;align-items:center;gap:10px;padding:10px;border-radius:10px;color:#f0f0f0;background:transparent;border:none;text-align:left;font:500 .95rem Roboto Condensed,sans-serif}.vsd-user-row svg{opacity:.9}.vsd-user-row.is-action{cursor:pointer}.vsd-user-row.is-action:hover{background:#ffffff12}.vsd-user-sep{height:1px;background:#ffffff1f;margin:6px;border-radius:1px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(20px,1fr));gap:1rem}.kpi-grid.KPIs{width:100%}.kpi-card{background:#353535;border-radius:18px;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid rgba(255,255,255,.06);box-shadow:0 6px 18px #00000040}.kpi-card--clickable{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.kpi-card--clickable:hover{transform:translateY(-1px);box-shadow:0 10px 22px #00000047;border-color:#ffffff1f}.kpi-card-left{display:flex;flex-direction:column;gap:4px}.kpi-card-title{color:#cfcfcf;font-size:clamp(12px,.95vw,16px)}.kpi-card-value{color:#fff;font-weight:600;font-size:clamp(20px,2.2vw,36px);line-height:1.1}.kpi-card-icon{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-size:22px}.kpi-card--ok .kpi-card-icon{color:#30d974;background:#30d97429}.kpi-card--warn .kpi-card-icon{color:#ffa133;background:#ffa13329}.kpi-card--neutral .kpi-card-icon{color:#cfcfcf;background:#ffffff1f}.kpi-card--error .kpi-card-icon{color:#d1060a;background:#d1060a5c}.dash-content{display:flex;flex-direction:column;margin:0 5vw;height:87vh;overflow:hidden}@media (max-width: 1024px){.dash-content{margin:0 2vw;height:auto;overflow:visible}}.dash-header{flex:0 0 auto;width:100%}.dash-top-row{display:flex;width:100%;margin-bottom:3vh}.dash-controls-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;width:100%;margin-bottom:3vh}.dash-control-group{display:flex;align-items:center;gap:12px;width:100%}.search-group{justify-content:flex-start}.filters-group{justify-content:center}.toggle-group{justify-content:flex-start}@media (max-width: 1024px){.dash-controls-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width: 768px){.dash-controls-grid{grid-template-columns:1fr;gap:12px}.filters-group,.toggle-group{justify-content:flex-start}}.dash-valves,.dash-list{flex:1 1 auto;min-height:0;overflow:auto}.dash-valves{display:grid;gap:1vw;grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width: 1200px){.dash-valves{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 640px){.dash-valves{grid-template-columns:1fr}}.dash-list{display:flex;flex-direction:column;gap:8px;padding-right:8px}.view-toggle{display:flex;background-color:#353535;border-radius:12px;padding:4px;margin-left:.5vw;border:1px solid rgba(255,255,255,.12);height:44px;align-items:center}.view-toggle-btn{background:transparent;border:none;color:#888;width:42px;height:36px;cursor:pointer;border-radius:10px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;font-size:1.2rem}.view-toggle-btn:hover{color:#fff;background-color:#ffffff0d}.view-toggle-btn.active{background-color:#ffffff1a;color:#d1060a}.valve-search{position:relative;width:100%}@media (max-width: 768px){.valve-search{max-width:100%}}.valve-search-input{width:100%;height:44px;border-radius:12px;padding:0 14px 0 40px;background:#353535;border:1px solid rgba(255,255,255,.12);color:#fff;outline:none;font-size:.98rem;font-family:Roboto Condensed,sans-serif}.valve-search-input::placeholder{color:#ffffffb3}.valve-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:18px;color:#fffc;pointer-events:none}.valve-suggestions{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#2f2f2f;border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:6px;max-height:260px;overflow:auto;box-shadow:0 10px 22px #00000059;z-index:20}.valve-suggestion{display:flex;align-items:center;gap:10px;padding:10px;border-radius:10px;color:#f0f0f0;cursor:pointer}.valve-suggestion:hover,.valve-suggestion.is-active{background:#ffffff12}.valve-suggestion.empty{cursor:default;color:#bfbfbf}.dot{width:10px;height:10px;border-radius:999px}.dot.online{background:#30d974}.dot.alert{background:#d1060a}.dot.offline{background:#9b9b9b}.label{display:inline-flex;align-items:baseline;gap:6px}.muted{color:#bdbdbd;font-size:.9em}.valve-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:28px;height:28px;border:none;border-radius:999px;background:transparent;color:#ffffffd9;display:grid;place-items:center;cursor:pointer}.valve-clear:hover{background:#ffffff14}.valve-clear:focus-visible{outline:none;box-shadow:0 0 0 3px #ffffff26}.label .primary{font-weight:700}.loc-chip{background:transparent;border:none;color:#cfcfcf;padding:2px 6px;margin-left:2px;border-radius:6px;cursor:pointer;font:inherit}.loc-chip:hover{background:#ffffff14;color:#fff}.loc-chip:focus-visible{outline:none;box-shadow:0 0 0 3px #ffffff26;border-radius:8px}.select{position:relative;width:100%;max-width:200px;font-family:Roboto Condensed,sans-serif}@media (max-width: 768px){.select{max-width:100%}}.select--full{width:100%}.select.is-disabled{opacity:.6;pointer-events:none}.select-trigger{width:100%;height:44px;border-radius:12px;padding:0 14px;background:#353535;border:1px solid rgba(255,255,255,.12);color:#fff;display:inline-flex;align-items:center;justify-content:space-between;gap:1vw;cursor:pointer;text-align:left}.select-trigger:hover{border-color:#ffffff2e}.select-trigger:focus-visible{outline:none;box-shadow:0 0 0 3px #ffffff26}.select-label{display:inline-flex;align-items:center;gap:8px}.select-right-icon{font-size:16px;opacity:.9}.select-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#2f2f2f;border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:6px;max-height:260px;overflow:auto;box-shadow:0 10px 22px #00000059;z-index:30}.select-option{display:flex;align-items:center;gap:10px;padding:10px;border-radius:10px;color:#f0f0f0;cursor:pointer}.select-option:hover,.select-option.is-active{background:#ffffff12}.select-option.is-selected{font-weight:600}.select-opt-icon{display:inline-grid;place-items:center;width:16px;height:16px;border-radius:999px}.select-opt-icon.online{background:#30d974}.select-opt-icon.alert{background:#d1060a}.select-opt-icon.offline{background:#9b9b9b}.select-right{display:inline-flex;align-items:center;gap:10px}.select-arrow{font-size:16px;opacity:.9;transition:transform .12s ease}.select-trigger.is-open .select-arrow{transform:rotate(180deg)}.select-right-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:999px;background:transparent;color:#fff;cursor:pointer}.select-right-icon-btn:hover{background:#ffffff14}.select-right-icon{font-size:16px;transition:transform .15s ease}.select-right-icon-btn.is-desc .select-right-icon{transform:rotate(180deg)}.select-menu{overflow:auto;scrollbar-gutter:stable;scrollbar-width:thin;scrollbar-color:#5a5a5a #1f1d1c}.select-menu::-webkit-scrollbar{width:10px}.select-menu::-webkit-scrollbar-track{background:#1f1d1c;border-radius:10px}.select-menu::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#6a6a6a,#515151);border-radius:10px;border:2px solid #1f1d1c}.select-menu::-webkit-scrollbar-thumb:hover{background:#7a7a7a}.valve-card{background:#353535;color:#fff;border-radius:18px;border:2px solid rgba(255,255,255,.08);box-shadow:0 6px 18px #00000040;padding:clamp(12px,1.6vh,18px);width:100%;height:clamp(300px,35vh,450px);display:flex;flex-direction:column;gap:clamp(8px,1vh,16px);font-family:Roboto Condensed,sans-serif;position:relative;overflow:hidden}.valve-card--alert{border-color:#dc26264d}.valve-card--alert:before{content:"";position:absolute;top:0;left:0;width:6px;height:100%;background:linear-gradient(to bottom,#dc2626,#dc26261a);z-index:1}.valve-card-header{display:flex;align-items:center;justify-content:flex-start}.valve-pn{font-size:clamp(24px,.95vw,36px);font-weight:700;letter-spacing:.3px}.valve-gauge-wrap{position:relative;display:grid;place-items:center;min-height:140px;padding:6px 0 2px}.gauge-center{position:absolute;display:grid;place-items:center;gap:4px;padding-top:1vh}.gauge-percent{font-weight:700;font-size:28px;line-height:1}.gauge-updated{font-size:12px;color:#cfcfcf}.valve-meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1vh 10vw;margin-top:1vh}.meta-item{display:flex;align-items:center;gap:8px;min-width:0}.meta-icon{width:22px;height:22px;display:grid;place-items:center;color:#cfcfcf}.meta-text{color:#fff;font-size:clamp(20px,.95vw,30px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width: 768px){.valve-card{height:auto;min-height:320px;padding:12px}.valve-pn{font-size:24px}.meta-text{font-size:18px}.valve-gauge-wrap{min-height:120px}}@media (max-width: 480px){.valve-meta-grid{grid-template-columns:1fr;gap:8px}.gauge-percent{font-size:22px}}.valve-gauge{position:relative;display:inline-block;width:100%;max-width:var(--gauge-size, 180px)}.valve-gauge-svg{display:block;width:100%;height:auto}.valve-gauge-track{opacity:.35}.valve-gauge-bar{transition:stroke-dasharray var(--gauge-dur, .7s) cubic-bezier(.22,1,.36,1),stroke var(--gauge-dur, .7s) linear;will-change:stroke-dasharray,stroke}.valve-gauge-center{position:absolute;left:0;top:0;width:100%;height:100%;display:grid;place-items:center;pointer-events:none}.valve-gauge-value{font-size:40px;font-weight:800;color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.35)}.valve-row{display:grid;grid-template-columns:8px 1.5fr 1fr 1fr 1fr 2fr 1.5fr;grid-template-rows:1fr;grid-auto-flow:column;align-items:center;background:#353535;color:#fff;border-radius:12px;border:1px solid rgba(255,255,255,.08);box-shadow:0 4px 12px #0003;height:70px;padding-right:1.5rem;gap:1.5rem;font-family:Roboto Condensed,sans-serif;transition:all .2s ease;cursor:default;margin-bottom:12px;overflow:hidden}@media (max-width: 1400px){.valve-row{grid-template-columns:8px 1.5fr 1fr 1fr 1.8fr 1.5fr;gap:1rem}.row-signal{display:none!important}}@media (max-width: 1200px){.valve-row{grid-template-columns:8px 1.5fr 1fr 1.8fr 1.5fr}.row-battery{display:none!important}}@media (max-width: 1000px){.valve-row{grid-template-columns:8px 1.5fr 1fr 1.5fr;padding-right:1rem}.row-updated{display:none!important}}@media (max-width: 768px){.valve-row{grid-template-columns:8px 1.4fr 1fr .8fr;gap:.8rem;height:64px}.row-percent-bar-bg{display:none!important}.row-percent-text{font-size:1.1rem;text-align:left}.row-status span{font-size:.9rem}}@media (max-width: 480px){.valve-row{grid-template-columns:6px 1.2fr 1fr;gap:.5rem}.row-status span{display:none}}.valve-row:hover{background-color:#3e3e3e;transform:translateY(-1px);box-shadow:0 6px 16px #0000004d}.row-alert-bar{width:100%;height:100%;background-color:transparent}.valve-row--alert .row-alert-bar{background-color:#dc2626}.valve-row--alert{background-color:#3d3434}.row-main-info{display:flex;flex-direction:column;justify-content:center;min-width:0}.row-pn{font-weight:700;font-size:1.25rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-location{display:flex;align-items:center;gap:6px;font-size:.85rem;color:#cfcfcf}.row-status,.row-battery,.row-signal{display:flex;align-items:center;gap:10px;font-size:1.1rem;color:#fff;min-width:0;white-space:nowrap}.row-status span,.row-battery span,.row-signal span{overflow:hidden;text-overflow:ellipsis}.row-percent-wrap{display:flex;align-items:center;gap:16px}.row-percent-bar-bg{flex:1;height:10px;background-color:#ffffff1a;border-radius:5px;overflow:hidden}.row-percent-bar-fill{height:100%;border-radius:5px;transition:width .4s cubic-bezier(.175,.885,.32,1.275)}.row-percent-text{min-width:60px;text-align:right;font-weight:700;font-size:1.2rem;white-space:nowrap}.row-updated{font-size:.85rem;color:#cfcfcf;text-align:right}.vsd-field{width:100%}.vsd-field-label{display:block;color:#ffffffd9;font-size:.92rem;margin:0 0 6px;font-family:Roboto Condensed,sans-serif}.vsd-input{position:relative;height:44px}.vsd-input-control{width:100%;height:100%;border-radius:12px;padding:0 14px;background:#353535;border:1px solid rgba(255,255,255,.12);color:#fff;outline:none;font-size:.98rem;font-family:Roboto Condensed,sans-serif;transition:box-shadow .15s ease,border-color .15s ease,background-color .15s ease}.vsd-input-control::placeholder{color:#ffffffb3}.vsd-input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:18px;color:#fffc;pointer-events:none}.vsd-input-control.has-left{padding-left:40px}.vsd-input-right,.vsd-input-clear{position:absolute;right:8px;top:0;bottom:0;margin:auto 0;display:grid;place-items:center}.vsd-input-control.has-right{padding-right:42px}.vsd-input-control:focus{border-color:#ffffff40;box-shadow:0 0 0 2px #ffffff26}.vsd-input.is-invalid .vsd-input-control{border-color:#e11d48bf;box-shadow:0 0 0 2px #e11d4833}.vsd-field-msg{color:#bdbdbd;font-size:.86rem;margin-top:6px;font-family:Roboto Condensed,sans-serif}.vsd-field-msg.is-error{color:#ffd7df}.vsd-input{position:relative}.vsd-input-right{position:absolute;right:8px;inset-block:0;margin-block:auto;width:32px;height:32px;display:grid;place-items:center;pointer-events:auto}.vsd-input-control.has-right{padding-right:48px}.vsd-input-right svg{display:block}.vsd-input-clear{position:absolute;right:8px;inset-block:0;margin-block:auto;width:32px;height:32px;display:grid;place-items:center;border:none;border-radius:8px;background:transparent;color:#ffffffd9;cursor:pointer;line-height:1}.vsd-input-clear:hover{background:#ffffff14}.vsd-input-clear:focus-visible{outline:none;box-shadow:0 0 0 3px #ffffff26}.vsd-input-toggle{width:32px;height:32px;display:grid;place-items:center;border-radius:8px;background:transparent;color:#fffc;border:none;cursor:pointer}.vsd-input-toggle:hover{background:#ffffff14}.vsd-input-toggle:focus-visible{outline:none;box-shadow:0 0 0 3px #ffffff26}.vsd-checkbox{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.98rem;color:#e6e6e6}.vsd-checkbox input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.vsd-checkbox .box{width:18px;height:18px;border-radius:4px;background:#353535;border:1px solid rgba(255,255,255,.18);box-shadow:inset 0 0 #e11d4800;display:inline-block;transition:box-shadow .15s ease,background .15s ease,border-color .15s ease;position:relative}.vsd-checkbox .box:after{content:"";position:absolute;inset:0;margin:auto;width:10px;height:10px;border-radius:2px;transform:scale(0);transition:transform .12s ease;background:#fff;-webkit-mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%23000' d='M7.629 13.233 3.9 9.504l1.4-1.4 2.329 2.329 6.07-6.07 1.4 1.4-7.47 7.47z'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%23000' d='M7.629 13.233 3.9 9.504l1.4-1.4 2.329 2.329 6.07-6.07 1.4 1.4-7.47 7.47z'/%3E%3C/svg%3E") center/contain no-repeat}.vsd-checkbox:hover .box{border-color:#ffffff47}.vsd-checkbox input:focus-visible+.box{box-shadow:0 0 0 3px #ffffff26;outline:none}.vsd-checkbox input:checked+.box{background:#e11d48;border-color:#ffffff2e;box-shadow:0 10px 20px #e11d482e inset}.vsd-checkbox input:checked+.box:after{transform:scale(1)}.vsd-checkbox .text{line-height:1}.login-screen{min-height:100vh;display:grid;place-items:center;background:#0c0c0d;color:#e6e6e6;padding:24px;font-family:Roboto Condensed,sans-serif}.login-card{width:min(92vw,420px);background:#2f2f2f;border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:22px;box-shadow:0 16px 48px #0006}.login-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}.login-logo{width:36px;height:36px;border-radius:8px;background:#e11d481f;border:1px solid rgba(225,29,72,.35);object-fit:contain}.login-title{margin:0;font-size:1.4rem;font-weight:700}.login-sub{margin:.25rem 0 0;color:#a3a3ad;font-size:.95rem}.login-form{display:grid;gap:14px}.login-row{display:flex;align-items:center;justify-content:space-between;margin-top:2px}.login-remember{display:flex;align-items:center;gap:8px;font-size:.95rem;color:#e6e6e6}.login-link{color:#f43f5e;text-decoration:none}.login-link:hover{filter:brightness(1.08)}.login-btn{width:100%;background:#e11d48;color:#fff;border:0;border-radius:12px;padding:12px 16px;font-weight:700;font-size:1rem;box-shadow:0 10px 24px #e11d482e;cursor:pointer}.login-btn:hover{filter:brightness(1.06)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-error{background:#e11d481a;border:1px solid rgba(225,29,72,.45);color:#ffd7df;border-radius:10px;padding:10px 12px;margin-bottom:8px}
