:root{--bg:#fff;--white:#fff;--text:#1a1a1a;--t2:#555;--t3:#999;--t4:#ccc;--lime:#cfe16f;--ld:#3a4a12;--grn:#16a34a;--grn-bg:#16a34a14;--red:#dc2626;--red-bg:#dc262614;--org:#ea580c;--org-bg:#ea580c14;--blu:#2563eb;--blu-bg:#2563eb14;--brd:transparent;--sh:0 0 0 1px #00000005,0 2px 6px #00000008,0 8px 24px #0000000d;--sh2:0 0 0 1px #00000005,0 4px 12px #0000000d,0 20px 48px #00000014;--r:18px;--f:"Sora",sans-serif;--b:"Inter",sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--b);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;height:100vh;overflow:hidden}[class^=iconoir-]{font-size:20px;line-height:1}.app{height:100vh;display:flex}.side{z-index:10;background:linear-gradient(#162a08 0%,#1e3a0c 35%,#193210 65%,#122006 100%);flex-direction:column;flex-shrink:0;align-items:center;width:72px;padding:1.2rem 0;display:flex;position:relative}.s-logo{background:var(--lime);cursor:pointer;border-radius:13px;justify-content:center;align-items:center;width:42px;height:42px;margin-bottom:1.8rem;transition:transform .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 14px #cfe16f66}.s-logo:after{content:"";background:linear-gradient(#ffffff4d,#0000);border-radius:13px 13px 50% 50%;height:45%;position:absolute;top:0;left:0;right:0}.s-logo:hover{transform:scale(1.06)}.s-logo i{color:var(--ld);z-index:1;font-size:20px;position:relative}.s-nav{scrollbar-width:none;-ms-overflow-style:none;flex-direction:column;flex:1;gap:2px;width:100%;display:flex;overflow-y:auto}.s-nav::-webkit-scrollbar{display:none}.sb{cursor:pointer;color:#ffffff59;background:0 0;border:none;justify-content:center;align-items:center;width:100%;height:46px;transition:color .2s;display:flex;position:relative}.sb:hover{color:#ffffffbf}.sb i{z-index:2;font-size:19px;position:relative}.sb.on{background:var(--bg);color:var(--ld);border-radius:18px 0 0 18px;width:calc(100% - 10px);height:48px;margin-left:10px;padding-left:6px}.sb.on:before{content:"";width:20px;height:20px;box-shadow:8px 8px 0 8px var(--bg);pointer-events:none;z-index:1;background:0 0;border-bottom-right-radius:20px;position:absolute;bottom:100%;right:0}.sb.on:after{content:"";width:20px;height:20px;box-shadow:8px -8px 0 8px var(--bg);pointer-events:none;z-index:1;background:0 0;border-top-right-radius:20px;position:absolute;top:100%;right:0}.sb:not(.on):before{content:attr(data-t);background:var(--white);color:var(--text);font-family:var(--b);white-space:nowrap;opacity:0;pointer-events:none;z-index:200;border-radius:9px;padding:.4rem .8rem;font-size:.72rem;font-weight:500;transition:opacity .15s,transform .15s;position:absolute;top:50%;left:calc(100% + 16px);transform:translateY(-50%)scale(.92);box-shadow:0 4px 16px #0000001a}.sb:not(.on):hover:before{opacity:1;transform:translateY(-50%)scale(1)}.s-dot{z-index:3;background:#ef4444;border-radius:50%;width:7px;height:7px;position:absolute;top:11px;right:14px;box-shadow:0 0 8px #ef444480}.s-sep{background:#ffffff1a;width:26px;height:1px;margin:6px auto}.lang-sw{cursor:pointer;color:#ffffff80;width:44px;height:26px;font-family:var(--f);letter-spacing:.04em;background:#ffffff14;border:none;border-radius:8px;justify-content:center;align-items:center;margin-bottom:.5rem;font-size:.6rem;font-weight:700;transition:all .2s;display:flex;position:relative}.lang-sw:hover{color:#fff;background:#ffffff26}.lang-sw:before{content:attr(data-t);background:var(--white);color:var(--text);font-family:var(--b);white-space:nowrap;opacity:0;pointer-events:none;z-index:200;border-radius:9px;padding:.4rem .8rem;font-size:.72rem;font-weight:500;transition:opacity .15s,transform .15s;position:absolute;top:50%;left:calc(100% + 14px);transform:translateY(-50%)scale(.92);box-shadow:0 4px 16px #0000001a}.lang-sw:hover:before{opacity:1;transform:translateY(-50%)scale(1)}.s-avatar{cursor:pointer;border:2px solid #ffffff1f;border-radius:11px;width:36px;height:36px;margin-top:auto;transition:border-color .3s,transform .2s;overflow:hidden}.s-avatar:hover{border-color:var(--lime);transform:scale(1.06)}.s-avatar img{object-fit:cover;width:100%;height:100%}.user-menu{background:var(--white);z-index:1000;border-radius:16px;width:280px;padding:.5rem;display:none;position:absolute;bottom:60px;left:76px;box-shadow:0 12px 48px #00000026}.user-menu.open{display:block}.um-header{align-items:center;gap:.7rem;padding:.8rem;display:flex}.um-name{font-family:var(--f);font-size:.85rem;font-weight:700}.um-email{color:var(--t3);font-size:.68rem}.um-role{color:var(--grn);margin-top:.1rem;font-size:.6rem;font-weight:600}.um-sep{background:#0000000f;height:1px;margin:.25rem .5rem}.um-item{width:100%;color:var(--t1);cursor:pointer;background:0 0;border:none;border-radius:10px;align-items:center;gap:.6rem;padding:.6rem .8rem;font-size:.78rem;transition:background .15s;display:flex}.um-item:hover{background:#0000000a}.um-item i{color:var(--t3);text-align:center;width:20px;font-size:16px}.um-logout,.um-logout i{color:var(--red)}.main{background:var(--bg);flex-direction:column;flex:1;display:flex;overflow:hidden}.top{background:var(--white);align-items:center;gap:1rem;padding:1.1rem 2rem;display:flex}.top-l{align-items:center;gap:.7rem;display:flex}.crumb{color:var(--t3);align-items:center;gap:.3rem;font-size:.82rem;display:flex}.crumb strong{color:var(--text);font-weight:600}.crumb i{font-size:11px}.pill-s{background:var(--grn-bg);color:var(--grn);border-radius:100px;align-items:center;gap:.3rem;padding:.25rem .7rem;font-size:.7rem;font-weight:600;display:flex}.pill-s:before{content:"";background:var(--grn);border-radius:50%;width:6px;height:6px}.top-r{align-items:center;gap:.5rem;margin-left:auto;display:flex}.srch{background:var(--bg);border:1px solid var(--brd);color:var(--text);font-size:.78rem;font-family:var(--b);border-radius:10px;outline:none;width:200px;padding:.45rem .9rem;transition:border-color .2s}.srch::placeholder{color:var(--t4)}.srch:focus{border-color:var(--lime)}.tb{border:1px solid var(--brd);background:var(--white);cursor:pointer;color:var(--t2);font-size:.76rem;font-weight:500;font-family:var(--b);border-radius:10px;align-items:center;gap:.3rem;padding:.45rem .9rem;transition:all .15s;display:flex}.tb i{font-size:14px}.tb:hover{background:var(--bg);border-color:#ccc}.tb.ac{background:var(--text);color:#fff;border-color:var(--text)}.tb.ac:hover{opacity:.88}.tabs{background:var(--white);gap:2px;padding:0 2rem;display:flex}.ta{color:var(--t3);cursor:pointer;border-bottom:2px solid #0000;align-items:center;gap:.35rem;padding:.65rem .9rem;font-size:.78rem;font-weight:500;transition:all .15s;display:flex}.ta i{font-size:14px}.ta:hover{color:var(--t2)}.ta.on{color:var(--text);border-bottom-color:var(--lime);font-weight:600}.content{flex:1;padding:1.4rem 2rem 6rem;overflow-y:auto}.c{background:var(--white);border-radius:var(--r);box-shadow:var(--sh);border:none;transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s;position:relative;overflow:hidden}.c:hover{box-shadow:var(--sh2);transform:translateY(-4px)}.metrics{grid-template-columns:repeat(4,1fr);gap:.85rem;margin-bottom:1.4rem;display:grid}.m{cursor:default;padding:1.3rem;overflow:hidden}.m .blob{filter:blur(40px);opacity:.18;pointer-events:none;border-radius:50%;width:130px;height:130px;transition:opacity .4s,transform .4s;position:absolute;top:-30px;right:-30px}.m:hover .blob{opacity:.3;transform:scale(1.15)}.m:first-child .blob{background:var(--grn)}.m:nth-child(2) .blob{background:var(--blu)}.m:nth-child(3) .blob{background:var(--lime)}.m:nth-child(4) .blob{background:var(--org)}.m-top{z-index:1;justify-content:space-between;align-items:center;margin-bottom:.7rem;display:flex;position:relative}.m-lab{color:var(--t3);font-size:.72rem;font-weight:500}.m-ic{z-index:1;transition:transform .35s cubic-bezier(.16,1,.3,1);position:relative}.m-ic i{font-size:22px}.m-ic.grn{color:var(--grn)}.m-ic.blu{color:var(--blu)}.m-ic.lim{color:var(--ld)}.m-ic.org{color:var(--org)}.m:hover .m-ic{transform:rotate(-8deg)scale(1.1)}.m-val{font-family:var(--f);letter-spacing:-.03em;z-index:1;font-size:1.65rem;font-weight:700;line-height:1;position:relative}.m-sub{z-index:1;align-items:center;gap:.25rem;margin-top:.4rem;font-size:.7rem;display:flex;position:relative}.m-sub.up{color:var(--grn)}.m-sub.dn{color:var(--red)}.m-sub.mu{color:var(--t3)}.m-sub i{font-size:12px}.row2{grid-template-columns:1.6fr 1fr;gap:.85rem;margin-bottom:1.4rem;display:grid}.c-hdr{z-index:1;justify-content:space-between;align-items:center;padding:1.2rem 1.3rem .8rem;display:flex;position:relative}.c-hdr h3{font-family:var(--f);font-size:.92rem;font-weight:700}.pls{background:#0000000a;border-radius:8px;gap:2px;padding:2px;display:flex}.pl{cursor:pointer;color:var(--t3);border-radius:6px;padding:.28rem .65rem;font-size:.65rem;font-weight:500;transition:all .15s}.pl.on{background:var(--white);color:var(--text);font-weight:600;box-shadow:0 1px 3px #0000000f}.pl:hover:not(.on){color:var(--t2)}.chart-box{z-index:1;padding:.8rem 1.3rem 1.3rem;position:relative}.chart-wrap{height:180px;margin-left:32px;position:relative}.ch-y{flex-direction:column;justify-content:space-between;display:flex;position:absolute;top:0;bottom:24px;left:-32px}.ch-y span{color:var(--t3);font-size:.63rem;font-family:var(--b);line-height:1}.ch-x{justify-content:space-between;padding:0 4px;display:flex;position:absolute;bottom:0;left:0;right:0}.ch-x span{color:var(--t3);font-size:.63rem;font-family:var(--b)}.ch-svg{position:absolute;inset:0 0 24px}.ch-svg svg{width:100%;height:100%;overflow:visible}.ch-grid{stroke:#0000000a;stroke-width:1px}.ch-avg{stroke:var(--t4);stroke-width:1px;stroke-dasharray:6 4}.ch-avg-label{color:var(--t3);font-size:.6rem;font-family:var(--b);position:absolute;right:0}.ch-line{fill:none;stroke:var(--lime);stroke-width:2.5px;stroke-linecap:round;stroke-linejoin:round}.ch-fill{fill:url(#limeGrad);opacity:.25}.ch-dot{fill:#fff;stroke:var(--lime);stroke-width:2.5px;cursor:pointer;transition:r .2s}.ch-dot:hover{r:6}.ch-tip{background:var(--text);color:#fff;pointer-events:none;white-space:nowrap;font-size:.68rem;font-weight:600;font-family:var(--b);opacity:0;border-radius:7px;padding:.3rem .6rem;transition:opacity .15s;position:absolute;transform:translate(-50%,-120%)}.ch-dot:hover+.ch-tip{opacity:1}.feed{padding:1.2rem 1.3rem}.fr{border-bottom:1px solid #0000000a;align-items:center;gap:.65rem;padding:.65rem 0;display:flex}.fr:last-child{border:none}.f-ic{text-align:center;flex-shrink:0;width:28px;font-size:17px}.f-ic.grn{color:var(--grn)}.f-ic.org{color:var(--org)}.f-ic.blu{color:var(--blu)}.f-ic.lim{color:var(--ld)}.fm{color:var(--t2);flex:1;font-size:.78rem;line-height:1.5}.fm strong{color:var(--text);font-weight:600}.ft{color:var(--t4);white-space:nowrap;font-size:.63rem}.dh{justify-content:space-between;align-items:center;margin-bottom:.85rem;display:flex}.dh h3{font-family:var(--f);font-size:.92rem;font-weight:700}.devs{grid-template-columns:repeat(3,1fr);gap:.85rem;display:grid}.d{cursor:pointer;padding:1.3rem;overflow:hidden}.d .blob{filter:blur(35px);opacity:.12;pointer-events:none;border-radius:50%;width:100px;height:100px;transition:opacity .4s;position:absolute;top:-20px;left:-20px}.d:hover .blob{opacity:.22}.d:first-child .blob{background:var(--grn)}.d:nth-child(2) .blob{background:var(--lime)}.d:nth-child(3) .blob{background:var(--org)}.d:nth-child(4) .blob{background:var(--grn)}.d:nth-child(5) .blob{background:var(--blu)}.d:nth-child(6) .blob{background:var(--grn)}.d .ln{background:linear-gradient(90deg,var(--lime),#cfe16f1a);transform-origin:0;height:3px;transition:transform .45s cubic-bezier(.16,1,.3,1);position:absolute;bottom:0;left:0;right:0;transform:scaleX(0)}.d:hover .ln{transform:scaleX(1)}.d-top{z-index:1;justify-content:space-between;align-items:center;margin-bottom:.55rem;display:flex;position:relative}.d-ic{transition:transform .35s cubic-bezier(.16,1,.3,1)}.d-ic i{font-size:22px}.d-ic.grn{color:var(--grn)}.d-ic.lim{color:var(--ld)}.d-ic.blu{color:var(--blu)}.d-ic.org{color:var(--org)}.d:hover .d-ic{transform:rotate(-8deg)scale(1.1)}.d-tg{border-radius:100px;align-items:center;gap:.2rem;padding:.18rem .5rem;font-size:.62rem;font-weight:600;display:flex}.d-tg:before{content:"";background:currentColor;border-radius:50%;width:5px;height:5px}.d-tg.ok{background:var(--grn-bg);color:var(--grn)}.d-tg.w{background:var(--org-bg);color:var(--org)}.d-nm{z-index:1;font-size:.85rem;font-weight:600;position:relative}.d-wh{color:var(--t3);z-index:1;margin:.12rem 0 .55rem;font-size:.7rem;line-height:1.4;position:relative}.d-vl{z-index:1;align-items:baseline;gap:.3rem;display:flex;position:relative}.d-n{font-family:var(--f);letter-spacing:-.02em;font-size:1.15rem;font-weight:700}.d-actions{z-index:1;flex-wrap:wrap;gap:.4rem;margin-top:.85rem;display:flex;position:relative}.d-act{border:1px solid var(--brd);background:var(--white);cursor:pointer;color:var(--t2);font-size:.65rem;font-weight:500;font-family:var(--b);white-space:nowrap;border-radius:8px;align-items:center;gap:.25rem;padding:.32rem .6rem;transition:all .2s;display:flex}.d-act i{font-size:12px}.d-act:hover{background:var(--bg);color:var(--text);border-color:#ccc}.d-act.primary{background:var(--text);color:#fff;border-color:var(--text)}.d-act.primary:hover{opacity:.85}.d-act.toggle{padding-left:2rem;position:relative}.d-act.toggle:before{content:"";background:var(--grn);border-radius:100px;width:22px;height:13px;transition:background .2s;position:absolute;top:50%;left:6px;transform:translateY(-50%)}.d-act.toggle:after{content:"";background:#fff;border-radius:50%;width:9px;height:9px;transition:left .2s;position:absolute;top:50%;left:17px;transform:translateY(-50%);box-shadow:0 1px 2px #00000026}.d-act.toggle.off:before{background:var(--t4)}.d-act.toggle.off:after{left:8px}.ac-toggle{cursor:pointer;background:#0000001f;border-radius:100px;width:40px;height:22px;padding:2px;transition:background .25s;position:relative}.ac-toggle.on{background:var(--grn)}.ac-knob{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .25s cubic-bezier(.16,1,.3,1);box-shadow:0 1px 4px #00000026}.ac-toggle.on .ac-knob{transform:translate(18px)}.rule{border-bottom:1px solid #0000000a;align-items:center;gap:.85rem;padding:1rem 1.35rem;transition:background .15s;display:flex}.rule:last-child{border:none}.rule:hover{background:#00000004}.rule-ic{flex-shrink:0;font-size:20px}.rule-ic.grn{color:var(--grn)}.rule-ic.blu{color:var(--blu)}.rule-ic.org{color:var(--org)}.rule-ic.lim{color:var(--ld)}.rule-body{flex:1}.rule-name{margin-bottom:.15rem;font-size:.82rem;font-weight:600}.rule-desc{color:var(--t3);font-size:.7rem;line-height:1.4}.rule-saves{color:var(--grn);white-space:nowrap;font-size:.63rem;font-weight:600}.dev-conn{cursor:pointer;z-index:5;align-items:center;display:inline-flex;position:relative}.dev-conn i{color:var(--grn);font-size:14px;transition:color .2s}.dev-conn.warn i{color:var(--org)}.dev-conn.off i{color:var(--t4)}.sig{align-items:flex-end;gap:1px;height:12px;margin-left:3px;display:flex}.sig span{background:var(--grn);border-radius:1px;width:3px}.sig span:first-child{height:3px}.sig span:nth-child(2){height:6px}.sig span:nth-child(3){height:9px}.sig span:nth-child(4){height:12px}.dev-conn.warn .sig span{background:var(--org)}.dev-conn.weak .sig span:nth-child(3),.dev-conn.weak .sig span:nth-child(4){background:var(--t4)}.conn-tip{background:var(--text);color:#fff;opacity:0;pointer-events:none;z-index:200;border-radius:12px;min-width:220px;padding:.85rem 1rem;transition:all .2s;position:absolute;top:calc(100% + 10px);right:0;transform:translateY(-4px);box-shadow:0 8px 30px #0003}.conn-tip:before{content:"";background:var(--text);border-radius:2px;width:10px;height:10px;position:absolute;top:-5px;right:16px;transform:rotate(45deg)}.dev-conn:hover .conn-tip{opacity:1;pointer-events:auto;transform:translateY(0)}.conn-row{border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:.3rem 0;display:flex}.conn-row:last-child{border:none}.conn-label{color:#ffffff80;text-transform:uppercase;letter-spacing:.05em;font-size:.62rem}.conn-val{font-size:.72rem;font-weight:600;font-family:var(--f)}.conn-val.ok{color:var(--lime)}.conn-val.warn{color:var(--org)}.conn-val.err{color:#f87171}.sensor-icon{width:40px;height:40px;color:var(--grn);justify-content:center;align-items:center;transition:transform .3s;display:flex}.app-card:hover .sensor-icon{transform:scale(1.12)rotate(-5deg)}.lock-visual{text-align:center;cursor:pointer;flex-shrink:0}.lock-ring{border:3px solid var(--grn);background:#16a34a0a;border-radius:50%;justify-content:center;align-items:center;width:90px;height:90px;margin:0 auto .5rem;transition:all .5s cubic-bezier(.16,1,.3,1);display:flex;position:relative}.lock-ring:after{content:"";border:2px solid #16a34a26;border-radius:50%;animation:2.5s ease-out infinite pulse-ring;position:absolute;inset:-6px}.lock-icon{color:var(--grn);font-size:32px;transition:all .4s}.lock-label{font-family:var(--f);letter-spacing:.12em;color:var(--grn);font-size:.65rem;font-weight:700;transition:color .3s}.lock-visual.unlocked .lock-ring{border-color:var(--org);background:#ea580c0a}.lock-visual.unlocked .lock-ring:after{border-color:#ea580c26}.lock-visual.unlocked .lock-icon{color:var(--org);transform:rotate(-15deg)}.lock-visual.unlocked .lock-label{color:var(--org)}.pin-list{flex-direction:column;display:flex}.pin-row{border-bottom:1px solid #0000000a;justify-content:space-between;align-items:center;padding:.75rem 0;display:flex}.pin-row:last-child{border:none}.pin-info{align-items:center;gap:.7rem;display:flex}.pin-code{letter-spacing:.15em;text-align:center;background:#0000000a;border-radius:8px;min-width:60px;padding:.3rem .6rem;font-family:Courier New,monospace;font-size:1.1rem;font-weight:700}.pin-name{font-size:.82rem;font-weight:600}.pin-detail{color:var(--t3);margin-top:.1rem;font-size:.65rem}.pin-status{border-radius:100px;padding:.2rem .5rem;font-size:.6rem;font-weight:600}.pin-status.active{background:var(--grn-bg);color:var(--grn)}.pin-status.scheduled{background:var(--blu-bg);color:var(--blu)}.pin-status.master{color:var(--t2);background:#0000000d}.pin-status.expired{color:var(--t4);background:#0000000a}.log-row{border-bottom:1px solid #0000000a;align-items:center;gap:.75rem;padding:.75rem 1.3rem;transition:background .15s;display:flex}.log-row:last-child{border:none}.log-row:hover{background:#00000004}.log-time{font-family:var(--f);color:var(--t2);min-width:42px;font-size:.78rem;font-weight:600}.log-icon{flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.log-icon.in{color:var(--grn)}.log-icon.out{color:var(--t3)}.log-icon.svc{color:var(--blu)}.log-icon.remote{color:var(--ld)}.log-body{flex:1}.log-action{color:var(--t2);font-size:.78rem}.log-action strong{color:var(--text);font-weight:600}.log-by{color:var(--t3);margin-top:.1rem;font-size:.65rem}.log-method{color:var(--t3);background:#00000008;border-radius:6px;padding:.2rem .5rem;font-size:.6rem;font-weight:600}.live-section{margin-bottom:1.5rem}.live-hdr{font-family:var(--f);align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.85rem;font-weight:700;display:flex}.live-pulse{background:var(--grn);border-radius:50%;width:8px;height:8px;position:relative}.live-pulse:after{content:"";border:2px solid var(--grn);opacity:0;border-radius:50%;animation:2s ease-out infinite pulse-ring;position:absolute;inset:-4px}@keyframes pulse-ring{0%{opacity:.8;transform:scale(.8)}to{opacity:0;transform:scale(1.8)}}.live-cards{flex-direction:column;gap:.5rem;display:flex}.live-card{border-radius:12px;align-items:flex-start;gap:.7rem;padding:.85rem 1rem;transition:all .2s;display:flex}.live-card:hover{transform:translate(4px)}.live-card.ok{background:var(--grn-bg);color:var(--grn)}.live-card.warn{background:var(--org-bg);color:var(--org)}.live-card.info{background:var(--blu-bg);color:var(--blu)}.live-card.err{background:var(--red-bg);color:var(--red)}.live-msg{color:var(--t2);flex:1;font-size:.78rem;line-height:1.5}.live-msg strong{color:var(--text);font-weight:600}.live-time{color:var(--t4);white-space:nowrap;flex-shrink:0;margin-top:.1rem;font-size:.62rem}.din-panel{margin-bottom:1.2rem}.din-section{margin-bottom:1rem}.din-section:last-child{margin-bottom:0}.din-label{color:var(--t3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.6rem;font-size:.68rem;font-weight:600}.din-row{flex-wrap:wrap;gap:.5rem;display:flex}.breaker{cursor:pointer;background:#00000005;border:1px solid #0000000a;border-radius:12px;flex:0 0 calc(12.5% - .44rem);padding:.75rem .6rem;transition:all .25s;position:relative}.breaker:hover{background:#0000000a;transform:translateY(-2px);box-shadow:0 4px 16px #0000000f}.breaker.diff{background:#2563eb0a;border-color:#2563eb14;flex:0 0 calc(25% - .38rem)}.breaker.hot{background:#ea580c08;border-color:#ea580c26}.brk-body{align-items:center;gap:.5rem;margin-bottom:.45rem;display:flex}.brk-handle{background:#0000000f;border-radius:5px;flex-shrink:0;width:18px;height:28px;transition:background .25s;position:relative}.brk-lever{background:var(--grn);border-radius:3px;height:12px;transition:all .25s;position:absolute;top:2px;left:3px;right:3px;box-shadow:0 2px 4px #0000001a}.breaker.off .brk-lever{background:var(--t4);box-shadow:none;top:auto;bottom:2px}.brk-info{flex:1;min-width:0}.brk-type{font-family:var(--f);color:var(--t3);font-size:.6rem;font-weight:700}.brk-name{white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;font-weight:600;overflow:hidden}.brk-spec{color:var(--t3);font-size:.58rem}.brk-power{font-family:var(--f);margin-bottom:.25rem;font-size:.78rem;font-weight:700}.brk-status{color:var(--grn);align-items:center;gap:.3rem;font-size:.6rem;font-weight:600;display:flex}.brk-dot{background:var(--grn);border-radius:50%;width:6px;height:6px;box-shadow:0 0 6px #16a34a66}.breaker.off .brk-status{color:var(--t4)}.breaker.off .brk-dot{background:var(--t4);box-shadow:none}.brk-tag{color:var(--t3);letter-spacing:.03em;background:#0000000d;border-radius:4px;padding:.15rem .35rem;font-size:.48rem;font-weight:700;position:absolute;top:6px;right:6px}.panel-total{background:#00000005;border-radius:12px;align-items:center;gap:1rem;margin-top:.5rem;padding:1rem;display:flex}.panel-total-left{flex-direction:column;flex-shrink:0;gap:.1rem;min-width:80px;display:flex}.panel-total-bar{background:#0000000d;border-radius:100px;flex:1;height:8px;overflow:hidden}.panel-total-fill{background:linear-gradient(90deg,var(--lime),var(--grn));border-radius:100px;height:100%;transition:width .5s}.app-card{text-align:center;cursor:default;padding:1rem;transition:all .3s cubic-bezier(.16,1,.3,1)}.app-card:hover{transform:translateY(-4px)}.app-card.app-off{opacity:.45}.app-card.app-off:hover{opacity:.7}.app-top{z-index:1;justify-content:space-between;align-items:center;margin-bottom:.2rem;display:flex;position:relative}.app-room{color:var(--t3);text-transform:uppercase;letter-spacing:.06em;font-size:.58rem;font-weight:500}.app-toggle-mini{background:#0000001a;border-radius:100px;width:28px;height:16px;padding:2px;transition:background .2s;position:relative}.app-toggle-mini.on{background:var(--grn)}.app-toggle-dot{background:#fff;border-radius:50%;width:12px;height:12px;transition:transform .2s;box-shadow:0 1px 3px #00000026}.app-toggle-mini.on .app-toggle-dot{transform:translate(12px)}.app-name{z-index:1;margin-bottom:.15rem;font-size:.78rem;font-weight:600;position:relative}.app-watts{font-family:var(--f);z-index:1;font-size:.85rem;font-weight:700;position:relative}.app-cost{color:var(--t3);z-index:1;margin-top:.1rem;font-size:.6rem;position:relative}.app-badge{z-index:1;border-radius:100px;margin-top:.5rem;padding:.2rem .5rem;font-size:.55rem;font-weight:600;display:inline-block;position:relative}.app-badge.always{background:var(--grn-bg);color:var(--grn)}.brand-badge{font-family:var(--f);letter-spacing:.06em;border-radius:7px;padding:.3rem .55rem;font-size:.55rem;font-weight:800;line-height:1}.brand-badge.sonoff,.brand-badge.ss{color:var(--t2);background:#0000000d}.brand-badge.daikin{color:#00785a;background:#00785a14}.brand-badge.mitsu{color:#cc1e1e;background:#dc1e1e0f}.batt-bar{z-index:1;align-items:center;gap:.4rem;margin-top:.7rem;display:flex;position:relative}.batt-bar:before{content:"";background:#0000000d;border-radius:100px;flex:1;height:4px}.batt-fill{border-radius:100px;height:4px;transition:width .3s;position:absolute;top:50%;left:0;transform:translateY(-50%)}.batt-pct{color:var(--t3);flex-shrink:0;font-size:.6rem;font-weight:500}.prop-card{cursor:pointer;padding:1.3rem;transition:all .3s}.prop-card:hover{box-shadow:var(--sh2);transform:translateY(-4px)}.pkg-badge{font-family:var(--f);letter-spacing:.04em;border-radius:6px;padding:.2rem .5rem;font-size:.55rem;font-weight:700}.inst-step{flex-direction:column;flex:1;align-items:center;display:flex;position:relative}.inst-dot{z-index:1;background:#00000014;border:2px solid #0000001a;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.inst-line{background:#00000014;height:2px;position:absolute;top:10px;left:calc(50% + 10px);right:calc(10px - 50%)}.inst-step:last-child .inst-line{display:none}.inst-label{color:var(--t3);margin-top:.4rem;font-size:.65rem;font-weight:600}.inst-date{color:var(--t4);font-size:.58rem}.inst-step.done .inst-dot{background:var(--grn);border-color:var(--grn)}.inst-step.done .inst-dot:after{content:"";background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") 50%/contain no-repeat;width:8px;height:8px}.inst-step.done .inst-line{background:var(--grn)}.inst-step.done .inst-label{color:var(--grn)}.inst-step.active .inst-dot{background:var(--org);border-color:var(--org);animation:2s infinite pulse}.inst-step.active .inst-label{color:var(--org);font-weight:700}.pend-dev{background:#00000005;border-radius:10px;align-items:center;gap:.75rem;padding:.6rem .8rem;display:flex}.pend-dev i{color:var(--t4);text-align:center;width:20px;font-size:16px}.pend-dev .pend-name{color:var(--t3);flex:1;font-size:.78rem}.pend-dev .pend-status{color:var(--t4);font-size:.6rem;font-style:italic}.pkg-badge.ess{color:var(--t2);background:#0000000d}.pkg-badge.std{color:var(--ld);background:#cfe16f26}.pkg-badge.prm{color:var(--lime);background:linear-gradient(135deg,#162a08,#1e3a0c)}.prop-stat{text-align:center;font-family:var(--f);background:#00000005;border-radius:6px;flex:1;padding:.4rem;font-size:.72rem;font-weight:700}.prop-actions{border-top:1px solid #0000000a;gap:.35rem;margin-top:.75rem;padding-top:.75rem;display:flex}.prop-menu-wrap{flex-shrink:0;margin-left:.3rem;position:relative}.prop-menu-btn{background:var(--white);cursor:pointer;width:30px;height:30px;color:var(--text);border:1px solid #00000014;border-radius:9px;justify-content:center;align-items:center;transition:all .15s;display:flex;box-shadow:0 1px 4px #0000000f}.prop-menu-btn:hover{background:var(--bg);border-color:#00000026;box-shadow:0 2px 8px #0000001a}.prop-menu-btn i{font-size:18px}.prop-dropdown{background:var(--white);opacity:0;pointer-events:none;z-index:10;border-radius:12px;min-width:170px;padding:.35rem;transition:all .2s;position:absolute;top:calc(100% + 6px);right:0;transform:translateY(-4px)scale(.95);box-shadow:0 8px 30px #0000001f}.prop-dropdown.open{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.prop-dd-item{color:var(--t2);cursor:pointer;width:100%;font-size:.72rem;font-weight:500;font-family:var(--b);background:0 0;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem .7rem;transition:background .15s;display:flex}.prop-dd-item:hover{background:#00000008}.prop-dd-item i{font-size:15px}.prop-dd-item.danger{color:var(--red)}.prop-dd-item.danger:hover{background:var(--red-bg)}.prop-dd-item.warn{color:var(--org)}.prop-dd-item.warn:hover{background:var(--org-bg)}.prop-dd-sep{background:#0000000d;height:1px;margin:.25rem .5rem}.confirm-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1100;opacity:0;pointer-events:none;background:#00000059;justify-content:center;align-items:center;transition:opacity .25s;display:flex;position:fixed;inset:0}.confirm-overlay.open{opacity:1;pointer-events:auto}.confirm-box{background:var(--white);border-radius:18px;width:420px;max-width:90vw;padding:1.6rem;transition:transform .3s cubic-bezier(.16,1,.3,1);transform:translateY(12px)scale(.97);box-shadow:0 24px 80px #0000002e}.confirm-overlay.open .confirm-box{transform:translateY(0)scale(1)}.confirm-icon{border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:1rem;display:flex}.confirm-icon.red{background:var(--red-bg);color:var(--red)}.confirm-icon.orange{background:var(--org-bg);color:var(--org)}.confirm-icon.green{background:var(--grn-bg);color:var(--grn)}.confirm-icon i{font-size:22px}.confirm-title{font-family:var(--f);margin-bottom:.4rem;font-size:1rem;font-weight:700}.confirm-desc{color:var(--t2);margin-bottom:1.3rem;font-size:.78rem;line-height:1.5}.confirm-actions{justify-content:flex-end;gap:.5rem;display:flex}.prop-img{background:#00000008;border:1px dashed #00000014;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;display:flex;overflow:hidden}.prop-img img{object-fit:cover;width:100%;height:100%}.ai-mode-badge{cursor:pointer;color:var(--t3);font-size:.6rem;font-weight:700;font-family:var(--f);letter-spacing:.03em;background:#0000000a;border-radius:6px;align-items:center;gap:.25rem;padding:.2rem .5rem;transition:all .2s;display:flex}.ai-mode-badge.on{color:var(--lime);background:linear-gradient(135deg,#162a08,#1e3a0c);box-shadow:0 2px 8px #cfe16f33}.ai-mode-badge:hover{transform:scale(1.05)}.auto-rule{color:var(--t2);background:#0000000a;border-radius:6px;align-items:center;gap:.25rem;padding:.25rem .55rem;font-size:.62rem;font-weight:500;display:inline-flex}.auto-rule.good{background:var(--grn-bg);color:var(--grn)}.auto-rule.warn{background:var(--org-bg);color:var(--org)}.ai-finding{color:var(--t2);border-radius:8px;align-items:flex-start;gap:.55rem;margin-bottom:.4rem;padding:.65rem .75rem;font-size:.72rem;line-height:1.55;display:flex}.ai-finding strong{color:var(--text)}.ai-finding.ok{color:var(--t2);background:#16a34a0a}.ai-finding.ok i{color:var(--grn)}.ai-finding.warn{color:var(--t2);background:#ea580c0a}.ai-finding.warn i{color:var(--org)}.ai-finding.info{color:var(--t2);background:#2563eb0a}.ai-finding.info i{color:var(--blu)}.ai-rec{color:var(--t2);border-bottom:1px solid #0000000a;padding:.5rem 0;font-size:.72rem;line-height:1.55}.ai-rec:last-child{border:none}.ai-rec strong{color:var(--text)}.bhv-row{align-items:center;gap:.6rem;margin-bottom:.55rem;display:flex}.bhv-label{color:var(--t2);min-width:130px;font-size:.72rem}.bhv-bar-wrap{background:#0000000a;border-radius:100px;flex:1;height:6px;overflow:hidden}.bhv-bar{border-radius:100px;height:100%;transition:width .6s}.bhv-score{font-family:var(--f);text-align:right;min-width:28px;font-size:.78rem;font-weight:700}.pattern-row{color:var(--t2);align-items:flex-start;gap:.5rem;padding:.35rem 0;font-size:.72rem;line-height:1.5;display:flex}.pattern-row strong{color:var(--text)}.floor-plan{position:relative}.fp-svg{width:100%;max-height:320px;display:block}.fp-label{font-family:var(--f);fill:var(--text);font-size:11px;font-weight:700}.fp-sublabel{font-family:var(--b);fill:var(--t3);font-size:8px}.presence-pulse{animation:2s ease-out infinite pp}@keyframes pp{0%{r:24;opacity:.12}50%{r:32;opacity:.04}to{r:24;opacity:.12}}.fp-legend{justify-content:center;gap:1rem;margin-top:.75rem;display:flex}.fp-leg-item{color:var(--t3);align-items:center;gap:.3rem;font-size:.6rem;display:flex}.fp-leg-dot{border-radius:50%;width:8px;height:8px}.mold-row{align-items:center;gap:.6rem;padding:.35rem 0;display:flex}.mold-row.warn{background:#ea580c08;border-radius:8px;margin:0 -1.3rem;padding:.5rem 1.3rem}.mold-room{min-width:80px;font-size:.78rem;font-weight:600}.mold-bar-wrap{background:#0000000a;border-radius:100px;flex:1;height:6px;overflow:hidden}.mold-bar{background:var(--blu);border-radius:100px;height:100%;transition:width .5s}.mold-bar.med{background:var(--org)}.mold-bar.high{background:var(--red)}.mold-pct{font-family:var(--f);text-align:right;min-width:32px;font-size:.72rem;font-weight:700}.mold-pct.low{color:var(--blu)}.mold-pct.med{color:var(--org)}.mold-pct.high{color:var(--red)}.mold-label{text-align:center;border-radius:100px;min-width:48px;padding:.15rem .4rem;font-size:.6rem;font-weight:600}.mold-label.low{background:var(--blu-bg);color:var(--blu)}.mold-label.med{background:var(--org-bg);color:var(--org)}.mold-label.high{background:var(--red-bg);color:var(--red)}.tab-pane{display:block}.tab-pane:not(.active){display:none}.d-u{color:var(--t3);font-size:.68rem}.ctx{background:var(--text);z-index:50;border-radius:14px;align-items:center;gap:.35rem;padding:.45rem .5rem;display:flex;position:fixed;bottom:1.5rem;left:50%;transform:translate(calc(36px - 50%));box-shadow:0 8px 32px #0000002e}.cb{color:#ffffff8c;cursor:pointer;font-size:.76rem;font-weight:500;font-family:var(--b);white-space:nowrap;background:0 0;border:none;border-radius:9px;align-items:center;gap:.3rem;padding:.48rem .85rem;transition:all .15s;display:flex}.cb i{font-size:14px}.cb:hover{color:#fff;background:#ffffff1a}.cb.ac{background:var(--lime);color:var(--ld);font-weight:600}.cb.ac:hover{box-shadow:0 4px 14px #cfe16f59}.cs{background:#ffffff1a;flex-shrink:0;width:1px;height:20px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.live-dot{color:#fff;text-transform:uppercase;letter-spacing:.06em;background:var(--red);opacity:0;vertical-align:middle;border-radius:4px;align-items:center;gap:.25rem;margin-left:.3rem;padding:.15rem .45rem;font-size:.55rem;font-weight:700;transition:opacity .3s;display:inline-flex}.live-dot.on{opacity:1}.live-dot:before{content:"";background:#fff;border-radius:50%;width:5px;height:5px;animation:1.5s infinite pulse}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;opacity:0;pointer-events:none;background:#00000059;justify-content:center;align-items:center;transition:opacity .25s;display:flex;position:fixed;inset:0}.modal-overlay.open{opacity:1;pointer-events:auto}.modal{background:var(--white);border-radius:22px;flex-direction:column;width:560px;max-width:92vw;max-height:88vh;transition:transform .3s cubic-bezier(.16,1,.3,1);display:flex;overflow:visible;transform:translateY(16px)scale(.97);box-shadow:0 24px 80px #0000002e}.modal .modal-body{overflow-y:auto}.modal-overlay.open .modal{transform:translateY(0)scale(1)}.modal-head{border-bottom:1px solid #0000000d;justify-content:space-between;align-items:center;padding:1.3rem 1.6rem .8rem;display:flex}.modal-title{font-family:var(--f);font-size:1.05rem;font-weight:700}.modal-close{cursor:pointer;width:34px;height:34px;color:var(--t3);background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;transition:all .15s;display:flex}.modal-close:hover{background:var(--bg);color:var(--text)}.modal-close i{font-size:18px}.modal-body{flex:1;padding:1.4rem 1.6rem;overflow-y:auto}.modal-footer{border-top:1px solid #0000000d;justify-content:flex-end;gap:.5rem;padding:.8rem 1.6rem 1.3rem;display:flex}.f-group{margin-bottom:1rem}.f-label{color:var(--t2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.35rem;font-size:.72rem;font-weight:600;display:block}.f-input{width:100%;font-size:.82rem;font-family:var(--b);color:var(--text);background:var(--bg);border:1px solid #00000014;border-radius:10px;outline:none;padding:.55rem .8rem;transition:border-color .2s}.f-input:focus{border-color:var(--lime);box-shadow:0 0 0 3px #cfe16f26}.f-input::placeholder{color:var(--t4)}textarea.f-input{resize:vertical;min-height:70px}select.f-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right .8rem center;background-repeat:no-repeat}.f-row{grid-template-columns:1fr 1fr;gap:.8rem;display:grid}.f-img-preview{background:var(--bg);cursor:pointer;border:2px dashed #00000014;border-radius:12px;justify-content:center;align-items:center;width:100%;height:120px;transition:border-color .2s;display:flex;position:relative;overflow:hidden}.f-img-preview:hover{border-color:var(--lime)}.f-img-preview img{object-fit:cover;width:100%;height:100%}.f-img-preview .placeholder{color:var(--t3);flex-direction:column;align-items:center;gap:.3rem;font-size:.72rem;display:flex}.f-img-preview .placeholder i{font-size:24px}.btn-save{cursor:pointer;font-size:.78rem;font-weight:600;font-family:var(--b);border:none;border-radius:10px;padding:.5rem 1.3rem;transition:all .15s}.btn-save.primary{background:var(--text);color:#fff}.btn-save.primary:hover{opacity:.85}.btn-save.secondary{background:var(--bg);color:var(--t2);border:1px solid #00000014}.btn-save.secondary:hover{background:#eee}.btn-save:disabled{opacity:.5;cursor:not-allowed}.save-status{color:var(--grn);opacity:0;align-items:center;gap:.3rem;margin-right:auto;font-size:.72rem;transition:opacity .3s;display:flex}.save-status.show{opacity:1}@media (max-width:1024px){.side{width:56px;padding:.8rem 0}.s-logo{width:36px;height:36px;margin-bottom:1rem}.sb{width:40px;height:40px}.lang-sw{width:28px;height:28px;font-size:.6rem}.s-avatar{width:32px;height:32px}.main{margin-left:0}.metrics{grid-template-columns:repeat(2,1fr)}.tabs{flex-wrap:nowrap;overflow-x:auto}.ta{white-space:nowrap;padding:.6rem .8rem;font-size:.72rem}}@media (max-width:768px){.app{flex-direction:column}.side{flex-direction:row;width:100%;height:56px;padding:0 .5rem;overflow-x:auto}.s-nav{flex-direction:row;flex:1;gap:0;overflow-x:auto}.s-sep{width:1px;height:24px;margin:0 2px}.sb{flex-shrink:0;width:44px;height:44px}.s-logo{margin-bottom:0;margin-right:.5rem}.lang-sw{margin-top:0;margin-left:auto}.s-avatar{margin-top:0;margin-left:.3rem}.main{height:calc(100vh - 56px)}.top{padding:.8rem 1rem}.top-l{font-size:.85rem}.top-r{gap:.3rem}.tb{padding:.35rem .6rem;font-size:.68rem}.metrics{grid-template-columns:1fr 1fr;gap:.5rem}.c.m{padding:.8rem}.m-val{font-size:1.1rem}.content{padding:1rem!important}.modal{max-height:90vh;width:95vw!important}.confirm-box{width:90vw;padding:1.5rem}.tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.ta{white-space:nowrap;padding:.5rem .6rem;font-size:.68rem}.f-row{flex-direction:column}.srch{min-width:100%!important}}
