*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f0f2f5;--surface:#fff;--surface-raised:#fff;--border:#e2e5eb;--border-hover:#b8bcc8;--text:#0f1117;--text2:#5a6070;--text3:#9299a8;--row-hover:#f7f8fa;--chip:#eef0f4;--avatar:#1a1f2e;--accent:#4f6ef7;--green:#16a34a;--amber:#d97706;--red:#dc2626;--scrollbar:#d1d5db;--radius:10px;--radius-sm:6px;--shadow-sm:0 1px 3px #00000012, 0 1px 2px #0000000d;--shadow-md:0 4px 12px #00000014, 0 1px 3px #0000000d}[data-theme=dark]{--bg:#0b0d14;--surface:#141720;--surface-raised:#1a1e2c;--border:#232737;--border-hover:#363b52;--text:#eaecf4;--text2:#8b92a8;--text3:#5c6378;--row-hover:#181c28;--chip:#1e2130;--avatar:#4f6ef7;--scrollbar:#363b52;--shadow-sm:0 1px 3px #0000004d, 0 1px 2px #0003;--shadow-md:0 4px 16px #0006, 0 1px 4px #0000004d}body{background:var(--bg);color:var(--text);font-family:Roboto,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5;transition:background .2s,color .2s}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:3px}.screen{display:none}.screen.active{display:block}#screen-auth{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}#screen-auth.active{display:flex}.auth-wrap{width:100%;max-width:380px}.auth-logo{text-align:center;margin-bottom:32px}.auth-logo .logo-mark{background:var(--avatar);color:#fff;border-radius:3px;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 12px;font-size:22px;display:flex}.auth-logo h1{color:var(--text);letter-spacing:-.3px;font-size:20px;font-weight:700}.auth-logo p{color:var(--text3);margin-top:4px;font-size:13px}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:28px}.auth-tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:24px;display:flex}.auth-tab{color:var(--text3);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-1px;padding:10px;font-family:inherit;font-size:13px;font-weight:500;transition:color .2s,border-color .2s}.auth-tab.active{color:var(--text);border-bottom-color:var(--accent)}.field{margin-bottom:14px}.field label{color:var(--text2);margin-bottom:5px;font-size:12px;font-weight:500;display:block}.field input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);outline:none;padding:9px 11px;font-family:inherit;font-size:14px;transition:border-color .2s,box-shadow .2s}.field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4f6ef71f}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;width:100%;margin-top:6px;padding:10px;font-family:inherit;font-size:14px;font-weight:500;transition:opacity .2s,box-shadow .2s;box-shadow:0 2px 8px #4f6ef74d}.btn-primary:hover{opacity:.88}.auth-msg{text-align:center;border-radius:3px;margin-top:10px;padding:8px;font-size:12px;display:none}.auth-msg.error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.auth-msg.success{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}[data-theme=dark] .auth-msg.error{color:#fca5a5;background:#dc26261a;border-color:#dc262633}[data-theme=dark] .auth-msg.success{color:#86efac;background:#16a34a1a;border-color:#16a34a33}.auth-footer{text-align:center;margin-top:14px}.auth-footer a{color:var(--text3);font-size:12px;text-decoration:none;transition:color .2s}.auth-footer a:hover{color:var(--accent)}.onboard-steps{border-bottom:1px solid var(--border);align-items:center;gap:0;margin-bottom:24px;padding-bottom:16px;display:flex}.onboard-step{color:var(--text3);text-transform:uppercase;letter-spacing:.5px;flex-direction:column;flex:1;align-items:center;gap:4px;font-size:10px;font-weight:500;display:flex;position:relative}.onboard-step:not(:last-child):after{content:"";background:var(--border);width:80%;height:1px;position:absolute;top:11px;left:60%}.onboard-dot{background:var(--chip);width:22px;height:22px;color:var(--text3);border:1.5px solid var(--border);z-index:1;border-radius:50%;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:flex;position:relative}.onboard-step.active .onboard-dot{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 0 0 3px #4f6ef733}.onboard-step.active{color:var(--accent)}.onboard-step.done .onboard-dot{background:var(--green);color:#fff;border-color:var(--green)}.onboard-step.done{color:var(--green)}.onboard-unit-row{align-items:center;gap:12px;margin-bottom:4px;display:flex}.onboard-unit-label{color:var(--text2);font-size:12px;font-weight:500}#screen-claim{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}#screen-claim.active{display:flex}.claim-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:460px;box-shadow:var(--shadow-md);padding:28px 32px}.claim-card h2{color:var(--text);margin-bottom:6px;font-size:16px;font-weight:700}.claim-card p{color:var(--text3);margin-bottom:20px;font-size:13px;line-height:1.5}.claim-input{background:var(--bg);border:1px solid var(--border);letter-spacing:3px;width:100%;color:var(--text);text-align:center;text-transform:uppercase;border-radius:3px;outline:none;margin-bottom:12px;padding:10px 11px;font-family:monospace;font-size:15px}.claim-input:focus{border-color:var(--accent)}.claim-input::placeholder{letter-spacing:1px;color:var(--text3);font-size:12px}.btn-ghost{width:100%;color:var(--text3);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:3px;margin-top:8px;padding:9px;font-family:inherit;font-size:13px;transition:all .2s}.btn-ghost:hover{border-color:var(--border-hover);color:var(--text)}.claim-msg{text-align:center;color:var(--red);margin-top:10px;font-size:12px;display:none}#screen-home{background:var(--bg);min-height:100vh}#screen-home.active{display:block}.home-body{max-width:960px;margin:0 auto;padding:28px 20px 60px}.home-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.home-title{color:var(--text);letter-spacing:-.3px;font-size:18px;font-weight:700}.btn-sm{border:1px solid var(--border);color:var(--text2);cursor:pointer;background:0 0;border-radius:3px;align-items:center;gap:6px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s;display:flex}.btn-sm:hover{border-color:var(--border-hover);color:var(--text)}.btn-sm-accent{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:3px;align-items:center;gap:6px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:opacity .2s;display:flex}.btn-sm-accent:hover{opacity:.88}.locations-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.loc-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow-sm);flex-direction:column;gap:12px;padding:20px;transition:border-color .2s,box-shadow .2s,transform .15s;display:flex}.loc-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.loc-card-header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.loc-name{color:var(--text);font-size:15px;font-weight:600}.loc-type-chip{background:var(--chip);color:var(--text3);border-radius:20px;flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:500}.loc-device-info{flex-direction:column;gap:4px;display:flex}.loc-device-name{color:var(--text2);align-items:center;gap:4px;font-size:12px;display:flex}.loc-device-name-text{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.loc-arrow-btn{border-radius:var(--radius-sm);width:20px;height:20px;color:var(--text3);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:color .15s,background .15s;display:flex}.loc-arrow-btn:hover{color:var(--text);background:var(--chip)}.loc-level{letter-spacing:-1px;font-size:36px;font-weight:700;line-height:1}.loc-status{text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:11px;font-weight:500}.loc-lastseen{color:var(--text3);align-items:center;gap:5px;margin-top:6px;font-size:11px;display:flex}.loc-cycle-dots{align-items:center;gap:4px;margin-left:2px;display:flex}.loc-cycle-dot{background:var(--border-hover);border-radius:50%;width:5px;height:5px;transition:background .3s}.loc-cycle-dot.active{background:var(--accent)}.loc-offline-badge{text-transform:uppercase;letter-spacing:.5px;color:var(--text3);background:var(--chip);border-radius:20px;padding:2px 8px;font-size:10px;font-weight:600}.online-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.online-dot.online{background:#22c55e;box-shadow:0 0 0 2px #22c55e33}.online-dot.offline{background:#94a3b8}.loc-empty{color:var(--text3);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:8px 0;display:flex}.loc-empty-icon{opacity:.35}.loc-empty-text{font-size:13px}.loc-link-btn{color:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:all .2s}.loc-link-btn:hover{background:#4f6ef70f}.loc-add-card{border:1px dashed var(--border);border-radius:var(--radius);cursor:pointer;color:var(--text3);background:0 0;justify-content:center;align-items:center;gap:8px;min-height:120px;padding:20px;font-size:13px;transition:border-color .2s;display:flex}.loc-add-card:hover{border-color:var(--accent);color:var(--accent)}#screen-app{background:var(--bg);min-height:100vh}#screen-app.active{display:block}.topnav{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;-webkit-backdrop-filter:blur(12px);justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}[data-theme=dark] .topnav{background:#141720d9}.nav-logo{flex:1;align-items:center;gap:10px;display:flex}.nav-logo .mark{background:var(--accent);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;font-weight:700;display:flex;box-shadow:0 2px 6px #4f6ef759}.nav-logo span{color:var(--text);letter-spacing:-.2px;font-size:15px;font-weight:700}.nav-center{flex:1;justify-content:center;align-items:center;display:flex}.nav-right{flex:1;justify-content:flex-end;align-items:center;gap:6px;display:flex}.nav-icon-btn{border-radius:var(--radius-sm);border:1px solid var(--border);width:34px;height:34px;color:var(--text2);cursor:pointer;background:0 0;justify-content:center;align-items:center;font-size:14px;transition:all .2s;display:flex;position:relative}.nav-icon-btn:hover{background:var(--row-hover);border-color:var(--border-hover);color:var(--text)}.nav-text-btn{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text2);cursor:pointer;background:0 0;padding:6px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s}.nav-text-btn:hover{border-color:var(--border-hover);color:var(--text)}.notif-badge{background:var(--red);border-radius:50%;width:7px;height:7px;display:none;position:absolute;top:4px;right:4px}.device-switcher{position:relative}.device-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:3px;align-items:center;gap:7px;max-width:200px;padding:5px 10px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s;display:flex}.device-btn:hover{border-color:var(--border-hover);background:var(--row-hover)}.device-btn-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.device-btn-chevron{color:var(--text3);flex-shrink:0;font-size:9px}.device-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-width:240px;box-shadow:var(--shadow-md);z-index:200;display:none;position:absolute;top:calc(100% + 6px);left:0;overflow:hidden}.device-dropdown.show{display:block}.device-dd-item{cursor:pointer;border-bottom:1px solid var(--border);color:var(--text);justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;transition:background .15s;display:flex}.device-dd-item:last-child{border-bottom:none}.device-dd-item:hover{background:var(--row-hover)}.device-dd-item.active{color:var(--accent);font-weight:500}.device-dd-active-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:6px;height:6px}.device-dd-add{cursor:pointer;color:var(--text3);border-top:1px solid var(--border);align-items:center;gap:8px;padding:10px 14px;font-size:13px;transition:background .15s;display:flex}.device-dd-add:hover{background:var(--row-hover);color:var(--accent)}.notif-dropdown{background:var(--surface);border:1px solid var(--border);z-index:200;border-radius:3px;width:320px;display:none;position:absolute;top:56px;right:16px;box-shadow:0 4px 16px #0000001f}.notif-dropdown.show{display:block}.notif-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.notif-head span{color:var(--text);font-size:13px;font-weight:500}.notif-mark{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:12px}.notif-list{max-height:300px;overflow-y:auto}.notif-item{border-bottom:1px solid var(--border);align-items:flex-start;gap:10px;padding:12px 16px;transition:background .15s;display:flex}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--row-hover)}.notif-item.unread{background:#4f6ef70a}.notif-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:5px}.notif-dot.urgent{background:var(--red)}.notif-dot.very_low{background:var(--amber)}.notif-dot.low{background:var(--green)}.notif-msg{color:var(--text);font-size:13px;line-height:1.4}.notif-time{color:var(--text3);margin-top:2px;font-size:11px}.notif-empty{text-align:center;color:var(--text3);padding:24px 16px;font-size:13px}.app-body{max-width:960px;margin:0 auto;padding:28px 20px 60px}.invite-banner{background:var(--surface);border:1px solid var(--border);border-radius:3px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;padding:14px 18px;display:flex}.invite-banner p{color:var(--text2);margin:0;font-size:13px}.invite-banner strong{color:var(--text);margin-bottom:1px;font-weight:500;display:block}.btn-accent{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:3px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:opacity .2s}.btn-accent:hover{opacity:.88}.status-bar{color:var(--text3);margin-bottom:24px;font-size:12px}.section-label{color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px;font-size:11px;font-weight:500}.dash-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:20px;display:flex}.dash-header-left{flex-direction:column;gap:5px;display:flex}.dash-location-label{color:var(--text3);text-transform:uppercase;letter-spacing:.6px;align-items:center;gap:6px;font-size:11px;font-weight:600;display:flex}.dash-device-row{flex-wrap:wrap;align-items:center;gap:10px;margin-top:2px;display:flex}.dash-device-name{color:var(--text);letter-spacing:-.3px;font-size:22px;font-weight:700;line-height:1.1}.dash-lastseen{color:var(--text3);align-items:center;gap:4px;font-size:12px;display:flex}.dash-update-freq{color:var(--text3);font-size:11px}.dash-header-actions{align-items:center;gap:6px;padding-top:2px;display:flex}.device-loc-select-inline{color:var(--text);letter-spacing:-.3px;cursor:pointer;appearance:none;background:0 0;border:none;padding:0;font-family:inherit;font-size:22px;font-weight:700;line-height:1.1}.stat-card-main-row{justify-content:space-between;align-items:flex-end;gap:8px;display:flex}.refill-card-confirming{background:#4f6ef70a!important;border-color:#4f6ef74d!important}.main-grid{grid-template-columns:180px 1fr;align-items:start;gap:24px;display:grid}.tank-section{flex-direction:column;align-items:center;gap:14px;display:flex}.tank-wrap{position:relative}.tank-top{background:linear-gradient(to bottom, var(--border-hover), var(--border));border:1px solid var(--border-hover);border-bottom:none;border-radius:10px 10px 0 0;width:160px;height:14px}.tank-outer{border:1.5px solid var(--border-hover);background:var(--bg);width:160px;height:300px;box-shadow:inset 0 -4px 12px #0000000a, var(--shadow-sm);border-top:none;border-radius:0 0 12px 12px;position:relative;overflow:hidden}.tank-neon{background:#0d0f14!important;border-color:#ffffff14!important}[data-theme=light] .tank-neon{background:#0d0f14!important}.threshold-line{z-index:10;height:1.5px;position:absolute;left:0;right:0}.threshold-line span{white-space:nowrap;color:#fff;z-index:11;border-radius:4px;padding:1px 5px;font-size:9px;font-weight:600;position:absolute;top:-14px;right:4px}.t-low{background:var(--amber);opacity:.8}.t-low span{background:var(--amber);opacity:1}.t-medium{background:var(--red);opacity:.8}.t-medium span{background:var(--red);opacity:1}.t-urgent{opacity:.8;background:#991b1b}.t-urgent span{opacity:1;background:#991b1b}.tank-pct{color:var(--text);letter-spacing:-1px;font-size:36px;font-weight:700;line-height:1}.tank-status{color:var(--text3);letter-spacing:.3px;text-transform:uppercase;font-size:12px;font-weight:500}.ok{color:var(--green)!important}.warn{color:var(--amber)!important}.danger{color:var(--red)!important}.loading{color:var(--text3)!important}.stats-col{flex-direction:column;gap:12px;display:flex}.stats-row{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.stats-row-2{grid-template-columns:1fr 1fr!important}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px 18px;transition:border-color .2s,box-shadow .2s,transform .15s;position:relative;overflow:hidden}.stat-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{transform:translateY(-1px)}.status-ok{border-left:3px solid var(--green)!important}.status-warn{border-left:3px solid var(--amber)!important}.status-danger{border-left:3px solid var(--red)!important}.s-label{color:var(--text3);text-transform:uppercase;letter-spacing:.8px;align-items:center;gap:5px;margin-bottom:8px;font-size:10px;font-weight:600;display:flex}.s-value{color:var(--text);letter-spacing:-.5px;font-size:26px;font-weight:700;line-height:1}.s-hint{color:var(--text3);margin-top:5px;font-size:11px}.tip{align-items:center;display:inline-flex;position:relative}.tip-icon{border:1px solid var(--border-hover);width:13px;height:13px;color:var(--text3);cursor:default;text-transform:none;letter-spacing:0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:9px;font-style:normal;font-weight:700;display:flex}.tip-box{background:var(--text);color:var(--surface);white-space:nowrap;z-index:500;pointer-events:none;letter-spacing:0;text-transform:none;border-radius:3px;padding:5px 9px;font-size:11px;font-weight:400;display:none;position:absolute;bottom:calc(100% + 7px);left:50%;transform:translate(-50%)}.tip-box:after{content:"";border:4px solid #0000;border-top-color:var(--text);position:absolute;top:100%;left:50%;transform:translate(-50%)}.tip:hover .tip-box{display:block}.infotip-wrap{cursor:default;align-items:center;display:inline-flex;position:relative}.infotip-icon{color:var(--text3);flex-shrink:0;transition:color .15s}.infotip-wrap:hover .infotip-icon{color:var(--accent)}.infotip-bubble{background:var(--text);color:var(--surface);white-space:normal;pointer-events:none;letter-spacing:0;text-transform:none;border-radius:6px;width:180px;padding:7px 10px;font-size:11px;font-style:normal;font-weight:400;line-height:1.5;box-shadow:0 4px 12px #0000002e}.infotip-fixed{z-index:9999;margin-top:-6px;position:fixed;transform:translate(-50%,-100%)}.infotip-bubble:after{content:"";border:5px solid #0000;border-top-color:var(--text);position:absolute;top:100%;left:50%;transform:translate(-50%)}@keyframes sectionPulse{0%{box-shadow:0 0 0 0 #4f6ef780, var(--shadow-sm);border-color:var(--accent)}60%{box-shadow:0 0 0 6px #4f6ef700, var(--shadow-sm);border-color:var(--accent)}to{box-shadow:var(--shadow-sm);border-color:var(--border)}}.section-highlight{animation:1.8s forwards sectionPulse}.day-filters{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.day-btn{border:1px solid var(--border);color:var(--text3);cursor:pointer;background:0 0;border-radius:20px;padding:5px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s}.day-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 6px #4f6ef74d}.day-btn:hover:not(.active):not(.day-btn-disabled){border-color:var(--border-hover);color:var(--text)}.day-btn.day-btn-disabled{opacity:.35;cursor:not-allowed}.refill-list{flex-direction:column;display:flex}.refill-row{border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:11px 0;display:flex}.refill-row:last-child{border-bottom:none}.refill-dot{background:var(--green);border-radius:50%;flex-shrink:0;width:8px;height:8px}.refill-info{flex:1}.refill-date{color:var(--text);font-size:13px;font-weight:500}.refill-detail{color:var(--text3);margin-top:1px;font-size:12px}.refill-badge{color:var(--green);background:var(--chip);border-radius:3px;padding:3px 8px;font-size:12px;font-weight:500}.empty-state{text-align:center;color:var(--text3);padding:20px 0;font-size:13px}.modal-overlay{z-index:400;background:#00000073;justify-content:center;align-items:center;padding:16px;display:none;position:fixed;inset:0}.modal-overlay.show{display:flex}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:640px;max-height:88vh;box-shadow:var(--shadow-md);flex-direction:column;animation:.2s modalIn;display:flex}@keyframes modalIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.modal-header h3{color:var(--text);font-size:14px;font-weight:600}.modal-body{padding:18px;overflow-y:auto}.panel-overlay{z-index:300;background:#0006;justify-content:flex-end;align-items:stretch;display:none;position:fixed;inset:0}.panel-overlay.show{display:flex}.panel-box{background:var(--surface);border-left:1px solid var(--border);flex-direction:column;width:400px;height:100%;animation:.25s slideIn;display:flex}.panel-body{flex:1;padding:20px;overflow-y:auto}.panel-footer{border-top:1px solid var(--border);background:var(--surface);align-items:center;gap:12px;padding:12px 20px;display:flex;position:sticky;bottom:0}@keyframes slideIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.panel-header{border-bottom:1px solid var(--border);background:var(--surface);z-index:1;justify-content:space-between;align-items:center;padding:16px 20px;display:flex;position:sticky;top:0}.panel-header h2{color:var(--text);font-size:15px;font-weight:700}.panel-close{border:1px solid var(--border);cursor:pointer;width:28px;height:28px;color:var(--text2);background:0 0;border-radius:3px;justify-content:center;align-items:center;font-size:13px;transition:all .2s;display:flex}.panel-close:hover{border-color:var(--border-hover);color:var(--text)}.p-section{margin-bottom:24px}.p-section-title{color:var(--text3);text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;font-size:11px;font-weight:500;display:flex}.p-notif-group{margin-bottom:14px}.p-notif-label{color:var(--text2);margin-bottom:6px;font-size:12px;font-weight:600}.p-notif-row{color:var(--text);cursor:pointer;align-items:center;gap:8px;padding:3px 0;font-size:13px;display:flex}.p-notif-row input{accent-color:var(--accent);cursor:pointer}.p-field{margin-bottom:14px}.p-field label{color:var(--text2);margin-bottom:5px;font-size:12px;font-weight:500;display:block}.p-field .p-hint{color:var(--text3);margin-bottom:6px;font-size:11px}.p-field-inline{align-items:center;gap:12px;margin-bottom:16px;display:flex}.p-field-inline label{min-width:40px;margin-bottom:0}.p-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);width:100%;color:var(--text);outline:none;padding:8px 10px;font-family:inherit;font-size:13px;transition:border-color .2s,box-shadow .2s}.p-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4f6ef71f}.p-select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);width:100%;color:var(--text);cursor:pointer;outline:none;padding:8px 10px;font-family:inherit;font-size:13px}.slider-row{align-items:center;gap:10px;display:flex}.slider-row input[type=range]{accent-color:var(--accent);flex:1}.num-input{border:1px solid var(--border);text-align:center;background:var(--bg);width:68px;color:var(--text);border-radius:3px;outline:none;padding:6px 8px;font-family:inherit;font-size:13px;transition:border-color .2s}.num-input:focus{border-color:var(--accent)}.unit-label{color:var(--text3);width:24px;font-size:12px;font-weight:400}.h-row{align-items:center;gap:8px;display:flex}.h-input{border:1px solid var(--border);background:var(--bg);width:90px;color:var(--text);border-radius:3px;outline:none;padding:8px 10px;font-family:inherit;font-size:13px;transition:border-color .2s}.h-input:focus{border-color:var(--accent)}.seg-control{background:var(--chip);border-radius:3px;width:fit-content;margin-bottom:20px;padding:2px;display:flex}.seg-btn{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:2px;padding:5px 16px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s}.seg-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #0000001a}.t-low-lbl{color:var(--amber)}.t-med-lbl{color:var(--red)}.t-urg-lbl{color:#991b1b}.save-confirm{text-align:center;color:var(--green);font-size:13px;font-weight:500;display:none}.p-edit-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:11px;font-weight:500}.p-edit-btn:hover{opacity:.75}.p-save-actions{gap:8px;display:flex}.p-save-btn{color:#fff;cursor:pointer;background:#16a34a;border:none;border-radius:3px;padding:3px 10px;font-family:inherit;font-size:11px;font-weight:500}.p-save-btn:hover{opacity:.88}.p-cancel-btn{color:var(--text2);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:3px;padding:3px 10px;font-family:inherit;font-size:11px;font-weight:500}.p-cancel-btn:hover{border-color:var(--border-hover);color:var(--text)}.style-picker{flex-wrap:wrap;gap:8px;display:flex}.style-pick-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);cursor:pointer;text-align:left;flex-direction:column;align-items:flex-start;gap:2px;min-width:90px;padding:8px 12px;font-family:inherit;transition:border-color .15s,box-shadow .15s;display:flex}.style-pick-btn:hover{border-color:var(--border-hover)}.style-pick-btn.active{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 2px #4f6ef726}.style-pick-label{color:var(--text);font-size:12px;font-weight:600}.style-pick-desc{color:var(--text3);font-size:10px}.chart-style-bar{border-top:1px solid var(--border);align-items:center;gap:10px;margin-top:16px;padding-top:12px;display:flex}.chart-style-arrow{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);cursor:pointer;width:28px;height:28px;color:var(--text2);flex-shrink:0;justify-content:center;align-items:center;transition:border-color .12s;display:flex}.chart-style-arrow:hover{border-color:var(--border-hover);color:var(--text)}.chart-style-info{flex-direction:column;flex:1;gap:1px;display:flex}.chart-style-name{color:var(--text);font-size:12px;font-weight:600}.chart-style-desc{color:var(--text3);font-size:11px}.chart-style-hint{color:var(--accent);margin-top:2px;font-size:10px}.chart-style-dots{align-items:center;gap:5px;display:flex}.chart-style-dot{background:var(--border-hover);border-radius:50%;width:5px;height:5px;transition:background .2s,transform .2s}.chart-style-dot.active{background:var(--accent);transform:scale(1.3)}.input-readonly{opacity:.55;cursor:default}.member-list{flex-direction:column;gap:0;margin-bottom:16px;display:flex}.member-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 0;display:flex}.member-row:last-child{border-bottom:none}.member-avatar{background:var(--avatar);color:#fff;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:12px;font-weight:700;display:flex}.member-info{flex:1;min-width:0}.member-email{text-overflow:ellipsis;white-space:nowrap;color:var(--text);font-size:13px;font-weight:400;overflow:hidden}.role-chip{background:var(--chip);color:var(--text2);border-radius:3px;padding:2px 7px;font-size:11px;font-weight:500}.role-chip.owner{background:var(--avatar);color:#fff}.role-chip.pending{color:#92400e;background:#fef3c7}[data-theme=dark] .role-chip.pending{color:#fbbf24;background:#fbbf241a}.member-actions{align-items:center;gap:6px;display:flex}.role-select{border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;border-radius:3px;padding:4px 7px;font-family:inherit;font-size:12px}.remove-btn{color:var(--red);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:3px;padding:4px 9px;font-size:12px;font-weight:500;transition:all .15s}.remove-btn:hover{border-color:var(--red);background:#dc26260d}.invite-row{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.invite-input{border:1px solid var(--border);background:var(--bg);min-width:140px;color:var(--text);border-radius:3px;outline:none;flex:1;padding:7px 10px;font-family:inherit;font-size:13px}.invite-input:focus{border-color:var(--accent)}.invite-role{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:3px;padding:7px 9px;font-family:inherit;font-size:13px}.invite-submit{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:3px;padding:7px 14px;font-size:13px;font-weight:500;transition:opacity .2s}.invite-submit:hover{opacity:.88}.invite-msg{margin-top:8px;font-size:12px;display:none}.invite-msg.error{color:var(--red)}.invite-msg.success{color:var(--green)}.assign-dev-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:11px 0;display:flex}.assign-dev-item:last-child{border-bottom:none}.assign-dev-name{color:var(--text);font-size:13px;font-weight:500}.assign-dev-sub{color:var(--text3);margin-top:2px;font-size:11px}.assign-dev-btn{border:1px solid var(--accent);color:var(--accent);cursor:pointer;white-space:nowrap;background:0 0;border-radius:3px;flex-shrink:0;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s}.assign-dev-btn:hover{background:#4f6ef712}.assign-dev-btn.assigned{border-color:var(--border);color:var(--text3);cursor:default}.device-loc-select{background:var(--bg);border:1px solid var(--border);width:calc(100% - 28px);color:var(--text);cursor:pointer;border-radius:3px;margin-top:4px;padding:4px 6px;font-family:inherit;font-size:13px}.device-loc-add{border:1px solid var(--border);width:22px;height:22px;color:var(--text3);cursor:pointer;background:0 0;border-radius:3px;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex;position:absolute;top:10px;right:10px}.device-loc-add:hover{border-color:var(--accent);color:var(--accent);background:#4f6ef712}.salt-tabs{border-bottom:1px solid var(--border);margin-bottom:16px;display:flex}.salt-tab{color:var(--text3);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-1px;padding:10px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.salt-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.salt-retailer-list{flex-direction:column;display:flex}.salt-retailer{border-bottom:1px solid var(--border);cursor:pointer;justify-content:space-between;align-items:center;gap:12px;padding:13px 0;text-decoration:none;transition:background .15s;display:flex}.salt-retailer:last-child{border-bottom:none}.salt-retailer:hover{background:var(--row-hover)}.salt-retailer-name{color:var(--text);font-size:13px;font-weight:600}.salt-retailer-desc{color:var(--text3);margin-top:2px;font-size:12px}.salt-retailer-link{color:var(--accent);flex-shrink:0;font-size:12px;font-weight:500}.btn-refilled{color:var(--text3);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:3px;align-items:center;gap:6px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:400;transition:all .2s;display:inline-flex}.btn-refilled:hover{border-color:var(--green);color:var(--green);background:0 0}.btn-refilled:disabled{opacity:.45;cursor:not-allowed}.firmware-version-row{flex-wrap:wrap;align-items:center;gap:16px;margin-top:4px;display:flex}.firmware-version-item{flex-direction:column;gap:2px;display:flex}.firmware-version-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text3);font-size:10px;font-weight:500}.firmware-version-val{color:var(--text);font-variant-numeric:tabular-nums;font-size:14px;font-weight:600}.firmware-version-sep{color:var(--text3);margin-top:10px;font-size:12px}.firmware-update-badge{color:var(--amber);white-space:nowrap;background:#d977061f;border:1px solid #d977064d;border-radius:3px;margin-top:10px;padding:3px 8px;font-size:11px;font-weight:600}.export-row{align-items:center;gap:4px;display:flex}.export-select{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--text2);cursor:pointer;outline:none;padding:6px 8px;font-family:inherit;font-size:12px}.export-select:hover{border-color:var(--border-hover)}.export-popover-wrap{position:relative}.export-popover{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:300;flex-direction:column;gap:2px;min-width:160px;padding:8px;display:flex;position:absolute;top:calc(100% + 6px);right:0}.export-popover-label{color:var(--text3);text-transform:uppercase;letter-spacing:.6px;padding:2px 6px 6px;font-size:10px;font-weight:600}.export-popover-opt{text-align:left;border-radius:var(--radius-sm);color:var(--text2);cursor:pointer;background:0 0;border:none;padding:7px 10px;font-size:13px;transition:background .12s}.export-popover-opt:hover{background:var(--bg);color:var(--text)}.export-popover-opt.active{color:var(--accent);background:var(--bg);font-weight:600}.export-popover-dl{justify-content:center;width:100%;margin-top:6px}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg, var(--border) 25%, var(--chip) 50%, var(--border) 75%);background-size:800px 100%;animation:1.4s linear infinite shimmer;display:block}.avatar-menu{position:relative}.avatar-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-family:inherit;font-size:13px;font-weight:700;transition:box-shadow .2s,opacity .2s;display:flex;box-shadow:0 2px 6px #4f6ef759}.avatar-btn:hover{opacity:.9;box-shadow:0 3px 10px #4f6ef773}.avatar-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-width:200px;box-shadow:var(--shadow-md);z-index:300;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.avatar-dd-email{color:var(--text3);border-bottom:1px solid var(--border);white-space:nowrap;text-overflow:ellipsis;padding:12px 14px 10px;font-size:12px;overflow:hidden}.avatar-dd-item{width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:9px;padding:10px 14px;font-family:inherit;font-size:13px;transition:background .15s;display:flex}.avatar-dd-item:hover{background:var(--row-hover)}.avatar-dd-divider{background:var(--border);height:1px;margin:2px 0}.avatar-dd-signout{color:var(--red)}.avatar-dd-signout:hover{background:#dc26260f}.device-health-card{margin-top:0}.device-health-row{flex-wrap:wrap;gap:24px;margin-top:8px;display:flex}.device-health-item{flex-direction:column;align-items:center;gap:3px;min-width:52px;display:flex}.device-health-icon{color:var(--text3);display:flex}.device-health-val{color:var(--text);font-size:13px;font-weight:600;line-height:1}.device-health-label{color:var(--text3);text-transform:uppercase;letter-spacing:.4px;font-size:10px}.settings-page{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.settings-nav{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;align-items:center;gap:12px;height:52px;padding:0 24px;display:flex;position:sticky;top:0}.settings-back{color:var(--text2);cursor:pointer;background:0 0;border:none;border-radius:3px;flex-shrink:0;align-items:center;gap:5px;padding:6px 8px 6px 4px;font-family:inherit;font-size:13px;font-weight:500;transition:color .15s;display:flex}.settings-back:hover{color:var(--text)}.settings-nav-title{color:var(--text);flex:1;font-size:15px;font-weight:700}.settings-nav-right{align-items:center;gap:4px;display:flex}.settings-body{width:100%;max-width:860px;margin:0 auto;padding:36px 32px 80px}.p-inline-body{grid-template-columns:1fr 1fr;gap:24px 40px;display:grid}.p-inline-body>form,.p-inline-body>div{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px 24px}.p-inline-body>form .p-section,.p-inline-body>div.p-section{margin-bottom:0}.p-inline-body>div#accessSection,.p-inline-body>div#firmwareSection{grid-column:1/-1}.nav-hide-mobile{display:flex}.nav-show-mobile{display:none}.nav-menu-dropdown{z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:8px;min-width:140px;display:none;position:absolute;top:40px;right:0;overflow:hidden;box-shadow:0 4px 16px #0000001f}.nav-menu-dropdown.show{display:block}.nav-menu-dropdown button{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;padding:11px 16px;font-family:inherit;font-size:14px;display:block}.nav-menu-dropdown button:hover{background:var(--row-hover)}@media (width<=640px){.nav-hide-mobile{display:none!important}.nav-show-mobile{display:flex}.main-grid{grid-template-columns:1fr;justify-items:center}.stats-row{grid-template-columns:1fr 1fr}.stats-col{width:100%}.tank-outer{width:140px;height:260px}.tank-top{width:140px}.app-body{padding:16px 14px 48px}.dash-header{flex-direction:column;gap:8px}.dash-device-name,.device-loc-select-inline{font-size:18px}.dash-update-freq{display:none}.notif-dropdown{width:calc(100vw - 16px);right:8px}.panel-overlay{justify-content:stretch;align-items:flex-end}.panel-box{max-height:90vh;border-radius:3px 3px 0 0!important;width:100%!important}.locations-grid{grid-template-columns:1fr 1fr}.settings-body{padding:16px 14px 48px}.p-inline-body{grid-template-columns:1fr}.p-inline-body>form,.p-inline-body>div{padding:16px}.p-inline-body>div#accessSection,.p-inline-body>div#firmwareSection{grid-column:1}}@media (width<=400px){.locations-grid{grid-template-columns:1fr}}.tasklist-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;max-width:640px;padding:16px 20px}.tasklist-header{align-items:center;gap:8px;margin-bottom:14px;display:flex}.tasklist-title{color:var(--text);font-size:13px;font-weight:600}.tasklist-badge{background:var(--accent);color:#fff;border-radius:10px;padding:1px 7px;font-size:11px;font-weight:700}.tasklist-loading{color:var(--text3);padding:8px 0;font-size:12px}.tasklist-empty{color:var(--text3);padding:6px 0 10px;font-size:13px}.tasklist-items{flex-direction:column;gap:2px;margin-bottom:12px;display:flex}.tasklist-item{border-radius:6px;align-items:center;gap:10px;padding:6px 4px;transition:background .1s;display:flex}.tasklist-item:hover{background:var(--row-hover)}.tasklist-item-done{opacity:.5}.tasklist-item-done .tasklist-item-title{text-decoration:line-through}.tasklist-check{cursor:pointer;color:var(--text3);background:0 0;border:none;flex-shrink:0;align-items:center;padding:0;transition:color .15s;display:flex}.tasklist-check:hover{color:var(--accent)}.tasklist-check.done{color:var(--green)}.tasklist-item-title{color:var(--text);flex:1;font-size:13px}.tasklist-auto-badge{color:var(--accent);background:#4f6ef71a;border-radius:4px;padding:1px 5px;font-size:10px;font-weight:600}.tasklist-delete{cursor:pointer;color:var(--text3);opacity:0;background:0 0;border:none;align-items:center;padding:0;transition:opacity .15s,color .15s;display:flex}.tasklist-item:hover .tasklist-delete{opacity:1}.tasklist-delete:hover{color:var(--red)}.tasklist-add-row{gap:8px;display:flex}.tasklist-input{background:var(--bg);border:1px solid var(--border);height:34px;color:var(--text);border-radius:8px;outline:none;flex:1;padding:0 12px;font-family:inherit;font-size:13px}.tasklist-input:focus{border-color:var(--accent)}.tasklist-add-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:opacity .15s;display:flex}.tasklist-add-btn:disabled{opacity:.4;cursor:not-allowed}.tasklist-add-btn:hover:not(:disabled){opacity:.85}.buysalt-page{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.buysalt-body{width:100%;max-width:720px;margin:0 auto;padding:36px 32px 80px}.buysalt-header{margin-bottom:20px}.buysalt-title{color:var(--text);font-size:22px;font-weight:700}.buysalt-sub{color:var(--text2);margin-top:4px;font-size:13px}.buysalt-notice{background:var(--surface);border:1px solid var(--border);color:var(--text2);border-radius:10px;align-items:flex-start;gap:8px;margin-bottom:24px;padding:12px 16px;font-size:12px;display:flex}.buysalt-notice svg{flex-shrink:0;margin-top:1px}.buysalt-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:32px;display:grid}.buysalt-retailer-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:12px;flex-direction:column;gap:4px;padding:18px 20px;text-decoration:none;transition:border-color .15s,box-shadow .15s;display:flex}.buysalt-retailer-card:hover{border-color:var(--accent);box-shadow:0 2px 12px #4f6ef71a}.buysalt-retailer-top{align-items:center;gap:8px;margin-bottom:4px;display:flex}.buysalt-retailer-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.buysalt-retailer-name{color:var(--text);font-size:15px;font-weight:700}.buysalt-member-badge{color:var(--accent);background:#4f6ef71a;border-radius:4px;margin-left:auto;padding:2px 5px;font-size:10px;font-weight:600}.buysalt-retailer-size{color:var(--text2);font-size:12px}.buysalt-retailer-note{color:var(--text3);font-size:11px}.buysalt-retailer-cta{color:var(--accent);align-items:center;gap:4px;margin-top:10px;font-size:12px;font-weight:600;display:flex}.buysalt-maps-title{color:var(--text2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;font-size:13px;font-weight:600}.buysalt-maps-grid{flex-wrap:wrap;gap:8px;display:flex}.buysalt-maps-btn{background:var(--surface);border:1px solid var(--border);color:var(--text2);border-radius:20px;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;text-decoration:none;transition:border-color .15s,color .15s;display:flex}.buysalt-maps-btn:hover{border-color:var(--accent);color:var(--accent)}@media (width<=640px){.buysalt-body{padding:16px 14px 48px}.buysalt-grid{grid-template-columns:1fr}}
