:root{--bg:#f5f5f7;--panel:#ffffff;--panel-2:#f5f5f7;--line:#e5e5ea;--txt:#1d1d1f;--muted:#86868b;--accent:#34c759;--accent-2:#0071e3;--warn:#ff9f0a;--down:#ff3b30;--orange:#f59331;--radius:18px;--side:264px;--shadow:0 1px 2px rgba(0,0,0,.04), 0 6px 18px rgba(0,0,0,.05)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Montserrat,-apple-system,system-ui,sans-serif;background:var(--bg);color:var(--txt);-webkit-font-smoothing:antialiased}.app{display:flex;min-height:100vh}.sidebar{width:var(--side);flex-shrink:0;background:#f5f5f7cc;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:22px 14px;position:sticky;top:0;height:100vh}.logo{display:flex;align-items:center;gap:11px;padding:4px 8px 20px;cursor:pointer}.logo .mark{width:34px;height:34px;object-fit:contain}.logo .name{font-weight:700;font-size:17px;letter-spacing:-.3px}.logo .name b{color:var(--txt)}.picker-lbl,.nav-label{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.2px;margin:6px 8px 8px;text-transform:none}.ele-select{width:100%;font-family:inherit;font-size:14px;font-weight:500;color:var(--txt);background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:11px 12px;outline:none;cursor:pointer;margin-bottom:14px;box-shadow:var(--shadow)}.ele-select:hover{border-color:#d0d0d5}.nav-label{margin-top:20px}.nav-item{display:flex;align-items:center;gap:11px;width:100%;text-align:left;font-family:inherit;font-size:14px;font-weight:500;color:var(--txt);background:none;border:none;border-radius:11px;padding:10px 12px;cursor:pointer;transition:.15s}.nav-item:hover{background:#0000000a}.nav-item.active{background:#0000000f;font-weight:600}.nav-item .ico{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;color:var(--muted)}.nav-item .ico svg{width:18px;height:18px}.nav-item.active .ico{color:var(--txt)}.sidebar .spacer{flex:1}.profile .av{width:32px;height:32px;border-radius:50%;background:linear-gradient(150deg,#c7c7cc,#aeaeb2)}.profile .who{font-size:13px;font-weight:600}.profile .who small{display:block;color:var(--muted);font-weight:400;font-size:11px}.profile-wrap{position:relative;margin-top:10px;border-top:1px solid var(--line)}.profile{display:flex;align-items:center;gap:10px;padding:12px 8px 4px;width:100%;background:none;border:none;cursor:pointer;font-family:inherit;text-align:left;border-radius:11px;transition:.15s}.profile:hover{background:#0000000a}.profile .chev{margin-left:auto;color:var(--muted);display:inline-flex;transition:.2s}.profile .chev svg{width:16px;height:16px}.profile-wrap.open .chev{transform:rotate(180deg)}.profile-menu{position:absolute;bottom:calc(100% + 6px);left:0;right:0;background:var(--panel);border:1px solid var(--line);border-radius:13px;box-shadow:0 8px 30px #0000001f;padding:6px;opacity:0;visibility:hidden;transform:translateY(6px);transition:.16s}.profile-wrap.open .profile-menu{opacity:1;visibility:visible;transform:translateY(0)}.pm-item{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;font-family:inherit;font-size:14px;font-weight:500;color:var(--txt);padding:10px 11px;border-radius:9px;cursor:pointer;transition:.15s}.pm-item:hover{background:#0000000d}.pm-item.logout{color:var(--down)}.pm-item .pm-ic{display:inline-flex}.pm-item .pm-ic svg{width:17px;height:17px}.main{flex:1;min-width:0;padding:30px 38px}header.top{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px;flex-wrap:wrap;gap:14px}header.top h1{font-size:26px;font-weight:700;letter-spacing:-.5px}header.top h1 .ctx{color:var(--muted);font-weight:600}.hgroup{display:flex;align-items:center;gap:14px}.home-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:var(--panel);border:1px solid var(--line);color:var(--muted);cursor:pointer;transition:.15s;flex-shrink:0;box-shadow:var(--shadow)}.home-btn:hover{color:var(--txt);background:#fff}.home-btn svg{width:19px;height:19px}.status{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);font-weight:500}.dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px #34c7592e}.grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow)}.card.full{grid-column:1 / -1}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:10px}.card-head h2{font-size:16px;font-weight:600;letter-spacing:-.2px}.card-head .hint{font-size:12px;color:var(--muted);font-weight:400}select,.toggle button{font-family:inherit;font-size:13px;font-weight:500;background:var(--panel-2);color:var(--txt);border:1px solid var(--line);border-radius:10px;padding:7px 13px;cursor:pointer;outline:none}select:hover{border-color:#d0d0d5}.toggle{display:flex;gap:6px;background:var(--panel-2);padding:3px;border-radius:11px;border:1px solid var(--line)}.toggle button{border:none;background:none;border-radius:8px;padding:6px 12px;color:var(--muted);transition:.15s}.toggle button.active{background:#fff;color:var(--txt);box-shadow:0 1px 2px #00000014}.daterange{display:flex;align-items:center;gap:8px}.daterange input[type=date],input.dateone{font-family:inherit;font-size:13px;font-weight:500;background:var(--panel-2);color:var(--txt);border:1px solid var(--line);border-radius:10px;padding:7px 11px;outline:none;cursor:pointer}.daterange input[type=date]:hover,input.dateone:hover{border-color:#d0d0d5}.daterange .arrow{color:var(--muted);font-size:13px}.chart-box{position:relative;height:240px}.chart-box.tall{height:300px}.floors{display:flex;flex-direction:column}.floor-row{display:grid;grid-template-columns:54px 1fr 150px 110px;align-items:center;gap:16px;padding:14px 6px;border-bottom:1px solid var(--line)}.floor-row:last-child{border-bottom:none}.floor-name{font-weight:600;font-size:15px}.floor-name small{display:block;font-size:11px;color:var(--muted);font-weight:400}.hbar{height:20px;background:var(--panel-2);border-radius:7px;overflow:hidden}.hbar .fill{height:100%;border-radius:7px;transition:width .4s ease}.hbar .fill.up,.hbar .fill.down{background:#38bdf8}.floor-val{text-align:right}.floor-val .num{font-size:16px;font-weight:600}.floor-val .lbl{font-size:11px;color:var(--muted);letter-spacing:.2px}.chip{justify-self:end;font-size:13px;font-weight:600;padding:5px 11px;border-radius:9px;display:inline-flex;align-items:center;gap:5px}.chip.up{color:#0f9d6b;background:#34d39924}.chip.down{color:#e0524b;background:#f8717124}.alarm-list{display:flex;flex-direction:column;gap:12px}.alarm{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:14px;background:var(--panel-2);border:1px solid var(--line)}.alarm .ico{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.alarm.ok .ico{background:#34c75924;color:#1d8a3f}.alarm .body strong{display:block;font-size:14px;font-weight:600}.alarm .body span{font-size:13px;color:var(--muted)}.alarm .time{margin-left:auto;font-size:12px;color:var(--muted);font-weight:500}.view{display:none}.view.active{display:block}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.cv-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:18px;font-size:13px;color:var(--muted);font-weight:500}.cv-sec{margin:30px 2px 14px}.cv-sec-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin:30px 2px 14px;flex-wrap:wrap}.cv-sec-row .ttl h2{font-size:16px;font-weight:600;letter-spacing:-.2px}.cv-sec-row .ttl p{font-size:13px;color:var(--muted);margin-top:4px}.chart-box.rough{height:360px}.cv-sec h2{font-size:16px;font-weight:600;letter-spacing:-.2px}.cv-sec p{font-size:13px;color:var(--muted);margin-top:4px;max-width:760px;line-height:1.5}.dir-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px}.dir-head .d{font-size:15px;font-weight:600}.dir-head .tr{font-size:12.5px;color:var(--muted);font-weight:500}@media (max-width:900px){.grid-3{grid-template-columns:1fr}}.home-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:22px}.ele-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:28px;cursor:pointer;transition:.2s;display:flex;flex-direction:column;gap:18px;box-shadow:var(--shadow)}.ele-card:hover{transform:translateY(-3px);box-shadow:0 8px 30px #0000001a}.ele-card .head{display:flex;align-items:center;gap:15px}.ele-card .ic{width:54px;height:54px;border-radius:15px;background:var(--panel-2);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--txt)}.ele-card .ic svg{width:27px;height:27px}.ele-card .nm{font-size:18px;font-weight:600;letter-spacing:-.2px}.ele-card .nm small{display:block;font-size:12px;color:var(--muted);font-weight:400}.ele-card .state{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:13px;background:#34c7591a}.ele-card .state .pulse{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px #34c75929}.ele-card .state b{font-size:14px;color:#1d8a3f}.ele-card .state span{display:block;font-size:12px;color:var(--muted);font-weight:400}.ele-card .meta{display:flex;gap:8px;flex-wrap:wrap}.ele-card .tag{font-size:12px;font-weight:500;color:var(--muted);background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:5px 10px}.ele-card .state.warn{background:#ff9f0a1a}.ele-card .state.warn .pulse{background:#ff9f0a;box-shadow:0 0 0 4px #ff9f0a29}.ele-card .state.warn b{color:#a86a00}.card-alerts{display:flex;flex-direction:column;gap:9px;border-top:1px solid var(--line);padding-top:16px}.ca{display:flex;align-items:center;gap:11px;font-size:13px}.ca .d{width:20px;height:20px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.ca.ok .d{background:#34d39929;color:#0f9d6b}.ca.warn .d{background:#ff9f0a2e;color:#a86a00}.ca .t{font-weight:600;line-height:1.3}.ca .t small{display:block;font-weight:400;color:var(--muted);font-size:11.5px}.ca.warn .t{color:#a86a00}.spec-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);margin-bottom:20px}.spec-card .spec-head{display:flex;align-items:center;gap:15px;padding-bottom:20px;margin-bottom:20px;border-bottom:1px solid var(--line)}.spec-card .spec-head .ic{width:50px;height:50px;border-radius:14px;background:var(--panel-2);display:flex;align-items:center;justify-content:center;color:var(--txt);flex-shrink:0}.spec-card .spec-head .ic svg{width:25px;height:25px}.spec-card .spec-head .nm{font-size:18px;font-weight:600;letter-spacing:-.2px}.spec-card .spec-head .dev{font-size:12px;color:var(--muted);font-family:ui-monospace,monospace;margin-top:2px}.spec-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:22px 32px}.spec{display:flex;flex-direction:column;gap:3px}.spec span{font-size:11px;color:var(--muted);font-weight:500;letter-spacing:.2px}.spec b{font-size:14px;font-weight:600}.u-intro{font-size:13.5px;color:var(--muted);line-height:1.6;max-width:720px;margin-bottom:20px}.u-stats{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:26px}.u-stat{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px 20px;box-shadow:var(--shadow);min-width:130px}.u-stat .n{font-size:24px;font-weight:700;letter-spacing:-.5px}.u-stat .l{font-size:12px;color:var(--muted);margin-top:2px}.u-stat.warn .n{color:#c98a00}.u-sec-title{font-size:13px;font-weight:600;color:var(--muted);margin:0 2px 12px}.pending-card{background:var(--panel);border:1px solid #f0e2c2;border-radius:16px;padding:20px 22px;box-shadow:var(--shadow);margin-bottom:14px}.pending-card .top{display:flex;align-items:center;gap:13px;margin-bottom:16px}.av-i{width:42px;height:42px;border-radius:50%;background:linear-gradient(150deg,#c7c7cc,#aeaeb2);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:15px;color:#fff;flex-shrink:0}.pending-card .nm{font-size:15px;font-weight:600}.pending-card .em{font-size:12.5px;color:var(--muted)}.pending-card .ubadge{margin-left:auto}.assign{display:flex;gap:22px;flex-wrap:wrap;align-items:flex-end}.assign .fld{display:flex;flex-direction:column;gap:6px}.assign .fld label{font-size:11px;color:var(--muted);font-weight:600}.assign select{min-width:160px}.ele-checks{display:flex;gap:14px;flex-wrap:wrap}.ele-checks label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;cursor:pointer}.assign .acts{margin-left:auto;display:flex;gap:8px}.btn{font-family:inherit;font-size:13px;font-weight:600;border-radius:10px;padding:9px 16px;cursor:pointer;border:1px solid var(--line);background:var(--panel-2);color:var(--txt);transition:.15s}.btn:hover{border-color:#d0d0d5}.btn.primary{background:#0071e3;border-color:#0071e3;color:#fff}.btn.primary:hover{background:#0062c4}.btn.ghost{background:none}.u-table-wrap{background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}.u-table{width:100%;border-collapse:collapse;font-size:13.5px}.u-table th{text-align:left;font-size:11px;font-weight:600;color:var(--muted);text-transform:none;padding:15px 22px;border-bottom:1px solid var(--line);letter-spacing:.2px}.u-table td{padding:17px 22px;border-bottom:1px solid var(--line);vertical-align:middle}.u-table tr:last-child td{border-bottom:none}.u-user{display:flex;align-items:center;gap:11px}.u-user .nm{font-weight:600}.u-user .em{font-size:12px;color:var(--muted)}.ubadge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:8px}.ubadge.pending{color:#a86a00;background:#ff9f0a24}.ubadge.active{color:#0f9d6b;background:#34d39924}.ubadge.suspended{color:#86868b;background:#0000000f}.u-ele{display:flex;gap:6px;flex-wrap:wrap}.u-ele .t{font-size:11px;font-weight:500;color:var(--muted);background:var(--panel-2);border:1px solid var(--line);border-radius:7px;padding:3px 8px}.u-act{font-family:inherit;font-size:12.5px;font-weight:600;color:#0071e3;background:none;border:none;cursor:pointer;padding:4px}.u-act.danger{color:var(--down)}@media (max-width:900px){.u-table-wrap{overflow-x:auto}.u-table{min-width:640px}.assign .acts{margin-left:0;width:100%}}.dev-card{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:24px 26px;box-shadow:var(--shadow);margin-bottom:20px}.dev-head{display:flex;align-items:center;gap:15px;padding-bottom:20px;margin-bottom:20px;border-bottom:1px solid var(--line)}.dev-head .ic{width:48px;height:48px;border-radius:13px;background:var(--panel-2);display:flex;align-items:center;justify-content:center;color:var(--txt);flex-shrink:0}.dev-head .ic svg{width:24px;height:24px}.dev-head .nm{font-size:17px;font-weight:600}.dev-head .mac{font-size:12.5px;color:var(--muted);font-family:ui-monospace,monospace;margin-top:2px}.dev-head .ubadge{margin-left:auto}.dev-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:22px 32px;margin-bottom:24px}.storage{margin-bottom:20px}.storage .lab{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:7px}.storage .track{height:8px;background:var(--panel-2);border-radius:5px;overflow:hidden}.storage .track .fill{height:100%;background:#38bdf8;border-radius:5px}.sensors{display:flex;gap:10px;flex-wrap:wrap}.sensor{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:500;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:8px 12px}.sensor .sd{width:8px;height:8px;border-radius:50%}.sensor.ok .sd{background:#34d399}.sensor.err .sd{background:#f87171}.sensor.err{color:#e0524b}.placeholder{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:56px;text-align:center;color:var(--muted);box-shadow:var(--shadow)}.placeholder .big{margin:0 auto 16px;color:var(--muted)}.placeholder .big svg{width:42px;height:42px}.placeholder h3{color:var(--txt);font-size:19px;margin-bottom:6px;font-weight:600}@media (max-width:900px){.app{flex-direction:column}.sidebar{width:100%;height:auto;position:sticky;top:0;z-index:50;flex-direction:column;padding:12px 14px;background:#f5f5f7eb;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px)}.sidebar .spacer{display:none}.logo{padding:2px 4px 12px}.picker-lbl,.nav-label{display:none}.ele-select{margin-bottom:12px}.sidebar>.nav-item{display:inline-flex}.sidebar{overflow:visible}.nav-scroll{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;scrollbar-width:none}.nav-scroll::-webkit-scrollbar{display:none}.nav-scroll .nav-item{flex:0 0 auto;white-space:nowrap;padding:9px 13px}.profile-wrap{margin-top:8px;border-top:1px solid var(--line)}.profile-menu{bottom:auto;top:calc(100% + 6px)}.main{padding:18px 16px}header.top{margin-bottom:18px}header.top h1{font-size:20px}.home-btn{width:36px;height:36px}.grid{grid-template-columns:1fr;gap:14px}.card{padding:18px 16px;border-radius:16px}.chart-box{height:200px}.chart-box.tall{height:230px}.home-grid{grid-template-columns:1fr;gap:14px}.ele-card{padding:22px}.spec-grid{grid-template-columns:1fr 1fr;gap:14px 18px}.floor-row{grid-template-columns:42px 1fr auto;gap:10px;padding:12px 2px}.floor-row .hbar,.floor-val{display:none}.floor-row .chip{justify-self:end}}@media (max-width:430px){.spec-grid{grid-template-columns:1fr}.toggle button{padding:6px 9px;font-size:12px}.card-head{gap:8px}.ele-card .meta{gap:6px}}
