*{box-sizing:border-box}body{margin:0;font-family:MiSans,MI Sans TC,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0a0e14;color:#e2e8f0;line-height:1.5}.layout{display:flex;min-height:100vh}.sidebar{width:240px;background:#0a0e14;border-right:1px solid #1f1f1f;display:flex;flex-direction:column;padding:24px 16px 0;gap:32px;position:fixed;top:0;left:0;height:100vh;z-index:200;transition:width .3s cubic-bezier(.4,0,.2,1)}.sidebar.collapsed{width:72px;padding:24px 12px 0}.sidebar.collapsed .sidebar-header,.sidebar.collapsed .sidebar-brand,.sidebar.collapsed .sidebar-nav a,.sidebar.collapsed .user-profile{justify-content:center}.sidebar.collapsed .user-popup-menu{left:4px;right:4px;min-width:auto}.sidebar.collapsed .popup-menu-item span:last-child{display:none}.sidebar.collapsed .popup-menu-item{justify-content:center;padding:10px}.sidebar-header{height:48px;display:flex;align-items:center;overflow:hidden}.sidebar-brand{display:flex;align-items:center;gap:12px;width:100%;padding:12px}.brand-icon{width:40px;height:40px;background:linear-gradient(135deg,#4f46e5,#9333ea);border-radius:10px;display:grid;place-items:center;font-size:24px;box-shadow:0 4px 12px #4f46e566;flex-shrink:0}.brand-icon-svg{width:32px;height:32px;flex-shrink:0}.sidebar-title{font-size:16px;font-weight:700;color:#fff;white-space:nowrap;opacity:1;transition:opacity .2s}.sidebar-nav{display:flex;flex-direction:column;gap:8px;width:100%;flex:1}.sidebar-nav a{display:flex;align-items:center;gap:12px;padding:12px;text-decoration:none;color:#a1a1aa;border-radius:8px;transition:all .2s;white-space:nowrap;overflow:hidden;position:relative}.sidebar-nav a:hover{background:#18181b;color:#fff}.sidebar-nav a.active{background:#6366f11a;color:#818cf8}.sidebar-nav a.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:24px;background:#6366f1;border-radius:0 4px 4px 0}.nav-icon{font-size:20px;width:24px;display:grid;place-items:center;flex-shrink:0}.nav-icon-svg{width:24px;height:24px;flex-shrink:0;opacity:.9}.sidebar-nav a:hover .nav-icon-svg,.sidebar-nav a.active .nav-icon-svg{opacity:1}.nav-label{font-size:14px;font-weight:500}.nav-todo-badge{margin-left:auto;min-width:20px;height:20px;padding:0 6px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;line-height:1;color:#fff;background:#ef4444;box-shadow:0 0 0 1px #00000026}.sidebar.collapsed .nav-todo-badge{margin-left:0;min-width:8px;width:8px;height:8px;padding:0;font-size:0;box-shadow:none}.sidebar-toggle{position:absolute;right:-12px;top:36px;width:24px;height:24px;background:#18181b;border:1px solid #27272a;border-radius:50%;color:#a1a1aa;display:grid;place-items:center;cursor:pointer;font-size:16px;z-index:150;transition:all .2s;padding-bottom:2px}.sidebar-toggle:hover{background:#27272a;color:#fff;border-color:#3f3f46}.sidebar-footer{position:absolute;bottom:0;left:0;right:0;height:44px;border-top:1px solid #1f1f1f;padding:0 16px;display:flex;align-items:center;gap:12px;overflow:visible}.sidebar.collapsed .sidebar-footer{padding:0 12px}.user-profile{display:flex;align-items:center;gap:12px;padding:0;width:100%;height:100%;cursor:pointer}.sidebar-footer:hover{background:#18181b}.user-popup-menu{position:absolute;bottom:100%;left:8px;right:8px;margin-bottom:8px;background:#18181b;border:1px solid #27272a;border-radius:8px;padding:4px;box-shadow:0 -4px 20px #0006;z-index:100;animation:slideUp .15s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.popup-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:6px;color:#a1a1aa;font-size:14px;cursor:pointer;transition:all .15s}.popup-menu-item:hover{background:#27272a;color:#fff}.popup-menu-item.logout:hover{background:#ef44441a;color:#ef4444}.popup-icon{font-size:14px}.sidebar.collapsed .user-profile{justify-content:center}.user-avatar{width:28px;height:28px;border-radius:50%;background:#27272a;color:#e4e4e7;display:grid;place-items:center;font-size:14px;font-weight:600;flex-shrink:0}.user-avatar-img{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0}.user-info{display:flex;flex-direction:column;gap:4px}.user-name{font-size:14px;font-weight:600;color:#fff}.user-role{font-size:14px;color:#71717a}.user-role-badge{display:inline-block;font-size:14px;font-weight:600;color:#a855f7;background:#a855f726;padding:3px 10px;border-radius:12px;letter-spacing:.3px}.sidebar-logout{width:100%;height:36px;border-radius:8px;background:transparent;border:1px solid transparent;color:#a1a1aa;display:flex;align-items:center;gap:12px;padding:0 12px;cursor:pointer;transition:all .2s;white-space:nowrap}.sidebar.collapsed .sidebar-logout{justify-content:center;padding:0}.sidebar-logout:hover{background:#18181b;color:#ef4444}.logout-icon{font-size:16px;width:24px;display:grid;place-items:center;flex-shrink:0}.logout-label{font-size:14px;font-weight:500}.content{flex:1;padding:0;background:#050505;min-height:100vh;margin-left:240px;overflow-y:auto;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.content.sidebar-collapsed{margin-left:72px}.page{width:100%;display:flex;flex-direction:column;gap:24px;padding:96px 48px 32px}.topbar{position:fixed;top:0;right:0;left:240px;z-index:100;display:flex;justify-content:space-between;align-items:center;height:72px;padding:0 48px;background:#0a0a0af2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid #1f1f1f;box-sizing:border-box}.topbar.sidebar-collapsed{left:72px}.topbar-title{font-size:18px;font-weight:700;color:#fff}.topbar-subtitle{font-size:14px;color:#71717a;margin-top:4px}.topbar-chip{font-size:14px;padding:0;height:42px;background:transparent;border:none;color:#a1a1aa;display:flex;align-items:center;gap:6px}.topbar-left{display:flex;align-items:center;flex:1}.topbar-actions{display:flex;align-items:center;gap:12px}.status-dot{width:6px;height:6px;border-radius:50%;background:#10b981;box-shadow:0 0 6px #10b98166}.client-dropdown,.account-dropdown{position:relative}.client-dropdown-trigger{display:flex;align-items:center;gap:12px;background:#18181b;border:1px solid #27272a;border-radius:8px;padding:0 18px;height:42px;font-size:14px;color:#e4e4e7;cursor:pointer;transition:border-color .2s,background-color .2s}.client-dropdown-trigger:hover{border-color:#3f3f46;background-color:#1f1f23}.client-logo{width:22px;height:22px;border-radius:0;object-fit:contain}.client-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.client-id-badge{flex-shrink:0;font-family:ui-monospace,Cascadia Code,Source Code Pro,monospace;font-size:12px;color:#a1a1aa;background:#3f3f4659;border:1px solid rgba(82,82,91,.45);border-radius:6px;padding:2px 6px}.dropdown-arrow{font-size:14px;color:#71717a;margin-left:4px}.client-dropdown-menu{position:absolute;top:calc(100% + 4px);right:0;background:#18181b;border:1px solid #27272a;border-radius:8px;padding:4px;min-width:100%;box-shadow:0 4px 12px #0000004d;z-index:200}.account-trigger{display:flex;align-items:center;gap:10px;background:#18181b;border:1px solid #27272a;border-radius:8px;padding:0 12px;height:42px;font-size:14px;color:#e4e4e7;cursor:pointer;transition:border-color .2s,background-color .2s}.account-trigger:hover{border-color:#3f3f46;background-color:#1f1f23}.account-avatar,.account-avatar-img{width:24px;height:24px;border-radius:50%;flex-shrink:0}.account-avatar{display:grid;place-items:center;background:#27272a;color:#e4e4e7;font-size:12px;font-weight:700}.account-avatar-img{object-fit:cover}.account-name{max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.account-dropdown-menu{position:absolute;top:calc(100% + 4px);right:0;min-width:320px;background:#18181b;border:1px solid #27272a;border-radius:10px;padding:12px;box-shadow:0 8px 24px #00000059;z-index:220}.account-dropdown-title{font-size:12px;color:#a1a1aa;letter-spacing:.04em;text-transform:uppercase;margin-bottom:10px}.account-row{display:flex;flex-direction:column;gap:2px;padding:8px 10px;border-radius:8px;background:#0f1115;border:1px solid #27272a}.account-row+.account-row{margin-top:8px}.account-label{font-size:11px;color:#71717a;text-transform:uppercase;letter-spacing:.04em}.account-value{font-size:13px;color:#e4e4e7;word-break:break-all}.account-value.uid{font-family:ui-monospace,Cascadia Code,Source Code Pro,monospace}.account-logout-btn{margin-top:10px;width:100%;height:36px;border-radius:8px;border:1px solid rgba(239,68,68,.4);background:#ef44441a;color:#f87171;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.account-logout-btn:hover{background:#ef44442e;border-color:#ef44448c}.client-dropdown-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:6px;font-size:14px;color:#e4e4e7;cursor:pointer;transition:background-color .15s;background:transparent;border:none;width:100%;text-align:left;min-width:0}.client-dropdown-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.client-dropdown-id{flex-shrink:0;font-family:ui-monospace,Cascadia Code,Source Code Pro,monospace;font-size:11px;color:#a1a1aa;background:#3f3f464d;border:1px solid rgba(82,82,91,.45);border-radius:5px;padding:1px 6px}.table-muted{color:#71717a}.invite-accept-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:48px 20px}.invite-accept-card{width:100%;max-width:520px;background:#0f1117;border:1px solid #20252f;border-radius:16px;padding:28px 28px 24px;box-shadow:0 12px 32px #00000059;text-align:center}.invite-accept-title{font-size:22px;font-weight:600;color:#f3f4f6}.invite-accept-subtitle{margin-top:10px;color:#9ca3af;font-size:14px}.invite-accept-message{margin-top:18px;padding:12px 14px;border-radius:10px;font-size:14px;color:#e5e7eb;background:#4f46e51a;border:1px solid rgba(79,70,229,.35)}.invite-accept-message.success{background:#10b9811f;border-color:#10b98166}.invite-accept-message.error{background:#ef44441a;border-color:#ef444459}.invite-accept-message.warning{background:#f59e0b1f;border-color:#f59e0b66}.invite-accept-button{margin-top:18px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border-radius:10px;background:#4f46e5;color:#fff;font-weight:600;text-decoration:none;border:none;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.invite-accept-button:hover{transform:translateY(-1px);box-shadow:0 8px 20px #4f46e559}.invite-accept-button.secondary{background:#1f2937;color:#e5e7eb;border:1px solid #374151}.invite-accept-button.secondary:hover{box-shadow:0 8px 20px #1f293759}.client-dropdown-item:hover{background:#27272a}.client-dropdown-item.active{background:#8b5cf626}.client-selector{display:flex;align-items:center;gap:10px}.client-select{background:#18181b;border:1px solid #27272a;border-radius:8px;padding:0 32px 0 14px;height:36px;font-size:14px;color:#e4e4e7;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;min-width:180px;transition:border-color .2s,background-color .2s}.client-select:hover{border-color:#3f3f46;background-color:#1f1f23}.client-select:focus{outline:none;border-color:#8b5cf6}.floating-toolbar{margin-bottom:16px}.header-search{flex:1;max-width:720px;display:flex;align-items:center}.toolbar-inner{background:#18181b;border:1px solid #27272a;border-radius:8px;padding:0 12px;height:42px;display:flex;align-items:center;gap:8px;width:100%}.search-icon{padding-left:12px;font-size:16px;color:#71717a}.search-icon-svg{width:22px;height:22px;margin-left:12px;opacity:.7}.search-input{flex:1;background:transparent;border:none;color:#fff;font-size:14px;padding:8px 0;outline:none}.search-input::placeholder{color:#52525b}.search-clear{background:transparent;border:none;color:#71717a;font-size:18px;cursor:pointer;padding:0 8px;display:flex;align-items:center;justify-content:center;transition:color .15s}.search-clear:hover{color:#e4e4e7}.toolbar-divider{width:1px;height:24px;background:#27272a}.search-select{background:transparent;border:none;color:#a1a1aa;font-size:14px;padding:8px;outline:none;cursor:pointer}.search-select option{background:#18181b;color:#fff}.search-button{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;padding:8px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 10px #6366f14d}.search-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 15px #6366f180}.search-button:disabled{opacity:.5;cursor:not-allowed}.hero-banner{background:linear-gradient(135deg,#7c3aed,#3b82f6);border-radius:12px;padding:24px 32px;color:#fff;position:relative;overflow:hidden;box-shadow:0 8px 30px #7c3aed40}.hero-banner:before{content:"";position:absolute;top:-50%;right:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%;pointer-events:none}.hero-title{font-size:18px;font-weight:700;margin-bottom:8px}.hero-subtitle{font-size:14px;opacity:.9;line-height:1.6;max-width:800px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.kpi-card{background:#0a0e14;border:1px solid #1f1f1f;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .3s}.kpi-card:hover{border-color:#27272a;transform:translateY(-2px);box-shadow:0 8px 20px #0000004d}.kpi-highlight{background:#f59e0b0d;border-color:#f59e0b33}.kpi-icon-wrapper{width:48px;height:48px;border-radius:10px;display:grid;place-items:center;flex-shrink:0}.kpi-icon-wrapper.purple{background:#8b5cf61a;color:#a78bfa}.kpi-icon-wrapper.green{background:#10b9811a;color:#34d399}.kpi-icon-wrapper.yellow{background:#f59e0b1a;color:#fbbf24}.kpi-icon-wrapper.blue{background:#3b82f61a;color:#60a5fa}.kpi-icon{font-size:20px}.kpi-icon-svg{width:24px;height:24px}.kpi-content{display:flex;flex-direction:column}.kpi-value{font-size:24px;font-weight:700;color:#fff;line-height:1.2}.kpi-label{font-size:14px;color:#71717a;margin-top:2px}.alert-section{background:#f59e0b0d;border:1px solid rgba(245,158,11,.2);border-radius:12px;overflow:hidden}.alert-header{padding:14px 20px;background:#f59e0b1a;color:#fbbf24;font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px;cursor:pointer;transition:background .2s}.alert-icon-svg{width:18px;height:18px}.alert-header:hover{background:#f59e0b26}.alert-toggle{margin-left:auto;font-size:14px;color:#fbbf24}.alert-body{padding:16px 20px;font-size:14px;color:#d1d5db}.alert-list{background:#0003}.alert-item{display:flex;align-items:center;padding:12px 20px;border-bottom:1px solid rgba(245,158,11,.1);gap:16px;transition:background .2s}.alert-item:last-child{border-bottom:none}.alert-item:hover{background:#f59e0b0d}.alert-status{font-size:14px;font-weight:600;padding:4px 10px;border-radius:4px}.alert-status.ok{background:#22c55e26;color:#22c55e}.alert-status.warning{background:#f59e0b26;color:#f59e0b}.alert-status.error{background:#ef444426;color:#ef4444}.alert-time{flex:1;font-size:14px;color:#71717a}.alert-expand{font-size:14px;color:#52525b}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.chart-card-full{grid-column:1 / -1}.card{background:#0a0e14;border:1px solid #1f1f1f;border-radius:12px;overflow:hidden}.full-width{grid-column:span 2}.card-header{padding:16px 20px;border-bottom:1px solid #1f1f1f;display:flex;justify-content:space-between;align-items:center}.card-header h3{margin:0;font-size:14px;font-weight:600;color:#e4e4e7;display:flex;align-items:center;gap:8px}.chart-body{padding:20px;min-height:240px}.rssi-legend{display:flex;justify-content:center;gap:24px;margin-top:12px;font-size:14px;color:#a1a1aa}.rssi-legend-item{display:flex;align-items:center;gap:6px}.rssi-dot{width:10px;height:10px;border-radius:50%}.rssi-dot.green{background:#10b981}.rssi-dot.yellow{background:#f59e0b}.rssi-dot.red{background:#ef4444}.flex-center{display:flex;justify-content:center;align-items:center}.no-data{color:#52525b;font-size:14px}.timeline-list{padding:0 20px;max-height:400px;overflow-y:auto}.timeline-item{display:flex;gap:16px;padding-bottom:24px;position:relative}.timeline-item:last-child{padding-bottom:0;margin-bottom:24px}.timeline-left{display:flex;flex-direction:column;align-items:center;width:24px;flex-shrink:0}.timeline-icon{width:12px;height:12px;border-radius:50%;background:#0a0e14;border:2px solid #3b82f6;z-index:2;margin-top:6px}.timeline-icon-solid{width:16px;height:16px;border-radius:50%;z-index:2;margin-top:4px;display:grid;place-items:center;box-shadow:0 0 8px #fff3}.timeline-icon-solid:after{content:"+";font-size:14px;font-weight:700;color:#fff}.timeline-line{width:2px;background:#1f1f1f;flex:1;margin-top:-2px;margin-bottom:-18px}.timeline-item:last-child .timeline-line{display:none}.timeline-content{flex:1;background:#121212;border:1px solid #1f1f1f;border-radius:8px;padding:12px 16px;transition:all .2s}.timeline-item:hover .timeline-content{border-color:#27272a;background:#18181b}.timeline-header{display:flex;justify-content:space-between;margin-bottom:6px;align-items:center}.timeline-category{font-size:14px;font-weight:600;color:#3b82f6;text-transform:uppercase;background:#3b82f61a;padding:2px 6px;border-radius:4px}.timeline-source-badge{font-size:14px;font-weight:600;padding:2px 8px;border-radius:10px;margin-left:8px}.timeline-time{font-size:14px;color:#52525b;font-family:monospace;margin-left:auto}.timeline-body{font-size:14px;color:#d4d4d8;line-height:1.5}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#27272a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#3f3f46}.error-banner{background:#451a1a;border:1px solid #7f1d1d;color:#fca5a5;padding:12px;border-radius:8px;font-size:14px;display:flex;align-items:center;gap:8px}.inline-icon{width:18px;height:18px;flex-shrink:0}.no-data-block{padding:48px 20px;text-align:center;color:#52525b;font-size:14px}.behavior-bars{display:flex;flex-direction:column;gap:16px;padding:12px 0}.behavior-row{display:flex;align-items:center;gap:16px}.behavior-label{width:48px;font-size:14px;font-weight:500;color:#a1a1aa;flex-shrink:0}.behavior-bar-bg{flex:1;height:24px;background:#1f1f1f;border-radius:6px;overflow:hidden}.behavior-bar{height:100%;border-radius:6px;transition:width .5s ease-out}.behavior-value{width:64px;text-align:right;font-size:14px;font-weight:500;color:#71717a;flex-shrink:0}.suggestions-section{background:#0a0e14;border:1px solid #1f1f1f;border-radius:12px;padding:20px}.suggestions-header{font-size:14px;font-weight:600;color:#e4e4e7;margin-bottom:16px;display:flex;align-items:center;gap:8px}.suggestions-buttons{display:flex;flex-wrap:wrap;gap:12px}.suggestion-btn{padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid transparent}.suggestion-btn.green{background:#22c55e1a;border-color:#22c55e4d;color:#22c55e}.suggestion-btn.green:hover{background:#22c55e33;border-color:#22c55e80}.suggestion-btn.gray{background:#71717a1a;border-color:#71717a4d;color:#a1a1aa}.suggestion-btn.gray:hover{background:#71717a33;border-color:#71717a80}.suggestion-btn.pink{background:#ec48991a;border-color:#ec48994d;color:#ec4899}.suggestion-btn.pink:hover{background:#ec489933;border-color:#ec489980}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0a1628,#0d1f3c,#0a1628);position:relative;overflow:hidden}.login-background{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.grid-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 25% 25%,rgba(34,211,238,.03) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(34,211,238,.02) 0%,transparent 50%)}.floating-dots{position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle,rgba(34,211,238,.15) 1px,transparent 1px);background-size:50px 50px;opacity:.3}.login-container{display:flex;align-items:center;gap:80px;max-width:1100px;width:100%;padding:40px;z-index:1}.login-left{flex:1;color:#fff;align-self:flex-start;margin-top:-60px}.brand-section{margin-bottom:24px}.brand-logo{display:flex;align-items:center;gap:12px;margin-bottom:20px}.brand-logo .logo-icon-svg{width:48px;height:48px}.brand-logo-text{font-size:24px;font-weight:700;color:#fff;letter-spacing:.5px}.logo-icon{font-size:32px;filter:brightness(1.2)}.logo-icon-svg{width:32px;height:32px}.brand-subtitle{font-size:18px;color:#a78bfa;margin:0 0 8px;font-weight:500;letter-spacing:.5px}.brand-title{font-size:48px;font-weight:800;margin:0 0 8px;color:#fff;letter-spacing:-1px;line-height:1.1}.gradient-text{background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-tagline{font-size:18px;color:#22d3ee;margin:0;font-weight:500}.brand-description{font-size:14px;color:#94a3b8;line-height:1.7;margin:24px 0}.brand-description .highlight{color:#22d3ee;font-weight:600}.feature-badges{display:flex;gap:12px;margin-bottom:40px}.badge{font-size:14px;font-weight:500;padding:6px 12px;border-radius:20px;display:flex;align-items:center;gap:6px}.badge:before{content:"";width:6px;height:6px;border-radius:50%}.badge.green{background:#22c55e26;color:#22c55e}.badge.green:before{background:#22c55e;box-shadow:0 0 8px #22c55e80}.badge.blue{background:#3b82f626;color:#3b82f6}.badge.blue:before{background:#3b82f6;box-shadow:0 0 8px #3b82f680}.building-illustration{display:flex;align-items:flex-end;gap:12px;margin-top:24px;opacity:.3}.building{border:2px solid #22d3ee;border-radius:4px 4px 0 0}.building.b1{width:60px;height:80px}.building.b2{width:80px;height:120px}.building.b3{width:50px;height:60px}.login-right{width:360px;flex-shrink:0}.login-card{background:#0f172acc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(34,211,238,.2);border-radius:16px;padding:32px;box-shadow:0 20px 60px #0006}.ultron-button{width:100%;padding:14px 24px;background:linear-gradient(135deg,#0891b2,#06b6d4);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .3s;box-shadow:0 4px 20px #0891b266}.ultron-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px #0891b299}.ultron-button:disabled{opacity:.6;cursor:not-allowed}.btn-icon{font-size:16px}.btn-icon-svg{width:18px;height:18px}.auth-divider{display:flex;align-items:center;margin:20px 0;color:#475569;font-size:14px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#1e293b}.auth-divider span{padding:0 16px}.license-button{width:100%;padding:14px 24px;background:transparent;border:1px solid #334155;border-radius:8px;color:#94a3b8;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .2s}.license-button:hover:not(:disabled){border-color:#475569;background:#3341554d;color:#cbd5e1}.license-button:disabled{opacity:.6;cursor:not-allowed}.privacy-note{font-size:14px;color:#475569;text-align:center;margin-top:20px;line-height:1.5}.login-error{position:fixed;bottom:60px;left:50%;transform:translate(-50%);background:#7f1d1d;border:1px solid #b91c1c;color:#fca5a5;padding:12px 24px;border-radius:8px;font-size:14px;z-index:100}.login-footer{position:absolute;bottom:24px;left:50%;transform:translate(-50%);font-size:14px;color:#fff;font-weight:700;letter-spacing:.5px}.page-footer{position:fixed;bottom:0;left:0;right:0;width:100%;height:44px;display:flex;align-items:center;justify-content:center;font-size:14px;color:#6b7280;font-weight:700;letter-spacing:.5px;border-top:1px solid #1f1f1f;background:#0a0e14;z-index:260}.access-denied-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#05050580;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.access-check-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#050505b8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:950;display:flex;align-items:center;justify-content:center}.access-check-card{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:10px;background:#101218;border:1px solid #2a2f3a}.access-check-text{font-size:14px;color:#cbd5e1}.access-denied-modal{width:100%;max-width:520px;background:#101218;border:1px solid #2a2f3a;border-radius:14px;padding:24px;box-shadow:0 22px 60px #00000073}.access-denied-title{margin:0 0 10px;color:#f3f4f6;font-size:22px;font-weight:700}.access-denied-message{margin:0 0 10px;color:#cbd5e1;font-size:14px;line-height:1.6}.access-denied-actions{margin-top:16px;display:flex;gap:10px}.access-denied-btn{height:40px;border-radius:9px;border:1px solid transparent;padding:0 14px;cursor:pointer;font-size:14px;font-weight:600}.access-denied-btn.primary{background:#4f46e5;color:#fff}.access-denied-btn.primary:hover{background:#5b52f6}.access-denied-btn.secondary{background:#1f2937;color:#e5e7eb;border-color:#334155}.access-denied-btn.secondary:hover{background:#273345}.admin-page{display:flex;flex-direction:column;gap:24px}.admin-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.stat-card{background:#0a0e14;border:1px solid #1f1f1f;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px}.stat-icon{width:48px;height:48px;border-radius:10px;display:grid;place-items:center;font-size:20px}.stat-icon-svg{width:28px;height:28px}.stat-icon.purple{background:#8b5cf61a}.stat-icon.green{background:#22c55e1a}.stat-icon.yellow{background:#f59e0b1a}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:28px;font-weight:700;color:#fff}.stat-label{font-size:14px;color:#71717a}.notification{padding:12px 16px;border-radius:8px;display:flex;align-items:center;gap:10px;font-size:14px}.notification.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.notification.success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#86efac}.notification-close{margin-left:auto;background:transparent;border:none;color:inherit;font-size:18px;cursor:pointer;opacity:.6}.notification-close:hover{opacity:1}.notification-icon{width:18px;height:18px;flex-shrink:0}.admin-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.admin-card{background:#0a0e14;border:1px solid #1f1f1f;border-radius:12px;overflow:hidden}.admin-card.full-width{grid-column:span 2}.admin-card-header{padding:16px 20px;border-bottom:1px solid #1f1f1f;display:flex;justify-content:space-between;align-items:center}.admin-card-header h3{margin:0;font-size:14px;font-weight:600;color:#e4e4e7;display:flex;align-items:center;gap:8px}.card-header-icon{width:20px;height:20px;opacity:.9}.admin-card-subtitle{font-size:14px;color:#71717a;margin-top:2px;display:block}.admin-card-body{padding:20px}.admin-card-body.no-padding{padding:0}.input-group{display:flex;gap:12px}.admin-input{flex:1;background:#18181b;border:1px solid #27272a;border-radius:8px;padding:10px 14px;color:#fff;font-size:14px;outline:none;transition:border-color .2s}.admin-input:focus{border-color:#6366f1}.admin-input::placeholder{color:#52525b}.admin-select{flex:1;background:#18181b;border:1px solid #27272a;border-radius:8px;padding:10px 36px 10px 14px;color:#fff;font-size:14px;outline:none;transition:border-color .2s;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2371717a' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.admin-select:focus{border-color:#6366f1}.admin-select option{background:#18181b;color:#fff;padding:8px}.admin-btn{padding:10px 18px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all .2s;white-space:nowrap}.admin-btn.primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.admin-btn.primary:hover:not(:disabled){box-shadow:0 4px 15px #6366f166}.admin-btn.secondary{background:#27272a;color:#a1a1aa}.admin-btn.secondary:hover:not(:disabled){background:#3f3f46;color:#fff}.admin-btn.warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:#fbbf24}.admin-btn.warning:hover:not(:disabled){background:#f59e0b33}.admin-btn.danger{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171}.admin-btn.danger:hover:not(:disabled){background:#ef444433}.admin-btn.small{padding:6px 12px;font-size:14px}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:14px 20px;text-align:left;border-bottom:1px solid #1f1f1f}.admin-table th{font-size:14px;font-weight:600;color:#71717a;text-transform:uppercase;letter-spacing:.5px;background:#0a0e14}.admin-table tr:hover{background:#0a0e14}.admin-table tr:last-child td{border-bottom:none}.audit-table-container{overflow-x:auto}.audit-table{width:100%;border-collapse:collapse;min-width:700px}.audit-table th,.audit-table td{padding:14px 16px;text-align:left;border-bottom:1px solid #1f1f1f}.audit-table th{font-size:12px;font-weight:600;color:#71717a;text-transform:uppercase;letter-spacing:.5px;background:#0a0e14;position:sticky;top:0}.audit-table tr:hover{background:#6366f10d}.audit-time{font-size:13px;color:#a1a1aa;white-space:nowrap;font-family:ui-monospace,Cascadia Code,Source Code Pro,monospace}.audit-user-info{display:flex;flex-direction:column;gap:2px}.audit-user-name{font-size:14px;font-weight:500;color:#fff}.audit-user-email{font-size:12px;color:#71717a}.audit-action-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500;color:#fff}.audit-details{font-size:14px;color:#e4e4e7}.audit-sn{display:inline-block;margin-left:8px;padding:2px 6px;background:#27272a;border-radius:4px;font-size:12px;font-family:ui-monospace,Cascadia Code,Source Code Pro,monospace;color:#6366f1}.audit-ip{font-size:13px;color:#71717a;font-family:ui-monospace,Cascadia Code,Source Code Pro,monospace}.load-more-container{display:flex;justify-content:center;padding:24px;border-top:1px solid #1f1f1f}.pagination{display:flex;align-items:center;justify-content:center;gap:8px;padding:20px;border-top:1px solid #1f1f1f}.pagination-btn{min-width:36px;height:36px;padding:0 12px;background:#18181b;border:1px solid #27272a;border-radius:8px;color:#a1a1aa;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.pagination-btn:hover:not(:disabled){background:#27272a;color:#fff;border-color:#3f3f46}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-btn.active{background:#6366f1;border-color:#6366f1;color:#fff}.pagination-ellipsis{color:#71717a;padding:0 4px}.pagination-info{margin-left:16px;color:#71717a;font-size:13px}.user-cell{display:flex;align-items:center;gap:12px}.user-avatar-small{width:36px;height:36px;border-radius:50%;background:#27272a;color:#e4e4e7;display:grid;place-items:center;font-size:14px;font-weight:600}.user-details{display:flex;flex-direction:column}.user-name-text{font-size:14px;font-weight:500;color:#fff}.user-email{font-size:14px;color:#71717a}.uid-code{font-size:14px;background:#18181b;padding:4px 8px;border-radius:4px;color:#a1a1aa;font-family:monospace}.role-badge{font-size:14px;font-weight:500;padding:4px 10px;border-radius:20px}.role-badge.admin{background:#8b5cf61a;color:#a78bfa}.role-badge.user{background:#71717a1a;color:#a1a1aa}.current-user-tag{margin-left:8px;font-size:14px;color:#6366f1;font-weight:500}.loading-state,.empty-state{padding:48px 20px;text-align:center;color:#71717a}.empty-state-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.6}.empty-state-title{font-size:18px;font-weight:600;color:#e4e4e7;margin-bottom:8px}.empty-state-subtitle{font-size:14px;color:#71717a;max-width:400px}.loading-state{display:flex;flex-direction:column;align-items:center;gap:12px}.spinner{width:24px;height:24px;border:2px solid #27272a;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-icon{font-size:48px;opacity:.3;display:block;margin-bottom:8px}.empty-icon-svg{width:48px;height:48px;opacity:.3;margin-bottom:8px}@media (max-width: 1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.login-container{flex-direction:column;gap:40px;text-align:center;padding-top:40px}.login-left{max-width:400px}.feature-badges,.building-illustration{justify-content:center}.login-right{width:100%;max-width:360px}}@media (max-width: 768px){.charts-grid,.kpi-grid{grid-template-columns:1fr}.suggestions-buttons{flex-direction:column}.brand-title{font-size:32px}.admin-stats,.admin-grid{grid-template-columns:1fr}.admin-card.full-width{grid-column:span 1}.input-group{flex-direction:column}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;padding:24px;min-width:320px;max-width:420px;box-shadow:0 20px 60px #00000080;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-title{margin:0 0 12px;font-size:18px;font-weight:600;color:#e4e4e7}.modal-message{margin:0 0 24px;font-size:14px;color:#a1a1aa;line-height:1.5}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.device-info-card{background:#18181b;border:1px solid #27272a;border-radius:12px;padding:20px;margin-bottom:24px}.device-info-header{display:flex;align-items:center;gap:16px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #27272a}.device-info-icon{width:48px;height:48px;padding:10px;background:#3b82f620;border-radius:12px;filter:brightness(0) saturate(100%) invert(55%) sepia(82%) saturate(2000%) hue-rotate(200deg) brightness(100%) contrast(95%)}.device-info-title{display:flex;flex-direction:column;gap:4px}.device-sn{font-size:18px;font-weight:600;color:#e4e4e7;font-family:SF Mono,Monaco,Consolas,monospace}.device-model{font-size:14px;color:#71717a}.device-name{font-size:14px;color:#cbd5e1;font-weight:600}.device-line{display:flex;align-items:baseline;gap:8px}.device-line-label{font-size:12px;color:#71717a;font-family:ui-monospace,Cascadia Code,Source Code Pro,monospace;letter-spacing:.03em}.device-line-value{font-size:14px;color:#e4e4e7;font-weight:600}.device-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.device-info-item{display:flex;flex-direction:column;gap:4px}.device-info-label{font-size:14px;color:#71717a;text-transform:uppercase;letter-spacing:.5px}.device-info-value{font-size:14px;color:#e4e4e7;font-weight:500;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.device-info-subvalue{margin-top:4px;font-size:12px;color:#71717a;font-family:ui-monospace,Cascadia Code,Source Code Pro,monospace;word-break:break-all}.firmware-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:14px;font-weight:600;text-transform:uppercase}.firmware-badge.firmware-latest{background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.firmware-badge.firmware-update{background:#fbbf2426;color:#fbbf24;border:1px solid rgba(251,191,36,.3)}.duration-badge{display:inline-flex;align-items:center;padding:2px 8px;background:#3b82f626;color:#3b82f6;border:1px solid rgba(59,130,246,.3);border-radius:4px;font-size:14px;font-weight:600}@media (max-width: 768px){.device-info-grid{grid-template-columns:repeat(2,1fr)}}.device-status-indicator{display:flex;align-items:center;gap:8px;margin-left:auto;padding:6px 12px;background:#27272a;border-radius:20px}.status-dot{width:10px;height:10px;border-radius:50%;animation:pulse 2s infinite}.status-dot.online{background:#22c55e;box-shadow:0 0 8px #22c55e80}.status-dot.offline{background:#ef4444;box-shadow:0 0 8px #ef444480;animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-text{font-size:14px;font-weight:500;color:#e4e4e7}.device-status-row{display:flex;gap:24px;margin-top:16px;padding-top:16px;border-top:1px solid #27272a}.status-item{display:flex;flex-direction:column;gap:4px}.status-label{font-size:14px;color:#71717a;text-transform:uppercase;letter-spacing:.5px}.status-value{font-size:14px;color:#e4e4e7;font-weight:500}.status-value.rssi-good{color:#22c55e}.status-value.rssi-fair{color:#f59e0b}.status-value.rssi-poor,.status-value.battery-low{color:#ef4444}.status-value.connection-type{display:flex;align-items:center;gap:6px}.status-value.connection-type svg{flex-shrink:0;opacity:.9}.status-value.health-state{color:#60a5fa}.device-settings-card{background:#18181b;border:1px solid #27272a;border-radius:12px;padding:20px;margin-bottom:24px}.device-settings-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.device-settings-icon{width:24px;height:24px;filter:brightness(0) saturate(100%) invert(60%) sepia(50%) saturate(500%) hue-rotate(220deg) brightness(100%) contrast(90%)}.device-settings-title{font-size:16px;font-weight:600;color:#e4e4e7}.device-settings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.device-settings-item{display:flex;flex-direction:column;gap:6px}.device-settings-label{font-size:14px;color:#71717a;text-transform:uppercase;letter-spacing:.5px}.device-settings-value{font-size:14px;color:#e4e4e7;font-weight:500}.device-settings-scenes{grid-column:span 1}.device-settings-scenes-list{display:flex;flex-wrap:wrap;gap:8px}.scene-tag{display:inline-flex;align-items:center;padding:4px 10px;background:#22c55e20;color:#22c55e;border-radius:16px;font-size:14px;font-weight:500}.no-scenes{font-size:14px;color:#52525b;font-style:italic}@media (max-width: 768px){.device-settings-grid{grid-template-columns:1fr}.device-settings-scenes{grid-column:span 1}}.diagnostic-report{background:#18181b;border:1px solid #27272a;border-radius:12px;padding:20px;margin-bottom:24px}.diagnostic-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.diagnostic-icon{width:24px;height:24px;filter:brightness(0) saturate(100%) invert(70%) sepia(50%) saturate(500%) hue-rotate(320deg) brightness(100%) contrast(90%)}.diagnostic-title{font-size:16px;font-weight:600;color:#e4e4e7}.diagnostic-content{display:flex;gap:24px}.health-score-section{display:flex;align-items:flex-start;gap:24px}.health-score-circle{width:100px;height:100px;border-radius:50%;border:4px solid;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0}.health-score-value{font-size:32px;font-weight:700;line-height:1}.health-score-label{font-size:14px;color:#71717a;margin-top:4px}.health-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.health-stat-item{display:flex;flex-direction:column;gap:2px}.health-stat-label{font-size:14px;color:#71717a;text-transform:uppercase;letter-spacing:.5px}.health-stat-value{font-size:14px;color:#e4e4e7;font-weight:500}.diagnostic-issues{flex:1;border-left:1px solid #27272a;padding-left:24px}.no-issues{display:flex;align-items:center;gap:12px;padding:16px;background:#22c55e10;border-radius:8px}.no-issues-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#22c55e20;color:#22c55e;border-radius:50%;font-size:18px;font-weight:600}.no-issues-text{font-size:14px;color:#22c55e;font-weight:500}.issues-header{font-size:14px;color:#71717a;margin-bottom:12px}.issues-list{display:flex;flex-direction:column;gap:12px}.issue-item{background:#1f1f23;border-radius:8px;padding:12px}.issue-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.issue-type-badge{padding:2px 8px;border-radius:4px;font-size:14px;font-weight:600;text-transform:uppercase}.issue-severity{font-size:14px;font-weight:500}.issue-message{font-size:14px;color:#e4e4e7;line-height:1.4}.issue-suggestion{margin-top:8px;font-size:14px;color:#a1a1aa;padding:8px;background:#27272a;border-radius:4px}.suggestion-label{font-weight:500;color:#71717a}@media (max-width: 768px){.diagnostic-content{flex-direction:column}.health-score-section{flex-direction:column;align-items:center}.diagnostic-issues{border-left:none;border-top:1px solid #27272a;padding-left:0;padding-top:20px}}.alert-history{background:#18181b;border:1px solid #27272a;border-radius:12px;margin-bottom:24px;overflow:hidden}.alert-history-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;transition:background .2s}.alert-history-header:hover{background:#1f1f23}.alert-history-title{display:flex;align-items:center;gap:12px;font-size:16px;font-weight:600;color:#e4e4e7}.alert-history-icon{width:20px;height:20px;filter:brightness(0) saturate(100%) invert(75%) sepia(50%) saturate(500%) hue-rotate(350deg) brightness(100%) contrast(95%)}.alert-count-badge{padding:2px 8px;background:#f59e0b20;color:#f59e0b;border-radius:12px;font-size:14px;font-weight:600}.alert-toggle{color:#71717a;font-size:14px}.alert-history-content{border-top:1px solid #27272a;padding:16px 20px}.alert-filter-tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.alert-filter-tab{padding:6px 12px;background:#27272a;border:none;border-radius:6px;color:#a1a1aa;font-size:14px;cursor:pointer;transition:all .2s}.alert-filter-tab:hover{background:#3f3f46;color:#e4e4e7}.alert-filter-tab.active{background:#3b82f6;color:#fff}.no-alerts{display:flex;align-items:center;justify-content:center;gap:12px;padding:24px;background:#22c55e10;border-radius:8px}.no-alerts-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#22c55e20;color:#22c55e;border-radius:50%;font-size:16px;font-weight:600}.no-alerts-text{font-size:14px;color:#22c55e;font-weight:500}.alert-list-container{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}.alert-history-item{display:flex;flex-wrap:wrap;align-items:center;gap:12px;padding:12px;background:#1f1f23;border-radius:8px;transition:background .2s}.alert-history-item:hover{background:#27272a}.alert-history-item.resolved{opacity:.6}.alert-item-left{display:flex;align-items:center;gap:10px}.alert-type-badge{padding:3px 8px;border-radius:4px;font-size:14px;font-weight:600}.alert-item-time{font-size:14px;color:#71717a;font-family:SF Mono,monospace}.alert-item-message{flex:1;font-size:14px;color:#e4e4e7}.alert-resolved-badge{padding:2px 8px;background:#22c55e20;color:#22c55e;border-radius:12px;font-size:14px;font-weight:500}@media (max-width: 768px){.alert-filter-tabs{overflow-x:auto;flex-wrap:nowrap;padding-bottom:8px}.alert-item-message{width:100%;margin-top:8px}}.mock-data-badge{display:inline-flex;align-items:center;padding:2px 8px;background:#a855f726;color:#a855f7;border:1px solid rgba(168,85,247,.3);border-radius:4px;font-size:14px;font-weight:600;text-transform:uppercase;margin-left:auto}.hamburger-menu{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;background:transparent;border:none;cursor:pointer;padding:8px;margin-right:8px}.hamburger-line{display:block;width:22px;height:2px;background:#a1a1aa;border-radius:1px;transition:all .3s ease}.hamburger-menu:hover .hamburger-line{background:#fff}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;z-index:150;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sidebar.mobile{transform:translate(-100%);width:280px;z-index:200}.sidebar.mobile.open{transform:translate(0)}.topbar.mobile{left:0;padding:0 16px}.content.mobile{margin-left:0}@media (min-width: 768px) and (max-width: 1024px){.sidebar{width:72px}.sidebar .sidebar-title,.sidebar .nav-label,.sidebar .user-info{display:none}.sidebar-nav a{justify-content:center;padding:12px}.content{margin-left:72px}.topbar{left:72px;padding:0 24px}.page{padding:96px 24px 24px}.sidebar-toggle{display:none}.device-info-grid,.device-settings-grid,.diagnostic-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 767px){.sidebar{display:none}.sidebar.mobile{display:flex}.content,.content.sidebar-collapsed{margin-left:0}.topbar{left:0;padding:0 12px;height:56px}.topbar.sidebar-collapsed{left:0}.topbar-left{flex:1;gap:8px;overflow:hidden}.header-search{flex:1;max-width:calc(100vw - 120px);min-width:0}.toolbar-inner{padding:0 6px;height:36px;gap:2px}.search-input{font-size:12px;min-width:0;flex:1}.search-input::placeholder{font-size:11px}.toolbar-divider{display:none}.search-select{font-size:11px;padding:2px 4px;min-width:auto;max-width:65px}.search-button{padding:5px 10px;font-size:11px;border-radius:5px;white-space:nowrap}.search-icon-svg{width:14px;height:14px;flex-shrink:0}.search-clear{font-size:14px;padding:2px}.topbar-actions{gap:6px;flex-shrink:0}.account-trigger{padding:0 8px}.account-dropdown-menu{min-width:260px;right:0}.client-dropdown-trigger{padding:4px 8px}.client-logo{width:24px;height:24px}.dropdown-arrow{font-size:10px}.page{padding:72px 16px 60px}.page-footer{left:0;width:100%}.search-section{padding:16px;gap:12px}.search-section h2{font-size:18px}.search-input-wrapper{flex-direction:column;gap:12px}.search-input-wrapper input{width:100%}.search-input-wrapper button{width:100%;justify-content:center}.device-info-card{padding:16px}.device-info-header{flex-direction:column;align-items:flex-start;gap:12px}.device-info-title-row{flex-direction:column;align-items:flex-start;gap:8px}.device-info-grid{grid-template-columns:1fr;gap:12px}.device-info-item{flex-direction:column;align-items:flex-start;gap:4px}.device-settings-card{padding:16px}.device-settings-grid{grid-template-columns:1fr}.setting-item{flex-direction:column;align-items:flex-start;gap:4px}.diagnostic-report{padding:16px}.diagnostic-grid{grid-template-columns:1fr}.diagnostic-header{flex-direction:column;align-items:flex-start;gap:12px}.summary-card{flex-direction:column;gap:12px;text-align:center}.recommendations-list li{padding:12px}.alert-history{padding:16px}.alert-history-header{flex-direction:column;align-items:flex-start;gap:12px}.alert-history-controls{width:100%;flex-direction:column;gap:8px}.alert-search-input{width:100%}.alert-filter-tabs{width:100%;justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap}.alert-history-item{flex-direction:column;align-items:flex-start;gap:8px}.modal-content{margin:16px;max-height:calc(100vh - 32px);width:calc(100% - 32px)}.form-row{flex-direction:column;gap:16px}.form-row .form-group{width:100%}.user-table{display:block;overflow-x:auto}.user-table th,.user-table td{min-width:120px;padding:12px 8px;font-size:14px}.client-dropdown-trigger{padding:6px 10px}.client-logo{width:28px;height:28px}.page-stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.firmware-badge,.duration-badge,.mock-data-badge{font-size:12px;padding:2px 6px}.status-badge{padding:3px 8px;font-size:14px}.topbar-actions{gap:8px}.topbar-chip{display:none}.access-denied-actions{flex-direction:column}}@media (max-width: 400px){.page{padding:70px 12px 20px}.search-section,.device-info-card,.device-settings-card,.diagnostic-report,.alert-history{padding:12px}.page-stats-grid{grid-template-columns:1fr}.modal-content{margin:8px;width:calc(100% - 16px)}.modal-header,.modal-body,.modal-footer{padding:16px}}@media (max-width: 1024px){.auth-divider,.license-button{display:none}}@media (max-width: 767px){.login-page{padding:100px 16px 24px;min-height:100vh;flex-direction:column;justify-content:flex-start;align-items:center}.login-container{flex-direction:column;gap:40px;padding:0;align-items:center;width:100%;flex:1}.login-left{max-width:100%;width:100%;text-align:center;margin-top:0;order:1}.login-right{width:100%;max-width:320px;order:2}.brand-logo{justify-content:center;margin-bottom:32px}.brand-logo .logo-icon-svg{width:36px;height:36px}.brand-logo-text{font-size:20px}.brand-subtitle{font-size:13px;margin-bottom:6px}.brand-title{font-size:24px;margin-bottom:0;line-height:1.3}.brand-tagline{font-size:14px}.brand-description{font-size:13px;margin:14px 0;padding:0 8px;line-height:1.6}.brand-description br{display:none}.feature-badges{justify-content:center;margin-bottom:0;flex-wrap:wrap;gap:8px}.badge{font-size:14px;padding:6px 14px}.building-illustration{display:none}.login-card{padding:24px 20px;border-radius:12px;width:100%;box-sizing:border-box}.ultron-button{padding:14px 20px;font-size:15px}.ultron-button img{width:22px;height:22px}.privacy-note{display:none}.login-footer{position:static;transform:none;margin-top:auto;padding:16px 0;text-align:center;font-size:12px;color:#475569;width:100%}.login-error{position:fixed;bottom:20px;left:16px;right:16px;transform:none;font-size:14px;padding:12px 16px}}@media (max-width: 400px){.login-page{padding:80px 12px 20px}.login-container{gap:32px}.login-right{max-width:280px}.brand-logo{margin-bottom:28px}.brand-logo .logo-icon-svg{width:32px;height:32px}.brand-logo-text{font-size:18px}.brand-title{font-size:22px}.brand-subtitle,.brand-description{font-size:14px}.login-card{padding:20px 16px}.ultron-button{padding:12px 16px;font-size:14px}.feature-badges{gap:6px}.badge{font-size:14px;padding:5px 10px}.login-footer{font-size:11px;padding:12px 0}}
