@import "https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=JetBrains+Mono:wght@400;600&display=swap";
@import "https://unpkg.com/leaflet@1.9.4/dist/leaflet.css";
:root{--space-1:8px;--space-2:16px;--space-3:24px;--space-4:32px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--bg:#0b1220;--surface:#101a2a;--surface-soft:#131f31;--border:#1f2a3f;--text:#e5e7eb;--muted:#94a3b8;--phase-r:#ef4444;--phase-y:#eab308;--phase-b:#3b82f6;--freq:#22d3ee;--pf:#22c55e;--danger:#ef4444;--shadow:0 12px 28px #02061759;--shadow-hover:0 18px 38px #0206177a}*{box-sizing:border-box}html,body{min-height:100%;margin:0;overflow-x:hidden}body{background:var(--bg);color:var(--text);font-family:Rajdhani,sans-serif}.app-shell{padding:var(--space-3);overflow-x:hidden}.page{gap:var(--space-3);opacity:.72;flex-direction:column;transition:opacity .32s;display:flex}.page.ready{opacity:1}.topbar{justify-content:space-between;align-items:center;gap:var(--space-2);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-2)var(--space-3);box-shadow:var(--shadow);display:flex}.topbar-left{flex-direction:column;gap:4px;display:flex}.topbar-title{letter-spacing:.5px;margin:0;font-size:34px;font-weight:700;line-height:1}.topbar-subtitle{color:var(--muted);margin:0;font-size:15px}.topbar-right{grid-auto-flow:column;align-items:center;gap:12px;display:grid}.conn-pill{border:1px solid var(--border);color:var(--muted);background:#0d1726;border-radius:999px;align-items:center;gap:8px;padding:6px 12px;font-family:JetBrains Mono,monospace;font-size:12px;display:inline-flex}.conn-dot{background:var(--danger);border-radius:999px;width:10px;height:10px}.conn-pill.ok .conn-dot{background:var(--pf)}.conn-pill.warn .conn-dot{background:#f59e0b}.last-seen{color:var(--muted);font-family:JetBrains Mono,monospace;font-size:13px}.icon-btn{border:1px solid var(--border);color:var(--text);border-radius:999px;padding:6px 12px;font-family:JetBrains Mono,monospace;font-size:12px;text-decoration:none;transition:border-color .18s,color .18s}.icon-btn:hover{border-color:var(--freq);color:var(--freq)}.dashboard{gap:var(--space-3);display:grid}.section{gap:var(--space-2);display:grid}.section-header{justify-content:space-between;align-items:flex-end;gap:var(--space-2);display:flex}.section-title{letter-spacing:.3px;margin:0;font-size:22px;font-weight:600;line-height:1}.section-subtitle{color:var(--muted);margin:6px 0 0;font-size:14px}.section-content{gap:var(--space-2);display:grid}.summary-grid{gap:var(--space-2);grid-template-columns:repeat(4,minmax(0,1fr));display:grid}.summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-2);box-shadow:var(--shadow);gap:6px;transition:transform .18s,box-shadow .18s,border-color .18s;display:grid}.summary-card:hover{box-shadow:var(--shadow-hover);border-color:#2a3957;transform:translateY(-1px)}.summary-label{text-transform:uppercase;letter-spacing:1.1px;color:var(--muted);font-size:12px}.summary-value{align-items:baseline;gap:6px;font-family:JetBrains Mono,monospace;font-size:32px;font-weight:600;line-height:1;display:inline-flex}.summary-unit{color:var(--muted);font-size:14px}.summary-meta{color:var(--muted);font-size:13px}.metric-frequency{color:var(--freq)}.metric-pf{color:var(--pf)}.ice-layout{gap:var(--space-2);grid-template-columns:minmax(320px,420px) minmax(0,1fr);display:grid}.ice-left-col{gap:var(--space-2);align-content:start;display:grid}.ice-right-col{min-width:0}.ice-bottom-col{grid-column:1/-1}.ice-card{background:var(--surface)}.ice-settings-body{gap:12px}.motor-shell{justify-content:center;align-items:center;width:220px;height:130px;margin:12px auto;display:flex;position:relative}.motor-body{background:linear-gradient(135deg,#334155,#0f172a);border:2px solid #475569;border-radius:18px;width:132px;height:86px;box-shadow:inset 0 0 18px #0f172ab3}.motor-shaft{background:#94a3b8;border-radius:8px;width:28px;height:14px;position:absolute;right:32px}.motor-fan{border:3px solid #94a3b8;border-radius:50%;width:42px;height:42px;position:absolute;right:6px}.motor-shell.on .motor-body{border-color:#22c55e;box-shadow:0 0 20px #22c55e59,inset 0 0 18px #22c55e33}.motor-shell.on .motor-fan{animation:.7s linear infinite motor-spin}.motor-shell.off{opacity:.5}@keyframes motor-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ice-map-wrap{padding:0}.ice-map{border-radius:var(--radius-md);border:1px solid var(--border);width:100%;min-height:440px;overflow:hidden}.ice-logs-wrap{padding:0;overflow:auto}.ice-logs-table{border-collapse:collapse;width:100%;min-width:980px;font-family:JetBrains Mono,monospace;font-size:12px}.ice-logs-table th,.ice-logs-table td{border-bottom:1px solid var(--border);text-align:left;vertical-align:top;padding:10px 12px}.ice-logs-table thead th{z-index:1;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;background:#0d1726;position:sticky;top:0}.ice-empty-row{text-align:center;color:var(--muted)}.point-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:#0d1726;border-radius:8px;padding:4px 8px}.point-btn:disabled{opacity:.45;cursor:not-allowed}@media (max-width:980px){.ice-layout{grid-template-columns:1fr}.ice-bottom-col{grid-column:1}.ice-map{min-height:360px}}.metric-avg{color:#cbd5e1}.metric-live{color:var(--pf)}.metric-offline{color:var(--danger)}.live-badge{background:var(--danger);border-radius:999px;width:10px;height:10px}.live-badge.is-live{background:var(--pf)}.live-pulse{animation:1.2s ease-in-out infinite pulse}@keyframes pulse{0%{box-shadow:0 0 #22c55e80}to{box-shadow:0 0 0 10px #22c55e00}}.voltage-layout{gap:var(--space-2);grid-template-columns:2fr 1fr;display:grid}.quality-layout{gap:var(--space-2);grid-template-columns:1fr 1fr;display:grid}.phasor-layout{display:grid}.bottom-layout{gap:var(--space-2);grid-template-columns:1fr 1fr;display:grid}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:var(--space-2);gap:var(--space-2);transition:transform .18s,box-shadow .18s,border-color .18s;display:grid}.card:hover{box-shadow:var(--shadow-hover);border-color:#2a3957;transform:translateY(-1px)}.card-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.card-title{text-transform:uppercase;letter-spacing:1.1px;color:var(--muted);font-size:12px}.card-slot,.card-value{color:#cbd5e1;font-family:JetBrains Mono,monospace;font-size:13px}.card-body{position:relative}.chart{width:100%;padding:var(--space-1);border-radius:var(--radius-md);background:var(--surface-soft);border:1px solid #1a2538;position:relative}.chart-lg{min-height:320px}.chart-md{min-height:260px}.chart-sm{min-height:240px}.chart-empty{color:var(--muted);z-index:2;pointer-events:none;font-size:14px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.chart canvas{max-width:100%!important}.gauge,.phasor{justify-content:center;align-items:center;min-height:260px;display:flex}.gauge svg,.phasor svg{width:min(100%,320px);height:auto}.info-grid{gap:var(--space-2);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.info-card{border-radius:var(--radius-md);background:var(--surface-soft);padding:var(--space-2);border:1px solid #22314b;gap:4px;display:grid}.info-label{color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-size:12px}.info-value{font-family:JetBrains Mono,monospace;font-size:30px;font-weight:600}.toggle-btn{color:var(--text);cursor:pointer;background:#0d1726;border:1px solid #2a3a58;border-radius:999px;padding:6px 12px;font-family:JetBrains Mono,monospace;font-size:12px}.toggle-btn:hover{border-color:var(--freq);color:var(--freq)}.panel-body{gap:var(--space-2);opacity:0;max-height:0;transition:max-height .22s,opacity .22s;display:grid;overflow:hidden}.panel-body.open{opacity:1;max-height:420px}.field{color:var(--muted);gap:6px;font-size:13px;display:grid}.field input{color:var(--text);background:#0e1828;border:1px solid #2b3b5b;border-radius:10px;outline:none;padding:10px 12px;font-family:JetBrains Mono,monospace;font-size:13px}.field input:focus{border-color:var(--freq)}.locked-input{cursor:not-allowed;color:#7c8ca8!important;background:#0a1322!important;border-color:#1d2a43!important}.panel-actions{gap:10px;display:grid}.primary-btn{color:#d9f6ff;cursor:pointer;background:#0f2635;border:1px solid #28506b;border-radius:10px;padding:10px 14px;font-family:JetBrains Mono,monospace;font-size:13px}.primary-btn:disabled{opacity:.5;cursor:not-allowed}.status-text{min-height:16px;color:var(--muted);font-size:12px}.status-text.success{color:var(--pf)}.status-text.error{color:var(--danger)}@media (max-width:1280px){.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.voltage-layout,.quality-layout,.bottom-layout{grid-template-columns:1fr}}@media (max-width:768px){.app-shell{padding:var(--space-2)}.page{gap:var(--space-2)}.topbar{border-radius:var(--radius-lg);padding:12px var(--space-2);gap:10px}.topbar-title{font-size:26px}.topbar-subtitle{font-size:13px}.topbar-right{grid-auto-flow:row;justify-items:start;gap:8px;width:100%}.conn-pill{padding:5px 10px;font-size:11px}.last-seen{font-size:12px}.dashboard,.section,.section-content{gap:var(--space-2)}.section-title{font-size:20px}.section-subtitle{font-size:13px}.summary-grid{grid-template-columns:1fr;gap:12px}.summary-card{gap:4px;padding:14px}.summary-value{font-size:30px}.summary-label{font-size:11px}.summary-meta{font-size:12px}.voltage-layout,.quality-layout,.bottom-layout{gap:var(--space-2);grid-template-columns:1fr}.card{border-radius:var(--radius-md);padding:14px}.card-title{font-size:11px}.card-slot,.card-value{font-size:12px}.chart{padding:6px}.chart-lg,.chart-md,.chart-sm,.gauge,.phasor{min-height:220px}.gauge svg,.phasor svg{width:min(100%,250px)}.info-grid{grid-template-columns:repeat(auto-fit,minmax(132px,1fr));gap:10px}.info-card{padding:12px}.info-value{font-size:24px}.toggle-btn,.icon-btn,.primary-btn,.field input{min-height:44px}.toggle-btn,.icon-btn{padding:10px 14px}.primary-btn{width:100%;font-size:14px}.panel-body{gap:12px}}@media (max-width:860px){.app-shell{padding:var(--space-2)}.topbar{flex-direction:column;align-items:flex-start}.topbar-right{grid-auto-flow:row;justify-items:start;width:100%}.summary-grid,.info-grid{grid-template-columns:1fr}.topbar-title{font-size:28px}}@media (max-width:640px){.topbar{padding:10px 12px}.topbar-title{font-size:23px}.topbar-subtitle{display:none}.last-seen{font-size:11px}.section-header{align-items:flex-start}.section-title{font-size:18px}.section-subtitle{font-size:12px}.summary-card{padding:12px}.summary-value{font-size:26px}.chart-lg,.chart-md,.chart-sm,.gauge,.phasor{min-height:210px}.gauge svg,.phasor svg{width:min(100%,220px)}}@media (max-width:480px){.app-shell{padding:10px}.page{gap:12px}.topbar{padding:10px}.topbar-title{font-size:21px}.conn-pill{justify-content:center;width:100%}.icon-btn{text-align:center;width:100%}.section-title{font-size:17px}.card{padding:12px}.summary-value{font-size:24px}.summary-unit{font-size:12px}.chart-lg,.chart-md,.chart-sm,.gauge,.phasor{min-height:200px}.gauge svg,.phasor svg{width:min(100%,200px)}.info-grid{grid-template-columns:1fr}}.lab-motor-container{background:var(--panel-bg);border:1px solid #334155;border-radius:8px;position:relative;box-shadow:0 10px 30px #00000080}.lab-header{justify-content:space-between;display:flex}.status-pill{background:#1e293b;border-radius:20px;align-items:center;gap:8px;padding:4px 12px;font-size:11px;font-weight:700;display:flex}.status-pill.active{color:#60a5fa;border:1px solid #2563eb}.status-pill.idle{color:#64748b;border:1px solid #334155}.pulse-dot{background:currentColor;border-radius:50%;width:8px;height:8px}.is-active .pulse-dot{animation:1.5s infinite pulse-glow}.pump-visualization{justify-content:center;align-items:center;height:140px;display:flex;position:relative}.motor-gauge-bg{z-index:1;background:repeating-conic-gradient(#0000 0deg 2deg,#94a3b81a 2deg 4deg);border:1px solid #ffffff0d;border-radius:50%;width:140px;height:140px;position:absolute}.pump-casing{background:var(--metal-finish);z-index:5;border:6px solid #475569;border-radius:50%;justify-content:center;align-items:center;width:110px;height:110px;display:flex;position:relative;box-shadow:inset 0 4px 10px #000c}.metal-texture{opacity:.1;background:repeating-linear-gradient(45deg,#fff,#fff 2px,#0000 2px 8px);border-radius:50%;width:100%;height:100%;position:absolute}.is-active .pump-casing{border-color:var(--lab-blue);box-shadow:inset 0 10px 20px #0009,0 0 25px #3b82f633}.impeller-unit.spinning{animation:.6s linear infinite spin}.pipe-network{justify-content:center;align-items:center;width:100%;display:flex;position:absolute}.pipe{background:var(--pipe-gray);border:1px solid #334155;width:40%;height:16px;position:relative}.pipe:before{content:"";background:#475569;width:8px;height:30px;position:absolute;top:-5px}.pipe-in:before{right:0}.pipe-out:before{left:0}.pipe:after{content:"";background:#1e293b;border:2px solid #475569;border-radius:2px;width:6px;height:34px;position:absolute;top:-10px}.pipe-in:after{right:-2px}.pipe-out:after{left:-2px}.water-flow{opacity:.6;background-image:radial-gradient(circle,#60a5fa 20%,#0000 20%);background-size:15px 15px;width:100%;height:100%;animation:.6s linear infinite particle-slide}.lab-footer{background:#0000004d;border-top:1px solid #1e293b;justify-content:center;padding:10px 15px;display:flex}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes particle-slide{0%{background-position:0 0}to{background-position:30px 0}}@keyframes pulse-glow{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.2)}}@keyframes micro-vibration{0%{transform:translate(0)}50%{transform:translate(.3px,.3px)}to{transform:translate(0)}}:root{--lab-blue:#3b82f6;--panel-bg:#0f172a;--pipe-gray:#1e293b;--metal-finish:linear-gradient(145deg,#1e293b,#0f172a)}.lab-motor-container{background:#0f172a;border:1px solid #1e293b;border-radius:12px;padding:0;overflow:hidden}.lab-header{border-bottom:1px solid #1e293b;justify-content:space-between;align-items:center;padding:16px;display:flex}.iso-badge{color:#fff;background:#2563eb;border-radius:3px;width:fit-content;margin-bottom:4px;padding:2px 6px;font-size:9px;font-weight:800}.pump-visualization{background:radial-gradient(circle,#1e293b 0%,#0f172a 100%);justify-content:center;align-items:center;height:200px;display:flex;position:relative}.main-display{z-index:5;align-items:center;width:100%;display:flex}.motor-core{background:#1e293b;border:4px solid #334155;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;display:flex;position:relative;box-shadow:inset 0 4px 10px #00000080}.is-active .motor-core{border-color:#3b82f6;box-shadow:0 0 25px #3b82f633,inset 0 4px 10px #00000080}.icon-wrapper.spinning{animation:.8s linear infinite spin}.core-hub{background:#94a3b8;border:2px solid #0f172a;border-radius:50%;width:12px;height:12px;position:absolute}.pipe-system{background:#1e293b;border:1px solid #334155;flex:1;height:14px;position:relative;overflow:hidden}.water-droplets{background-image:repeating-linear-gradient(90deg,#0000,#0000 20px,#3b82f666 20px 40px);width:100%;height:100%;animation:1s linear infinite flow}.lab-footer{color:#64748b;letter-spacing:1px;background:#0003;justify-content:space-between;padding:12px 16px;font-size:10px;display:flex}.telemetry{align-items:center;gap:6px;display:flex}@keyframes flow{0%{transform:translate(-40px)}to{transform:translate(0)}}.is-active .pump-visualization{animation:.1s linear infinite micro-vibration}.mode-toggle-row{grid-template-columns:1fr 1fr;gap:8px;display:grid}.mode-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:#0d1726;border-radius:10px;min-height:40px;font-family:JetBrains Mono,monospace;font-size:12px}.mode-btn.active{border-color:var(--freq);color:var(--freq);background:#22d3ee14}
