:root{color:#0f172a;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--ink:#10203a;--muted:#5b6b7b;--line:#10203a1f;--panel:#ffffffd1;--panel-strong:#fffffff0;--brand:#0b63f6;--brand-strong:#094fcc;--accent:#f25f3a;--success:#127c56;--danger:#cf3f2c;--shadow:0 24px 60px #12253f1f;background:radial-gradient(circle at 0 0,#ffd699d9,#0000 28%),radial-gradient(circle at 100% 0,#537fe733,#0000 22%),linear-gradient(145deg,#f7f4ec 0%,#edf4ff 46%,#eef7f3 100%);font-family:Noto Sans SC,PingFang SC,Microsoft YaHei,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html,body,#app{min-height:100vh}body{margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}.shell{width:min(1320px,100% - 32px);margin:0 auto;padding:32px 0 48px}.hero-panel,.workspace-card,.login-card,.session-card,.modal-card{background:var(--panel);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);box-shadow:var(--shadow);border:1px solid #ffffff8c}.hero-panel{border-radius:28px;grid-template-columns:minmax(0,1.3fr) minmax(320px,420px);align-items:stretch;gap:24px;margin-bottom:24px;padding:28px;display:grid}.hero-copy{flex-direction:column;height:100%;padding:8px 8px 8px 4px;display:flex}.eyebrow{color:var(--brand-strong);letter-spacing:.08em;text-transform:uppercase;background:#0b63f614;border-radius:999px;align-items:center;padding:6px 12px;font-size:12px;font-weight:700;display:inline-flex}h1,h2,h3,p,dl,dd{margin:0}h1,h2,h3{color:var(--ink);font-family:Source Han Sans SC,Noto Sans SC,sans-serif}h1{letter-spacing:-.04em;margin-top:16px;font-size:clamp(2.2rem,4vw,4.1rem);line-height:1.04}h2{font-size:1.9rem}h3{font-size:1.4rem}.hero-copy p{max-width:62ch;color:var(--muted);margin-top:16px;font-size:1.02rem}.feature-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:24px;display:grid}.feature-list div{background:#ffffffad;border:1px solid #10203a14;border-radius:20px;padding:16px 18px}.feature-list dt{color:var(--muted);margin-bottom:6px;font-size:.88rem}.feature-list dd{color:var(--ink);word-break:break-all;font-weight:700}.login-card,.session-card{border-radius:24px;padding:22px}.card-head{justify-content:space-between;align-items:baseline;gap:16px;margin-bottom:18px;display:flex}.card-head span,.session-label,.workspace-head p{color:var(--muted)}.login-card,.dialog-form{gap:14px;display:grid}label{gap:8px;display:grid}label span{color:var(--muted);font-size:.9rem;font-weight:600}input,select,textarea{width:100%;color:var(--ink);background:#ffffffeb;border:1px solid #10203a26;border-radius:16px;padding:12px 14px;transition:border-color .2s,box-shadow .2s,transform .2s}input:focus,select:focus,textarea:focus{border-color:#0b63f673;outline:none;box-shadow:0 0 0 4px #0b63f61f}.primary-btn,.ghost-btn,.text-btn,.danger-btn{border:none;border-radius:14px;padding:12px 18px;transition:transform .18s,opacity .18s,background .18s}.primary-btn:hover,.ghost-btn:hover,.text-btn:hover,.danger-btn:hover{transform:translateY(-1px)}.primary-btn:disabled,.ghost-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.primary-btn{background:linear-gradient(135deg, var(--brand) 0%, #2d89ff 100%);color:#fff;font-weight:700}.ghost-btn{color:var(--brand-strong);background:#0b63f614;font-weight:700}.text-btn{color:var(--brand-strong);background:0 0;padding-inline:10px;font-weight:700}.danger-btn{color:var(--danger);background:#cf3f2c14;font-weight:700}.session-card{justify-content:space-between;align-items:center;gap:20px;display:flex}.session-actions,.workspace-actions{flex-wrap:wrap;gap:10px;display:flex}.checkbox-field{color:var(--ink);background:#ffffffb8;border:1px solid #10203a1f;border-radius:999px;align-items:center;gap:8px;padding:10px 14px;font-weight:700;display:inline-flex}.checkbox-field input{width:16px;height:16px;margin:0}.checkbox-field span{color:inherit;font-size:.92rem}.session-actions-vertical{flex-direction:column;align-items:stretch;min-width:160px}.session-actions-vertical>*{width:100%}.top-nav{flex-wrap:wrap;gap:10px;margin-top:auto;padding-top:14px;display:flex}.top-nav-btn{color:var(--ink);background:#ffffffb8;border:1px solid #10203a1f;border-radius:999px;padding:10px 16px;font-weight:700;transition:background .18s,border-color .18s,color .18s,transform .18s}.top-nav-btn:hover{transform:translateY(-1px)}.top-nav-btn.active{background:linear-gradient(135deg, var(--brand) 0%, #2d89ff 100%);color:#fff;border-color:#0000}.session-card strong{margin-top:6px;font-size:1.2rem;display:block}.session-card p{color:var(--muted);margin-top:6px}.workspace-card{border-radius:28px;padding:28px}.workspace-head{justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.feedback{border-radius:14px;margin-bottom:16px;padding:12px 14px}.feedback-success{color:var(--success);background:#127c5617}.feedback-error{color:var(--danger);background:#cf3f2c1a}.empty-state{text-align:center;color:var(--muted);background:#ffffff80;border:1px dashed #10203a24;border-radius:24px;padding:48px 20px}.toolbar{grid-template-columns:minmax(220px,320px) 180px auto;align-items:end;gap:14px;margin-bottom:18px;display:grid}.toolbar-field{min-width:0}.toolbar-users{grid-template-columns:minmax(220px,1.6fr) 120px 140px minmax(170px,1fr) auto}.toolbar-devices{grid-template-columns:minmax(160px,240px) 160px minmax(180px,220px) auto}.toolbar-boxes{grid-template-columns:minmax(160px,240px) minmax(180px,220px) auto}.toolbar-logs{grid-template-columns:minmax(240px,1fr) auto}.toolbar-logs-alarms{grid-template-columns:repeat(2,minmax(220px,1fr)) auto}.toolbar-logs-audit{grid-template-columns:repeat(3,minmax(200px,1fr)) auto}.log-sections{gap:18px;display:grid}.log-card{border:1px solid var(--line);background:#ffffffb8;border-radius:20px;padding:18px}.log-card h3{margin-bottom:12px}.borrow-panel{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:18px;display:grid}.toolbar-users .toolbar-field-role{max-width:140px}.toolbar-users .toolbar-field-status{max-width:120px}.toolbar-users .toolbar-field-group{max-width:220px}.toolbar-actions{justify-content:flex-end;gap:10px;display:flex}.table-wrap{border:1px solid var(--line);background:var(--panel-strong);border-radius:22px;overflow:auto}table{border-collapse:collapse;width:100%;min-width:920px}thead{background:#0b63f60f}th,td{text-align:left;vertical-align:top;border-bottom:1px solid #10203a14;padding:16px 18px}th{color:var(--muted);font-size:.9rem;font-weight:700}.table-status{text-align:center;color:var(--muted);padding:28px}.remark-cell{max-width:220px;color:var(--muted)}.tag,.status-pill{border-radius:999px;justify-content:center;align-items:center;min-width:72px;padding:6px 12px;font-size:.88rem;font-weight:700;display:inline-flex}.tag{color:var(--brand-strong);background:#0b63f614}.status-on{color:var(--success);background:#127c561a}.status-off{color:var(--danger);background:#cf3f2c1f}.row-actions{flex-wrap:wrap;gap:2px;display:flex}.pager{color:var(--muted);justify-content:space-between;align-items:center;gap:16px;margin-top:18px;display:flex}.pager-actions{gap:10px;display:flex}.modal-mask{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:20;background:#09142666;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal-card{border-radius:28px;width:min(760px,100%);padding:24px}.modal-sm{width:min(460px,100%)}.modal-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.dialog-form{grid-template-columns:repeat(2,minmax(0,1fr))}.full-width{grid-column:1/-1}.modal-actions{justify-content:flex-end;gap:12px;display:flex}@media (width<=960px){.shell{width:min(100%,100% - 20px);padding-top:18px}.hero-panel{grid-template-columns:1fr;padding:20px}.feature-list,.toolbar,.borrow-panel,.dialog-form{grid-template-columns:1fr}.workspace-card,.login-card,.session-card,.modal-card{padding:20px}.workspace-head,.pager,.session-card{flex-direction:column;align-items:stretch}.toolbar-actions,.pager-actions,.modal-actions{justify-content:stretch}.toolbar-actions>*,.pager-actions>*,.modal-actions>*{flex:1}}.status-indicator{border-radius:20px;align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:500;display:inline-flex}.status-indicator .status-dot{border-radius:50%;width:8px;height:8px}.status-indicator.status-enabled{color:var(--success);background:#127c561a}.status-indicator.status-enabled .status-dot{background:var(--success)}.status-indicator.status-disabled{color:var(--muted);background:#5b6b7b1a}.status-indicator.status-disabled .status-dot{background:var(--muted)}
