*,*:before,*:after{box-sizing:border-box}:root{--bg:#05070d;--bg2:#070a14;--panel:rgba(255,255,255,.035);--panel-strong:rgba(255,255,255,.06);--border:rgba(255,255,255,.08);--border-soft:rgba(255,255,255,.05);--txt:#f1f3f6;--txt-dim:#a9adb6;--txt-faint:#717682;--cyan:#ff4d4d;--emerald:#c81e2c;--teal:#ff6b6b;--amber:#f59e0b;--red:#ef4444;--green:#22c55e;--shadow:0 18px 50px -20px rgba(0,0,0,.7)}html{background:var(--bg)}html,body{margin:0;padding:0;height:100%;font-family:Inter,system-ui,sans-serif;-webkit-font-smoothing:antialiased;color:var(--txt)}body{min-height:100vh;overflow:hidden;background:radial-gradient(1000px 700px at 8% -12%,rgba(239,68,68,.18),transparent 60%),radial-gradient(800px 600px at 98% 6%,rgba(190,18,60,.13),transparent 60%),radial-gradient(800px 800px at 60% 120%,rgba(120,20,30,.12),transparent 60%),linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%)}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input{font-family:inherit}.mono{font-family:JetBrains Mono,monospace;font-variant-numeric:tabular-nums}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:8px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#ffffff29;background-clip:padding-box}.glass{backdrop-filter:blur(22px) saturate(140%);-webkit-backdrop-filter:blur(22px) saturate(140%)}.ic{width:18px;height:18px;stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round;flex:none}#login{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:50;padding:24px}#login .card{width:100%;max-width:400px;border-radius:22px;padding:38px 34px;background:linear-gradient(180deg,#ffffff0f,#ffffff06);border:1px solid var(--border);box-shadow:var(--shadow)}.brand{display:flex;align-items:center;gap:12px;margin-bottom:6px}.logo-img{height:30px;width:auto;display:block}.logo-img-lg{height:42px}.brand .name{font-size:21px;font-weight:800;letter-spacing:-.5px;background:linear-gradient(135deg,#fff,#ff5a5f);-webkit-background-clip:text;background-clip:text;color:transparent}#login .sub{color:var(--txt-faint);font-size:13px;margin:10px 0 28px 2px}.field{margin-bottom:16px}.field label{display:block;font-size:12.5px;color:var(--txt-dim);margin-bottom:7px;font-weight:500}.field input{width:100%;padding:12px 14px;border-radius:11px;color:var(--txt);font-size:14px;background:#00000040;border:1px solid var(--border);transition:.2s}.field input:focus{outline:none;border-color:#ef44448c;box-shadow:0 0 0 3px #ef444426}.login-row{display:flex;align-items:center;justify-content:space-between;margin:6px 0 22px;font-size:12.5px;color:var(--txt-dim)}.login-row label{display:flex;align-items:center;gap:8px;cursor:pointer}.login-row a{color:var(--cyan);text-decoration:none}.btn-primary{width:100%;padding:13px;border-radius:12px;font-size:14.5px;font-weight:600;color:#04121a;background:linear-gradient(135deg,var(--cyan),var(--teal));box-shadow:0 10px 30px -10px #ef44448c;transition:.2s}.btn-primary:hover{filter:brightness(1.06);transform:translateY(-1px)}#login .foot{text-align:center;margin-top:22px;font-size:11.5px;color:var(--txt-faint)}#app{display:none;height:100vh;grid-template-columns:248px 1fr;grid-template-rows:64px 1fr}#app.on{display:grid}.sidebar{grid-row:1 / span 2;display:flex;flex-direction:column;border-right:1px solid var(--border-soft);background:#070a128c;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.sb-brand{display:flex;align-items:center;gap:11px;height:64px;padding:0 20px;border-bottom:1px solid var(--border-soft);flex:none}.sb-brand .name{font-weight:800;font-size:17px;letter-spacing:-.4px;background:linear-gradient(135deg,#fff,#ff5a5f);-webkit-background-clip:text;background-clip:text;color:transparent}.sb-nav{flex:1;overflow-y:auto;padding:14px 12px;display:flex;flex-direction:column;gap:3px}.nav-group-label{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--txt-faint);padding:14px 12px 6px;font-weight:600}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;font-size:13.5px;color:var(--txt-dim);font-weight:500;transition:.16s;width:100%;text-align:left;position:relative}.nav-item:hover{background:var(--panel);color:var(--txt)}.nav-item.active{background:linear-gradient(180deg,#ef44442e,#be123c14);color:#fff;box-shadow:inset 0 0 0 1px #ef44444d}.nav-item.active:before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:3px;height:18px;border-radius:0 3px 3px 0;background:linear-gradient(var(--cyan),var(--emerald))}.nav-item .badge{margin-left:auto;font-size:10.5px;font-weight:700;padding:2px 7px;border-radius:999px;background:#ef44442e;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.nav-parent{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;font-size:13.5px;color:var(--txt-dim);font-weight:500;width:100%;text-align:left;transition:.16s}.nav-parent:hover{background:var(--panel);color:var(--txt)}.nav-parent .chev{margin-left:auto;width:15px;height:15px;transition:transform .2s;stroke:currentColor;stroke-width:2;fill:none}.nav-parent.open .chev{transform:rotate(90deg)}.nav-children{display:flex;flex-direction:column;gap:2px;margin:2px 0 4px}.nav-children:not(.open){display:none}.nav-child{padding:7px 12px 7px 41px;border-radius:9px;font-size:13px;color:var(--txt-dim);font-weight:500;text-align:left;width:100%;transition:.16s}.nav-child:hover{background:var(--panel);color:var(--txt)}.nav-child.active{color:#fff;background:#ef444424;box-shadow:inset 0 0 0 1px #ef444447}.sb-foot{flex:none;padding:14px;border-top:1px solid var(--border-soft);display:flex;align-items:center;gap:11px}.sb-foot .av{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-weight:700;font-size:13px;color:#04121a;background:linear-gradient(135deg,var(--cyan),var(--teal))}.sb-foot .who{font-size:12.5px;line-height:1.3}.sb-foot .who b{font-weight:600}.sb-foot .who span{display:block;color:var(--txt-faint);font-size:11px;margin-top:1px}.sb-foot button{margin-left:auto;color:var(--txt-faint);padding:6px;border-radius:8px}.sb-foot button:hover{color:var(--txt);background:var(--panel)}.header{grid-column:2;display:flex;align-items:center;gap:18px;padding:0 26px;border-bottom:1px solid var(--border-soft);background:#070a1266;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.header .h-title{font-size:18px;font-weight:700;letter-spacing:-.3px}.header .h-sub{font-size:12px;color:var(--txt-faint);margin-top:1px}.h-spacer{flex:1}.ranges{display:flex;gap:3px;background:#00000040;padding:4px;border-radius:11px;border:1px solid var(--border-soft)}.range-btn{padding:6px 11px;border-radius:8px;font-size:12px;font-weight:600;color:var(--txt-dim);transition:.16s}.range-btn:hover{color:var(--txt)}.range-btn.active{background:linear-gradient(180deg,#ef44443d,#be123c1a);color:#fff;box-shadow:inset 0 0 0 1px #ef44444d}.lang-switch{display:flex;gap:2px;background:#00000040;padding:3px;border-radius:9px;border:1px solid var(--border-soft)}.lang-switch button{padding:5px 10px;border-radius:7px;font-size:11.5px;font-weight:700;color:var(--txt-dim);transition:.16s}.lang-switch button:hover{color:var(--txt)}.lang-switch button.active{background:linear-gradient(180deg,#ef44443d,#be123c1a);color:#fff;box-shadow:inset 0 0 0 1px #ef44444d}.mqtt-pill{display:flex;align-items:center;gap:8px;padding:7px 13px;border-radius:999px;font-size:12px;color:#a7f3d0;background:#10b9811f;border:1px solid rgba(16,185,129,.25)}.mqtt-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.content{grid-column:2;overflow-y:auto;padding:24px 26px 60px}.view{display:none;animation:fade .25s ease}.view.active{display:block}@keyframes fade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.card{border-radius:16px;border:1px solid var(--border);background:var(--panel);box-shadow:var(--shadow)}.faint{color:var(--txt-faint)}.chart-card{padding:20px 22px;margin-bottom:22px}.chart-head{display:flex;align-items:center;gap:14px;margin-bottom:14px;flex-wrap:wrap}.chart-head h3{margin:0;font-size:15px;font-weight:600}.chart-head .unit{font-size:11.5px;color:var(--txt-faint);padding:3px 8px;border-radius:7px;background:#00000040;border:1px solid var(--border-soft)}.legend-actions{display:flex;gap:8px;margin:2px 0 12px}.lg-btn{font-size:11.5px;font-weight:600;padding:5px 11px;border-radius:8px;color:var(--txt-dim);background:#ffffff0d;border:1px solid var(--border-soft);cursor:pointer;transition:.15s}.lg-btn:hover{color:#fff;background:#ef44442e;border-color:#ef444459}.legend-chips{display:flex;flex-wrap:wrap;gap:7px;margin:2px 0 16px}.chip{display:flex;align-items:center;gap:7px;padding:5px 11px;border-radius:999px;font-size:12px;font-weight:500;color:var(--txt-dim);background:#0003;border:1px solid var(--border-soft);transition:.16s;cursor:pointer;-webkit-user-select:none;user-select:none}.chip:hover{color:var(--txt);border-color:var(--border)}.chip .dot{width:9px;height:9px;border-radius:50%;transition:.16s}.chip.off{opacity:.42}.chip.off .dot{background:#475569!important}.chip.off .nm{text-decoration:line-through}.thr-note{display:flex;gap:16px;font-size:11.5px;color:var(--txt-faint);margin-top:12px}.thr-note span{display:flex;align-items:center;gap:6px}.thr-note i{width:18px;height:0;border-top:2px solid;display:inline-block}.chart-wrap{position:relative;height:340px}.dash-head{display:flex;align-items:center;gap:14px;margin-bottom:20px}.dash-head h2{margin:0;font-size:20px;font-weight:700}.alert-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:14px}.alert{padding:16px 18px;border-radius:14px;display:grid;grid-template-columns:38px minmax(0,1fr) minmax(68px,auto);gap:14px;align-items:flex-start;background:var(--panel);border:1px solid var(--border);min-width:0}.alert.crit{border-color:#ef444466;background:linear-gradient(180deg,#ef44441a,#ef444408)}.alert.warn{border-color:#f59e0b61;background:linear-gradient(180deg,#f59e0b14,#f59e0b05)}.alert .ico{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex:none}.alert.crit .ico{background:#ef44442e;color:#fca5a5}.alert.warn .ico{background:#f59e0b2e;color:#fcd34d}.alert .a-srv{font-size:13.5px;font-weight:600;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.alert .a-metric{font-size:12px;color:var(--txt-dim);margin-top:2px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.alert .a-val{text-align:right;min-width:68px}.alert .a-val b{font-size:19px;font-weight:700}.alert.crit .a-val b{color:#fca5a5}.alert.warn .a-val b{color:#fcd34d}.alert .a-val span{display:block;font-size:10.5px;color:var(--txt-faint);max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tag{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:6px}.tag.crit{background:#ef444433;color:#fca5a5}.tag.warn{background:#f59e0b33;color:#fcd34d}.all-good{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:70px 20px;border-radius:18px;border:1px dashed rgba(16,185,129,.3);background:#10b9810a}.all-good .ring{width:78px;height:78px;border-radius:50%;display:grid;place-items:center;margin-bottom:18px;background:#10b9811f;border:1px solid rgba(16,185,129,.35)}.all-good .ring svg{width:38px;height:38px;stroke:var(--green);stroke-width:2.4}.all-good h3{margin:0 0 6px;font-size:18px;font-weight:700}.all-good p{margin:0;color:var(--txt-dim);font-size:13.5px}.stor-card{padding:16px 18px;margin-bottom:14px}.stor-row{display:flex;align-items:center;gap:22px}.stor-srv{width:130px;flex:none}.stor-srv b{font-size:14px;font-weight:600}.stor-srv span{display:block;font-size:11px;color:var(--txt-faint)}.stor-total{width:200px;flex:none}.stor-total .bar{height:24px;border-radius:7px;overflow:hidden;display:flex;border:1px solid var(--border-soft);background:#0000004d}.stor-total .bar .used{background:linear-gradient(90deg,#475569,#64748b)}.stor-total .bar .free{background:linear-gradient(90deg,#10b981,#34d399)}.stor-total .lbl{display:flex;justify-content:space-between;font-size:10.5px;color:var(--txt-faint);margin-top:5px}.stor-pct{width:96px;flex:none;text-align:center}.stor-pct b{font-size:27px;font-weight:800;line-height:1}.stor-pct span{display:block;font-size:10px;color:var(--txt-faint);margin-top:3px;letter-spacing:.04em}.stor-disks{flex:1;display:flex;gap:10px;flex-wrap:wrap}.disk{min-width:104px;flex:1;max-width:160px;padding:9px 11px;border-radius:10px;background:#00000038;border:1px solid var(--border-soft)}.disk .d-top{display:flex;justify-content:space-between;align-items:center;font-size:11.5px;margin-bottom:7px}.disk .d-top b{font-weight:600}.disk .d-top span{color:var(--txt-faint)}.disk .d-bar{height:6px;border-radius:4px;background:#ffffff14;overflow:hidden}.disk .d-bar i{display:block;height:100%;border-radius:4px}.disk .d-free{font-size:10.5px;color:var(--txt-faint);margin-top:6px}.sev-ok{color:var(--green)}.sev-warn{color:var(--amber)}.sev-crit{color:var(--red)}.bg-ok{background:linear-gradient(90deg,#10b981,#34d399)}.bg-warn{background:linear-gradient(90deg,#d97706,var(--amber))}.bg-crit{background:linear-gradient(90deg,#b91c1c,var(--red))}.status-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}.status-card{padding:16px 18px;display:flex;align-items:center;gap:15px}.status-led{width:14px;height:14px;border-radius:50%;flex:none;position:relative}.status-led.on{background:var(--green);box-shadow:0 0 0 4px #22c55e29,0 0 12px var(--green)}.status-led.off{background:var(--red);box-shadow:0 0 0 4px #ef444429,0 0 12px var(--red)}.status-led.on:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:var(--green);animation:pulse 2s infinite}.status-srv{flex:1}.status-srv b{font-size:15px;font-weight:600}.status-srv span{display:block;font-size:11.5px;color:var(--txt-faint);margin-top:1px}.status-up{text-align:right;flex:none}.status-up .lab{font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--txt-faint)}.status-up .val{font-size:14.5px;font-weight:600;margin-top:2px}.status-up.on .val{color:#86efac}.status-up.off .val{color:#fca5a5}.status-summary{display:flex;gap:10px;margin-bottom:18px}.stat-pill{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:11px;font-size:13px;font-weight:600;background:var(--panel);border:1px solid var(--border)}.stat-pill .d{width:9px;height:9px;border-radius:50%}.stat-pill .d.g{background:var(--green)}.stat-pill .d.r{background:var(--red)}.svc-head{display:flex;align-items:center;gap:11px;margin-bottom:13px}.svc-head .led.on{background:var(--green);box-shadow:0 0 8px var(--green)}.svc-head .led.off{background:var(--red);box-shadow:0 0 8px var(--red)}.svc-head .cnt{margin-left:auto;font-size:11.5px;color:var(--txt-faint)}.svc-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:8px}.svc-row{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;background:#00000038;border:1px solid var(--border-soft)}.svc-dot{width:9px;height:9px;border-radius:50%;flex:none}.svc-dot.run{background:var(--green)}.svc-dot.stop{background:var(--red)}.svc-name{font-size:13px;font-weight:500}.svc-state{font-size:11px;color:var(--txt-faint);margin-left:1px}.svc-badge{margin-left:auto;font-size:9.5px;font-weight:600;padding:2px 8px;border-radius:999px;background:#f59e0b29;color:#fcd34d;border:1px solid rgba(245,158,11,.3);white-space:nowrap}.set-card{padding:18px 20px;margin-bottom:14px}.set-card h3{margin:0 0 4px;font-size:15px;font-weight:600}.set-card .desc{margin:0 0 16px;font-size:12.5px;color:var(--txt-faint)}.thr-table{display:flex;flex-direction:column;gap:2px}.thr-row{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:14px;align-items:center;padding:10px 0;border-top:1px solid var(--border-soft)}.thr-row.head{border-top:none;padding-bottom:8px}.thr-row.head span{font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--txt-faint);font-weight:600}.thr-name{font-size:13.5px;font-weight:500}.thr-name small{display:block;color:var(--txt-faint);font-weight:400;font-size:11px;margin-top:1px}.num-field{display:flex;align-items:center;gap:8px;background:#00000040;border:1px solid var(--border);border-radius:10px;padding:8px 12px;transition:.2s}.num-field:focus-within{border-color:#ef444480;box-shadow:0 0 0 3px #ef44441f}.num-field input{width:100%;background:none;border:none;color:var(--txt);font-size:14px;font-family:JetBrains Mono,monospace;outline:none}.num-field input::-webkit-outer-spin-button,.num-field input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.num-field input[type=number]{-moz-appearance:textfield}.step{display:flex;flex-direction:column;gap:3px;margin-left:4px;flex:none}.step button{width:21px;height:14px;display:grid;place-items:center;border-radius:5px;color:var(--txt-faint);background:#ffffff0d;border:1px solid var(--border-soft);transition:.14s;padding:0}.step button:hover{color:#fff;background:#ef444438;border-color:#ef444466}.step button:active{transform:scale(.9)}.step svg{width:10px;height:10px;stroke:currentColor;stroke-width:2.6;fill:none;stroke-linecap:round;stroke-linejoin:round}.num-field .u{font-size:11.5px;color:var(--txt-faint)}.num-field.warn{border-left:3px solid var(--amber)}.num-field.crit{border-left:3px solid var(--red)}.set-actions{display:flex;gap:10px;margin-top:6px;align-items:center;flex-wrap:wrap}.btn{padding:10px 18px;border-radius:11px;font-size:13.5px;font-weight:600;transition:.18s;border:1px solid var(--border)}.btn-accent{color:#04121a;background:linear-gradient(135deg,var(--cyan),var(--teal));border:none;box-shadow:0 8px 24px -10px #ef444480}.btn-accent:hover{filter:brightness(1.06)}.btn-ghost{background:var(--panel);color:var(--txt-dim)}.btn-ghost:hover{color:var(--txt);background:var(--panel-strong)}.save-note{font-size:12.5px;color:#86efac;opacity:0;transition:.3s}.save-note.show{opacity:1}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:4px}.form-grid .full{grid-column:1 / -1}.form-field label{display:block;font-size:12.5px;color:var(--txt-dim);margin-bottom:6px;font-weight:500}.form-field input,.form-field select,.form-field textarea{width:100%;padding:11px 13px;border-radius:10px;background:#00000040;border:1px solid var(--border);color:var(--txt);font-size:13.5px;transition:.2s}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:#ef444480;box-shadow:0 0 0 3px #ef44441f}.form-field textarea{resize:vertical;min-height:64px;font-family:inherit}.toggle-row{display:flex;align-items:center;gap:12px;padding:4px 0 16px;border-bottom:1px solid var(--border-soft);margin-bottom:18px}.toggle-row .t-txt{flex:1}.toggle-row .t-txt b{font-size:13.5px;font-weight:600}.toggle-row .t-txt span{display:block;font-size:11.5px;color:var(--txt-faint);margin-top:2px}.switch{position:relative;width:44px;height:24px;border-radius:999px;background:#ffffff1f;transition:.2s;flex:none;cursor:pointer}.switch.on{background:linear-gradient(135deg,var(--cyan),var(--teal))}.switch:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.2s}.switch.on:after{transform:translate(20px)}.chk-row{display:flex;gap:18px;margin-top:2px}.sev-toggles{display:flex;gap:10px;margin-top:4px;flex-wrap:wrap}.sev-toggle{display:inline-flex;align-items:center;gap:10px;padding:9px 16px;border-radius:12px;font-size:13px;font-weight:600;cursor:pointer;border:1px solid var(--border-soft);background:#0003;color:var(--txt-dim);transition:.16s;-webkit-user-select:none;user-select:none}.sev-toggle:hover{color:var(--txt);border-color:var(--border)}.sev-toggle .tick{width:19px;height:19px;border-radius:6px;border:1.6px solid var(--txt-faint);display:grid;place-items:center;transition:.16s}.sev-toggle .tick svg{width:12px;height:12px;stroke:#0b0e15;stroke-width:3.2;fill:none;opacity:0;transition:.16s}.sev-toggle.on .tick svg{opacity:1}.sev-toggle.warn.on{background:#f59e0b26;border-color:#f59e0b8c;color:#fcd34d}.sev-toggle.crit.on{background:#ef444426;border-color:#ef44448c;color:#fca5a5}.sev-toggle.warn.on .tick{background:var(--amber);border-color:var(--amber)}.sev-toggle.crit.on .tick{background:var(--red);border-color:var(--red)}.chk{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--txt-dim);cursor:pointer}.task-new{display:flex;gap:10px}.task-new input{flex:1;padding:11px 13px;border-radius:10px;background-color:#00000040;border:1px solid var(--border);color:var(--txt);font-size:13.5px}.task-new input:focus{outline:none;border-color:#ef444480;box-shadow:0 0 0 3px #ef44441a}.task-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}.task-col-head{display:flex;align-items:center;gap:9px;font-size:13px;font-weight:700;color:var(--txt-dim);margin-bottom:12px}.task-col-head .cnt{margin-left:auto;font-size:11px;font-weight:700;color:var(--txt-faint);background:#ffffff0d;border:1px solid var(--border-soft);padding:1px 9px;border-radius:999px}.task-col-head .dot-open{width:9px;height:9px;border-radius:50%;background:var(--amber);box-shadow:0 0 8px var(--amber)}.task-col-head .dot-done{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}.task-card{padding:14px 15px;border-radius:13px;border:1px solid var(--border);background:var(--panel);margin-bottom:12px}.task-card.done{opacity:.78}.task-main{display:flex;align-items:flex-start;gap:12px}.task-check{position:relative;flex:none;cursor:pointer;display:inline-flex;width:22px;height:22px}.task-check input{position:absolute;opacity:0;width:22px;height:22px;cursor:pointer;margin:0;z-index:1}.task-check .box{width:22px;height:22px;border-radius:7px;border:2px solid var(--txt-faint);transition:.15s;display:grid;place-items:center}.task-check .box:after{content:"";width:11px;height:6px;border-left:2.5px solid #fff;border-bottom:2.5px solid #fff;transform:rotate(-45deg) translateY(-1px);opacity:0;transition:.15s}.task-check input:checked+.box{background:linear-gradient(135deg,#ff6b6b,#ef4444);border-color:#ef4444}.task-check input:checked+.box:after{opacity:1}.task-body{flex:1;min-width:0;padding-top:1px}.task-title{font-size:14px;font-weight:600;word-break:break-word}.task-card.done .task-title{text-decoration:line-through;color:var(--txt-dim)}.task-meta{font-size:11.5px;color:var(--txt-faint);margin-top:3px}.task-del{margin-left:auto}.subtasks{margin:11px 0 4px;padding-left:34px;display:flex;flex-direction:column;gap:6px}.subtask{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--txt-dim);cursor:pointer}.subtask input{width:16px;height:16px;accent-color:#ef4444;cursor:pointer;flex:none}.subtask span.is-done{text-decoration:line-through;color:var(--txt-faint)}.subtask .sub-del{margin-left:auto;color:var(--txt-faint);cursor:pointer;font-size:15px;opacity:0;line-height:1}.subtask:hover .sub-del{opacity:1}.subtask-add{display:flex;gap:8px;margin-top:10px;padding-left:34px}.subtask-add input{flex:1;padding:7px 10px;border-radius:8px;background-color:#00000038;border:1px solid var(--border-soft);color:var(--txt);font-size:12.5px}.subtask-add input:focus{outline:none;border-color:#ef444473}.task-empty{font-size:12.5px;color:var(--txt-faint);padding:16px;text-align:center;border:1px dashed var(--border-soft);border-radius:11px}.task-error{font-size:12.5px;color:#fca5a5;padding:12px 14px;border-radius:10px;background:#ef44441a;border:1px solid rgba(239,68,68,.25);margin-top:12px}@media(max-width:900px){.task-cols{grid-template-columns:1fr}}.bk-card{padding:18px 20px;margin-bottom:14px}.bk-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}.bk-head .led.fail{background:var(--red);box-shadow:0 0 8px var(--red)}.bk-head b{font-size:14.5px;font-weight:600}.bk-head .grp{font-size:11.5px;color:var(--txt-faint)}.bk-badge{margin-left:auto;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:3px 10px;border-radius:999px}.bk-badge.fail{background:#ef44442e;color:#fca5a5;border:1px solid rgba(239,68,68,.35)}.bk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:15px 22px}.bk-item .k{font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--txt-faint);margin-bottom:3px}.bk-item .v{font-size:14px;font-weight:600}.bk-error{margin-top:16px;padding:11px 14px;border-radius:10px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;font-family:JetBrains Mono,monospace;font-size:12px;line-height:1.5;word-break:break-word}.bk-error b{display:block;font-family:Inter,sans-serif;font-size:11px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;color:#f87171}.upd-row{display:grid;grid-template-columns:1.6fr 1fr 1fr auto;gap:14px;align-items:center;padding:10px 0;border-top:1px solid var(--border-soft)}.upd-row.head{border-top:none;padding-bottom:8px}.upd-row.head span{font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--txt-faint);font-weight:600}.upd-name{font-size:13.5px;font-weight:500}.ver{font-family:JetBrains Mono,monospace;font-size:13px;color:var(--txt-dim)}.tag-chips{display:flex;flex-wrap:wrap;gap:8px}.tag-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--border-soft);background:#0003;color:var(--txt-dim);transition:.14s;-webkit-user-select:none;user-select:none}.tag-chip:hover{color:var(--txt);border-color:var(--border)}.tag-chip.on{background:#ef444429;border-color:#ef444466;color:#fff}.tag-chip .x{cursor:pointer;opacity:.6;font-weight:700;font-size:14px;line-height:1}.tag-chip .x:hover{opacity:1;color:#fca5a5}.add-tag{display:flex;gap:10px;margin-top:16px;max-width:380px}.add-tag input{flex:1;padding:9px 12px;border-radius:10px;background:#00000040;border:1px solid var(--border);color:var(--txt);font-size:13px}.add-tag input:focus{outline:none;border-color:#ef444480;box-shadow:0 0 0 3px #ef44441f}.srv-tag-row{display:grid;grid-template-columns:160px 1fr;gap:18px;align-items:center;padding:13px 0;border-top:1px solid var(--border-soft)}.srv-tag-row .s b{font-size:13.5px;font-weight:600}.srv-tag-row .s span{display:block;font-size:11px;color:var(--txt-faint);margin-top:1px}.user-card{padding:13px 16px;margin-bottom:10px;display:flex;align-items:center;gap:14px}.user-card .uav{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-weight:700;font-size:13px;color:#04121a;background:linear-gradient(135deg,var(--cyan),var(--teal));flex:none}.user-card .uinfo{flex:1;min-width:0}.user-card .uinfo b{font-size:14px;font-weight:600}.user-card .uinfo span{display:block;font-size:11.5px;color:var(--txt-faint);margin-top:1px}.user-card .uright{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex:none;max-width:55%}.role-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 9px;border-radius:6px;background:#ef444429;color:#fca5a5;border:1px solid rgba(239,68,68,.28)}.role-badge.leser{background:#ffffff12;color:var(--txt-dim);border-color:var(--border-soft)}.utags{display:flex;flex-wrap:wrap;gap:5px;justify-content:flex-end}.utag{font-size:10.5px;padding:2px 8px;border-radius:999px;background:#ffffff0f;border:1px solid var(--border-soft);color:var(--txt-dim)}.utag.all{background:#22c55e24;border-color:#22c55e4d;color:#86efac}.tag-chip{gap:7px;padding:6px 12px}.tag-chip .tc-dot{width:9px;height:9px;border-radius:50%;background:var(--tc,#888);flex:none;box-shadow:0 0 6px var(--tc,#888)}.tag-chip.on{background:var(--tc,#ef4444);border-color:var(--tc,#ef4444);color:#0b0e15;font-weight:600}.tag-chip.on:hover{color:#0b0e15;filter:brightness(1.05)}.tag-chip.on .tc-dot{background:#0b0e158c;box-shadow:none}.tag-chip .x{color:var(--txt-faint)}.tag-chip .x:hover{color:#fca5a5}.tag-chip.on .x{color:#0b0e15a6}.tag-chip.on .x:hover{color:#7f1d1d}.utag{display:inline-flex;align-items:center;gap:6px;font-size:11px;padding:3px 10px;border-radius:999px;background:#ffffff0d;border:1px solid var(--tc,var(--border-soft));color:var(--txt)}.utag .tc-dot{width:8px;height:8px;border-radius:50%;background:var(--tc,#888);flex:none;box-shadow:0 0 6px var(--tc,#888)}.utag.all{border-color:#22c55e80;background:#22c55e24;color:#86efac}.user-card{cursor:pointer;transition:.16s}.user-card:hover{border-color:#ef444466;background:var(--panel-strong)}.user-card .uedit{color:var(--txt-faint);flex:none;margin-left:2px}.user-card:hover .uedit{color:#fff}.btn-danger{background:#ef444424;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:#ef444438;color:#fff}.int-cell{display:flex;flex-direction:column;gap:8px;align-items:stretch}.int-presets{display:flex;gap:5px;flex-wrap:wrap}.preset{font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:7px;color:var(--txt-faint);background:#ffffff0d;border:1px solid var(--border-soft);transition:.14s;cursor:pointer}.preset:hover{color:#fff;background:#ef44442e;border-color:#ef444459}.preset.on{color:#fff;background:#ef444438;border-color:#ef444480}.dash-section{margin-bottom:26px}.dash-sec-head{display:flex;align-items:center;gap:12px;margin:0 0 12px}.dash-sec-head h3{margin:0;font-size:15px;font-weight:700}.dash-sec-meta{display:flex;gap:7px}.upd-sub{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--txt-faint);font-weight:600;margin:16px 0 6px}.upd-ghead{display:flex;align-items:center;gap:9px;margin-bottom:6px}.cmp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(335px,1fr));gap:14px;margin-bottom:18px}.cmp-card{padding:15px 16px;border-radius:14px;border:1px solid var(--border);background:var(--panel);display:flex;flex-direction:column;gap:13px}.cmp-card-head{display:flex;align-items:center;gap:12px}.cmp-ico{width:42px;height:42px;border-radius:11px;background:linear-gradient(180deg,#333a45,#1e232b);display:grid;place-items:center;flex:none;box-shadow:inset 0 1px #ffffff1f,0 1px 2px #0006}.cmp-ico svg{width:22px;height:22px;stroke:#aeb6c2;stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}.cmp-name{flex:1;min-width:0}.cmp-name input{width:100%;font-size:14.5px;font-weight:600;background:transparent;border:none;border-bottom:1px solid transparent;color:var(--txt);padding:3px 0}.cmp-name input:focus{outline:none;border-bottom-color:#ef444480}.icon-btn{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;color:var(--txt-faint);background:#ffffff0d;border:1px solid var(--border-soft);cursor:pointer;flex:none}.icon-btn:hover{color:#fca5a5;border-color:#ef444459}.icon-btn.disabled,.icon-btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.icon-btn svg{width:15px;height:15px;stroke:currentColor;stroke-width:1.9;fill:none}.cmp-fields{display:grid;grid-template-columns:1fr 72px;gap:10px}.cmp-field.full{grid-column:1 / -1}.cmp-field label{font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--txt-faint);display:block;margin-bottom:5px;font-weight:600}.cmp-field input,.cmp-field select{width:100%;padding:9px 11px;border-radius:9px;background-color:#00000040;border:1px solid var(--border);color:var(--txt);font-size:13px}.cmp-field input:focus,.cmp-field select:focus{outline:none;border-color:#ef444480;box-shadow:0 0 0 3px #ef44441a}.cmp-field select,.rack-add select{-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:30px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a9adb6' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 10px center;background-size:14px}select option{background-color:#12161e;color:#e7ecf3;font-weight:500}select option:checked{background:linear-gradient(#1c222c,#1c222c);color:#fff}select option[value=""]{color:#8b93a3}.cmp-pdf-row{display:flex;align-items:center;gap:9px;border-top:1px solid var(--border-soft);padding-top:12px;flex-wrap:wrap}.pdf-chip{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--txt-dim);min-width:90px;flex:1}.pdf-chip svg{width:16px;height:16px;stroke:#fca5a5;stroke-width:1.7;fill:none;flex:none}.pdf-chip.none{color:var(--txt-faint)}.pdf-chip.none svg{stroke:var(--txt-faint)}.pdf-chip span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-sm{padding:7px 12px;border-radius:9px;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:6px;cursor:pointer;border:1px solid var(--border-soft);background:var(--panel);color:var(--txt-dim);transition:.15s}.btn-sm:hover{color:#fff;background:var(--panel-strong)}.btn-sm svg{width:14px;height:14px;stroke:currentColor;stroke-width:2;fill:none}.btn-sm.disabled{opacity:.4;pointer-events:none}.btn-sm input[type=file]{display:none}.env-temps{display:flex;gap:14px;margin-bottom:22px;flex-wrap:wrap}.env-temp{flex:1;min-width:175px;padding:15px 18px;border-radius:14px;border:1px solid var(--border);background:var(--panel);display:flex;align-items:center;gap:14px}.env-temp .et-ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;flex:none}.env-temp .et-ic svg{width:22px;height:22px;stroke:#fff;stroke-width:1.8;fill:none}.env-temp .et-val{font-size:23px;font-weight:800;line-height:1}.env-temp .et-lbl{font-size:11.5px;color:var(--txt-faint);margin-top:3px}.env-temp.room .et-ic{background:linear-gradient(135deg,#38bdf8,#0ea5e9)}.env-temp.outside .et-ic{background:linear-gradient(135deg,#34d399,#10b981)}.env-temp.rackavg .et-ic{background:linear-gradient(135deg,#f59e0b,#ef4444)}.racks{display:flex;gap:26px;flex-wrap:wrap;align-items:flex-start}.rack{width:340px;flex:none}.rack-head{display:flex;align-items:center;gap:9px;margin-bottom:8px}.rack-head b{font-size:15px;font-weight:700}.rk-temp{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--tc);padding:3px 10px;border-radius:999px;background:#ffffff0d;border:1px solid var(--border-soft)}.rk-temp i{width:7px;height:7px;border-radius:50%;background:var(--tc);box-shadow:0 0 8px var(--tc)}.rk-del{margin-left:auto;color:var(--txt-faint);cursor:pointer;font-size:17px;line-height:1}.rk-del:hover{color:#fca5a5}.rack-cap{display:flex;align-items:center;gap:10px;margin-bottom:11px;font-size:10.5px;color:var(--txt-faint);font-family:JetBrains Mono,monospace}.rack-cap-bar{flex:1;height:5px;border-radius:3px;background:#ffffff14;overflow:hidden}.rack-cap-bar i{display:block;height:100%;border-radius:3px;background:linear-gradient(90deg,#fb7185,#ef4444)}.rack-cap-txt{display:inline-flex;align-items:center;gap:5px}.rack-he-input{width:44px;padding:3px 6px;border-radius:7px;background-color:#0000004d;border:1px solid var(--border-soft);color:var(--txt);font-size:11px;font-family:JetBrains Mono,monospace;text-align:center}.rack-he-input::-webkit-outer-spin-button,.rack-he-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.rack-he-input:focus{outline:none;border-color:#ef444480;box-shadow:0 0 0 2px #ef444426}.rack-cab{display:flex;border-radius:16px;padding:12px;background:linear-gradient(180deg,#11151d,#0a0d13);border:1px solid rgba(255,255,255,.1);box-shadow:inset 0 1px #ffffff0d,0 24px 50px -26px #000000d9}.rack-scale{display:flex;flex-direction:column;width:22px;flex:none;margin-right:8px}.ru-tick{height:20px;display:flex;align-items:center;justify-content:flex-end;padding-right:6px;font-size:8px;color:#565d6b;font-family:JetBrains Mono,monospace}.rack-bay{flex:1;display:flex;flex-direction:column;border-radius:8px;overflow:hidden;padding:0 10px;background:radial-gradient(circle,rgba(255,255,255,.12) 1px,transparent 1.5px) left 3px top 2px/10px 10px repeat-y,radial-gradient(circle,rgba(255,255,255,.12) 1px,transparent 1.5px) right 3px top 2px/10px 10px repeat-y,linear-gradient(180deg,#0c0f16,#090b11)}.rd{position:relative;display:flex;align-items:center;gap:10px;padding:0 12px 0 15px;color:#dfe4ec;cursor:grab;overflow:hidden;border-radius:5px;background:linear-gradient(180deg,#333a45,#1e232b);box-shadow:inset 0 1px #ffffff21,inset 0 -3px 6px #00000052,0 1px 2px #00000080}.rd:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,#ff6b6b,#ef4444)}.rd:active{cursor:grabbing}.rd-ico{width:20px;flex:none;color:#aeb6c2;display:flex;align-items:center;justify-content:center}.rd-ico svg{width:18px;height:18px;stroke:currentColor;stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}.rd-txt{display:flex;flex-direction:column;min-width:0;line-height:1.08}.rd-name{font-size:12px;font-weight:700;color:#eef1f6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rd-sub{font-size:9.5px;font-weight:500;color:#99a2b0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:JetBrains Mono,monospace}.rd:not(.tall) .rd-sub{display:none}.rd-face{flex:1;height:60%;min-width:30px;margin:0 6px;border-radius:2px;background:#0e1117;box-shadow:inset 0 0 0 1px #ffffff0d}.rd--server .rd-face{background-color:#10141b;background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.1) 0 1px,transparent 1px 3px)}.rd--switch .rd-face,.rd--router .rd-face,.rd--firewall .rd-face{background-color:#0c0f15;background-image:repeating-linear-gradient(90deg,rgba(125,211,252,.35) 0 6px,transparent 6px 9px)}.rd--patch .rd-face{background-color:#0c0f15;background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.16) 0 4px,transparent 4px 6px)}.rd--ups .rd-face{background-color:#0c1f17;box-shadow:inset 0 0 0 1px #22c55e40}.rd-led{width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 6px #22c55e;flex:none}.rd-he{font-size:9px;font-weight:800;color:#8b93a3;font-family:JetBrains Mono,monospace;flex:none}.rd .rm{position:absolute;top:2px;right:5px;font-size:12px;color:#9aa3b1;cursor:pointer;opacity:0;font-weight:800;line-height:1}.rd:hover .rm{opacity:1}.rd--blank{background:linear-gradient(180deg,#262b33,#191d24);color:#7f8794}.rd--blank:before{display:none}.rd--blank .rd-face{background:none;box-shadow:none}.rd-slot{border-radius:4px;box-shadow:inset 0 0 0 1px #ffffff06;transition:box-shadow .1s,background .1s}.rd-slot.drop-target{box-shadow:inset 0 0 0 2px #ff6b6ba6;background:#ff6b6b1a}.rack-add{margin-top:12px}.rack-add select{width:100%;padding:10px 34px 10px 13px;border-radius:11px;background-color:#00000040;border:1px solid var(--border);color:var(--txt);font-size:13px}.rack-add select:focus{outline:none;border-color:#ef444480;box-shadow:0 0 0 3px #ef44441f}.rack-legend{display:flex;flex-wrap:wrap;gap:15px;margin:6px 0 20px;font-size:12px;color:var(--txt-dim)}.rack-legend span{display:flex;align-items:center;gap:7px}.rack-legend .lg-ic{color:#aeb6c2;display:inline-flex}.rack-legend .lg-ic svg{width:16px;height:16px;stroke:currentColor;stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}.btn-add-rack{margin-top:20px;display:inline-flex;align-items:center;gap:8px}.btn-add-rack svg{width:16px;height:16px;stroke:currentColor;stroke-width:2.2;fill:none}.stat-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.stat-tile{padding:20px;border-radius:14px;border:1px solid var(--border);background:var(--panel)}.stat-tile .num{font-size:30px;font-weight:800;line-height:1}.stat-tile .lab{font-size:12.5px;color:var(--txt-dim);margin-top:9px}.stat-tile .sub2{font-size:11px;color:var(--txt-faint);margin-top:3px}.stat-tile.green .num{color:#86efac}.stat-tile.accent .num{color:#fca5a5}.section-intro{margin:0 0 18px}.section-intro h2{margin:0 0 4px;font-size:20px;font-weight:700}.section-intro p{margin:0;font-size:13px;color:var(--txt-dim)}@media(max-width:1100px){.stor-row{flex-wrap:wrap;gap:14px}.stor-disks{width:100%}}.hamburger{display:none;width:40px;height:40px;border-radius:10px;align-items:center;justify-content:center;color:var(--txt-dim);background:var(--panel);border:1px solid var(--border-soft);flex:none}.hamburger:hover{color:var(--txt);background:var(--panel-strong)}.hamburger svg{width:22px;height:22px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}.sb-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:39}.sb-backdrop.show{display:block}.h-heading{min-width:0}@media(max-width:1024px){.hamburger{display:inline-flex}#app.on{grid-template-columns:1fr;grid-template-rows:60px 1fr}.sidebar{position:fixed;top:0;left:0;bottom:0;width:268px;max-width:84vw;z-index:40;background:#080b13fa;transform:translate(-100%);transition:transform .26s ease;box-shadow:0 0 60px -8px #000000d9}.sidebar.open{transform:none}.header{grid-column:1;grid-row:1;padding:0 16px;gap:12px}.content{grid-column:1;grid-row:2;padding:20px 18px 70px}.header .h-sub{display:none}}@media(max-width:760px){#app.on{grid-template-rows:auto 1fr}.header{flex-wrap:wrap;height:auto;min-height:60px;padding:10px 14px;gap:10px 12px;align-items:center}.h-heading{flex:1;min-width:120px}.header .h-title{font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.h-spacer{display:none}.ranges{order:5;width:100%;overflow-x:auto;justify-content:flex-start;-ms-overflow-style:none;scrollbar-width:none}.ranges::-webkit-scrollbar{display:none}.range-btn{flex:none}.lang-switch{margin-left:auto}.mqtt-pill{font-size:0;gap:0;padding:8px}.mqtt-pill .dot{font-size:0}.content{padding:16px 14px 64px}.chart-wrap{height:280px}.dash-head h2,.section-intro h2{font-size:18px}.alert-grid,.status-grid,.svc-list,.bk-grid,.cmp-grid,.form-grid{grid-template-columns:1fr}.thr-row.head,.upd-row.head{display:none}.thr-row{grid-template-columns:1fr 1fr;gap:8px 12px;align-items:end}.thr-name{grid-column:1 / -1}.upd-row{grid-template-columns:1fr 1fr;gap:6px 12px;align-items:center}.upd-name{grid-column:1 / -1}.stor-srv,.stor-total,.stor-pct{width:auto}.stor-total{flex:1;min-width:180px}.rack{width:100%;max-width:380px}.racks{gap:18px}}@media(max-width:480px){.header{padding:9px 12px}.header .h-title{font-size:15px}.content{padding:14px 12px 60px}.chart-card,.set-card,.bk-card,.upd-card,.svc-card,.stor-card{padding:14px}.chart-wrap{height:240px}.status-summary{flex-wrap:wrap}.status-card{align-items:flex-start}.status-up{text-align:left}.alert{grid-template-columns:32px minmax(0,1fr);gap:12px}.alert .ico{width:32px;height:32px;border-radius:10px}.alert .a-val{grid-column:2;min-width:0;text-align:left}.alert .a-val span{max-width:100%}.cmp-fields{grid-template-columns:1fr}.stat-tiles{grid-template-columns:1fr 1fr;gap:10px}.stat-tile{padding:15px}.stat-tile .num{font-size:24px}.env-temp{min-width:140px}.user-card{flex-wrap:wrap}.user-card .uright{max-width:100%;align-items:flex-start;flex-direction:row;flex-wrap:wrap}#login .card{padding:30px 22px}}#vue-root{min-height:100vh}.vue-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}.vue-stat-grid .kpi{min-height:96px;display:flex;flex-direction:column;justify-content:space-between}.vue-stat-grid .kpi span{color:var(--txt-dim);font-size:13px;font-weight:700}.vue-stat-grid .kpi b{color:var(--txt);font-family:JetBrains Mono,monospace;font-size:28px}.vue-muted{color:var(--txt-faint);font-size:12px;font-weight:700}.empty-card{padding:28px;color:var(--txt-faint);font-weight:700}.chart-actions{display:flex;align-items:center;gap:8px;margin:10px 0 12px}.chart-wrap canvas{display:block;width:100%!important;height:100%!important}.save-note.is-bad{color:#fca5a5}.btn:disabled,.btn-sm:disabled,.icon-btn:disabled,.btn-primary:disabled{opacity:.45;cursor:not-allowed}.nav-child.disabled,.nav-child:disabled{opacity:.38;cursor:not-allowed;color:var(--txt-faint)}.nav-child.disabled:hover,.nav-child:disabled:hover{background:transparent;color:var(--txt-faint)}.login-error{margin:-4px 0 14px;padding:9px 11px;border-radius:10px;border:1px solid rgba(239,68,68,.32);background:#ef444421;color:#fca5a5;font-size:12.5px;font-weight:650}.change-sub{margin-bottom:18px!important}.muted-row{justify-content:flex-start}.mail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.mail-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}.mail-status{min-width:0;padding:12px 13px;border:1px solid var(--border-soft);border-radius:12px;background:#0000002e}.mail-status span{display:block;margin-bottom:5px;color:var(--txt-faint);font-size:11px;font-weight:800;text-transform:uppercase}.mail-status b{display:block;overflow:hidden;color:var(--txt);font-family:JetBrains Mono,monospace;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.mail-badge{flex:none;padding:6px 10px;border:1px solid rgba(239,68,68,.38);border-radius:999px;background:#ef444429;color:#fecaca;font-size:11px;font-weight:900;text-transform:uppercase}.mail-badge.ok{border-color:#22c55e66;background:#22c55e24;color:#86efac}.mail-settings-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:14px}.mail-event-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.mail-toggle{display:flex;align-items:center;gap:9px;padding:11px 12px;border:1px solid var(--border-soft);border-radius:12px;background:#0000002e;color:var(--txt-dim);font-size:13px;font-weight:800;cursor:pointer}.mail-toggle input{width:16px;height:16px;accent-color:var(--green)}.mail-test-row{display:grid;grid-template-columns:minmax(240px,1fr) auto;align-items:end;gap:12px}.user-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.user-actions{grid-column:1 / -1}.user-list{display:grid;gap:12px}.user-card{display:block;min-width:0;padding:15px 16px;border-radius:14px;border:1px solid var(--border);background:var(--panel);box-shadow:var(--shadow)}.user-card.locked{border-color:#ef444457;background:linear-gradient(180deg,#ef444414,#ffffff06)}.user-card-main{display:flex;align-items:center;gap:14px;min-width:0}.user-avatar{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex:none;color:#04121a;font-size:13px;font-weight:800;background:linear-gradient(135deg,var(--cyan),var(--teal))}.user-main{flex:1;min-width:0}.user-name{display:flex;align-items:center;flex-wrap:wrap;gap:7px;min-width:0}.user-name b{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14.5px}.user-mail{margin-top:3px;color:var(--txt-faint);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-badge{font-size:10px;font-weight:750;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:999px;white-space:nowrap}.user-badge.admin{color:#bfdbfe;border:1px solid rgba(96,165,250,.3);background:#60a5fa33}.user-badge.pending{color:#fcd34d;border:1px solid rgba(245,158,11,.32);background:#f59e0b2e}.user-badge.locked{color:#fecaca;border:1px solid rgba(239,68,68,.34);background:#ef44442e}.user-meta{flex:none;min-width:140px;text-align:right}.user-meta span{display:block;color:var(--txt-faint);font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.user-meta b{display:block;margin-top:3px;color:var(--txt-dim);font-family:JetBrains Mono,monospace;font-size:12px}.user-edit-button{flex:none;padding:8px 12px;font-size:12px}.user-edit-form{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:15px;padding-top:15px;border-top:1px solid var(--border-soft)}.user-lock-toggle{grid-column:1 / -1;display:inline-flex;align-items:center;gap:9px;width:fit-content;color:var(--txt-dim);font-size:13px;font-weight:700;cursor:pointer}.user-lock-toggle input{accent-color:var(--red)}.user-lock-toggle.disabled{opacity:.5;cursor:not-allowed}@media(max-width:720px){.mail-head{flex-direction:column;align-items:stretch}.mail-test-row{align-items:stretch;grid-template-columns:1fr}.mail-settings-grid,.mail-event-grid,.user-form{grid-template-columns:1fr}.user-card-main{align-items:flex-start}.user-meta{display:none}.user-edit-form{grid-template-columns:1fr}}button.sub-del{border:0;background:transparent;padding:0}button.rk-del,.rd .rm{background:transparent;border:0;padding:0}.rd--nas .rd-face{background-color:#10141b;background-image:repeating-linear-gradient(0deg,rgba(56,189,248,.22) 0 2px,transparent 2px 5px)}.rd--pi .rd-face{background-color:#10141b;background-image:radial-gradient(circle,rgba(255,255,255,.13) 1px,transparent 1.4px) 0 0 / 6px 6px}.rd--pimount{padding:0 12px 0 14px}.rd--pimount .rd-ico{align-self:center}.pimount-body{flex:1;display:flex;align-items:stretch;min-width:0;height:100%;padding:5px 8px}.pi-slots{display:flex;gap:8px;width:100%;height:100%;align-items:stretch}.pi-slot{flex:1;min-width:0;border-radius:5px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:3px;font-size:10px;position:relative;border:1px solid rgba(255,255,255,.12)}.pi-slot.empty{border-style:dashed;color:#6b7280;background:#00000040}.pi-slot.filled{background:linear-gradient(180deg,#3a414d,#252b34);color:#e6eaf0;cursor:grab;box-shadow:inset 0 1px #ffffff26}.pi-slot.filled:active{cursor:grabbing}.pi-slot.drop-target{border-color:#34d399;border-style:solid;background:#34d39924}.pi-slot .pi-led{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 6px #22c55e;flex:none}.pi-slot .pi-name{white-space:normal;text-align:center;font-size:10px;line-height:1.12;font-weight:600;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}.pi-slot .pi-rm{position:absolute;top:0;right:3px;font-size:11px;color:#ffffff8c;cursor:pointer;opacity:0;line-height:1;background:transparent;border:0;padding:0}.pi-slot.filled:hover .pi-rm{opacity:1}.pi-palette{margin:0 0 20px;padding:13px 16px;border:1px solid var(--border);border-radius:14px;background:var(--panel)}.pp-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--txt-faint);font-weight:600;display:block;margin-bottom:10px}.pp-list{display:flex;flex-wrap:wrap;gap:9px;min-height:38px;border-radius:10px;padding:4px;align-items:center}.pp-list.drop-target{outline:2px dashed rgba(52,211,153,.5);outline-offset:-2px}.pp-pi{display:flex;align-items:center;gap:8px;padding:8px 13px;border-radius:9px;background:linear-gradient(180deg,#3a414d,#252b34);color:#e6eaf0;font-size:12.5px;font-weight:600;cursor:grab;border:1px solid var(--border-soft);box-shadow:inset 0 1px #ffffff1f}.pp-pi:active{cursor:grabbing}.pp-pi .pi-led{width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 6px #22c55e;flex:none}.pp-empty{font-size:12px;color:var(--txt-faint);padding-left:4px}.rack-add select option{background:#11151d;color:#eef1f6}.svc-filters{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap;align-items:center}.svc-filter{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:11px;font-size:13px;font-weight:600;background:var(--panel);border:1px solid var(--border);color:var(--txt-dim);cursor:pointer;transition:.15s}.svc-filter .d{width:9px;height:9px;border-radius:50%;flex:none}.svc-filter.run .d{background:var(--green)}.svc-filter.warn .d{background:var(--amber)}.svc-filter.stop .d{background:var(--red)}.svc-filter:not(.on){opacity:.4}.svc-filter.on{color:var(--txt)}.svc-filter.on.run{border-color:#22c55e73}.svc-filter.on.warn{border-color:#f59e0b73}.svc-filter.on.stop{border-color:#ef444473}.svc-card{padding:16px 18px;margin-bottom:14px}.svc-head{width:100%;display:flex;align-items:center;gap:11px;margin-bottom:13px;padding:0;border:0;background:transparent;color:inherit;cursor:pointer;-webkit-user-select:none;user-select:none;text-align:left;font:inherit}.svc-head .led{width:11px;height:11px;border-radius:50%;flex:none}.svc-head .led.run{background:var(--green);box-shadow:0 0 8px var(--green)}.svc-head .led.warn{background:var(--amber);box-shadow:0 0 8px var(--amber)}.svc-head .led.stop{background:var(--red);box-shadow:0 0 8px var(--red)}.svc-head b{font-size:14.5px;font-weight:600}.svc-head .grp{font-size:11.5px;color:var(--txt-faint)}.svc-chev{width:15px;height:15px;stroke:var(--txt-faint);stroke-width:2;fill:none;transition:transform .2s;flex:none}.svc-card .svc-head .svc-chev{transform:rotate(90deg)}.svc-card.collapsed .svc-head .svc-chev{transform:rotate(0)}.svc-card.collapsed .svc-head{margin-bottom:0}.svc-card.collapsed .svc-list{display:none}.svc-cnt{margin-left:auto;font-size:10.5px;font-weight:700;padding:2px 10px;border-radius:999px;white-space:nowrap}.svc-cnt.ok{background:#22c55e24;color:#86efac;border:1px solid rgba(34,197,94,.28)}.svc-cnt.warn{background:#f59e0b29;color:#fcd34d;border:1px solid rgba(245,158,11,.3)}.svc-cnt.bad{background:#ef444429;color:#fca5a5;border:1px solid rgba(239,68,68,.32)}.svc-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:8px}.svc-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;background:#00000038;border:1px solid var(--border-soft);min-width:0}.svc-item.stop{border-color:#ef44444d;background:#ef44440f}.svc-item.warn{border-color:#f59e0b4d;background:#f59e0b0d}.svc-pill{font-size:9.5px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;padding:2px 8px;border-radius:6px;flex:none}.svc-pill.run{background:#22c55e29;color:#86efac}.svc-pill.warn{background:#f59e0b29;color:#fcd34d}.svc-pill.stop{background:#ef44442e;color:#fca5a5}.svc-name{font-size:13px;font-weight:500;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.svc-badge{font-size:9.5px;font-weight:600;padding:2px 8px;border-radius:999px;background:#ffffff0f;color:var(--txt-faint);border:1px solid var(--border-soft);white-space:nowrap;flex:none;max-width:48%;overflow:hidden;text-overflow:ellipsis}.svc-badge.warn{background:#f59e0b29;color:#fcd34d;border-color:#f59e0b4d}.svc-badge.stop{background:#ef444429;color:#fca5a5;border-color:#ef44444d}.svc-empty{font-size:12.5px;color:var(--txt-faint);padding:16px;text-align:center;border:1px dashed var(--border-soft);border-radius:11px}.bk-summary{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:18px}.bk-summary .stat-pill .d.y{background:var(--amber)}.bk-group{margin-bottom:18px}.bk-card{padding:16px 18px;margin-bottom:14px}.bk-card.warn{border-color:#f59e0b47}.bk-card.crit{border-color:#ef444452}.bk-head{display:flex;align-items:center;gap:12px;margin-bottom:16px;min-width:0}.bk-head .led{width:11px;height:11px;border-radius:50%;flex:none}.bk-head .led.ok{background:var(--green);box-shadow:0 0 8px var(--green)}.bk-head .led.warn{background:var(--amber);box-shadow:0 0 8px var(--amber)}.bk-head .led.crit{background:var(--red);box-shadow:0 0 8px var(--red)}.bk-title{flex:1;min-width:0}.bk-title b{display:block;font-size:14.5px;font-weight:650;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bk-title span{display:block;margin-top:2px;font-size:11.5px;color:var(--txt-faint)}.bk-badge{margin-left:auto;font-size:10px;font-weight:750;letter-spacing:.05em;text-transform:uppercase;padding:3px 10px;border-radius:999px;white-space:nowrap;flex:none}.bk-badge.ok{background:#22c55e29;color:#86efac;border:1px solid rgba(34,197,94,.3)}.bk-badge.warn{background:#f59e0b29;color:#fcd34d;border:1px solid rgba(245,158,11,.3)}.bk-badge.crit{background:#ef44442e;color:#fca5a5;border:1px solid rgba(239,68,68,.35)}.bk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px 20px}.bk-item.wide{grid-column:span 2}.bk-item .k{font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--txt-faint);margin-bottom:4px}.bk-item .v{font-size:13.5px;font-weight:650;min-width:0;overflow:hidden;text-overflow:ellipsis}.bk-message{margin-top:15px;padding:10px 12px;border-radius:10px;border:1px solid var(--border-soft);background:#0000002e;color:var(--txt-dim);font-size:12.5px}.bk-toggle{margin-top:13px;padding:7px 11px;border-radius:9px;border:1px solid var(--border-soft);background:#ffffff0d;color:var(--txt-dim);font-size:12px;font-weight:700;cursor:pointer}.bk-toggle:hover{color:var(--txt);border-color:var(--border)}.bk-events{display:grid;gap:8px;margin-top:13px}.bk-event{display:grid;grid-template-columns:10px 1fr;gap:10px;padding:9px 11px;border-radius:10px;border:1px solid var(--border-soft);background:#0000002e}.bk-event .dot{width:8px;height:8px;border-radius:50%;margin-top:5px}.bk-event.ok .dot{background:var(--green)}.bk-event.warn .dot{background:var(--amber)}.bk-event.crit .dot{background:var(--red)}.bk-event b{display:block;font-size:12.5px;font-weight:700}.bk-event span{display:block;margin-top:2px;color:var(--txt-faint);font-family:JetBrains Mono,monospace;font-size:10.5px}.bk-event p{margin:4px 0 0;color:var(--txt-dim);font-size:12px}.upd-summary .stat-pill .d.y{background:var(--amber)}.upd-card{padding:18px 20px;margin-bottom:14px}.upd-card.warn{border-color:#f59e0b47}.upd-card.crit{border-color:#ef44445c}.upd-card.unknown{border-color:#60a5fa3d}.upd-card .bk-head .led.upd{background:var(--amber);box-shadow:0 0 8px var(--amber)}.upd-card .bk-head .led.crit{background:var(--red);box-shadow:0 0 9px #ef4444b3}.upd-card .bk-head .led.unknown{background:#60a5fa;box-shadow:0 0 8px #60a5fa8c}.bk-badge.upd{background:#f59e0b29;color:#fcd34d;border:1px solid rgba(245,158,11,.3)}.bk-badge.crit{background:#ef444429;color:#fecaca;border:1px solid rgba(239,68,68,.34)}.bk-badge.unknown{background:#60a5fa24;color:#bfdbfe;border:1px solid rgba(96,165,250,.26)}.upd-group{border:1px solid var(--border-soft);border-radius:12px;padding:12px 15px;margin-top:13px;background:#0000002e}.upd-group.docker{border-color:#38bdf838;background:#38bdf80d}.upd-group.kernel{border-color:#94a3b833;background:#94a3b80b}.upd-ghead{width:100%;display:flex;align-items:center;gap:9px;min-height:24px;color:var(--txt);cursor:pointer;text-align:left}.upd-ghead svg{width:17px;height:17px;stroke:var(--txt-dim);stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round;flex:none}.upd-group.docker .upd-ghead svg{stroke:#7dd3fc}.upd-group.kernel .upd-ghead svg{stroke:#cbd5e1}.upd-ghead .t{font-size:13px;font-weight:600}.upd-gcount{margin-left:auto;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 9px;border-radius:999px}.upd-ghead .chev{width:15px;height:15px;stroke:var(--txt-faint);stroke-width:2;fill:none;transition:transform .15s ease,stroke .15s ease}.upd-ghead:hover .chev{stroke:var(--txt)}.upd-group.open .upd-ghead{margin-bottom:6px}.upd-group.open .upd-ghead .chev{transform:rotate(90deg)}.upd-gcount.ok{background:#22c55e24;color:#86efac;border:1px solid rgba(34,197,94,.28)}.upd-gcount.upd{background:#f59e0b29;color:#fcd34d;border:1px solid rgba(245,158,11,.3)}.upd-gcount.crit{background:#ef444429;color:#fecaca;border:1px solid rgba(239,68,68,.34)}.upd-gcount.unknown{background:#60a5fa24;color:#bfdbfe;border:1px solid rgba(96,165,250,.26)}.upd-table{display:flex;flex-direction:column;gap:2px}.kernel-panel{display:flex;flex-direction:column;gap:12px;padding-top:6px}.kernel-state{display:flex;align-items:center;gap:10px;min-width:0}.kernel-reason{color:var(--txt-faint);font-family:JetBrains Mono,monospace;font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kernel-facts{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.kernel-fact{min-width:0;border:1px solid var(--border-soft);border-radius:10px;padding:10px 11px;background:#00000024}.kernel-fact span{display:block;color:var(--txt-faint);font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:5px}.kernel-fact b{display:block;color:var(--txt);font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kernel-packages{padding-top:2px}.upd-row{display:grid;grid-template-columns:1.6fr 1fr 1fr auto;gap:14px;align-items:center;padding:10px 0;border-top:1px solid var(--border-soft);min-width:0}.upd-row.head{border-top:0;padding-bottom:8px}.upd-row.head span{color:var(--txt-faint);font-size:10.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.upd-name{font-size:13.5px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upd-name .img{display:block;font-size:10.5px;color:var(--txt-faint);font-weight:400;font-family:JetBrains Mono,monospace;margin-top:2px}.ver{font-family:JetBrains Mono,monospace;font-size:13px;color:var(--txt-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ver.old{color:#fcd34d}.ver.new{color:#86efac}.ver.unknown{color:#bfdbfe}.ver.crit{color:#fecaca}.upd-badge{font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 9px;border-radius:999px}.upd-badge.ok{background:#22c55e24;color:#86efac;border:1px solid rgba(34,197,94,.28)}.upd-badge.upd{background:#f59e0b29;color:#fcd34d;border:1px solid rgba(245,158,11,.3)}.upd-badge.crit{background:#ef444429;color:#fecaca;border:1px solid rgba(239,68,68,.34)}.upd-badge.unknown{background:#60a5fa24;color:#bfdbfe;border:1px solid rgba(96,165,250,.26)}.upd-note{color:var(--txt-faint);font-size:12px;padding:9px 0 0}.tag.unknown{background:#60a5fa24;color:#bfdbfe;border-color:#60a5fa42}.upd-empty{color:var(--txt-faint);font-size:12px;padding:12px 13px;border:1px dashed var(--border-soft);border-radius:11px;background:#0000001f}@media(max-width:720px){.kernel-facts{grid-template-columns:1fr}.svc-head{flex-wrap:wrap}.svc-cnt{margin-left:0}.svc-list{grid-template-columns:1fr}.bk-head{flex-wrap:wrap}.bk-badge{margin-left:0}.bk-item.wide{grid-column:span 1}.upd-row{grid-template-columns:1fr;gap:5px}.upd-row.head{display:none}}
