:root{--bg-color-main: #eef5f9;--bg-color-surface: #ffffff;--bg-color-soft: #f5f9fc;--primary-color: #1e88e5;--primary-color-dark: #1c81d9;--border-color: rgba(120, 140, 160, .18);--text-color: #314354;--text-color-secondary: #72879a;--danger-color: #dc3545;--success-color: #198754;--warning-color: #f4b740;--shadow-main: 0 18px 40px rgba(16, 24, 40, .08);--shadow-soft: 0 8px 20px rgba(17, 24, 39, .05);--radius-xl: 28px;--radius-lg: 20px;--radius-md: 16px;--radius-sm: 12px;--header-height: 84px;--sidebar-width: 260px;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:var(--text-color);background:var(--bg-color-main);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{min-height:100vh}body{margin:0;min-width:320px;background:radial-gradient(circle at top left,rgba(30,136,229,.14),transparent 26%),linear-gradient(180deg,#f8fbfe 0%,var(--bg-color-main) 100%);color:var(--text-color)}a{color:var(--primary-color);text-decoration:none}a:hover{text-decoration:underline}button,input,textarea,select{font:inherit}img{max-width:100%}.shell{display:grid;grid-template-columns:var(--sidebar-width) minmax(0,1fr);min-height:100vh}.shell-brand{position:fixed;inset:0 auto auto 0;width:var(--sidebar-width);height:var(--header-height);display:flex;align-items:center;gap:1rem;padding:1.1rem 1.4rem;background:linear-gradient(135deg,var(--primary-color),var(--primary-color-dark));color:#fff;box-shadow:0 14px 34px #1e88e54d;z-index:20}.shell-brand-mark{width:3rem;height:3rem;display:inline-flex;align-items:center;justify-content:center;border-radius:18px;background:radial-gradient(circle at 30% 30%,#ffffff73,#ffffff14),#ffffff1f;box-shadow:inset 0 1px #ffffff40,0 10px 22px #0a2d5a33}.shell-brand-mark img{width:2rem;height:2rem;object-fit:contain;filter:brightness(0) invert(1)}.shell-brand-copy{display:flex;flex-direction:column;min-width:0}.shell-brand-copy strong{font-size:1.1rem}.shell-brand-copy span{color:#ffffffc7;font-size:.9rem}.shell-sidebar{position:fixed;top:var(--header-height);left:0;width:var(--sidebar-width);height:calc(100vh - var(--header-height));padding:1rem;background:#fffc;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-right:1px solid rgba(120,140,160,.14)}.shell-nav{display:flex;flex-direction:column;gap:.5rem}.shell-nav-link{display:flex;align-items:center;gap:.8rem;min-height:3rem;padding:.75rem 1rem;border-radius:999px;border:1px solid transparent;color:var(--text-color-secondary);font-weight:600;transition:.2s ease}.shell-nav-icon{width:1.2rem;height:1.2rem;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.shell-nav-icon svg{width:100%;height:100%}.shell-nav-icon img,.shell-nav-icon span,.shell-nav-icon span svg{width:100%;height:100%;display:block}.shell-nav-link:hover{text-decoration:none;color:var(--text-color);border-color:var(--border-color);background:#ffffffb3}.shell-nav-link.active{color:#fff;background:linear-gradient(135deg,var(--primary-color),#4fa6f5);box-shadow:0 14px 28px #1e88e53d}.shell-main{grid-column:2;min-width:0;margin-left:0}.shell-topbar{position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;align-items:center;gap:1rem;min-height:var(--header-height);padding:1.4rem 2rem 1rem;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#eff5fad6;border-bottom:1px solid rgba(120,140,160,.12)}.shell-topbar-label{display:block;color:var(--text-color-secondary);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.2rem}.shell-topbar-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;justify-content:flex-end}.shell-user-summary{display:flex;align-items:center;gap:.75rem}.shell-user-avatar{width:2.75rem;height:2.75rem;border-radius:50%;object-fit:cover;border:1px solid rgba(120,140,160,.18);box-shadow:0 8px 18px #1118271f;background:#fff}.shell-user-avatar-fallback{display:inline-flex;align-items:center;justify-content:center;font-weight:800;color:var(--primary-color-dark);background:linear-gradient(135deg,#1e88e529,#4fa6f547)}.shell-user-chip{display:inline-flex;align-items:center;min-height:2.65rem;padding:.45rem .9rem;border-radius:999px;background:#ffffffe6;border:1px solid var(--border-color);color:var(--text-color-secondary)}.shell-content{padding:1.6rem 2rem 2.2rem}.page-header{display:flex;justify-content:space-between;gap:1.25rem;align-items:flex-start;margin-bottom:1.5rem}.page-header h1{margin:0 0 .35rem;font-size:clamp(1.9rem,2vw,2.35rem);line-height:1.1}.page-header p{margin:0;max-width:60rem;color:var(--text-color-secondary)}.page-header-actions{display:flex;gap:.75rem;flex-wrap:wrap}.section-card{background:#ffffffc7;border:1px solid rgba(120,140,160,.12);border-radius:var(--radius-lg);padding:1.4rem;box-shadow:var(--shadow-soft);margin-bottom:1.2rem}.section-card-header{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;margin-bottom:1rem}.section-card-header h2{margin:0 0 .35rem;font-size:1.2rem}.section-card-header p{margin:0;color:var(--text-color-secondary)}.stats-grid,.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.device-card-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.overview-summary{margin-bottom:1.5rem;grid-template-columns:minmax(0,2fr) repeat(2,minmax(220px,1fr))}.stat-card,.entity-card{background:var(--bg-color-surface);border:1px solid rgba(120,140,160,.12);border-radius:var(--radius-md);padding:1.15rem;box-shadow:var(--shadow-soft)}.stat-card-label,.stat-card-hint{display:block;color:var(--text-color-secondary)}.stat-card-value{display:block;margin:.25rem 0;font-size:1.8rem;line-height:1.1}.entity-card-header{display:flex;justify-content:space-between;gap:.75rem;align-items:flex-start;margin-bottom:1rem}.entity-card-header>div{min-width:0;flex:1}.entity-card-header h3{margin:0 0 .2rem;font-size:1.05rem;overflow-wrap:anywhere}.entity-card-header p{margin:0;color:var(--text-color-secondary);overflow-wrap:anywhere}.entity-card-subtle{margin-top:.15rem;color:var(--text-color-secondary);font-size:.95rem}.pill{display:inline-flex;align-items:center;padding:.3rem .7rem;border-radius:999px;background:#1e88e51a;color:var(--primary-color);font-size:.82rem;font-weight:700;white-space:nowrap;flex-shrink:0;max-width:100%}.entity-list{display:grid;gap:.7rem;margin:0}.entity-list div{display:flex;justify-content:space-between;gap:1rem;padding-bottom:.65rem;border-bottom:1px solid rgba(120,140,160,.08)}.entity-list div:last-child{border-bottom:none;padding-bottom:0}.entity-list dt{color:var(--text-color-secondary)}.entity-list dd{margin:0;text-align:right;overflow-wrap:anywhere}.entity-list-compact dt,.entity-list-compact dd{font-size:.95rem}.profile-avatar-block{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-color-surface);border:1px solid rgba(120,140,160,.12);border-radius:var(--radius-md)}.overview-summary .profile-avatar-block{height:100%}.profile-avatar{width:5.5rem;height:5.5rem;border-radius:50%;object-fit:cover;flex-shrink:0;background:#1e88e514;border:1px solid rgba(120,140,160,.16)}.profile-avatar-fallback{display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:var(--primary-color-dark);background:linear-gradient(135deg,#1e88e529,#4fa6f54d)}.profile-avatar-meta{min-width:0;display:flex;flex-direction:column;gap:.2rem}.profile-avatar-meta strong{font-size:1.1rem}.profile-avatar-meta span,.profile-avatar-meta small,.profile-capabilities-note{color:var(--text-color-secondary)}.profile-capabilities-list{margin:0;padding-left:1.2rem;display:grid;gap:.45rem}.profile-form{display:grid;gap:1rem;max-width:36rem}.profile-form-actions{display:flex;gap:.75rem;flex-wrap:wrap}.profile-avatar-editor{display:grid;gap:1rem}.profile-avatar-field{max-width:36rem}.gateway-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem}.gateway-rename-form{margin-top:1rem}.gateway-actions-row{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.75rem}.states-block{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(120,140,160,.08)}.states-block p{margin:0;color:var(--text-color-secondary)}.state-list{list-style:none;margin:0;padding:0;display:grid;gap:.25rem}.state-list li{display:flex;justify-content:space-between;align-items:flex-start;gap:.6rem}.state-list li span,.state-list li strong{min-width:0;overflow-wrap:anywhere}.state-list li span{color:var(--text-color-secondary)}.state-list li strong{text-align:right}.ui-button{display:inline-flex;align-items:center;justify-content:center;min-height:2.9rem;border-radius:999px;border:1px solid transparent;padding:.65rem 1.05rem;font-weight:700;cursor:pointer;transition:.2s ease}.ui-button:disabled{opacity:.65;cursor:wait}.ui-button-primary{background:linear-gradient(135deg,var(--primary-color),var(--primary-color-dark));color:#fff;box-shadow:0 14px 28px #1e88e538}.ui-button-secondary{background:#ffffffe6;border-color:var(--border-color);color:var(--text-color)}.ui-button-danger{background:#dc35451a;border-color:#dc354533;color:var(--danger-color)}.ui-button-danger:hover{background:#dc354529}.ui-alert{display:flex;justify-content:space-between;gap:1rem;padding:1rem 1.1rem;border-radius:var(--radius-sm);border:1px solid transparent;margin-bottom:1rem}.ui-alert p,.ui-alert small{margin:.2rem 0 0}.ui-alert-info{background:#1e88e514;border-color:#1e88e529}.ui-alert-success{background:#19875414;border-color:#19875429}.ui-alert-danger{background:#dc354514;border-color:#dc354529}.ui-alert-action{display:inline-flex;align-items:center}.page-state,.placeholder-panel{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;justify-content:center;min-height:220px;padding:1.3rem;background:#ffffffad;border:1px dashed rgba(120,140,160,.25);border-radius:var(--radius-md)}.page-state h3,.placeholder-panel h3{margin:0;font-size:1.15rem}.page-state p,.placeholder-panel p{margin:0;color:var(--text-color-secondary);max-width:42rem}.placeholder-panel span{display:inline-flex;padding:.35rem .75rem;border-radius:999px;background:#1e88e514;color:var(--primary-color);font-weight:700}.page-state-compact{min-height:140px}.page-spinner{width:2.5rem;height:2.5rem;border-radius:50%;border:3px solid rgba(30,136,229,.18);border-top-color:var(--primary-color);animation:spin .8s linear infinite}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.auth-card{width:min(1120px,100%);display:grid;grid-template-columns:minmax(0,1.1fr) minmax(360px,440px);gap:1.4rem}.auth-card-wide{align-items:stretch}.auth-hero,.auth-form-card{border-radius:var(--radius-xl);box-shadow:var(--shadow-main)}.auth-hero{padding:2.2rem;background:linear-gradient(145deg,#10365e,#1b5fa1 45%,#2f95f0);color:#fff;display:flex;flex-direction:column;justify-content:flex-end;min-height:520px}.auth-kicker{display:inline-flex;align-self:flex-start;margin-bottom:auto;padding:.35rem .75rem;border-radius:999px;background:#ffffff1f;font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:.78rem}.auth-hero h1{margin:0 0 .75rem;font-size:clamp(2.2rem,4vw,3.5rem);line-height:1}.auth-hero p{margin:0;color:#ffffffd6;max-width:34rem}.auth-form-card{padding:1.5rem;background:#fffffff0;display:flex;flex-direction:column}.auth-form-header{margin-bottom:1rem}.auth-form-header h2{margin:0 0 .3rem}.auth-form-header p,.auth-footer-copy{color:var(--text-color-secondary)}.auth-form{display:flex;flex-direction:column;gap:.95rem;margin-bottom:1rem}.field{display:flex;flex-direction:column;gap:.4rem}.field span{font-weight:600}.field-input{min-height:3rem;width:100%;border-radius:14px;border:1px solid rgba(120,140,160,.22);background:#fff;padding:.8rem .95rem;color:var(--text-color)}.field-input:focus{outline:none;border-color:#1e88e580;box-shadow:0 0 0 4px #1e88e51f}.field-hint{font-size:.9rem;color:var(--text-color-secondary)}.field-hint-danger{color:var(--danger-color)}.file-picker{position:relative;display:flex;align-items:center;gap:.75rem;min-height:3.2rem;padding:.4rem .5rem .4rem .4rem;border-radius:16px;border:1px solid rgba(120,140,160,.22);background:linear-gradient(180deg,#fffffff5,#f5f9fcf5);box-shadow:inset 0 1px #fffc;cursor:pointer}.file-picker:hover{border-color:#1e88e559;box-shadow:0 0 0 4px #1e88e514}.file-picker-input{position:absolute;inset:0;opacity:0;cursor:pointer}.file-picker-button{display:inline-flex;align-items:center;justify-content:center;min-height:2.3rem;padding:.45rem .9rem;border-radius:999px;background:linear-gradient(135deg,var(--primary-color),var(--primary-color-dark));color:#fff;font-weight:700;white-space:nowrap;box-shadow:0 10px 20px #1e88e52e}.file-picker-value{min-width:0;color:var(--text-color-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:980px){:root{--sidebar-width: 92px}.shell-brand-copy,.shell-user-chip,.shell-nav-link{font-size:.95rem}}@media(max-width:860px){.shell{grid-template-columns:1fr;padding-bottom:88px}.shell-brand{position:sticky;width:100%}.shell-sidebar{top:auto;bottom:0;width:100%;height:auto;padding:.75rem;border-right:none;border-top:1px solid rgba(120,140,160,.12)}.shell-nav{flex-direction:row;overflow-x:auto;padding-bottom:.1rem}.shell-nav-link{white-space:nowrap;min-height:2.7rem;padding:.55rem .9rem}.shell-main{grid-column:auto}.shell-topbar,.shell-content{padding-left:1rem;padding-right:1rem}.auth-card{grid-template-columns:1fr}.auth-hero{min-height:280px}.device-card-grid{grid-template-columns:1fr}.overview-summary{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}}@media(max-width:640px){.page-header,.section-card-header,.shell-topbar,.entity-card-header,.ui-alert{flex-direction:column;align-items:flex-start}.entity-list div,.state-list li{flex-direction:column;gap:.35rem}.entity-list dd{text-align:left}.auth-page,.auth-form-card,.auth-hero,.section-card,.entity-card,.stat-card{padding:1rem}}
