*{box-sizing:border-box}html,body,#app{width:100%;height:100%;margin:0;overflow:hidden}.boot-loading{min-height:100vh;min-height:100dvh;display:grid;place-items:center;color:rgba(223,251,255,.75);font-size:15px;letter-spacing:2px;background:linear-gradient(180deg,#02060c,#010408)}body{font-family:Microsoft YaHei,PingFang SC,Inter,sans-serif;color:#dffbff;background:linear-gradient(180deg,rgba(1,4,10,.96),rgba(0,2,6,.98)),radial-gradient(circle at 50% -10%,rgba(63,214,255,.06),transparent 28%),radial-gradient(circle at 10% 20%,rgba(0,255,170,.04),transparent 20%),radial-gradient(circle at 90% 20%,rgba(120,92,255,.04),transparent 20%),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1200' height='800' viewBox='0 0 1200 800'%3E%3Cdefs%3E%3ClinearGradient id='g' x1='0' y1='0' x2='1' y2='1'%3E%3Cstop offset='0%25' stop-color='%232beeff' stop-opacity='.08'/%3E%3Cstop offset='100%25' stop-color='%238f7bff' stop-opacity='.01'/%3E%3C/linearGradient%3E%3C/defs%3E%3Cg fill='none' stroke='url(%23g)' stroke-width='1.2'%3E%3Cpath d='M40 120 C180 20, 320 20, 460 120 S740 220, 880 120 S1060 20, 1160 120'/%3E%3Cpath d='M20 620 C180 520, 340 520, 500 620 S820 720, 980 620 S1140 520, 1180 620'/%3E%3Cpath d='M120 60 L1080 60'/%3E%3Cpath d='M80 740 L1120 740'/%3E%3Cpath d='M120 160 L320 160 L320 360 L120 360 Z'/%3E%3Cpath d='M880 420 L1080 420 L1080 620 L880 620 Z'/%3E%3C/g%3E%3Cg opacity='.15' fill='%232beeff'%3E%3Ccircle cx='170' cy='180' r='4'/%3E%3Ccircle cx='320' cy='360' r='4'/%3E%3Ccircle cx='880' cy='420' r='4'/%3E%3Ccircle cx='1040' cy='620' r='4'/%3E%3C/g%3E%3C/svg%3E") center center / cover no-repeat,linear-gradient(180deg,#02060c,#010408)}.app-shell,.screen{width:100vw;height:100vh}.login-page{position:relative;width:100%;height:100%;display:grid;place-items:center;padding:24px;overflow:hidden;background:radial-gradient(circle at 50% 42%,rgba(43,238,255,.12),transparent 38%),radial-gradient(circle at 18% 78%,rgba(88,255,176,.05),transparent 24%),radial-gradient(circle at 82% 22%,rgba(120,92,255,.05),transparent 22%)}.login-bg-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(43,238,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(43,238,255,.035) 1px,transparent 1px);background-size:56px 56px;-webkit-mask-image:radial-gradient(circle at center,#000 24%,transparent 72%);mask-image:radial-gradient(circle at center,#000 24%,transparent 72%);pointer-events:none}.login-card{position:relative;width:min(440px,100%);padding:34px 32px 28px;border-radius:16px;background:linear-gradient(180deg,rgba(6,16,30,.97),rgba(3,10,20,.99));border:1px solid rgba(60,130,180,.32);box-shadow:0 24px 60px rgba(0,0,0,.38),inset 0 0 24px rgba(43,238,255,.03);overflow:hidden}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 8%,rgba(43,238,255,.45) 50%,transparent 92%);pointer-events:none}.login-brand{text-align:center}.login-logo{width:56px;height:56px;margin:0 auto 14px;display:grid;place-items:center;border-radius:14px;color:#2beeff;background:rgba(43,238,255,.08);border:1px solid rgba(43,238,255,.18);box-shadow:0 0 24px rgba(43,238,255,.12)}.login-logo svg{width:30px;height:30px}.login-logo.logo-has-image,.topbar-logo.logo-has-image,.logo-upload-preview.logo-has-image{--logo-surface-radius: 10px;position:relative;display:flex;align-items:center;justify-content:center;padding:2px;border:none;color:inherit;overflow:hidden;isolation:isolate;background:linear-gradient(145deg,rgba(43,238,255,.62),rgba(88,255,176,.38) 42%,rgba(43,238,255,.28));box-shadow:0 0 0 1px rgba(43,238,255,.14),0 10px 32px rgba(0,0,0,.28),0 0 40px rgba(43,238,255,.1);animation:logoReveal .45s ease-out both}.login-logo.logo-has-image:before,.topbar-logo.logo-has-image:before,.logo-upload-preview.logo-has-image:before{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;border-radius:var(--logo-surface-radius);background:linear-gradient(180deg,#fff,#f8fbfe 58%,#eef4fa);box-shadow:inset 0 1px rgba(255,255,255,.96),inset 0 -1px rgba(20,50,90,.05);z-index:0}.login-logo.logo-has-image:after,.topbar-logo.logo-has-image:after,.logo-upload-preview.logo-has-image:after{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;border-radius:var(--logo-surface-radius);background:linear-gradient(125deg,rgba(255,255,255,.78) 0%,rgba(255,255,255,.18) 34%,transparent 62%);pointer-events:none;z-index:2}.login-logo.logo-has-image img,.topbar-logo.logo-has-image img,.logo-upload-preview.logo-has-image img{position:relative;z-index:1;width:100%;height:100%;object-fit:contain;display:block;filter:contrast(1.05) saturate(1.08)}.login-logo.logo-has-image{--logo-surface-radius: 12px;width:min(252px,82vw);height:auto;aspect-ratio:1996 / 1340;margin:0 auto 20px;border-radius:14px}.login-logo.logo-has-image img{padding:12px 16px}.topbar-logo.logo-has-image,.topbar-logo.preview.logo-has-image{--logo-surface-radius: 8px;width:144px;height:52px;border-radius:10px;flex-shrink:0;box-shadow:0 0 0 1px rgba(43,238,255,.12),0 6px 20px rgba(0,0,0,.24),0 0 28px rgba(43,238,255,.08)}.topbar-logo.logo-has-image img{padding:5px 10px;background:unset}.topbar-logo.logo-has-image:before,.topbar-logo.preview.logo-has-image:before{background:transparent;box-shadow:none}.topbar-logo.logo-has-image:after,.topbar-logo.preview.logo-has-image:after{display:none}.logo-upload-preview.logo-has-image{--logo-surface-radius: 11px;width:min(260px,100%);height:auto;aspect-ratio:1996 / 1340;flex-shrink:0;border-radius:13px}.logo-upload-preview.logo-has-image img{padding:12px 16px}@keyframes logoReveal{0%{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.login-brand h1{margin:0;font-size:22px;font-weight:800;color:#fff;letter-spacing:2px;line-height:1.35;text-shadow:0 0 20px rgba(43,238,255,.22)}.login-title-line{width:120px;height:2px;margin:12px auto 10px;background:linear-gradient(90deg,transparent,rgba(43,238,255,.75),transparent)}.login-brand p{color:rgba(210,236,248,.68);margin:0;font-size:13px;letter-spacing:1px}.login-form{display:grid;gap:16px;margin-top:28px}.login-form label{display:grid;gap:8px}.login-form span{color:rgba(210,236,248,.82);font-size:12px;letter-spacing:.5px}.login-form input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid rgba(60,130,180,.24);background:rgba(255,255,255,.03);color:#fff;outline:none;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.login-form input::placeholder{color:rgba(255,255,255,.28)}.login-form input:focus{border-color:rgba(43,238,255,.42);background:rgba(43,238,255,.04);box-shadow:0 0 0 3px rgba(43,238,255,.08)}.login-password-wrap{position:relative;display:flex;align-items:center}.login-password-wrap input{padding-right:58px}.login-password-toggle{position:absolute;right:8px;border:0;background:rgba(43,238,255,.08);color:rgba(210,236,248,.78);font-size:11px;padding:5px 8px;border-radius:6px;cursor:pointer;transition:color .2s ease,background .2s ease}.login-password-toggle:hover{color:#2beeff;background:rgba(43,238,255,.14)}.login-submit{margin-top:4px;border:0;border-radius:10px;padding:13px 16px;background:linear-gradient(90deg,#2beeff,#58ffb0);color:#04111f;font-size:15px;font-weight:700;letter-spacing:4px;cursor:pointer;transition:transform .15s ease,opacity .2s ease,box-shadow .2s ease;box-shadow:0 8px 24px rgba(43,238,255,.18)}.login-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 28px rgba(43,238,255,.24)}.login-submit:disabled{opacity:.72;cursor:not-allowed}.login-hints{margin-top:22px;padding-top:18px;border-top:1px solid rgba(43,238,255,.08)}.login-hints-label{display:block;margin-bottom:10px;font-size:11px;color:rgba(210,236,248,.48);letter-spacing:1px}.login-hint-chips{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.login-hint-chip{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:9px 10px;border-radius:8px;border:1px solid rgba(60,130,180,.2);background:rgba(255,255,255,.02);color:rgba(210,236,248,.82);cursor:pointer;text-align:left;transition:border-color .2s ease,background .2s ease,transform .15s ease}.login-hint-chip:hover{border-color:rgba(43,238,255,.28);background:rgba(43,238,255,.05);transform:translateY(-1px)}.login-hint-chip strong{font-size:12px;color:#eafcff;font-weight:600}.login-hint-chip span{font-size:11px;color:rgba(43,238,255,.78);font-family:Consolas,Courier New,monospace}.login-error{margin:14px 0 0;padding:10px 12px;border-radius:8px;font-size:12px;color:#ffb14a;background:rgba(255,177,74,.08);border:1px solid rgba(255,177,74,.18)}.screen{padding:18px 18px 16px;display:flex;flex-direction:column;position:relative}.fancy-topbar{position:relative;flex:0 0 82px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;margin-bottom:16px;padding:0 24px;background:linear-gradient(180deg,rgba(6,16,30,.98),rgba(3,10,20,.99));border:1px solid rgba(60,130,180,.36);border-radius:8px;box-shadow:0 8px 28px rgba(0,0,0,.38);overflow:hidden}.fancy-topbar:before,.card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 8%,rgba(43,238,255,.42) 50%,transparent 92%);pointer-events:none;z-index:1}.fancy-topbar:after,.card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;z-index:0;box-shadow:inset 0 0 24px rgba(43,238,255,.03)}.fancy-topbar>*{position:relative;z-index:2}.topbar-side{display:flex;align-items:center;min-width:0}.left-side{justify-content:flex-start}.right-side{justify-content:flex-end}.topbar-brand{display:flex;align-items:center;gap:0;padding-right:2px}.topbar-logo{width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:linear-gradient(135deg,rgba(43,238,255,.12),rgba(43,238,255,.04));border:1px solid rgba(43,238,255,.22);color:#2beeff;box-shadow:0 0 20px rgba(43,238,255,.12);overflow:hidden}.topbar-logo svg{width:32px;height:32px}.topbar-user-panel{display:flex;flex-direction:column;align-items:flex-end;gap:8px;min-width:220px;padding:4px 0}.topbar-user-card{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border-radius:8px;background:linear-gradient(135deg,rgba(43,238,255,.08),rgba(43,238,255,.02));border:1px solid rgba(43,238,255,.18);box-shadow:inset 0 0 20px rgba(43,238,255,.04)}.topbar-user-avatar{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:rgba(88,255,176,.08);border:1px solid rgba(88,255,176,.22);flex-shrink:0}.topbar-user-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.topbar-user-info strong{font-size:14px;font-weight:700;color:#eafcff;letter-spacing:.5px;line-height:1.2}.topbar-user-info span{font-size:11px;color:rgba(150,190,210,.72);letter-spacing:.5px}.topbar-tag{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:6px;background:rgba(43,238,255,.06);border:1px solid rgba(43,238,255,.16);font-size:13px;font-weight:600;color:rgba(210,236,248,.92);letter-spacing:1px;white-space:nowrap}.topbar-tag-dot{width:7px;height:7px;border-radius:50%;background:#58ffb0;box-shadow:0 0 10px rgba(88,255,176,.55);flex-shrink:0}.topbar-center{display:flex;align-items:center;justify-content:center;gap:18px;z-index:1;min-width:0}.topbar-deco{width:56px;height:1px;background:linear-gradient(90deg,transparent,rgba(43,238,255,.45));flex-shrink:0}.topbar-deco:last-child{background:linear-gradient(270deg,transparent,rgba(43,238,255,.45))}.topbar-title-wrap{display:flex;flex-direction:column;align-items:center;min-width:0}.topbar-title{font-size:30px;font-weight:700;color:rgba(210,236,248,.88);letter-spacing:4px;white-space:nowrap;line-height:1.1;text-shadow:0 0 18px rgba(43,238,255,.14),0 1px 1px rgba(0,0,0,.12)}.topbar-title-line{width:100%;min-width:220px;height:2px;margin-top:7px;background:linear-gradient(90deg,transparent,rgba(43,238,255,.7),transparent);opacity:.85}.topbar-meta{display:flex;flex-direction:column;align-items:flex-end;gap:5px;padding:6px 0}.topbar-user-panel .logout-link{flex-shrink:0;padding:4px 0 4px 10px;margin-left:auto;border-left:1px solid rgba(60,130,180,.22);white-space:nowrap}.topbar-time{font-size:15px;font-weight:700;color:#eafcff;letter-spacing:.5px;font-variant-numeric:tabular-nums;text-shadow:0 0 14px rgba(43,238,255,.22)}.logout-link{border:0;background:none;padding:0;font-size:12px;color:rgba(150,180,205,.78);cursor:pointer;letter-spacing:1px;line-height:1.2;transition:color .2s ease}.logout-link:hover{color:#2beeff}.layout{flex:1;min-height:0;display:grid;grid-template-columns:330px 1fr 330px;gap:16px;position:relative;z-index:1}.dashboard-shell{flex:1;min-height:0;display:flex;flex-direction:column;gap:12px}.device-switcher{flex:0 0 auto;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:10px 14px;border-radius:8px;background:linear-gradient(180deg,rgba(6,16,30,.98),rgba(3,10,20,.99));border:1px solid rgba(60,130,180,.32);overflow-x:auto}.device-switcher-left{display:flex;align-items:center;gap:14px;flex-shrink:0}.device-switcher-label{flex-shrink:0;font-size:12px;color:rgba(210,236,248,.58);letter-spacing:1px}.device-switcher-tabs{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.feature-switcher-tabs{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;min-width:0;padding:6px 10px;border-radius:10px;background:linear-gradient(180deg,rgba(8,22,40,.72),rgba(4,12,24,.55));border:1px solid rgba(43,238,255,.12);box-shadow:inset 0 1px rgba(255,255,255,.04),0 4px 18px rgba(0,0,0,.18)}.feature-tab{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-width:118px;padding:9px 16px;border-radius:8px;border:1px solid rgba(60,130,180,.28);background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02)),linear-gradient(135deg,rgba(var(--tab-rgb),.14),rgba(var(--tab-rgb),.04));color:rgba(232,247,255,.9);font-size:12px;font-weight:500;letter-spacing:.5px;cursor:pointer;white-space:nowrap;overflow:hidden;isolation:isolate;box-shadow:inset 0 1px rgba(255,255,255,.08),0 2px 10px rgba(0,0,0,.22);transition:border-color .2s ease,background .2s ease,color .2s ease,box-shadow .2s ease,transform .2s ease}.feature-tab:before{content:"";position:absolute;inset:0 auto 0 0;width:3px;border-radius:8px 0 0 8px;background:linear-gradient(180deg,rgba(var(--tab-rgb),.95),rgba(var(--tab-rgb),.35));opacity:.85}.feature-tab:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 0%,rgba(var(--tab-rgb),.18),transparent 58%);opacity:.9;pointer-events:none;z-index:-1}.feature-tab-icon{position:relative;width:7px;height:7px;border-radius:50%;flex-shrink:0;background:rgb(var(--tab-rgb));box-shadow:0 0 10px rgba(var(--tab-rgb),.65)}.feature-tab-label{position:relative}.feature-tab--commands{--tab-rgb: 43, 238, 255}.feature-tab--alarms{--tab-rgb: 255, 177, 74}.feature-tab--runtime{--tab-rgb: 88, 255, 176}.feature-tab--events{--tab-rgb: 142, 124, 255}.feature-tab:hover{border-color:rgba(var(--tab-rgb),.55);color:#fff;transform:translateY(-1px);box-shadow:inset 0 1px rgba(255,255,255,.1),0 0 0 1px rgba(var(--tab-rgb),.12),0 6px 18px rgba(var(--tab-rgb),.18)}.feature-tab.active{border-color:rgba(var(--tab-rgb),.62);background:linear-gradient(180deg,rgba(var(--tab-rgb),.24),rgba(var(--tab-rgb),.08)),linear-gradient(135deg,rgba(var(--tab-rgb),.18),rgba(4,12,24,.2));color:#fff;box-shadow:inset 0 0 0 1px rgba(var(--tab-rgb),.18),0 0 20px rgba(var(--tab-rgb),.22),0 4px 16px rgba(0,0,0,.28)}.feature-tab.active .feature-tab-icon{box-shadow:0 0 14px rgba(var(--tab-rgb),.9)}.device-switcher-mqtt{flex-shrink:0;display:inline-flex;align-items:center;gap:8px;font-size:12px;color:rgba(210,236,248,.72);white-space:nowrap}.device-tab{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:999px;border:1px solid rgba(60,130,180,.24);background:rgba(255,255,255,.03);color:rgba(210,236,248,.82);font-size:13px;cursor:pointer;white-space:nowrap;transition:border-color .2s ease,background .2s ease,color .2s ease,box-shadow .2s ease}.device-tab:hover{border-color:rgba(43,238,255,.32);color:#2beeff}.device-tab.active{border-color:rgba(43,238,255,.45);background:rgba(43,238,255,.12);color:#2beeff;box-shadow:0 0 16px rgba(43,238,255,.12)}.device-tab-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.device-tab-dot.on{background:#58ffb0;box-shadow:0 0 8px rgba(88,255,176,.55)}.device-tab-dot.off{background:#ffb14a;box-shadow:0 0 8px rgba(255,177,74,.35)}.admin-page{flex:1;min-height:0;overflow:hidden;padding:0}.admin-layout{display:grid;grid-template-columns:240px 1fr;gap:0;height:100%;min-height:0;border-radius:8px;overflow:hidden;border:1px solid rgba(43,238,255,.22);box-shadow:0 8px 32px rgba(0,0,0,.35)}.admin-sidebar{display:flex;flex-direction:column;min-height:0;padding:12px 10px;border-radius:0;border:none;border-right:2px solid rgba(43,238,255,.45);background:linear-gradient(180deg,#030a14,#01060d);box-shadow:inset -8px 0 24px rgba(43,238,255,.06)}.admin-sidebar:before{background:linear-gradient(180deg,rgba(43,238,255,.55),rgba(88,255,176,.35));opacity:1;height:2px}.admin-sidebar:after{box-shadow:inset 0 0 40px rgba(43,238,255,.04)}.admin-sidebar-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:4px 6px 12px;margin-bottom:8px;border-bottom:1px solid rgba(43,238,255,.22)}.admin-sidebar-head h3{margin:0;font-size:15px}.admin-nav{display:flex;flex-direction:column;gap:8px;padding:0 2px;overflow-y:auto}.admin-nav-item{display:flex;flex-direction:column;align-items:flex-start;gap:4px;width:100%;padding:12px 14px;border-radius:8px;border:1px solid rgba(43,238,255,.12);background:rgba(43,238,255,.04);color:rgba(210,236,248,.82);cursor:pointer;text-align:left;transition:border-color .2s ease,background .2s ease,transform .15s ease}.admin-nav-item strong{font-size:13px;color:#eafcff;font-weight:600;letter-spacing:.5px}.admin-nav-item span{font-size:11px;color:rgba(210,236,248,.48);line-height:1.4}.admin-nav-item:hover{border-color:rgba(43,238,255,.38);background:rgba(43,238,255,.1)}.admin-nav-item.active{border-color:rgba(43,238,255,.55);background:linear-gradient(90deg,rgba(43,238,255,.22),rgba(43,238,255,.08));box-shadow:inset 4px 0 #2beeff,0 0 16px rgba(43,238,255,.12)}.admin-nav-item.active strong{color:#2beeff}.admin-content{display:flex;flex-direction:column;min-height:0;padding:12px 14px 16px;overflow:hidden;border-radius:0;border:none;background:#0e3e4a;box-shadow:inset 0 0 60px rgba(88,255,176,.04)}.admin-content:before{background:linear-gradient(90deg,rgba(88,255,176,.45),rgba(43,238,255,.3));opacity:1;height:2px}.admin-content:after{box-shadow:inset 0 0 48px rgba(255,255,255,.03)}.admin-content-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:12px;margin-bottom:4px;border-bottom:1px solid rgba(88,255,176,.22)}.admin-content-head h3{margin:0 0 4px;font-size:18px;font-weight:700;color:#fff;letter-spacing:1px}.admin-content-head p{margin:0;font-size:12px;color:rgba(210,236,248,.52)}.admin-view{flex:1;min-height:0;overflow-y:auto;padding-right:4px}.admin-quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}.admin-quick-item{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:14px;border-radius:8px;border:1px solid rgba(60,130,180,.2);background:rgba(255,255,255,.02);color:rgba(210,236,248,.82);cursor:pointer;text-align:left;transition:border-color .2s ease,background .2s ease,transform .15s ease}.admin-quick-item:hover{border-color:rgba(43,238,255,.28);background:rgba(43,238,255,.05);transform:translateY(-1px)}.admin-quick-item strong{font-size:13px;color:#eafcff}.admin-quick-item span{font-size:11px;color:rgba(210,236,248,.48)}.admin-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}.admin-stats-2{grid-template-columns:repeat(2,1fr)}.topic-value{font-size:14px!important;word-break:break-all;line-height:1.4}.admin-stat{padding:14px 16px;border-radius:8px;background:rgba(255,255,255,.02);border:1px solid rgba(60,130,180,.22)}.admin-stat-label{display:block;font-size:11px;color:rgba(210,236,248,.58);letter-spacing:1px;margin-bottom:8px}.admin-stat-value{display:block;font-size:28px;font-weight:800;color:#2beeff;line-height:1.1;text-shadow:0 0 16px rgba(43,238,255,.22)}.admin-stat-value.sm{font-size:18px}.admin-stat-sub{display:block;margin-top:6px;font-size:11px;color:rgba(210,236,248,.52)}.mqtt-status-row{display:flex;align-items:center;gap:8px;margin-bottom:2px}.mqtt-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.mqtt-dot.on{background:#58ffb0;box-shadow:0 0 10px rgba(88,255,176,.55)}.mqtt-dot.off{background:#ffb14a;box-shadow:0 0 10px rgba(255,177,74,.35)}.admin-section{margin-top:20px}.admin-section-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(43,238,255,.08)}.admin-section-head h4{margin:0;font-size:14px;font-weight:600;color:#e8f4fc;letter-spacing:1px}.admin-section-head h4:before{content:"";display:inline-block;width:3px;height:14px;margin-right:8px;vertical-align:-2px;border-radius:1px;background:linear-gradient(180deg,#2beeff,#58ffb0)}.admin-section-head span{font-size:12px;color:rgba(210,236,248,.48)}.admin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.admin-grid-2{grid-template-columns:1fr 1fr}.admin-panel{padding:14px 16px;border-radius:8px;background:rgba(255,255,255,.02);border:1px solid rgba(60,130,180,.22)}.admin-panel-full{margin-top:12px}.admin-panel p{margin:0;color:rgba(210,236,248,.72);font-size:12px;line-height:1.6}.admin-form{display:grid;grid-template-columns:repeat(4,1fr) auto;gap:10px;align-items:end}.admin-form label{display:grid;gap:6px}.admin-form label span{font-size:11px;color:rgba(210,236,248,.62);letter-spacing:.5px}.admin-form input,.admin-form select,.mqtt-form input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid rgba(60,130,180,.24);background:rgba(255,255,255,.03);color:#fff;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.admin-form input:focus,.admin-form select:focus,.mqtt-form input:focus{border-color:rgba(43,238,255,.38);box-shadow:0 0 0 3px rgba(43,238,255,.08)}.admin-form-btn,.mqtt-connect-btn{border:0;border-radius:8px;padding:10px 16px;white-space:nowrap;background:linear-gradient(90deg,#2beeff,#58ffb0);color:#04111f;font-weight:700;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease}.admin-form-btn:hover,.mqtt-connect-btn:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(43,238,255,.18)}.settings-form{grid-template-columns:repeat(2,minmax(220px,1fr)) auto;margin-top:12px}.settings-logo-field{grid-column:1 / -1;display:grid;gap:6px}.settings-logo-field>span{font-size:11px;color:rgba(210,236,248,.62);letter-spacing:.5px}.logo-upload-box{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding:14px 16px;border-radius:8px;background:rgba(255,255,255,.02);border:1px dashed rgba(60,130,180,.28)}.logo-upload-preview{width:96px;height:96px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:linear-gradient(135deg,rgba(43,238,255,.12),rgba(43,238,255,.04));border:1px solid rgba(43,238,255,.22);color:#2beeff;overflow:hidden;flex-shrink:0}.logo-upload-preview svg{width:48px;height:48px}.logo-upload-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.logo-upload-btn,.logo-reset-btn{padding:8px 14px;border-radius:8px;font-size:12px;cursor:pointer;transition:border-color .2s ease,color .2s ease,opacity .2s ease}.logo-upload-btn{border:0;background:linear-gradient(90deg,#2beeff,#58ffb0);color:#04111f;font-weight:700}.logo-upload-btn:disabled,.logo-reset-btn:disabled{opacity:.55;cursor:not-allowed}.logo-reset-btn{border:1px solid rgba(60,130,180,.28);background:rgba(255,255,255,.04);color:#d2ecf8}.logo-reset-btn:hover:not(:disabled){border-color:rgba(43,238,255,.45);color:#2beeff}.logo-upload-tip{width:100%;margin:0;font-size:11px;color:rgba(150,190,210,.68)}.settings-tip{margin-top:8px;font-size:12px;color:rgba(210,236,248,.62)}.settings-message{grid-column:1 / -1;margin:0;font-size:12px}.settings-message.success{color:#58ffb0}.settings-message.error{color:#ffb14a}.settings-topbar-preview{display:flex;align-items:center;gap:16px;margin-top:12px;padding:16px 18px;border-radius:8px;background:rgba(255,255,255,.02);border:1px solid rgba(60,130,180,.18)}.topbar-logo.preview{flex-shrink:0}.settings-preview-title{font-size:22px;font-weight:800;color:#fff;letter-spacing:3px;text-shadow:0 0 18px rgba(43,238,255,.24)}.mqtt-form{display:grid;gap:10px;margin-top:10px}.mqtt-form-grid{grid-template-columns:repeat(3,1fr);align-items:end}.mqtt-form-grid .mqtt-connect-btn{grid-column:1 / -1;justify-self:start}.mqtt-platform-panel{margin-bottom:12px}.mqtt-platform-info{display:grid;gap:10px;margin:10px 0 14px;padding:12px 14px;border-radius:8px;background:rgba(255,255,255,.02);border:1px solid rgba(60,130,180,.16)}.mqtt-platform-row{display:flex;align-items:center;gap:12px;font-size:12px}.mqtt-platform-row span{flex:0 0 72px;color:rgba(210,236,248,.58)}.mqtt-platform-row a{color:#2beeff;text-decoration:none}.mqtt-platform-row a:hover{text-decoration:underline}.mqtt-platform-row strong{color:#eafcff;font-weight:600}.mqtt-form label{display:grid;gap:6px}.mqtt-form label span{font-size:11px;color:rgba(210,236,248,.58)}.device-table{margin-top:10px;border-radius:8px;overflow:hidden;border:1px solid rgba(60,130,180,.16)}.device-table-head,.device-table-row{display:grid;grid-template-columns:1fr 1fr .7fr .8fr;gap:8px;padding:9px 12px;font-size:12px}.device-table-head{background:rgba(255,255,255,.04);color:rgba(210,236,248,.58)}.device-table-row{border-top:1px solid rgba(255,255,255,.05);color:rgba(255,255,255,.88);align-items:center}.device-table-row.clickable{cursor:pointer;transition:background .2s ease}.device-table-row.clickable:hover{background:rgba(43,238,255,.05)}.device-table-row.clickable.active{background:rgba(43,238,255,.1)}.device-data-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:4px}.device-data-head h4{margin:0}.device-switcher-tabs.compact{gap:8px}.device-switcher-tabs.compact .device-tab{padding:5px 12px;font-size:11px}.device-time{color:rgba(43,238,255,.72);font-variant-numeric:tabular-nums}.telemetry-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:10px}.telemetry-item{padding:12px;border-radius:8px;background:rgba(255,255,255,.02);border:1px solid rgba(60,130,180,.18)}.telemetry-item span{display:block;font-size:11px;color:rgba(210,236,248,.58);margin-bottom:6px}.telemetry-item strong{font-size:16px;color:#2beeff;font-weight:700}.telemetry-item strong.warn{color:#ffb14a}.warning-binary-line{margin:0 0 10px;font-size:11px;color:rgba(210,236,248,.62);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;word-break:break-all}.warning-bit-table{margin-top:8px;border:1px solid rgba(60,130,180,.18);border-radius:8px;overflow:hidden}.warning-bit-head,.warning-bit-row{display:grid;grid-template-columns:72px 1fr 48px 72px;gap:8px;align-items:center;padding:8px 12px;font-size:12px}.warning-bit-head{background:rgba(43,238,255,.08);color:rgba(210,236,248,.72);font-weight:600}.warning-bit-row{border-top:1px solid rgba(60,130,180,.12);color:rgba(230,245,255,.88)}.warning-bit-row:nth-child(2n){background:rgba(255,255,255,.02)}.state-pill.sm{padding:2px 8px;font-size:11px;justify-self:start}.message-panel{padding-bottom:12px}.message-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.message-panel-head h4{margin:0}.message-panel-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.message-panel-meta{font-size:12px;color:rgba(210,236,248,.62)}.message-refresh-btn{padding:5px 12px;border-radius:6px;border:1px solid rgba(60,130,180,.28);background:rgba(43,238,255,.08);color:#2beeff;font-size:12px;cursor:pointer}.message-refresh-btn:hover:not(:disabled){border-color:rgba(43,238,255,.45);background:rgba(43,238,255,.14)}.message-refresh-btn:disabled{opacity:.55;cursor:not-allowed}.message-list{display:grid;gap:10px;margin-top:10px;max-height:220px;overflow-y:auto;padding-right:4px}.message-list-full{max-height:none;flex:1}.message-item{padding:10px 12px;border-radius:8px;background:rgba(255,255,255,.02);border:1px solid rgba(60,130,180,.16)}.message-meta{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px}.message-topic{font-size:12px;color:#58ffb0;font-weight:600}.message-time{font-size:11px;color:rgba(43,238,255,.72);font-variant-numeric:tabular-nums}.message-payload{margin:0;padding:10px;border-radius:6px;background:rgba(0,0,0,.22);border:1px solid rgba(255,255,255,.04);font-size:11px;line-height:1.5;color:rgba(210,236,248,.82);font-family:Consolas,Courier New,monospace;white-space:pre-wrap;word-break:break-all}.admin-table-wrap{margin-top:14px;border-radius:8px;overflow:hidden;border:1px solid rgba(60,130,180,.16)}.admin-table-head,.admin-table-row{display:grid;grid-template-columns:1fr .8fr 1.4fr .6fr .6fr;gap:10px;padding:11px 14px;align-items:center}.account-table-head,.account-table-row{grid-template-columns:.8fr .7fr 1.6fr 1fr .5fr .5fr}.account-device-cell{display:flex;flex-wrap:wrap;gap:6px}.perm-chip.sm{padding:3px 8px;font-size:10px}.admin-table-head{background:rgba(255,255,255,.04);color:rgba(210,236,248,.58);font-size:12px}.admin-table-row{border-top:1px solid rgba(255,255,255,.05);color:rgba(255,255,255,.88);font-size:12px}.admin-action-btn{border:1px solid rgba(43,238,255,.22);background:rgba(43,238,255,.06);color:rgba(210,236,248,.82);border-radius:6px;padding:4px 10px;font-size:11px;cursor:pointer;transition:background .2s ease,color .2s ease}.admin-action-btn:hover{background:rgba(43,238,255,.12);color:#2beeff}.perm-matrix-wrap{margin-top:10px;border-radius:8px;overflow:hidden;border:1px solid rgba(60,130,180,.16)}.perm-matrix-head,.perm-matrix-row{display:grid;grid-template-columns:1.6fr repeat(3,80px);gap:10px;padding:11px 14px;align-items:center}.perm-matrix-head{background:rgba(255,255,255,.04);color:rgba(210,236,248,.58);font-size:12px;text-align:center}.perm-matrix-head span:first-child{text-align:left}.perm-matrix-row{border-top:1px solid rgba(255,255,255,.05);color:rgba(255,255,255,.88);font-size:12px}.perm-matrix-label strong{display:block;font-size:13px;color:#eafcff;margin-bottom:3px}.perm-matrix-label small{display:block;font-size:11px;color:rgba(210,236,248,.48);line-height:1.4}.perm-check{display:flex;justify-content:center;align-items:center;cursor:pointer}.perm-check input{width:16px;height:16px;accent-color:#2beeff;cursor:pointer}.perm-account-list{display:grid;gap:10px;margin-top:10px}.perm-account-item{padding:12px 14px;border-radius:8px;background:rgba(255,255,255,.02);border:1px solid rgba(60,130,180,.16)}.perm-account-info{display:flex;align-items:center;gap:10px;margin-bottom:10px}.perm-account-info strong{font-size:13px;color:#eafcff}.perm-account-info span{font-size:11px;color:rgba(43,238,255,.78);padding:2px 8px;border-radius:999px;background:rgba(43,238,255,.08);border:1px solid rgba(43,238,255,.16)}.perm-chip-group{display:flex;flex-wrap:wrap;gap:8px}.perm-chip{border:1px solid rgba(60,130,180,.22);background:rgba(255,255,255,.02);color:rgba(210,236,248,.62);border-radius:999px;padding:5px 12px;font-size:11px;cursor:pointer;transition:border-color .2s ease,background .2s ease,color .2s ease}.perm-chip:hover{border-color:rgba(43,238,255,.28);color:#2beeff}.perm-chip.active{border-color:rgba(88,255,176,.35);background:rgba(88,255,176,.1);color:#58ffb0}.state-pill{padding:4px 8px;border-radius:999px;text-align:center;font-size:11px;display:inline-block}.state-pill.on{background:rgba(88,255,176,.1);color:#58ffb0}.state-pill.off{background:rgba(255,177,74,.1);color:#ffb14a}.panel.left,.panel.right{position:relative}.panel,.center{min-height:0;display:flex;flex-direction:column;gap:16px}.left .card,.right .card{flex:1;min-height:0;display:flex;flex-direction:column}.panel.right .chart-card,.panel.right .metric-card{flex:0 0 auto;flex-shrink:0}.panel.right .log-card{flex:1;min-height:0}.panel.right .log-card .log-list{flex:1;min-height:0;overflow-y:auto}.panel.right .metric-card .metric-list{flex:0 0 auto}.card{position:relative;color:#fff;background:linear-gradient(180deg,rgba(5,14,26,.96),rgba(3,9,18,.98));border:1px solid rgba(60,130,180,.32);border-radius:8px;padding:8px 10px 10px;box-shadow:0 6px 24px rgba(0,0,0,.35);backdrop-filter:blur(6px);overflow:hidden}.card>*{position:relative;z-index:2}.card-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:0 0 8px;padding:6px 0 8px;border-radius:0;border:none;border-bottom:1px solid rgba(43,238,255,.12);background:transparent;box-shadow:none;position:relative}.card-head:after{content:none;display:none}.card h3,.admin-panel h4{margin:0;font-size:14px;font-weight:600;color:#e8f4fc;letter-spacing:1px;display:flex;align-items:center;gap:8px}.card h3:before,.admin-panel h4:before{content:"";width:3px;height:14px;flex-shrink:0;border-radius:1px;background:linear-gradient(180deg,#2beeff,#58ffb0)}.card h3:after{content:none}.admin-panel h4{position:relative;margin:0 0 10px;padding:0 0 8px;border-radius:0;border:none;border-bottom:1px solid rgba(43,238,255,.1);background:transparent}.admin-panel h4:after{content:none;display:none}.card-tag{flex-shrink:0;font-size:10px;font-weight:600;letter-spacing:1px;color:#58ffb0;padding:3px 8px;border:1px solid rgba(88,255,176,.22);border-radius:4px;background:rgba(88,255,176,.06)}.card-tag.accent{color:#2beeff;border-color:rgba(43,238,255,.22);background:rgba(43,238,255,.06)}.overview-card{flex:1.1}.kpi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:5px}.kpi{position:relative;background:rgba(255,255,255,.02);border:1px solid rgba(60,130,180,.18);border-radius:6px;padding:6px 8px;overflow:hidden}.kpi.clickable{cursor:pointer;transition:border-color .2s,box-shadow .2s}.kpi.clickable:hover{border-color:rgba(255,177,74,.45);box-shadow:0 0 16px rgba(255,177,74,.12)}.kpi:after{content:"";position:absolute;inset:auto -20% -40% auto;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,rgba(43,238,255,.2),transparent 70%)}.kpi-label{font-size:11px;color:rgba(255,255,255,.82);margin-bottom:4px}.kpi-value{font-size:20px;font-weight:700;color:#2beeff;text-shadow:0 0 12px rgba(43,238,255,.28)}.kpi-value.warn{color:#ffb14a;text-shadow:0 0 12px rgba(255,177,74,.18)}.kpi-bar{display:block;height:5px;margin-top:6px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}.kpi-bar i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#2beeff,#58ffb0);box-shadow:0 0 12px rgba(43,238,255,.35)}.alarm-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(2,8,16,.72);backdrop-filter:blur(4px)}.alarm-modal{width:min(920px,100%);max-height:min(88vh,900px);display:flex;flex-direction:column;overflow:hidden}.alarm-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:16px 18px 12px;border-bottom:1px solid rgba(60,130,180,.18)}.alarm-modal-head h3{margin:0 0 6px;font-size:18px;color:#e8f7ff}.alarm-modal-head p{margin:0;font-size:12px;color:rgba(210,236,248,.68)}.alarm-modal-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.alarm-modal-refresh,.alarm-modal-close{flex-shrink:0;padding:6px 14px;border-radius:6px;border:1px solid rgba(60,130,180,.28);background:rgba(255,255,255,.04);color:#d2ecf8;cursor:pointer}.alarm-modal-refresh:hover:not(:disabled),.alarm-modal-close:hover{border-color:rgba(43,238,255,.45);color:#2beeff}.alarm-modal-refresh:disabled{opacity:.55;cursor:not-allowed}.alarm-modal-tabs{display:flex;gap:8px;padding:0 18px;border-bottom:1px solid rgba(60,130,180,.18)}.alarm-modal-tab{position:relative;padding:10px 14px 12px;border:none;border-bottom:2px solid transparent;background:transparent;color:rgba(210,236,248,.62);font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.alarm-modal-tab:hover{color:#d2ecf8}.alarm-modal-tab.active{color:#2beeff;border-bottom-color:#2beeff}.alarm-modal-tab-badge{min-width:18px;padding:1px 6px;border-radius:999px;background:rgba(43,238,255,.12);color:#2beeff;font-size:11px;line-height:1.4}.alarm-modal-tab.active .alarm-modal-tab-badge{background:rgba(43,238,255,.22)}.alarm-modal-body{overflow-y:auto;padding:14px 18px 18px;flex:1;min-height:280px}.alarm-active-panel,.alarm-history-panel{min-height:240px}.alarm-section h4,.alarm-active-panel h4,.alarm-history-panel h4{margin:0 0 8px;font-size:14px;color:rgba(230,245,255,.92)}.alarm-active-list,.alarm-history-list{display:grid;gap:8px}.alarm-active-item,.alarm-history-item{display:grid;grid-template-columns:150px auto 1fr auto;gap:8px 12px;align-items:center;padding:10px 12px;border-radius:8px;background:rgba(255,177,74,.06);border:1px solid rgba(255,177,74,.18);font-size:12px}.alarm-active-tag,.alarm-history-tag{padding:2px 8px;border-radius:999px;background:rgba(43,238,255,.12);color:#2beeff;font-size:11px;white-space:nowrap}.alarm-active-bit,.alarm-history-time{font-size:11px;color:rgba(210,236,248,.62);font-variant-numeric:tabular-nums}.alarm-active-item strong,.alarm-history-item strong{color:#ffb14a;font-weight:600}.message-empty.sm{margin:8px 0;padding:16px;font-size:12px}.alarm-history-admin-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.alarm-history-admin-head h4{margin:0}.alarm-history-admin-filters{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.alarm-history-admin-filters select{min-width:160px;padding:6px 10px;border-radius:6px;border:1px solid rgba(60,130,180,.28);background:rgba(255,255,255,.04);color:#d2ecf8}.alarm-history-admin-list{display:grid;gap:0;max-height:min(68vh,720px);overflow-y:auto;border-radius:8px;border:1px solid rgba(60,130,180,.16)}.alarm-history-admin-head-row,.alarm-history-admin-row{display:grid;grid-template-columns:150px 120px 140px 1fr 72px;gap:10px;align-items:center;padding:10px 12px;font-size:12px}.alarm-history-admin-head-row{position:sticky;top:0;z-index:1;background:rgba(8,24,40,.96);color:rgba(210,236,248,.58);border-bottom:1px solid rgba(255,255,255,.06)}.alarm-history-admin-row{border-top:1px solid rgba(255,255,255,.05);color:rgba(255,255,255,.88)}.alarm-history-admin-row strong{color:#ffb14a;font-weight:600}.record-panel{min-height:180px}.record-table{display:flex;flex-direction:column;gap:8px}.record-table-head,.record-table-row{display:grid;gap:10px;align-items:center;padding:10px 12px;border-radius:6px}.record-table-head.commands,.record-table-row.commands{grid-template-columns:160px 1fr}.record-table-head.runtime,.record-table-row.runtime{grid-template-columns:150px repeat(5,minmax(72px,1fr))}.record-table-head{background:rgba(43,238,255,.06);border:1px solid rgba(60,130,180,.18);color:rgba(210,236,248,.72);font-size:12px}.record-table-row{background:rgba(255,255,255,.02);border:1px solid rgba(60,130,180,.12);font-size:13px;color:#d2ecf8}.record-table-row strong{color:#e8f7ff;font-weight:600}.record-time{font-size:12px;color:rgba(210,236,248,.62);white-space:nowrap}.record-event-list{display:flex;flex-direction:column;gap:8px}.record-event-item{display:grid;grid-template-columns:10px 1fr auto;gap:12px;align-items:start;padding:12px 14px;border-radius:6px;background:rgba(255,255,255,.02);border:1px solid rgba(60,130,180,.12)}.record-event-content strong{display:block;color:#e8f7ff;font-size:13px;margin-bottom:4px}.record-event-content p{margin:0;font-size:12px;color:rgba(210,236,248,.68);line-height:1.5}.record-event-type{display:inline-block;margin-top:6px;padding:2px 8px;border-radius:999px;background:rgba(43,238,255,.1);color:#2beeff;font-size:11px}.state-pill.sm{padding:2px 8px;font-size:11px}.metric-card{flex:0 0 auto}.metric-list{display:flex;flex-direction:column;gap:4px}.panel.left .metric-card .metric-list-auto{flex:1;min-height:0;overflow:hidden;-webkit-mask-image:linear-gradient(180deg,transparent 0,#000 10px,#000 calc(100% - 10px),transparent 100%);mask-image:linear-gradient(180deg,transparent 0,#000 10px,#000 calc(100% - 10px),transparent 100%)}.metric-list-auto .metric-list-track{display:flex;flex-direction:column;gap:4px;animation:metric-list-scroll var(--scroll-duration, 24s) linear infinite}.metric-list-auto:hover .metric-list-track{animation-play-state:paused}@keyframes metric-list-scroll{0%{transform:translateY(0)}to{transform:translateY(-50%)}}.metric-row{display:grid;grid-template-columns:1fr auto;align-items:center;padding:5px 8px;border-radius:6px;background:rgba(255,255,255,.02);border:1px solid rgba(60,130,180,.16);position:relative;overflow:hidden}.metric-row span{position:relative;z-index:1;color:rgba(255,255,255,.88);font-size:12px;letter-spacing:.5px}.metric-row strong{position:relative;z-index:1;color:#2beeff;font-size:13px;font-weight:700;text-shadow:0 0 10px rgba(43,238,255,.18)}.center{overflow:hidden}.hero{flex:1.55;min-height:0;padding:8px}.hero-frame{position:relative;width:100%;height:100%;border-radius:8px;overflow:hidden;background:linear-gradient(135deg,rgba(6,28,48,.95),rgba(2,12,24,.98));box-shadow:inset 0 0 24px rgba(0,0,0,.25)}.hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background:url(/assets/monitor-bg-zFwL2QeR.jpg) center center / 100% 72% no-repeat;background-color:#020810}.hero-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(43,238,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(43,238,255,.04) 1px,transparent 1px);background-size:120px 120px;opacity:.08}.hero-scan,.hero-corners{display:none}.hero-frame:after{content:none;display:none}.hero-badge{position:absolute;top:16px;z-index:2;font-size:11px;padding:6px 10px;border-radius:999px;background:rgba(5,16,29,.72);border:1px solid rgba(49,240,255,.16);color:#8af8ff;letter-spacing:1px}.hero-badge.left{left:16px}.hero-badge.right{right:16px}.hero-float-panel{position:absolute;z-index:3;min-width:148px;padding:10px 12px;border-radius:8px;background:rgba(4,14,28,.52);border:1px solid rgba(43,238,255,.22);backdrop-filter:blur(8px);box-shadow:0 8px 24px rgba(0,0,0,.28),inset 0 0 0 1px rgba(255,255,255,.03)}.hero-float-panel:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(135deg,rgba(43,238,255,.08),transparent 55%);pointer-events:none}.hero-float-panel.tl{top:52px;left:16px}.hero-float-panel.tr{top:16px;right:16px}.hero-float-panel.tc{top:12px;left:40%;transform:translate(-50%);min-width:168px}.hero-float-panel.mc{top:84%;left:47%;transform:translate(-50%,-50%)}.hero-float-panel-wide{min-width:300px;display:flex;flex-direction:column}.hero-float-panel-wide .hero-float-title{margin-bottom:6px}.hero-float-scroll-wide{max-height:88px}.hero-float-groups-set{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}.hero-float-groups-set+.hero-float-groups-set{margin-top:8px}.hero-float-groups-set .hero-float-group+.hero-float-group{border-left:1px solid rgba(43,238,255,.12);padding-left:14px}.hero-float-panel-wide .hero-float-row{padding:3px 0;font-size:10px}.hero-float-panel-wide .hero-float-row strong{font-size:11px}.hero-float-panel-wide .hero-float-subtitle{margin-bottom:4px}.hero-float-subtitle{margin-bottom:6px;font-size:10px;color:rgba(138,248,255,.82);letter-spacing:1px}.hook-metric-card .metric-list{gap:6px}.hook-metric-card{display:flex;flex-direction:column;min-height:0}.hook-metric-scroll{flex:1;min-height:0;max-height:168px;overflow:hidden;-webkit-mask-image:linear-gradient(180deg,transparent 0,#000 8px,#000 calc(100% - 8px),transparent 100%);mask-image:linear-gradient(180deg,transparent 0,#000 8px,#000 calc(100% - 8px),transparent 100%)}.hook-metric-track{display:flex;flex-direction:column;gap:12px}.hook-metric-groups{display:grid;gap:12px}.hook-metric-group-title{margin-bottom:6px;font-size:11px;color:#8af8ff;letter-spacing:1px}.hero-float-panel.bl{bottom:16px;left:12%}.hero-float-panel.br{bottom:16px;right:16px}.hero-float-title{position:relative;margin-bottom:8px;font-size:11px;color:#8af8ff;letter-spacing:1px;text-transform:uppercase}.hero-float-row{position:relative;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:4px 0;font-size:11px}.hero-float-row+.hero-float-row{border-top:1px solid rgba(43,238,255,.08)}.hero-float-row span{color:rgba(210,236,248,.62);white-space:nowrap}.hero-float-row strong{color:#e8f7ff;font-size:12px;font-weight:600;text-align:right}.hero-float-row strong.warn{color:#ffb14a;text-shadow:0 0 10px rgba(255,177,74,.25)}.hero-float-scroll{overflow:hidden;max-height:108px;-webkit-mask-image:linear-gradient(180deg,transparent 0,#000 8px,#000 calc(100% - 8px),transparent 100%);mask-image:linear-gradient(180deg,transparent 0,#000 8px,#000 calc(100% - 8px),transparent 100%)}.hero-float-track{animation:hero-float-scroll var(--scroll-duration, 18s) linear infinite}.hero-float-scroll:hover .hero-float-track{animation-play-state:paused}@keyframes hero-float-scroll{0%{transform:translateY(0)}to{transform:translateY(-50%)}}.camera-strip{flex:.65;display:flex;flex-direction:column;gap:12px}.carousel-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.carousel-header .card-head{flex:1;min-width:0;margin-bottom:0}.carousel-viewport{overflow:hidden}.carousel-track{display:flex;gap:12px;transition:transform .6s ease}.camera-shell{flex:0 0 calc(50% - 6px);position:relative;border-radius:14px;overflow:hidden;border:1px solid rgba(49,240,255,.1);background:#020810;min-height:140px;aspect-ratio:16 / 9}.camera-shell.disabled{border-style:dashed;border-color:rgba(60,130,180,.22)}.camera-shell.offline{border-color:rgba(255,177,74,.28)}.camera-feed{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;background:#020810}.camera-feed-player{overflow:hidden}.camera-feed-player :deep(video),.camera-feed-player :deep(canvas){width:100%!important;height:100%!important;object-fit:cover}.camera-placeholder,.camera-status-mask{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:16px;text-align:center;z-index:1}.camera-placeholder{background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.22)),radial-gradient(circle at 30% 36%,rgba(255,255,255,.12),transparent 14%),linear-gradient(135deg,rgba(57,255,212,.12),rgba(18,40,68,.9))}.camera-status-mask{background:rgba(3,10,20,.62);backdrop-filter:blur(2px)}.camera-placeholder-icon{width:42px;height:42px;border-radius:50%;border:2px solid rgba(43,238,255,.35);box-shadow:0 0 0 8px rgba(43,238,255,.08);margin-bottom:4px}.camera-placeholder strong,.camera-status-mask strong{color:#e8f7ff;font-size:13px}.camera-placeholder p,.camera-status-mask p,.camera-placeholder small{margin:0;color:rgba(210,236,248,.68);font-size:11px;line-height:1.5}.camera-live-dot{display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:6px;vertical-align:middle}.camera-live-dot.on{background:#58ffb0;box-shadow:0 0 8px rgba(88,255,176,.55)}.camera-live-dot.off{background:#ffb14a;box-shadow:0 0 8px rgba(255,177,74,.35)}.camera-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(3,12,22,.1),rgba(3,12,22,.38))}.camera-label{position:absolute;left:10px;top:10px;z-index:1;font-size:11px;padding:4px 6px;background:rgba(4,17,31,.74);border:1px solid rgba(255,255,255,.08);border-radius:8px}.camera-shell.expandable{cursor:pointer}.camera-shell.expandable .camera-overlay{pointer-events:none}.camera-shell.expandable:hover{border-color:rgba(49,240,255,.28);box-shadow:0 0 0 1px rgba(43,238,255,.12)}.camera-shell.expanded{flex:none;width:100%;min-height:0;aspect-ratio:16 / 9;border-radius:0;border:none}.camera-expand-hint{position:absolute;left:50%;top:50%;z-index:2;transform:translate(-50%,-50%);padding:6px 12px;border-radius:999px;font-size:12px;color:#e8f7ff;background:rgba(4,17,31,.78);border:1px solid rgba(43,238,255,.28);opacity:0;transition:opacity .2s ease;pointer-events:none}.camera-shell.expandable:hover .camera-expand-hint{opacity:1}.camera-paused{background:linear-gradient(180deg,rgba(3,12,22,.72),rgba(3,12,22,.88))}.camera-modal{width:min(1100px,96vw);max-height:min(90vh,900px);display:flex;flex-direction:column;overflow:hidden}.camera-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:16px 18px 12px;border-bottom:1px solid rgba(60,130,180,.18)}.camera-modal-head h3{margin:0 0 6px;font-size:18px;color:#e8f7ff}.camera-modal-head p{margin:0;font-size:12px;color:rgba(210,236,248,.68)}.camera-modal-body{flex:1;min-height:0;background:#020810}.camera-modal-overlay{z-index:1001}.camera-live{position:absolute;right:10px;bottom:10px;z-index:1;font-size:11px;color:rgba(255,255,255,.72)}.carousel-indicators{display:flex;gap:8px}.carousel-indicators span{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.2)}.carousel-indicators span.active{background:#2beeff;box-shadow:0 0 10px rgba(43,238,255,.3)}.admin-action-btn.danger:hover{border-color:rgba(255,120,120,.45);color:#ffb4b4}.camera-admin-form{grid-template-columns:repeat(2,minmax(0,1fr))}.camera-admin-toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px}.camera-admin-toolbar h4{margin:0 0 6px}.camera-admin-toolbar-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.camera-remote-input{min-width:160px;padding:8px 10px;border-radius:6px;border:1px solid rgba(60,130,180,.28);background:rgba(255,255,255,.04);color:#e8f7ff}.camera-admin-head,.camera-admin-row{grid-template-columns:1.2fr 1fr .6fr .7fr .9fr .7fr .7fr;align-items:center}.camera-admin-row input[type=text],.camera-admin-row input[type=number]{width:100%;padding:7px 8px;border-radius:6px;border:1px solid rgba(60,130,180,.22);background:rgba(255,255,255,.04);color:#e8f7ff}.camera-admin-check{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:rgba(210,236,248,.72)}.camera-admin-empty{padding:18px;text-align:center;color:rgba(210,236,248,.58);font-size:13px}.camera-admin-footer{display:flex;align-items:center;gap:12px;margin-top:14px}.camera-admin-saved-tip{margin-top:10px;padding:8px 10px;border-radius:6px;font-size:12px;color:rgba(138,248,255,.88);background:rgba(43,238,255,.08);border:1px solid rgba(43,238,255,.16)}.chart-card{flex:0 0 auto}.weight-chart-card .card-head{margin-bottom:4px}.weight-chart-unit{font-size:11px;color:rgba(43,238,255,.72);letter-spacing:.5px}.weight-chart{display:flex;flex-direction:column;gap:6px}.weight-chart-frame{position:relative;display:grid;grid-template-columns:34px 1fr;gap:6px;align-items:stretch;padding:0 2px}.weight-chart-frame:before,.weight-chart-frame:after{content:"";position:absolute;top:8px;bottom:0;width:3px;border-radius:2px;background:linear-gradient(180deg,rgba(120,150,170,.55),rgba(80,110,130,.18));pointer-events:none}.weight-chart-frame:before{left:0}.weight-chart-frame:after{right:0}.weight-y-labels{display:flex;flex-direction:column;justify-content:space-between;min-height:180px;padding:10px 0 18px;color:#2beeff;font-size:11px;line-height:1;text-shadow:0 0 8px rgba(43,238,255,.22)}.weight-chart-svg{width:100%;height:180px;min-height:0;flex-shrink:0;overflow:visible}.weight-plot-bg{fill:rgba(0,0,0,.58);stroke:rgba(43,238,255,.08);stroke-width:1}.weight-grid-h line,.weight-grid-v line{stroke:rgba(255,255,255,.1);stroke-width:1;vector-effect:non-scaling-stroke}.weight-area{opacity:.95}.weight-line{fill:none;stroke:url(#weightLineGradient);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 6px rgba(43,238,255,.35));vector-effect:non-scaling-stroke}.weight-point{fill:#2beeff;stroke:rgba(255,255,255,.85);stroke-width:1.5;vector-effect:non-scaling-stroke}.weight-x-labels{display:grid;gap:0;padding:0 38px 2px 40px}.weight-x-label{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:0;color:#2beeff;text-align:center}.weight-x-time{font-size:10px;line-height:1.2;white-space:nowrap;opacity:.92}.weight-x-date{font-size:9px;line-height:1.2;color:rgba(43,238,255,.72);white-space:nowrap}.line-chart{height:auto;display:flex;flex-direction:column;gap:8px}.line-svg{width:100%;height:220px;min-height:0;flex-shrink:0;overflow:visible}.line-area{fill:rgba(43,238,255,.12)}.line-path{fill:none;stroke:url(#lineGradientRight);stroke-width:4;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 8px rgba(43,238,255,.35))}.line-point{fill:#2beeff;stroke:rgba(255,255,255,.9);stroke-width:2}.line-glow{fill:rgba(43,238,255,.1)}.axis-labels{display:grid;grid-template-columns:repeat(6,1fr);color:rgba(215,248,255,.65);font-size:11px}.axis-labels span{text-align:center}.log-card{flex:1;min-height:0}.log-list{display:flex;flex-direction:column;gap:4px;padding-right:4px;min-height:0;overflow-y:auto}.log-item{display:grid;grid-template-columns:10px 1fr auto;gap:8px;align-items:center;padding:6px 8px;border-radius:6px;background:rgba(255,255,255,.02);border:1px solid rgba(60,130,180,.16);flex-shrink:0}.log-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.log-dot.safe{background:#58ffb0;box-shadow:0 0 12px rgba(88,255,176,.45)}.log-dot.warn{background:#ffb14a;box-shadow:0 0 12px rgba(255,177,74,.45)}.log-content{min-width:0;overflow:hidden}.log-content strong{display:block;font-size:12px;color:rgba(255,255,255,.88);letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.log-time{flex-shrink:0;font-size:12px;color:#2beeff;font-weight:700;text-shadow:0 0 10px rgba(43,238,255,.18);opacity:.95}@media(max-width:1280px){html,body,#app{overflow:auto;height:auto;min-height:100%;-webkit-overflow-scrolling:touch}.app-shell,.screen{height:auto;min-height:100vh;min-height:100dvh;overflow:visible}.screen{padding:12px 12px calc(16px + env(safe-area-inset-bottom,0px))}.layout{grid-template-columns:1fr;gap:12px;min-height:auto}.panel,.center{overflow:visible;min-height:auto}.left .card,.right .card{flex:none;min-height:auto}.dashboard-shell{min-height:auto;overflow:visible}.hero{flex:none;min-height:280px;height:52vw;max-height:420px}.hero-frame{min-height:240px}.camera-strip{flex:none}.carousel-track{flex-direction:column}.camera-shell{flex:none;width:100%;min-height:180px}.camera-shell.expanded{min-height:220px}.admin-layout{grid-template-columns:1fr;border-radius:8px}.admin-sidebar{border-right:none;border-bottom:2px solid rgba(43,238,255,.45)}.admin-nav{flex-direction:row;flex-wrap:wrap}.admin-nav-item{flex:1 1 calc(50% - 4px)}.admin-stats,.admin-stats-2,.admin-grid,.admin-grid-2,.telemetry-grid,.admin-quick-grid,.mqtt-form-grid{grid-template-columns:1fr}.admin-form{grid-template-columns:1fr 1fr}.admin-form-btn{grid-column:1 / -1}.admin-table-head,.admin-table-row,.account-table-head,.account-table-row{grid-template-columns:1fr 1fr;gap:6px}.account-device-cell{grid-column:1 / -1}.admin-table-head span:nth-child(n+3),.admin-table-row span:nth-child(n+3),.admin-table-row button{grid-column:1 / -1}.perm-matrix-head,.perm-matrix-row{grid-template-columns:1fr;text-align:left}.perm-matrix-head span:not(:first-child),.perm-check{display:none}.camera-admin-form{grid-template-columns:1fr}.camera-admin-head,.camera-admin-row{grid-template-columns:1fr 1fr}.camera-admin-toolbar{flex-direction:column;align-items:stretch}.camera-admin-toolbar-actions{justify-content:stretch}.camera-remote-input{flex:1;min-width:0}}@media(max-width:900px){.device-switcher{grid-template-columns:1fr;gap:10px;padding:12px}.device-switcher-left{flex-direction:column;align-items:stretch;gap:8px}.device-switcher-tabs,.feature-switcher-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;scrollbar-width:none}.device-switcher-tabs::-webkit-scrollbar,.feature-switcher-tabs::-webkit-scrollbar{display:none}.feature-tab{min-width:104px;flex-shrink:0}.device-tab{flex-shrink:0}.alarm-modal-overlay{padding:0;align-items:stretch}.alarm-modal{width:100%;max-height:100vh;max-height:100dvh;border-radius:0;min-height:100vh;min-height:100dvh}.alarm-modal-head{flex-direction:column;gap:10px}.alarm-modal-actions{width:100%;justify-content:flex-end}.alarm-modal-tabs{overflow-x:auto;flex-wrap:nowrap}.camera-modal-overlay .alarm-modal{min-height:auto;max-height:100dvh}}@media(max-width:768px){html,body,#app{overflow-x:hidden}.screen,.screen-mobile{padding:12px 16px calc(200px + env(safe-area-inset-bottom,0px))}.panel.left .metric-card .metric-list-auto,.panel.left .metric-card .hook-metric-scroll,.panel.left .metric-card .hook-metric-static,.panel.right .metric-card .metric-list{overflow:visible!important;-webkit-mask-image:none!important;mask-image:none!important;flex:none;min-height:auto;max-height:none}.panel.left .card,.panel.right .card,.metric-card,.metric-list{min-width:0;max-width:100%;box-sizing:border-box}.metric-row{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:4px 10px;padding:10px 12px;border-radius:8px;overflow:visible;width:100%;box-sizing:border-box}.metric-row span{flex:1 1 120px;font-size:13px;min-width:0;line-height:1.4;word-break:break-word}.metric-row strong{flex:0 1 auto;font-size:15px;font-weight:700;white-space:nowrap;text-align:right;max-width:100%;overflow:visible}.hook-metric-static{gap:16px}.hook-metric-scroll,.hook-metric-scroll--static{max-height:none;overflow:visible;-webkit-mask-image:none;mask-image:none}.hook-metric-track,.hook-metric-track--static{animation:none!important;transform:none!important}.hook-metric-groups[aria-hidden=true]{display:none!important}.hook-metric-group-title{font-size:12px;margin-bottom:8px}.fancy-topbar{flex:none;display:grid;grid-template-areas:"brand title" "user user";grid-template-columns:auto 1fr;align-items:center;gap:10px 12px;padding:14px 16px;margin-bottom:14px;border-radius:12px}.topbar-side.left-side{grid-area:brand;justify-content:flex-start}.topbar-center{grid-area:title;order:unset;justify-content:flex-start;gap:0;min-width:0}.topbar-side.right-side{grid-area:user;justify-content:stretch}.topbar-deco,.topbar-title-line{display:none}.topbar-logo.logo-has-image{width:84px;height:32px;margin:0}.topbar-title{font-size:15px;font-weight:700;line-height:1.35;letter-spacing:.5px;white-space:normal;text-align:left;text-shadow:none}.topbar-user-panel{align-items:stretch;min-width:0;width:100%;gap:8px}.topbar-time{font-size:11px;text-align:right;width:100%;opacity:.85}.topbar-user-card{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:10px 12px;flex-wrap:nowrap}.topbar-user-panel .logout-link{border-left:none;padding:6px 0 6px 10px;margin-left:0;min-height:auto;font-size:12px;white-space:nowrap}.layout{gap:14px}.card{padding:12px 14px 14px;border-radius:12px}.card-head{margin-bottom:10px;padding-bottom:10px}.card-head h3{font-size:15px}.kpi-grid{grid-template-columns:1fr 1fr;gap:10px}.kpi{padding:12px;border-radius:10px}.kpi-label{font-size:12px;margin-bottom:6px}.kpi-value{font-size:20px}.hero-float-panel{display:none!important}.center{display:flex;flex-direction:column;gap:14px}.center .camera-strip{order:-1}.camera-shell{min-height:200px;border-radius:12px}.weight-chart-frame{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -4px;padding:0 4px}.weight-chart-svg{min-width:480px}.log-list{max-height:240px}.dashboard-shell.is-mobile{padding-bottom:0}.device-switcher{position:fixed;left:0;right:0;bottom:0;z-index:200;margin:0;display:grid;grid-template-columns:1fr;gap:8px;border-radius:16px 16px 0 0;border-left:none;border-right:none;border-bottom:none;padding:10px 14px calc(10px + env(safe-area-inset-bottom,0px));box-shadow:0 -10px 40px rgba(0,0,0,.48);max-height:34vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.device-switcher-left{flex-direction:row;align-items:center;gap:10px;min-width:0}.device-switcher-tabs{flex:1;min-width:0;overflow-x:auto}.feature-switcher-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;overflow:visible;padding-bottom:0}.device-switcher-label{font-size:11px;font-weight:600;flex-shrink:0}.feature-tab,.device-tab{min-height:38px;padding:8px 10px;font-size:11px}.feature-tab{min-width:0;flex-shrink:1}.device-switcher-mqtt{display:block;width:100%;text-align:center;margin-top:4px;padding-top:8px;border-top:1px solid rgba(60,130,180,.16)}.device-switcher-mqtt.offline-hint{color:#ffb14a}.admin-page{overflow:visible}.admin-layout{min-height:auto}.admin-content{overflow:visible}.admin-nav-item{flex:1 1 100%;min-height:44px}.admin-form,.settings-form{grid-template-columns:1fr}.admin-form-btn,.admin-action-btn,.login-submit{min-height:44px}.alarm-history-admin-head-row,.alarm-history-admin-row{grid-template-columns:1fr;gap:4px}.alarm-history-admin-head-row{display:none}.alarm-history-admin-row{padding:12px;border-radius:10px;background:rgba(255,255,255,.02);border:1px solid rgba(60,130,180,.16);margin-bottom:10px}.message-panel-head{flex-direction:column;align-items:stretch;gap:8px}.message-panel-actions{flex-wrap:wrap}.camera-admin-head{display:none}.camera-admin-row{grid-template-columns:1fr;gap:8px;padding:12px;border-radius:10px;background:rgba(255,255,255,.02);border:1px solid rgba(60,130,180,.16);margin-bottom:10px}}@media(max-width:480px){.login-page{padding:16px;padding-top:calc(16px + env(safe-area-inset-top,0px))}.login-card{padding:24px 18px 20px;border-radius:14px}.login-brand h1{font-size:19px;letter-spacing:1px}.login-hint-chips{grid-template-columns:1fr}.login-submit{min-height:48px;font-size:15px}.login-form input{font-size:16px;min-height:44px}.topbar-logo.logo-has-image{width:72px;height:28px}.topbar-title{font-size:13px;line-height:1.4}.topbar-user-card{padding:8px 10px;gap:8px}.topbar-user-avatar{width:28px;height:28px}.kpi-grid{grid-template-columns:1fr}.kpi-value{font-size:22px}.camera-shell{min-height:180px;border-radius:10px}.camera-label{font-size:11px}.feature-tab{min-width:88px;padding:10px 12px;font-size:11px}.device-tab{padding:10px 12px;font-size:12px}.device-switcher{padding:10px 14px calc(10px + env(safe-area-inset-bottom,0px))}.alarm-modal-head h3{font-size:16px}.alarm-modal-refresh,.alarm-modal-close{min-height:40px;padding:8px 16px}.admin-content-head h3{font-size:16px}.admin-stat-value{font-size:24px}}@media(min-width:1281px){html,body,#app{overflow:hidden}}.project-tree{display:flex;flex-direction:column;gap:12px}.project-tree-item{padding:14px 16px;border-radius:10px;border:1px solid rgba(43,238,255,.14);background:rgba(8,24,48,.45)}.project-tree-head{display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px}.project-tree-head strong{font-size:15px;color:#dff8ff}.project-tree-meta{font-size:12px;color:rgba(180,220,240,.72)}.project-tree-desc{margin:8px 0 0;font-size:12px;color:rgba(180,220,240,.65)}.project-device-list{margin-top:12px;display:flex;flex-direction:column;gap:8px}.project-device-row{display:grid;grid-template-columns:1.2fr 1fr auto auto auto;gap:8px;align-items:center;padding:10px 12px;border-radius:8px;background:rgba(4,16,32,.55)}.admin-action-btn.danger{color:#ff8f8f;border-color:rgba(255,120,120,.35)}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}
