:root{--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-card: rgba(17, 24, 39, .7);--bg-card-hover: rgba(23, 32, 52, .8);--bg-card-border: rgba(56, 189, 248, .08);--accent-teal: #06b6d4;--accent-teal-dim: rgba(6, 182, 212, .15);--accent-blue: #3b82f6;--accent-amber: #f59e0b;--accent-amber-dim: rgba(245, 158, 11, .15);--accent-red: #ef4444;--accent-green: #10b981;--accent-green-dim: rgba(16, 185, 129, .15);--accent-purple: #8b5cf6;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--glass-bg: rgba(15, 23, 42, .6);--glass-border: rgba(56, 189, 248, .1);--glass-blur: 20px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow-teal: 0 0 20px rgba(6, 182, 212, .3);--shadow-glow-amber: 0 0 20px rgba(245, 158, 11, .3);--shadow-glow-green: 0 0 20px rgba(16, 185, 129, .3);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;background-image:radial-gradient(ellipse at 20% 50%,rgba(6,182,212,.06) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(59,130,246,.05) 0%,transparent 60%),radial-gradient(ellipse at 50% 100%,rgba(139,92,246,.04) 0%,transparent 50%)}#app{max-width:520px;margin:0 auto;padding:0 16px 40px}button{font-family:inherit;cursor:pointer;border:none;outline:none;background:none;color:inherit}button:focus-visible{outline:2px solid var(--accent-teal);outline-offset:2px}input{font-family:inherit}.status-bar{display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0a0e1acc;margin:0 -16px;padding:16px}.status-bar__left{display:flex;align-items:center;gap:8px}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-amber);box-shadow:0 0 8px #f59e0b80;animation:pulse-dot 2s infinite}.status-dot.connected{background:var(--accent-green);box-shadow:0 0 8px #10b98180}.status-label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.status-bar__title{font-size:1rem;font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,var(--accent-teal),var(--accent-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.icon-btn{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition-fast)}.icon-btn:hover{background:#ffffff0d;color:var(--text-primary)}.temp-hero{display:flex;flex-direction:column;align-items:center;padding:32px 0 24px}.temp-hero__ring{position:relative;width:200px;height:200px;border-radius:50%;background:conic-gradient(from 180deg,var(--accent-teal) 0deg,var(--accent-blue) 120deg,var(--accent-purple) 240deg,var(--accent-teal) 360deg);padding:4px;animation:ring-rotate 8s linear infinite;box-shadow:var(--shadow-glow-teal);transition:box-shadow var(--transition-slow)}.temp-hero__ring.heating{box-shadow:var(--shadow-glow-amber);background:conic-gradient(from 180deg,var(--accent-amber) 0deg,var(--accent-red) 120deg,var(--accent-amber) 240deg,var(--accent-amber) 360deg)}.temp-hero__inner{width:100%;height:100%;border-radius:50%;background:var(--bg-primary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.temp-hero__label{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.temp-hero__value{font-size:4rem;font-weight:900;line-height:1;letter-spacing:-.04em;background:linear-gradient(180deg,var(--text-primary) 0%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:transform var(--transition-fast)}.temp-hero__value.bump-up{animation:bump-up .2s ease}.temp-hero__value.bump-down{animation:bump-down .2s ease}.temp-hero__unit{font-size:1rem;font-weight:500;color:var(--text-muted)}.temp-hero__heater{display:flex;align-items:center;gap:4px;margin-top:4px;padding:3px 10px;border-radius:var(--radius-full);background:var(--accent-amber-dim);opacity:0;transform:translateY(4px);transition:all var(--transition-base)}.temp-hero__heater.active{opacity:1;transform:translateY(0)}.heater-icon{font-size:.7rem}.heater-label{font-size:.65rem;font-weight:600;color:var(--accent-amber);text-transform:uppercase;letter-spacing:.05em}.temp-controls{display:flex;align-items:center;gap:24px;margin-top:24px}.temp-btn{width:56px;height:56px;border-radius:50%;background:var(--glass-bg);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:all var(--transition-fast);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.temp-btn:hover{background:#06b6d426;border-color:var(--accent-teal);box-shadow:var(--shadow-glow-teal);transform:scale(1.05)}.temp-btn:active{transform:scale(.95)}.temp-set{display:flex;flex-direction:column;align-items:center;gap:2px}.temp-set__label{font-size:.7rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.temp-set__value{font-size:1.5rem;font-weight:700;color:var(--accent-teal)}.temp-set__unit{font-size:.75rem;color:var(--text-muted)}.controls-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px}.card{background:var(--bg-card);border:1px solid var(--bg-card-border);border-radius:var(--radius-lg);padding:16px;-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));transition:all var(--transition-base)}.card:hover{background:var(--bg-card-hover);border-color:#38bdf826}.card--wide{grid-column:1 / -1}.card__title{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:6px;margin-bottom:12px}.card__title svg{opacity:.5}.pump-controls{display:flex;flex-direction:column;gap:10px}.pump-control{display:flex;align-items:center;justify-content:space-between}.pump-label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.toggle-btn{min-width:72px;height:36px;border-radius:var(--radius-full);background:#ffffff0d;border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.toggle-btn__text{font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);transition:color var(--transition-fast)}.toggle-btn:hover{background:#ffffff14;border-color:#ffffff26}.toggle-btn:active{transform:scale(.95)}.toggle-btn[data-state=low]{background:var(--accent-teal-dim);border-color:#06b6d44d;box-shadow:0 0 12px #06b6d426}.toggle-btn[data-state=low] .toggle-btn__text{color:var(--accent-teal)}.toggle-btn[data-state=high],.toggle-btn[data-state=on]{background:linear-gradient(135deg,#06b6d440,#3b82f640);border-color:#06b6d466;box-shadow:var(--shadow-glow-teal)}.toggle-btn[data-state=high] .toggle-btn__text,.toggle-btn[data-state=on] .toggle-btn__text{color:var(--accent-teal)}.toggle-btn--large{width:100%;height:48px;margin-top:4px}.light-btn{width:100%;height:100px;border-radius:var(--radius-lg);background:#ffffff08;border:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;position:relative;overflow:hidden;transition:all var(--transition-base)}.light-btn__glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,rgba(245,158,11,.4),transparent);opacity:0;transition:opacity var(--transition-slow);pointer-events:none}.light-btn__icon{color:var(--text-muted);transition:all var(--transition-base)}.light-btn__label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);transition:color var(--transition-fast)}.light-btn:hover{background:#ffffff0f}.light-btn:active{transform:scale(.97)}.light-btn[data-state=on]{background:var(--accent-amber-dim);border-color:#f59e0b4d}.light-btn[data-state=on] .light-btn__glow{opacity:1}.light-btn[data-state=on] .light-btn__icon{color:var(--accent-amber);filter:drop-shadow(0 0 8px rgba(245,158,11,.6))}.light-btn[data-state=on] .light-btn__label{color:var(--accent-amber)}.heat-mode-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.heat-mode-btn{padding:12px 8px;border-radius:var(--radius-md);background:#ffffff08;border:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;align-items:center;gap:4px;transition:all var(--transition-base)}.heat-mode-btn:hover{background:#ffffff0f;border-color:#ffffff1f}.heat-mode-btn:active{transform:scale(.96)}.heat-mode-btn.active{background:var(--accent-amber-dim);border-color:#f59e0b4d;box-shadow:0 0 12px #f59e0b1a}.heat-mode-btn__icon{font-size:1.2rem}.heat-mode-btn__label{font-size:.75rem;font-weight:600;color:var(--text-primary)}.heat-mode-btn__desc{font-size:.6rem;color:var(--text-muted)}.heat-mode-btn.active .heat-mode-btn__label{color:var(--accent-amber)}.range-toggle{display:flex;flex-direction:column;gap:8px}.range-btn{width:100%;padding:10px 12px;border-radius:var(--radius-md);background:#ffffff08;border:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;align-items:center;gap:2px;transition:all var(--transition-base)}.range-btn:hover{background:#ffffff0f}.range-btn:active{transform:scale(.96)}.range-btn.active{background:var(--accent-teal-dim);border-color:#06b6d44d}.range-btn__label{font-size:.8rem;font-weight:600;color:var(--text-secondary);transition:color var(--transition-fast)}.range-btn__desc{font-size:.6rem;color:var(--text-muted)}.range-btn.active .range-btn__label{color:var(--accent-teal)}.scale-toggle{display:flex;gap:8px}.scale-btn{flex:1;height:48px;border-radius:var(--radius-md);background:#ffffff08;border:1px solid rgba(255,255,255,.06);font-size:1.1rem;font-weight:700;color:var(--text-muted);transition:all var(--transition-base)}.scale-btn:hover{background:#ffffff0f}.scale-btn:active{transform:scale(.95)}.scale-btn.active{background:var(--accent-teal-dim);border-color:#06b6d44d;color:var(--accent-teal)}.filter-cycles{display:flex;flex-direction:column;gap:10px}.filter-cycle{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:var(--radius-md);background:#ffffff08;border:1px solid rgba(255,255,255,.04)}.filter-cycle__name{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.filter-cycle__time{font-size:.75rem;font-weight:500;color:var(--accent-teal);font-variant-numeric:tabular-nums}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity var(--transition-base);padding:16px}.modal-overlay.open{opacity:1;pointer-events:all}.modal{width:100%;max-width:400px;background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:24px;transform:translateY(20px) scale(.95);transition:transform var(--transition-slow)}.modal-overlay.open .modal{transform:translateY(0) scale(1)}.modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal__title{font-size:1.1rem;font-weight:700}.modal__body{display:flex;flex-direction:column;gap:16px}.modal__footer{margin-top:24px;display:flex;justify-content:flex-end}.setting-row{display:flex;flex-direction:column;gap:6px}.setting-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.setting-input{width:100%;height:40px;padding:0 12px;border-radius:var(--radius-md);background:#ffffff0d;border:1px solid rgba(255,255,255,.08);color:var(--text-primary);font-size:.9rem;outline:none;transition:all var(--transition-fast)}.setting-input:focus{border-color:var(--accent-teal);box-shadow:0 0 0 3px #06b6d426}.setting-input::placeholder{color:var(--text-muted)}.setting-value{font-size:.85rem;color:var(--text-secondary)}.btn{height:40px;padding:0 24px;border-radius:var(--radius-full);font-size:.85rem;font-weight:600;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.btn--primary{background:linear-gradient(135deg,var(--accent-teal),var(--accent-blue));color:#fff}.btn--primary:hover{box-shadow:var(--shadow-glow-teal);transform:translateY(-1px)}.btn--primary:active{transform:translateY(0) scale(.98)}.setting-section{margin-top:8px;padding-top:16px;border-top:1px solid rgba(255,255,255,.06)}.setting-section__title{font-size:.85rem;font-weight:700;color:var(--text-secondary);margin-bottom:12px}.setting-input-group{display:flex;gap:8px;align-items:center}.setting-input-group .setting-input{flex:1}.btn--small{height:40px;padding:0 14px;border-radius:var(--radius-md);font-size:.75rem;font-weight:600;white-space:nowrap}.btn--discover{background:#06b6d426;color:var(--accent-teal);border:1px solid rgba(6,182,212,.25)}.btn--discover:hover{background:#06b6d440}.btn--discover:disabled{opacity:.5;cursor:not-allowed}.discover-results{display:flex;flex-direction:column;gap:6px;max-height:120px;overflow-y:auto}.discover-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:var(--radius-md);background:#06b6d414;border:1px solid rgba(6,182,212,.15);cursor:pointer;transition:all var(--transition-fast)}.discover-item:hover{background:#06b6d42e;border-color:var(--accent-teal)}.discover-item__name{font-size:.85rem;font-weight:600;color:var(--text-primary)}.discover-item__ip{font-size:.75rem;font-weight:500;color:var(--accent-teal);font-family:Inter,monospace}.discover-empty{font-size:.8rem;color:var(--text-muted);text-align:center;padding:8px}.setting-row--actions{flex-direction:row;gap:8px;margin-top:4px}.btn--connect{flex:1;height:40px;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;background:linear-gradient(135deg,var(--accent-teal),var(--accent-blue));color:#fff}.btn--connect:hover{box-shadow:var(--shadow-glow-teal);transform:translateY(-1px)}.btn--connect:disabled{opacity:.5;cursor:not-allowed}.btn--disconnect{flex:1;height:40px;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;background:#f8717126;color:#f87171;border:1px solid rgba(248,113,113,.25)}.btn--disconnect:hover{background:#f8717140}.circ-pump-status{display:flex;align-items:center;gap:10px;padding:10px 0}.circ-pump-dot{width:12px;height:12px;border-radius:50%;background:#ffffff26;transition:all var(--transition-base)}.circ-pump-dot.active{background:#34d399;box-shadow:0 0 8px #34d39999;animation:pulse-dot 2s ease-in-out infinite}.circ-pump-label{font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.status-dot.connected{background:#34d399;box-shadow:0 0 8px #34d39999;animation:none}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}@keyframes ring-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.temp-hero__inner{animation:ring-counter-rotate 8s linear infinite}@keyframes ring-counter-rotate{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}@keyframes bump-up{0%{transform:translateY(0)}40%{transform:translateY(-6px)}to{transform:translateY(0)}}@keyframes bump-down{0%{transform:translateY(0)}40%{transform:translateY(6px)}to{transform:translateY(0)}}@keyframes bubbles{0%{transform:translateY(0) scale(1);opacity:.6}to{transform:translateY(-20px) scale(0);opacity:0}}@media (min-width: 768px){#app{max-width:600px;padding:0 24px 60px}.temp-hero__ring{width:240px;height:240px}.temp-hero__value{font-size:4.5rem}.controls-grid{gap:16px}.card{padding:20px}}@media (min-width: 1024px){#app{max-width:700px}.controls-grid{grid-template-columns:repeat(3,1fr)}.card--wide{grid-column:1 / -1}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}.hidden{display:none!important}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px 20px;border-radius:var(--radius-md);background:#1e2337f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);color:var(--text-primary);font-size:.85rem;font-weight:500;pointer-events:auto;box-shadow:0 8px 24px #0006;animation:toast-in .35s ease-out;max-width:340px}.toast.removing{animation:toast-out .3s ease-in forwards}.toast__icon{font-size:1.1rem;flex-shrink:0}.toast--success{border-left:3px solid #34d399}.toast--success .toast__icon{color:#34d399}.toast--error{border-left:3px solid #f87171}.toast--error .toast__icon{color:#f87171}.toast--info{border-left:3px solid var(--accent-primary)}.toast--info .toast__icon{color:var(--accent-primary)}@keyframes toast-in{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes toast-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(40px)}}.reconnect-banner{position:fixed;top:0;left:0;right:0;z-index:9999;display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 16px;background:#f59e0b26;border-bottom:1px solid rgba(245,158,11,.3);color:#fbbf24;font-size:.8rem;font-weight:600;letter-spacing:.02em;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:banner-slide .3s ease-out}.reconnect-banner__spinner{width:14px;height:14px;border:2px solid rgba(251,191,36,.3);border-top-color:#fbbf24;border-radius:50%;animation:spin .8s linear infinite}@keyframes banner-slide{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}
