@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-card: #151c2c;--bg-card-hover: #1a2332;--bg-glass: rgba(21, 28, 44, .85);--bg-input: #0d1321;--accent-cyan: #06d6a0;--accent-cyan-dim: rgba(6, 214, 160, .15);--accent-cyan-glow: rgba(6, 214, 160, .4);--accent-blue: #4361ee;--accent-blue-dim: rgba(67, 97, 238, .15);--accent-orange: #ff6b35;--accent-orange-dim: rgba(255, 107, 53, .15);--accent-red: #ef233c;--accent-red-dim: rgba(239, 35, 60, .15);--accent-yellow: #ffd166;--accent-yellow-dim: rgba(255, 209, 102, .15);--accent-purple: #7b2cbf;--accent-purple-dim: rgba(123, 44, 191, .15);--text-primary: #f0f4f8;--text-secondary: #8492a6;--text-muted: #5a6a7e;--text-accent: var(--accent-cyan);--border-subtle: rgba(255, 255, 255, .06);--border-active: rgba(6, 214, 160, .3);--gradient-primary: linear-gradient(135deg, #06d6a0 0%, #4361ee 100%);--gradient-danger: linear-gradient(135deg, #ef233c 0%, #ff6b35 100%);--gradient-dark: linear-gradient(180deg, #0a0e1a 0%, #111827 100%);--gradient-card: linear-gradient(135deg, rgba(21, 28, 44, .9) 0%, rgba(17, 24, 39, .9) 100%);--gradient-sidebar: linear-gradient(180deg, #0d1321 0%, #0a0e1a 100%);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow-cyan: 0 0 20px rgba(6, 214, 160, .2);--shadow-glow-blue: 0 0 20px rgba(67, 97, 238, .2);--sidebar-width: 260px;--sidebar-collapsed: 72px;--header-height: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--transition-fast: .15s ease;--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:14px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}a{color:var(--accent-cyan);text-decoration:none;transition:var(--transition-fast)}a:hover{color:var(--accent-blue)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 20% 30%,rgba(6,214,160,.08) 0%,transparent 70%),radial-gradient(ellipse 50% 60% at 80% 70%,rgba(67,97,238,.06) 0%,transparent 70%);pointer-events:none}.login-card{width:420px;padding:48px 40px;background:var(--bg-glass);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);position:relative;z-index:1;animation:slideUp .6s var(--transition-base)}.login-logo{display:flex;flex-direction:column;align-items:center;margin-bottom:36px}.login-logo .shield-icon{width:64px;height:64px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin-bottom:16px;box-shadow:var(--shadow-glow-cyan);animation:pulse-glow 3s ease-in-out infinite}.login-logo h1{font-size:1.75rem;font-weight:800;letter-spacing:-.5px;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-logo span{color:var(--text-secondary);font-size:.85rem;font-weight:400;margin-top:4px;letter-spacing:2px;text-transform:uppercase}.form-group{margin-bottom:20px;position:relative}.form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.8px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-family:inherit;font-size:.95rem;transition:var(--transition-base);outline:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent-cyan);box-shadow:0 0 0 3px var(--accent-cyan-dim),var(--shadow-glow-cyan)}.form-group input::placeholder{color:var(--text-muted)}.form-group .input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);transition:var(--transition-fast)}.form-group input.has-icon{padding-left:44px}.form-group input.has-icon:focus~.input-icon,.form-group input.has-icon:focus+.input-icon{color:var(--accent-cyan)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;font-family:inherit;font-size:.9rem;font-weight:600;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-base);letter-spacing:.3px;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 50%);opacity:0;transition:var(--transition-fast)}.btn:hover:after{opacity:1}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow-cyan)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 30px #06d6a059}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-subtle)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-active)}.btn-danger{background:var(--gradient-danger);color:#fff}.btn-danger:hover{transform:translateY(-2px)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:8px 12px}.btn-ghost:hover{color:var(--text-primary);background:var(--border-subtle)}.btn-full{width:100%}.btn-sm{padding:8px 16px;font-size:.82rem}.btn-lg{padding:14px 32px;font-size:1rem}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-sm)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--gradient-sidebar);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100;transition:var(--transition-slow)}.sidebar-brand{height:var(--header-height);display:flex;align-items:center;padding:0 20px;gap:12px;border-bottom:1px solid var(--border-subtle)}.sidebar-brand .brand-icon{width:36px;height:36px;background:var(--gradient-primary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-brand h2{font-size:1.1rem;font-weight:800;letter-spacing:-.3px;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-brand small{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;display:block}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-section-title{font-size:.68rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;padding:12px 12px 8px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-sm);color:var(--text-secondary);font-weight:500;font-size:.88rem;cursor:pointer;transition:var(--transition-base);margin-bottom:2px;text-decoration:none;position:relative}.nav-item:hover{background:var(--accent-cyan-dim);color:var(--accent-cyan)}.nav-item.active{background:var(--accent-cyan-dim);color:var(--accent-cyan);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--accent-cyan);border-radius:0 4px 4px 0}.nav-item .badge{margin-left:auto;background:var(--accent-red);color:#fff;font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:10px;min-width:20px;text-align:center}.sidebar-footer{padding:16px;border-top:1px solid var(--border-subtle)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-base)}.sidebar-user:hover{background:var(--border-subtle)}.sidebar-user .avatar{width:36px;height:36px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff;flex-shrink:0}.sidebar-user .user-info{flex:1;overflow:hidden}.sidebar-user .user-name{font-weight:600;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user .user-role{font-size:.72rem;color:var(--text-muted)}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;display:flex;flex-direction:column}.header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 28px;background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:50}.header-left{display:flex;align-items:center;gap:16px}.header-title{font-size:1.1rem;font-weight:700;letter-spacing:-.3px}.header-subtitle{font-size:.78rem;color:var(--text-muted)}.header-right{display:flex;align-items:center;gap:12px}.header-status{display:flex;align-items:center;gap:6px;padding:6px 14px;background:var(--accent-cyan-dim);border-radius:20px;font-size:.78rem;font-weight:600;color:var(--accent-cyan)}.header-status .status-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-cyan);animation:pulse-dot 2s ease-in-out infinite}.page-content{flex:1;padding:28px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:28px}.stat-card{background:var(--gradient-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:24px;position:relative;overflow:hidden;transition:var(--transition-base)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);opacity:0;transition:var(--transition-base)}.stat-card:hover{transform:translateY(-3px);border-color:var(--border-active);box-shadow:var(--shadow-glow-cyan)}.stat-card:hover:before{opacity:1}.stat-card .stat-icon{width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:14px}.stat-card .stat-icon.cyan{background:var(--accent-cyan-dim);color:var(--accent-cyan)}.stat-card .stat-icon.blue{background:var(--accent-blue-dim);color:var(--accent-blue)}.stat-card .stat-icon.orange{background:var(--accent-orange-dim);color:var(--accent-orange)}.stat-card .stat-icon.red{background:var(--accent-red-dim);color:var(--accent-red)}.stat-card .stat-icon.yellow{background:var(--accent-yellow-dim);color:var(--accent-yellow)}.stat-card .stat-icon.purple{background:var(--accent-purple-dim);color:var(--accent-purple)}.stat-card .stat-icon.green{background:#22c55e1a;color:#22c55e}.stat-card .stat-value{font-size:2rem;font-weight:800;line-height:1;margin-bottom:4px;font-family:JetBrains Mono,monospace}.stat-card .stat-label{font-size:.8rem;color:var(--text-secondary);font-weight:500}.stat-card .stat-trend{position:absolute;top:20px;right:20px;font-size:.78rem;font-weight:700;display:flex;align-items:center;gap:4px}.stat-card .stat-trend.up{color:var(--accent-cyan)}.stat-card .stat-trend.down{color:var(--accent-red)}.card{background:var(--gradient-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border-subtle)}.card-header h3{font-size:1rem;font-weight:700;display:flex;align-items:center;gap:10px}.card-body{padding:24px}.card-body.no-pad{padding:0}.data-table{width:100%;border-collapse:collapse}.data-table thead th{text-align:left;padding:12px 16px;font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border-subtle);background:#0003;position:sticky;top:0}.data-table tbody tr{transition:var(--transition-fast);border-bottom:1px solid var(--border-subtle)}.data-table tbody tr:hover{background:var(--accent-cyan-dim)}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody td{padding:12px 16px;font-size:.88rem;vertical-align:middle}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:600}.status-badge.online{background:var(--accent-cyan-dim);color:var(--accent-cyan)}.status-badge.offline{background:var(--accent-orange-dim);color:var(--accent-orange)}.status-badge.danger{background:var(--accent-red-dim);color:var(--accent-red)}.status-badge.warning{background:var(--accent-yellow-dim);color:var(--accent-yellow)}.status-badge.info{background:var(--accent-blue-dim);color:var(--accent-blue)}.status-badge.success{background:#22c55e1a;color:#22c55e}.status-badge.inside{background:var(--accent-cyan-dim);color:var(--accent-cyan)}.status-badge.outside{background:var(--border-subtle);color:var(--text-secondary)}.status-badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.buildings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.building-card{background:var(--gradient-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:20px;transition:var(--transition-base);cursor:pointer}.building-card:hover{border-color:var(--border-active);transform:translateY(-2px)}.building-card .building-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:16px}.building-card .building-name{font-weight:700;font-size:.95rem}.building-card .building-addr{font-size:.78rem;color:var(--text-muted);margin-top:2px}.building-card .building-stats{display:flex;gap:20px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-subtle)}.building-card .building-stat{text-align:center}.building-card .building-stat-value{font-size:1.3rem;font-weight:800;font-family:JetBrains Mono,monospace;color:var(--accent-cyan)}.building-card .building-stat-label{font-size:.68rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.building-card .sync-info{display:flex;align-items:center;gap:6px;margin-top:12px;font-size:.78rem;color:var(--text-muted)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}.grid-sidebar{display:grid;grid-template-columns:1fr 360px;gap:20px}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);width:90%;max-width:600px;max-height:90vh;overflow-y:auto;animation:slideUp .3s var(--transition-base)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-subtle)}.modal-header h3{font-size:1.1rem;font-weight:700}.modal-body{padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border-subtle)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 15px #06d6a033}50%{box-shadow:0 0 30px #06d6a066}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}@keyframes scanline{0%{transform:translateY(-100%)}to{transform:translateY(100vh)}}.page-enter{animation:slideUp .4s var(--transition-base)}.empty-state{display:flex;flex-direction:column;align-items:center;padding:60px 20px;color:var(--text-muted)}.empty-state svg{margin-bottom:16px;opacity:.4}.empty-state h4{font-size:1rem;color:var(--text-secondary);margin-bottom:4px}.empty-state p{font-size:.85rem}.loading-spinner{display:inline-block;width:24px;height:24px;border:3px solid var(--border-subtle);border-top-color:var(--accent-cyan);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{display:flex;align-items:center;justify-content:center;min-height:400px;flex-direction:column;gap:16px}.search-bar{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);transition:var(--transition-base);max-width:320px}.search-bar:focus-within{border-color:var(--accent-cyan);box-shadow:0 0 0 3px var(--accent-cyan-dim)}.search-bar input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:.88rem}.search-bar input::placeholder{color:var(--text-muted)}.search-bar svg{color:var(--text-muted);flex-shrink:0}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.grid-2,.grid-3,.grid-sidebar{grid-template-columns:1fr}}@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.page-content{padding:16px}.header{padding:0 16px}.login-card{width:95%;padding:32px 24px}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mt-4{margin-top:16px}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-secondary)}.text-accent{color:var(--accent-cyan)}.font-mono{font-family:JetBrains Mono,monospace}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
