.configurator-overlay{position:fixed;inset:0;background:#020617cc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.configurator-card{background:#0f172af2;border:1px solid rgba(255,255,255,.1);box-shadow:0 25px 50px -12px #00000080;border-radius:1.5rem;width:100%;max-width:600px;display:flex;flex-direction:column;max-height:90vh}.configurator-header{padding:1.5rem 2rem;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.configurator-header h3{margin:0;font-size:1.25rem;color:var(--config-accent)}.close-button{background:none;border:none;color:var(--config-text-muted);font-size:1.5rem;cursor:pointer;padding:.5rem;line-height:1}.configurator-body{padding:2rem;overflow-y:auto}.field-group{margin-bottom:1.5rem}.field-group label{display:block;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--config-text-muted);margin-bottom:.5rem}.field-group select,.field-group input[type=text],.field-group input[type=number]{width:100%;background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;padding:.75rem 1rem;color:var(--config-text);font-size:1rem;outline:none;transition:border-color .2s ease}.field-group select:focus,.field-group input:focus{border-color:var(--config-accent)}.field-hint{margin-top:.5rem;font-size:.8rem;color:var(--config-text-muted)}.radio-group{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.radio-label{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;padding:.75rem;display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.9rem;transition:all .2s ease}.radio-label:hover{border-color:#fff3}.radio-label:has(input:checked){border-color:var(--config-accent);background:#38bdf81a}.checkbox-group{margin-top:2rem}.checkbox-container{display:flex;align-items:center;gap:1rem;cursor:pointer;font-weight:600;color:var(--config-text)}.checkbox-container input{width:20px;height:20px;accent-color:var(--config-accent)}.configurator-footer{padding:1.5rem 2rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:flex-end;gap:1rem}.cancel-button{background:transparent;border:1px solid rgba(255,255,255,.1);color:var(--config-text);padding:.75rem 1.5rem;border-radius:.5rem;cursor:pointer;transition:all .2s ease}.cancel-button:hover{background:#ffffff0d}.save-button{background:var(--config-accent);border:none;color:#000;font-weight:700;padding:.75rem 2rem;border-radius:.5rem;cursor:pointer;transition:all .2s ease}.save-button:hover{background:var(--config-accent-hover);transform:translateY(-2px)}.help-tooltip-container{display:inline-flex;align-items:center;position:relative;cursor:help;margin-left:8px;vertical-align:middle}.info-icon{color:var(--config-accent, #4a90e2);opacity:.7;transition:opacity .2s}.help-tooltip-container:hover .info-icon{opacity:1}.tooltip-box{position:absolute;background:#0f172af2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:12px;width:260px;z-index:1000;box-shadow:0 10px 25px #00000080;font-size:.85rem;line-height:1.4;color:#e2e8f0;pointer-events:none;animation:fadeIn .15s ease-out}.tooltip-title{font-weight:600;margin-bottom:6px;color:var(--config-accent, #4a90e2);font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:4px}.tooltip-content{white-space:normal;text-align:left}.position-top{bottom:150%;left:50%;transform:translate(-50%)}.position-bottom{top:150%;left:50%;transform:translate(-50%)}.position-right{left:150%;top:50%;transform:translateY(-50%)}.position-left{right:150%;top:50%;transform:translateY(-50%)}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,5px)}to{opacity:1;transform:translate(-50%)}}.efficiency-banner{background:#22c55e1a;border:1px solid rgba(34,197,94,.2);border-radius:12px;padding:1rem 1.5rem;display:flex;gap:1rem;margin-bottom:2rem;align-items:center}.banner-icon{font-size:1.5rem}.banner-content h4{margin:0 0 .25rem;color:#4ade80;font-size:1rem}.banner-content p{margin:0;font-size:.85rem;opacity:.8}:root{--config-bg: rgba(15, 23, 42, .95);--config-card-bg: rgba(30, 41, 59, .5);--config-border: rgba(255, 255, 255, .1);--config-accent: #38bdf8;--config-accent-hover: #0ea5e9;--config-text: #f8fafc;--config-text-muted: #94a3b8;--config-warning: #f59e0b;--config-error: #ef4444;--config-success: #10b981}.adv-config-container{max-width:1200px;margin:0 auto;padding:2rem;color:var(--config-text);font-family:Inter,system-ui,-apple-system,sans-serif;min-height:80vh}.adv-config-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.adv-config-header h1{font-size:2rem;font-weight:700;margin:0;background:linear-gradient(135deg,#fff,#94a3b8);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.header-subtitle{color:var(--config-text-muted);margin-top:.5rem}.header-right{display:flex;gap:1rem}.help-button,.export-button{background:var(--config-card-bg);border:1px solid var(--config-border);color:var(--config-text);padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;transition:all .2s ease}.help-button:hover,.export-button:hover{background:#334155cc;border-color:var(--config-accent)}.adv-config-warning{display:flex;align-items:center;gap:1rem;background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);padding:1rem;border-radius:.75rem;margin-bottom:2rem;animation:slideInDown .3s ease-out}.warning-icon{font-size:1.25rem}.warning-text{flex:1;font-size:.9rem;color:#fbbf24}.warning-dismiss{background:none;border:none;color:#fbbf24;cursor:pointer;opacity:.6}.warning-dismiss:hover{opacity:1}.adv-config-tabs{display:flex;gap:.5rem;background:#0f172a66;padding:.5rem;border-radius:1rem;margin-bottom:2rem;overflow-x:auto;scrollbar-width:none}.adv-config-tabs::-webkit-scrollbar{display:none}.tab-button{flex:1;min-width:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem .5rem;background:transparent;border:none;color:var(--config-text-muted);border-radius:.75rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.tab-icon{font-size:1.5rem;margin-bottom:.5rem}.tab-label{font-size:.8rem;font-weight:500}.tab-button:hover{color:var(--config-text);background:#ffffff0d}.tab-button.active{color:var(--config-accent);background:#38bdf81a;box-shadow:inset 0 0 0 1px #38bdf833}.adv-config-content{background:var(--config-card-bg);border:1px solid var(--config-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:1.5rem;padding:2rem;min-height:400px;position:relative}.tab-panel h2{font-size:1.5rem;margin-bottom:.5rem}.panel-description{color:var(--config-text-muted);margin-bottom:2rem}.config-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px}.loading-spinner{width:40px;height:40px;border:3px solid rgba(56,189,248,.1);border-top:3px solid var(--config-accent);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.config-error{background:#ef44441a;border:1px solid rgba(239,68,68,.2);padding:1rem;border-radius:.75rem;color:var(--config-error);margin-bottom:2rem}.circuits-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.circuit-card{background:#0f172a66;border:1px solid var(--config-border);border-radius:1rem;padding:1.25rem;transition:transform .2s ease,border-color .2s ease}.circuit-card:hover{transform:translateY(-4px);border-color:var(--config-accent)}.circuit-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.circuit-id{font-size:.8rem;color:var(--config-text-muted);font-weight:600}.circuit-name{font-weight:600;flex:1}.circuit-state{font-size:.7rem;font-weight:700;padding:.2rem .6rem;border-radius:2rem;text-transform:uppercase}.circuit-state.on{background:#10b98133;color:#10b981}.circuit-state.off{background:#94a3b833;color:#94a3b8}.detail-row{display:flex;justify-content:space-between;font-size:.9rem;margin-bottom:.5rem}.detail-row label{color:var(--config-text-muted)}.edit-button{width:100%;margin-top:1rem;padding:.6rem;background:#ffffff0d;border:1px solid var(--config-border);border-radius:.5rem;color:var(--config-text);cursor:pointer;transition:all .2s ease}.edit-button:hover{background:var(--config-accent);color:#000;border-color:var(--config-accent)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideInDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.adv-config-gated,.adv-config-disconnected{display:flex;align-items:center;justify-content:center;min-height:400px;text-align:center;padding:3rem}.gated-content,.disconnected-content{max-width:500px}.gated-icon,.disconnected-icon{font-size:4rem;margin-bottom:1.5rem}.gated-features{text-align:left;background:#0f172a66;padding:1.5rem;border-radius:1rem;margin:1.5rem 0}.gated-features h3{font-size:1rem;margin-bottom:1rem}.gated-features ul{list-style:none;padding:0;margin:0}.gated-features li{margin-bottom:.5rem;font-size:.9rem}.upgrade-button{background:var(--config-accent);color:#000;border:none;padding:1rem 2.5rem;border-radius:2rem;font-weight:700;cursor:pointer;transition:transform .2s ease}.upgrade-button:hover{transform:scale(1.05);background:var(--config-accent-hover)}.pump-card{background:#0f172a66;border:1px solid var(--config-border);border-radius:1rem;padding:1.5rem;margin-bottom:2rem}.pump-header h3{margin:0 0 1.5rem;font-size:1.1rem;color:var(--config-accent)}.speed-row{display:flex;align-items:center;gap:2rem;margin-bottom:1.5rem;background:#1e293b4d;padding:1rem;border-radius:.75rem}.speed-label{min-width:120px;font-weight:600}.speed-input-container{flex:1;display:flex;align-items:center;gap:1.5rem}.speed-input-container input[type=range]{flex:1;accent-color:var(--config-accent)}.speed-value{min-width:80px;font-family:JetBrains Mono,monospace;font-weight:700;color:var(--config-accent)}.pump-actions{margin-top:2rem;display:flex;justify-content:flex-end}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.create-manual-button{background:var(--config-card-bg);border:1px solid var(--config-accent);color:var(--config-accent);padding:.75rem 1.5rem;border-radius:.5rem;cursor:pointer;font-weight:600;transition:all .2s ease}.create-manual-button:hover{background:var(--config-accent);color:#000}.snapshots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.snapshot-card{background:#0f172a66;border:1px solid var(--config-border);border-radius:1rem;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.snapshot-card.is-baseline{border-color:#f59e0b80;background:#f59e0b0d}.snapshot-card-header{display:flex;gap:1rem}.snapshot-type-icon{font-size:1.5rem}.snapshot-label{font-weight:700;font-size:1.1rem}.snapshot-meta{font-size:.8rem;color:var(--config-text-muted);margin-top:.25rem}.snapshot-card-actions{display:flex;gap:.75rem;margin-top:.5rem}.restore-btn{flex:1;background:#ffffff0d;border:1px solid var(--config-border);color:var(--config-text);padding:.6rem;border-radius:.5rem;cursor:pointer;font-size:.9rem;transition:all .2s ease}.restore-btn:hover{background:var(--config-accent);color:#000;border-color:var(--config-accent)}.delete-btn{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#ef4444;padding:.6rem;border-radius:.5rem;cursor:pointer;transition:all .2s ease}.delete-btn:hover{background:#ef4444;color:#fff}.history-footer-info{margin-top:3rem;padding:1.5rem;background:#38bdf80d;border-radius:1rem;display:flex;gap:1rem;font-size:.9rem;color:var(--config-text-muted);line-height:1.5}.heater-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:3rem}.heater-body-card{background:#0f172a66;border:1px solid var(--config-border);border-radius:1rem;padding:1.5rem}.heater-body-card .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.heater-body-card h3{margin:0;font-size:1.25rem;color:var(--config-accent)}.current-temp{font-family:JetBrains Mono,monospace;font-size:1rem;font-weight:700;background:#38bdf81a;color:var(--config-accent);padding:.25rem .75rem;border-radius:2rem}.slider-container{margin-top:1rem}.slider-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--config-text-muted);margin-top:.5rem}.heater-footer-notices{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background:#1e293b4d;border-radius:1rem}.notice-item{display:flex;gap:1rem;font-size:.9rem}.notice-item.warning{color:var(--config-warning)}.notice-item.info{color:var(--config-success)}.lights-control-card{background:#0f172a66;border:1px solid var(--config-border);border-radius:1.5rem;padding:2rem}.sync-section{text-align:center;margin-bottom:3rem}.sync-button{background:linear-gradient(135deg,#38bdf8,#3b82f6);color:#000;border:none;padding:1rem 3rem;border-radius:2.5rem;font-weight:800;font-size:1.1rem;cursor:pointer;box-shadow:0 4px 20px #3b82f64d;transition:all .2s ease}.sync-button:hover{transform:scale(1.02);box-shadow:0 6px 25px #3b82f680}.modes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;margin-bottom:3rem}.mode-card{background:#1e293b80;border:1px solid rgba(255,255,255,.05);border-radius:1rem;padding:1.25rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.mode-card:hover{background:#38bdf81a;border-color:var(--config-accent);transform:translateY(-4px)}.mode-icon{font-size:2rem}.mode-name{font-size:.8rem;font-weight:600;color:var(--config-text-muted)}.mode-card:hover .mode-name{color:var(--config-text)}.lights-footer-actions{display:flex;justify-content:center;gap:1.5rem;border-top:1px solid rgba(255,255,255,.1);padding-top:2rem}.action-btn{background:#ffffff0d;border:1px solid var(--config-border);color:var(--config-text);padding:.75rem 2rem;border-radius:.75rem;cursor:pointer;font-weight:600;transition:all .2s ease}.action-btn:hover{border-color:var(--config-accent);color:var(--config-accent)}.lights-info-box{margin-top:2rem;background:#38bdf80d;border-radius:1rem;padding:1.5rem;display:flex;gap:1rem;font-size:.9rem;color:var(--config-text-muted)}.system-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:3rem}.system-card{background:#0f172a66;border:1px solid var(--config-border);border-radius:1rem;padding:1.5rem}.system-card h3{margin:0 0 1.5rem;font-size:1.1rem;color:var(--config-accent)}.lat-long-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.sync-time-box{margin-bottom:2rem}.sync-time-btn{width:100%;background:#38bdf81a;border:1px solid var(--config-accent);color:var(--config-accent);padding:.75rem;border-radius:.5rem;cursor:pointer;font-weight:600}.system-footer-info{margin-top:2rem;background:#1e293b4d;padding:1.5rem;border-radius:1rem;display:flex;gap:1rem;font-size:.9rem;color:var(--config-text-muted)}.chemistry-section{background:#0f172a66;border:1px solid var(--config-border);border-radius:1.5rem;padding:2rem;margin-bottom:2.5rem}.chemistry-section h3{margin:0 0 2rem;color:var(--config-accent)}.chlor-status-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2.5rem}.status-item label{display:block;font-size:.75rem;color:var(--config-text-muted);margin-bottom:.5rem;text-transform:uppercase}.status-item .value{font-size:1.25rem;font-weight:700}.status-badge{font-size:.7rem;margin-left:.5rem;color:var(--config-success)}.boost-button{width:100%;margin-top:2rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#000;border:none;padding:1rem;border-radius:.75rem;font-weight:800;cursor:pointer}.chem-readings-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2.5rem}.chem-card{background:#1e293b80;padding:1.5rem;border-radius:1rem}.card-label{font-size:.8rem;color:var(--config-text-muted)}.card-value{font-size:2rem;font-weight:800;margin:.5rem 0}.card-target{font-size:.9rem;color:var(--config-accent)}.card-progress{height:6px;background:#ffffff1a;border-radius:3px;margin-top:1rem;overflow:hidden}.progress-fill{height:100%}.status-row{display:flex;justify-content:space-between;padding:1rem 0;border-top:1px solid rgba(255,255,255,.05)}.status-row .ok{color:var(--config-success)}.status-row .error{color:var(--config-error)}.solar-card{background:#0f172a66;border:1px solid var(--config-border);border-radius:1.5rem;padding:2rem}@media(max-width:768px){.adv-config-tabs{flex-wrap:nowrap}.tab-button{min-width:100px}.adv-config-header{flex-direction:column;gap:1rem}.speed-row{flex-direction:column;align-items:stretch;gap:1rem}.history-header{flex-direction:column;gap:1rem;align-items:flex-start}}:root{--primary-bg: #f1f5f9;--secondary-bg: #ffffff;--tertiary-bg: #f8fafc;--accent-blue: #3b82f6;--accent-green: #10b981;--accent-orange: #f59e0b;--danger: #ef4444;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--border-color: #e2e8f0;--glass: rgba(255, 255, 255, .8);--glass-border: rgba(0, 0, 0, .08);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}[data-theme=dark]{--primary-bg: #0f172a;--secondary-bg: #1e293b;--tertiary-bg: #334155;--accent-blue: #60a5fa;--accent-green: #34d399;--accent-orange: #fbbf24;--danger: #f87171;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--border-color: #334155;--glass: rgba(30, 41, 59, .8);--glass-border: rgba(255, 255, 255, .1);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -2px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 10px 10px -5px rgba(0, 0, 0, .4)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--primary-bg);color:var(--text-primary);font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;transition:background-color var(--transition-slow),color var(--transition-slow)}.app-container{max-width:1200px;margin:0 auto;padding:1rem;display:flex;flex-direction:column;gap:1.5rem}.card{background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-md);transition:box-shadow var(--transition-normal),transform var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg)}.glass-card{background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:1.5rem;color:var(--text-primary)}.glass-card label{color:var(--text-secondary);display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500}input.glass-card,input[type=text],input[type=email],input[type=password],input[type=time],select{background:var(--tertiary-bg);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.75rem 1rem;outline:none;transition:all var(--transition-fast);font-family:inherit;font-size:.9375rem}input.glass-card:focus,input:focus,select:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f626}input::placeholder{color:var(--text-muted)}.btn{padding:.75rem 1.5rem;border-radius:var(--radius-md);border:none;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background:var(--accent-blue);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.btn-ghost:hover{background:var(--tertiary-bg);color:var(--text-primary);border-color:var(--text-muted)}.btn-ghost:disabled{opacity:.5;cursor:not-allowed}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.status-pill{padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.025em}.status-online{background:#10b98126;color:var(--accent-green)}.status-offline{background:#ef444426;color:var(--danger)}h1{font-size:1.875rem;font-weight:800;letter-spacing:-.025em;color:var(--text-primary)}h2{font-size:1.5rem;font-weight:700;color:var(--text-primary)}h3{font-size:1.125rem;font-weight:600;color:var(--text-secondary)}.temp-display{font-size:3rem;font-weight:800;line-height:1;color:var(--text-primary)}.unit{font-size:1.25rem;vertical-align:super;color:var(--text-secondary)}.fade-in{animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner{animation:spin 1s linear infinite}.progress-container{width:100%;margin-top:1.5rem}.progress-header{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.875rem;color:var(--text-secondary)}.progress-value{color:var(--accent-green);font-weight:600}.progress-bar{height:8px;background:var(--tertiary-bg);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:var(--accent-green);transition:width var(--transition-slow);border-radius:4px}.pump-row{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--tertiary-bg);border-radius:var(--radius-lg);margin-bottom:.75rem;gap:1rem;border:1px solid var(--border-color)}.pump-circuit-btn{background:var(--secondary-bg);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:var(--radius-sm);min-width:120px;font-weight:500;text-align:center;transition:all var(--transition-fast)}.pump-circuit-btn.active{background:var(--accent-green);color:#fff;border-color:var(--accent-green)}.pump-setting-adjust{display:flex;align-items:center;gap:1rem;flex:1;justify-content:center}.adj-btn{background:transparent;border:none;color:var(--accent-blue);cursor:pointer;display:flex;align-items:center;padding:.5rem;transition:transform var(--transition-fast);border-radius:var(--radius-sm)}.adj-btn:hover{background:var(--tertiary-bg)}.adj-btn:active{transform:scale(.9)}.adj-val{font-size:1.25rem;font-weight:700;min-width:100px;text-align:center;color:var(--text-primary)}.target-toggle{display:flex;background:var(--tertiary-bg);border-radius:var(--radius-sm);padding:2px;border:1px solid var(--border-color)}.toggle-option{padding:.4rem 1rem;border-radius:calc(var(--radius-sm) - 2px);font-size:.75rem;font-weight:700;cursor:pointer;transition:all var(--transition-fast);color:var(--text-secondary);text-transform:uppercase}.toggle-option.active{background:var(--accent-blue);color:#fff}.toggle-option.disabled{cursor:not-allowed;opacity:.5}@media(max-width:640px){.app-container{padding:.75rem}.grid{grid-template-columns:1fr}.pump-row{flex-direction:column;gap:.75rem}.pump-setting-adjust{width:100%}}
