@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-primary:#f5f5f7;--bg-secondary:#ffffffbf;--border-color:#ffffff80;--accent-blue:#007aff;--accent-blue-light:#007aff26;--accent-red:#ff3b30;--accent-red-light:#ff3b3026;--status-connected:#34c759;--status-disconnected:#ff3b30;--status-connecting:#ff9500;--text-main:#1d1d1f;--text-muted:#86868b;--text-dark:#fff;--shadow-sm:0 2px 8px #0000000a;--shadow-glass:0 6px 20px #0000000d;--font-sans:-apple-system, BlinkMacSystemFont, "Plus Jakarta Sans", "Segoe UI", Roboto, sans-serif;--font-mono:"JetBrains Mono", monospace;--border-radius-lg:16px;--border-radius-md:12px;--border-radius-sm:8px;--transition-smooth:all .25s cubic-bezier(.25, 1, .5, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:radial-gradient(at 0% 0%, #007aff0d 0px, transparent 50%), radial-gradient(at 100% 100%, #ff3b300d 0px, transparent 50%), var(--bg-primary);color:var(--text-main);-webkit-font-smoothing:antialiased;background-attachment:fixed;height:100vh;min-height:100vh;font-size:13px;line-height:1.4;overflow:hidden}#app{flex-direction:column;height:100vh;display:flex}header{background:0 0;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 24px;display:flex}.logo-section{align-items:center;gap:10px;display:flex}.logo-icon{background:linear-gradient(135deg, var(--accent-blue), var(--accent-red));border-radius:var(--border-radius-sm);justify-content:center;align-items:center;width:28px;height:28px;display:flex;box-shadow:0 3px 8px #007aff40}.logo-icon svg{fill:#fff;width:15px;height:15px}.logo-section h1{letter-spacing:-.4px;color:var(--text-main);font-size:15px;font-weight:700}.header-actions{align-items:center;gap:12px;display:flex}.btn-header{border-radius:20px;width:auto;padding:6px 14px;font-size:11px}.status-badge{background:var(--bg-secondary);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-color);color:var(--text-muted);box-shadow:var(--shadow-sm);border-radius:30px;align-items:center;gap:6px;padding:6px 12px;font-size:11px;font-weight:600;display:flex}.status-dot{background-color:var(--status-disconnected);border-radius:50%;width:8px;height:8px}.status-badge.connected .status-dot{background-color:var(--status-connected)}.status-badge.connecting .status-dot{background-color:var(--status-connecting)}.dashboard-grid{flex-grow:1;grid-template-rows:auto auto;grid-template-columns:repeat(2,1fr);gap:20px;max-width:1000px;min-height:0;margin:0 auto;padding:24px;display:grid;overflow-y:auto}.dashboard-grid.dashboard-disabled .pump-ops-card,.dashboard-grid.dashboard-disabled .wifi-config-card,.dashboard-grid.dashboard-disabled .status-group{opacity:.65;pointer-events:none;filter:grayscale(80%);transition:var(--transition-smooth)}.card{background:var(--bg-secondary);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border-color);box-shadow:var(--shadow-glass);border-radius:var(--border-radius-lg);transition:var(--transition-smooth);padding:12px 16px;position:relative;overflow:hidden}.card-title{letter-spacing:-.3px;color:var(--text-main);align-items:center;gap:8px;margin-bottom:12px;font-size:13px;font-weight:700;display:flex}.card-title svg{width:16px;height:16px;fill:var(--text-main)}.telemetry-card{flex-direction:column;justify-content:space-between;align-items:stretch;padding:8px 12px;display:flex}.telemetry-header{flex-direction:row;align-items:center;gap:8px;width:100%;display:flex}.telemetry-icon-wrapper{background:var(--text-muted);width:28px;height:28px;transition:var(--transition-smooth);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.telemetry-icon-wrapper svg{fill:#fff;width:14px;height:14px}.telemetry-label{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:600;overflow:hidden}.telemetry-content{flex-direction:column;align-items:flex-start;gap:2px;width:100%;margin-top:6px;display:flex}.telemetry-value{letter-spacing:-.3px;color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;width:100%;font-size:14px;font-weight:700;overflow:hidden}.telemetry-card.pump-active .telemetry-icon-wrapper{background:var(--accent-blue)}.glow-status{color:var(--text-muted);background:#0000000d;border-radius:30px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.telemetry-card.pump-active .glow-status{background:var(--accent-blue-light);color:var(--accent-blue)}.control-item{border-radius:var(--border-radius-sm);background:#fff6;border:1px solid #00000008;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.control-label{color:var(--text-main);font-size:11px;font-weight:600}.switch-wrapper{width:56px;height:24px;display:inline-block;position:relative}.switch-wrapper input{opacity:0;width:0;height:0}.switch-slider{cursor:pointer;background-color:#00000026;border-radius:24px;transition:all .3s cubic-bezier(.25,1,.5,1);position:absolute;inset:0}.switch-slider:before{content:"";background-color:#fff;border-radius:50%;width:20px;height:20px;transition:all .3s cubic-bezier(.25,1,.5,1);position:absolute;bottom:2px;left:2px;box-shadow:0 2px 4px #0003}input:disabled+.switch-slider{opacity:.5;cursor:not-allowed}input:checked+.switch-slider.switch-blue{background-color:var(--accent-blue)}input:checked+.switch-slider.switch-red{background-color:var(--accent-red)}input:checked+.switch-slider:before{transform:translate(32px)}.form-group{margin-bottom:10px}.form-row{grid-template-columns:1fr 1fr;gap:8px;display:grid}.form-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:10px;font-weight:600;display:block}input[type=text],input[type=password],select{border-radius:var(--border-radius-sm);width:100%;color:var(--text-main);font-family:var(--font-sans);transition:var(--transition-smooth);background:#ffffff80;border:1px solid #0000000d;padding:8px 12px;font-size:13px}input:focus,select:focus{border-color:var(--accent-blue);box-shadow:0 0 0 2px var(--accent-blue-light);background:#fff;outline:none}input:disabled{opacity:.6;cursor:not-allowed}.btn{border-radius:var(--border-radius-sm);cursor:pointer;width:100%;transition:var(--transition-smooth);border:none;justify-content:center;align-items:center;gap:8px;padding:10px;font-size:13px;font-weight:600;display:flex}.btn-primary{background:var(--accent-blue);color:#fff}.btn-primary:hover:not(:disabled){background:#0062cc;transform:scale(.98)}.btn-danger{background:var(--accent-red);color:#fff}.btn-danger:hover:not(:disabled){background:#cc2f26;transform:scale(.98)}.btn:disabled{color:var(--text-muted);cursor:not-allowed;opacity:.6;background:#0000000d}.console-card{flex-direction:column;height:100%;display:flex}.console-header{border-bottom:1px solid #0000000d;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:6px;display:flex}.btn-icon{color:var(--text-muted);cursor:pointer;border-radius:var(--border-radius-sm);transition:var(--transition-smooth);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}.btn-icon:hover{color:var(--text-main);background:#0000000d}.console-output{border-radius:var(--border-radius-md);font-family:var(--font-mono);background:#00000008;border:1px solid #0000000d;flex-direction:column;flex-grow:1;gap:6px;padding:10px;font-size:11px;line-height:1.5;display:flex;overflow-y:auto}.log-entry{border-bottom:1px solid #00000003;flex-wrap:wrap;align-items:baseline;gap:6px;padding-bottom:2px;display:flex}.log-time{color:#8b5cf6;flex-shrink:0;font-weight:500}.log-topic{color:#f59e0b;flex-shrink:0;font-weight:600}.log-msg{word-break:break-all;flex-grow:1}.log-system{color:#64748b;font-style:italic}.log-publish{color:var(--accent-blue);font-weight:500}.log-error{color:var(--accent-red);font-weight:600}.log-msg.log-msg{color:var(--text-main)}footer{text-align:center;color:var(--text-muted);flex-shrink:0;padding:16px 0;font-size:11px}.tab-view{display:contents}.status-group{grid-area:1/1/auto/span 2;grid-template-columns:repeat(5,1fr);gap:16px;display:grid}.pump-ops-card{grid-area:2/1;align-self:stretch}.wifi-config-card{grid-area:2/2;align-self:stretch}@media (width<=768px){body{height:auto;overflow:auto}#app{flex-direction:column;min-height:100vh;display:flex}header{z-index:100;background:var(--bg-primary);flex-shrink:0;padding:10px 16px;position:sticky;top:0;box-shadow:0 1px #00000008}.dashboard-grid{flex-direction:column;gap:16px;height:auto;margin:0;padding:16px;display:flex;overflow:visible}.status-group{grid-area:auto;grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.controls-card,.schedule-card,.wifi-config-card{grid-area:auto;align-self:stretch;padding:16px}.console-card{grid-area:auto;height:auto;min-height:200px}.telemetry-card{gap:6px;padding:8px 10px}.telemetry-header{gap:6px}.telemetry-icon-wrapper{width:24px;height:24px}.telemetry-icon-wrapper svg{width:12px;height:12px}.telemetry-label{font-size:10px}.telemetry-value{font-size:13px}.glow-status{padding:1px 4px;font-size:8px}.control-item{padding:4px 8px}.control-label{font-size:10px}.switch-wrapper{width:50px;height:20px}.switch-slider:before{width:16px;height:16px;bottom:2px;left:2px}input:checked+.switch-slider:before{transform:translate(30px)}.console-card{padding:10px}.console-output{padding:6px 8px;font-size:10px}.wifi-config-card{padding:10px}.card-title{margin-bottom:8px;font-size:12px}.form-group{margin-bottom:6px}input[type=text],input[type=password],select{padding:6px 10px;font-size:11px}.btn{padding:6px;font-size:11px}footer{display:none}}.auth-container{background:radial-gradient(at 0% 0%, #007aff14 0px, transparent 50%), radial-gradient(at 100% 100%, #ff3b3014 0px, transparent 50%), var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{background:var(--bg-secondary);-webkit-backdrop-filter:blur(30px);border:1px solid var(--border-color);width:100%;max-width:400px;transition:var(--transition-smooth);border-radius:24px;padding:32px;position:relative;box-shadow:0 10px 40px #00000014}.auth-lang-selector{align-items:center;gap:4px;display:flex;position:absolute;top:20px;right:24px}.lang-btn{color:var(--text-muted);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:11px;font-weight:700}.lang-btn.active{color:var(--accent-blue)}.lang-btn:hover{background:#007aff0d}.divider{color:#0000001a;font-size:10px}.auth-header{text-align:center;margin-bottom:28px}.auth-icon{width:48px;height:48px;fill:var(--accent-blue);margin-bottom:16px}.auth-header h2{letter-spacing:-.5px;color:var(--text-main);margin-bottom:4px;font-size:18px;font-weight:700}.auth-subtitle{color:var(--text-muted);font-size:12px;font-weight:500}.auth-alert{border-radius:var(--border-radius-sm);margin-bottom:16px;padding:10px 14px;font-size:11px;font-weight:500;line-height:1.4}.auth-alert.error{background-color:var(--accent-red-light);color:var(--accent-red);border:1px solid #ff3b3026}.auth-alert.success{color:var(--status-connected);background-color:#34c7591a;border:1px solid #34c75926}.btn-link{color:var(--accent-blue);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;font-size:12px;font-weight:600}.btn-link:hover{color:#0056b3;text-decoration:underline}.auth-footer{text-align:center;margin-top:20px}.device-manager-card{grid-area:auto/1/auto/span 3;margin-bottom:16px}.device-list{flex-direction:column;gap:10px;max-height:200px;margin-bottom:16px;padding-right:4px;display:flex;overflow-y:auto}.device-item{border-radius:var(--border-radius-md);transition:var(--transition-smooth);background:#ffffff80;border:1px solid #00000008;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.device-item:hover{box-shadow:var(--shadow-sm);background:#fff}.device-info{flex-direction:column;gap:2px;display:flex}.device-alias{color:var(--text-main);font-size:13px;font-weight:600}.device-mac{font-family:var(--font-mono);color:var(--text-muted);font-size:10px}.device-status{align-items:center;gap:6px;font-size:10px;font-weight:600;display:flex}.device-actions{gap:8px;display:flex}.btn-action{border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition-smooth);border:none;padding:4px 10px;font-size:10px;font-weight:600}.btn-action.rename{background:var(--accent-blue-light);color:var(--accent-blue)}.btn-action.unclaim{background:var(--accent-red-light);color:var(--accent-red)}.empty-devices{text-align:center;color:var(--text-muted);border-radius:var(--border-radius-md);background:#00000005;border:1px dashed #0000000d;padding:24px;font-size:12px}.claim-form{border-radius:var(--border-radius-md);background:#fff6;border:1px solid #00000005;grid-template-columns:1fr 1fr auto;align-items:flex-end;gap:12px;padding:16px;display:grid}@media (width<=768px){.claim-form{grid-template-columns:1fr;gap:8px}}.devices-container{flex:1;padding:24px;overflow-y:auto}.devices-header-section{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.devices-header-title{color:var(--text-main);align-items:center;gap:8px;font-size:18px;font-weight:700;display:flex}.devices-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:20px;display:grid}.device-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);height:180px;box-shadow:var(--shadow-glass);-webkit-backdrop-filter:blur(20px);transition:var(--transition-smooth);cursor:pointer;flex-direction:column;justify-content:space-between;padding:20px;display:flex;position:relative}.device-card:hover{background:#fff;transform:translateY(-4px);box-shadow:0 10px 25px #00000014}.device-card-header{justify-content:space-between;align-items:flex-start;display:flex}.device-card-alias{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;max-width:70%;font-size:16px;font-weight:700;overflow:hidden}.device-card-mac{font-family:var(--font-mono);color:var(--text-muted);margin-top:4px;font-size:11px}.device-card-status{align-items:center;gap:6px;font-size:11px;font-weight:500;display:flex}.device-card-actions{justify-content:space-between;align-items:center;margin-top:auto;display:flex}.device-card-btns{gap:8px;display:flex}.btn-card-action{color:var(--text-main);border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition-smooth);background:#00000008;border:1px solid #00000005;padding:6px 12px;font-size:11px;font-weight:500}.btn-card-action:hover{color:var(--accent-blue);background:#007aff14;border-color:#007aff1a}.btn-card-action.danger:hover{color:var(--accent-red);background:#ff3b3014;border-color:#ff3b301a}.btn-monitor-arrow{background:var(--accent-blue-light);color:var(--accent-blue);width:32px;height:32px;transition:var(--transition-smooth);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.device-card:hover .btn-monitor-arrow{background:var(--accent-blue);color:#fff;transform:scale(1.1)}.back-btn-container{align-items:center;gap:12px;display:flex}.btn-back-nav{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);cursor:pointer;box-shadow:var(--shadow-sm);color:var(--text-main);transition:var(--transition-smooth);justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:12px;font-weight:500;display:flex}.btn-back-nav:hover{background:#fff;transform:translate(-2px)}.btn-back-nav svg{fill:currentColor;width:14px;height:14px}.monitor-modal-overlay{background:radial-gradient(at 0% 0%, #007aff08 0px, transparent 50%), radial-gradient(at 100% 100%, #ff3b3008 0px, transparent 50%), var(--bg-primary);z-index:9999;background-attachment:fixed;flex-direction:column;width:100vw;height:100vh;animation:.35s cubic-bezier(.16,1,.3,1) forwards slideUp;display:flex;position:fixed;top:0;left:0;overflow:hidden}@keyframes slideUp{0%{opacity:.8;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.dialog-backdrop{-webkit-backdrop-filter:blur(8px);z-index:10000;background:#0006;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.2s ease-out forwards fadeIn;display:flex;position:fixed;top:0;left:0}.dialog-box{border:1px solid var(--border-color);border-radius:var(--border-radius-lg);background:#ffffffd9;flex-direction:column;gap:16px;width:90%;max-width:380px;padding:24px;animation:.25s cubic-bezier(.34,1.56,.64,1) forwards scaleUp;display:flex;box-shadow:0 20px 40px #00000026}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleUp{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.dialog-title{color:var(--text-main);font-size:16px;font-weight:700}.dialog-message{color:var(--text-muted);font-size:13px;line-height:1.5}.dialog-input{border-radius:var(--border-radius-sm);width:100%;transition:var(--transition-smooth);background:#fff;border:1px solid #0000001a;outline:none;padding:10px 12px;font-size:13px}.dialog-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px var(--accent-blue-light)}.dialog-actions{justify-content:flex-end;gap:10px;margin-top:8px;display:flex}.btn-dialog{border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition-smooth);border:none;padding:8px 16px;font-size:12px;font-weight:600}.btn-dialog-cancel{color:var(--text-main);background:#0000000d}.btn-dialog-cancel:hover{background:#00000014}.btn-dialog-confirm{background:var(--accent-blue);color:#fff}.btn-dialog-confirm:hover{background:#0066d6}.btn-dialog-confirm.danger{background:var(--accent-red)}.btn-dialog-confirm.danger:hover{background:#d93025}.console-drawer{border-left:1px solid var(--border-color);z-index:10001;-webkit-backdrop-filter:blur(20px);background:#ffffffd9;flex-direction:column;width:380px;height:100vh;transition:transform .35s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;top:0;right:0;transform:translate(100%);box-shadow:-10px 0 30px #00000014}.console-drawer.open{transform:translate(0)}.console-drawer-header{border-bottom:1px solid #0000000d;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.console-drawer-title{color:var(--text-main);align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.console-drawer-close{color:var(--text-muted);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}.console-drawer-close:hover{color:var(--accent-red);transform:scale(1.1)}.console-drawer-content{flex-direction:column;flex:1;gap:16px;padding:20px;display:flex;overflow-y:auto}.drawer-backdrop{z-index:10000;background:#00000026;width:100vw;height:100vh;animation:.2s ease-out forwards fadeIn;position:fixed;top:0;left:0}@media (width<=480px){.console-drawer{width:100%}}
