@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap";:root{--font-title:"Outfit", "Inter", sans-serif;--font-body:"Inter", sans-serif;--transition-speed:.3s;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--bg-primary:#070b19;--bg-secondary:#0a0f26;--glass-bg:#0d142fb3;--glass-border:#ffffff12;--glass-border-focus:#00d4ff66;--primary:#00d4ff;--primary-hover:#00b8e6;--primary-glow:#00d4ff59;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--success:#10b981;--success-glow:#10b98133;--warning:#f59e0b;--warning-glow:#f59e0b33;--danger:#ef4444;--danger-glow:#ef444433;--info:#3b82f6;--info-glow:#3b82f633;--table-header-bg:#0d142f;--card-bg:#ffffff05;--input-bg:#ffffff08;--input-focus-bg:#ffffff0d;--navbar-bg:#070b19d9;--panel-shadow:0 8px 32px 0 #0000005e;--body-bg-gradient:radial-gradient(at 0% 0%, #00d4ff14 0px, transparent 50%), radial-gradient(at 100% 100%, #3b82f614 0px, transparent 50%)}[data-theme=light]{--bg-primary:#f1f5f9;--bg-secondary:#fff;--glass-bg:#ffffffbf;--glass-border:#0f172a14;--glass-border-focus:#0284c766;--primary:#0284c7;--primary-hover:#0369a1;--primary-glow:#0284c733;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#64748b;--success:#16a34a;--success-glow:#16a34a1a;--warning:#d97706;--warning-glow:#d977061a;--danger:#dc2626;--danger-glow:#dc26261a;--info:#2563eb;--info-glow:#2563eb1a;--table-header-bg:#e2e8f0;--card-bg:#0f172a05;--input-bg:#0f172a08;--input-focus-bg:#0f172a03;--navbar-bg:#ffffffd9;--panel-shadow:0 8px 32px 0 #0000000f;--body-bg-gradient:radial-gradient(at 0% 0%, #0284c70d 0px, transparent 50%), radial-gradient(at 100% 100%, #2563eb0d 0px, transparent 50%)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);background-image:var(--body-bg-gradient);color:var(--text-primary);font-family:var(--font-body);min-height:100vh;transition:background-color var(--transition-speed), color var(--transition-speed), background-image var(--transition-speed);line-height:1.5;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}.app-container{flex-direction:column;min-height:100vh;display:flex}.glass-panel{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--panel-shadow);-webkit-backdrop-filter:blur(16px);transition:background var(--transition-speed), border-color var(--transition-speed), box-shadow var(--transition-speed);padding:1.75rem}.glass-panel:hover{border-color:var(--glass-border-focus)}.navbar{background:var(--navbar-bg);border-bottom:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100;transition:background var(--transition-speed), border-bottom var(--transition-speed);justify-content:space-between;align-items:center;padding:1.25rem 2.5rem;display:flex;position:sticky;top:0}.nav-logo{font-family:var(--font-title);background:linear-gradient(135deg, var(--text-primary) 30%, var(--primary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;align-items:center;gap:.5rem;font-size:1.6rem;font-weight:800;display:flex}.nav-actions{align-items:center;gap:1.5rem;display:flex}.user-badge{color:var(--text-secondary);background:var(--input-bg);border:1px solid var(--glass-border);transition:background var(--transition-speed), border var(--transition-speed);border-radius:50px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;display:flex}.role-tag{text-transform:uppercase;background:var(--info-glow);color:var(--info);border:1px solid #3b82f64d;border-radius:4px;padding:.2rem .6rem;font-size:.75rem;font-weight:700}.role-tag.super-admin{background:var(--primary-glow);color:var(--primary);border:1px solid #00d4ff4d}.btn{font-family:var(--font-body);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-speed) cubic-bezier(.4, 0, .2, 1);border:1px solid #0000;outline:none;justify-content:center;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-size:.95rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--primary);color:#030712;box-shadow:0 4px 14px 0 var(--primary-glow)}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 6px 20px 0 var(--primary-glow);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{color:var(--text-primary);border:1px solid var(--glass-border);background:#ffffff0d}.btn-secondary:hover{background:#ffffff1a;border-color:#fff3}.btn-danger{color:var(--danger);background:#ef444426;border:1px solid #ef44444d}.btn-danger:hover{background:var(--danger);color:#fff;box-shadow:0 4px 12px var(--danger-glow)}.btn-text{color:var(--text-secondary);background:0 0;padding:.5rem}.btn-text:hover{color:var(--text-primary)}.form-group{flex-direction:column;gap:.4rem;margin-bottom:1.25rem;display:flex}.form-group label{color:var(--text-secondary);letter-spacing:.5px;font-size:.85rem;font-weight:500}.input-field{background:var(--input-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);transition:all var(--transition-speed);outline:none;width:100%;padding:.75rem 1rem;font-size:.95rem}.input-field:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow);background:var(--input-focus-bg)}.input-field::placeholder{color:var(--text-muted)}.input-field option{background-color:var(--bg-secondary);color:var(--text-primary)}.auth-page{background:radial-gradient(circle at center, var(--glass-bg) 0%, var(--bg-primary) 100%);transition:background var(--transition-speed);flex:1;justify-content:center;align-items:center;padding:2rem;display:flex;position:relative}.auth-card{width:100%;max-width:450px}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h2{font-family:var(--font-title);margin-bottom:.5rem;font-size:1.75rem;font-weight:700}.auth-header p{color:var(--text-secondary);font-size:.9rem}.auth-tabs{border-bottom:1px solid var(--glass-border);margin-bottom:1.5rem;display:flex}.auth-tab{text-align:center;cursor:pointer;color:var(--text-secondary);transition:all var(--transition-speed);border-bottom:2px solid #0000;flex:1;padding:.75rem;font-size:.95rem;font-weight:600}.auth-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.auth-toggle-link{text-align:center;color:var(--text-secondary);margin-top:1rem;font-size:.9rem}.auth-toggle-link span{color:var(--primary);cursor:pointer;font-weight:600}.auth-toggle-link span:hover{text-decoration:underline}.dashboard-content{flex-direction:column;flex:1;gap:2rem;width:100%;max-width:1600px;margin:0 auto;padding:2rem 2.5rem;display:flex}.dashboard-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.dashboard-title h1{font-family:var(--font-title);font-size:2rem;font-weight:700}.dashboard-title p{color:var(--text-secondary);font-size:.95rem}.admin-grid{grid-template-columns:1fr 2fr;gap:2rem;display:grid}@media (width<=1024px){.admin-grid{grid-template-columns:1fr}}.device-cards-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;display:grid}.table-container{border-radius:var(--radius-sm);border:1px solid var(--glass-border);margin-top:1rem;overflow-x:auto}.telemetry-table{border-collapse:collapse;text-align:left;width:100%;font-size:.9rem}.telemetry-table th{background:var(--table-header-bg);z-index:10;color:var(--text-secondary);border-bottom:1px solid var(--glass-border);text-transform:uppercase;letter-spacing:.5px;transition:background var(--transition-speed);padding:1rem;font-size:.85rem;font-weight:600;position:sticky;top:0}.telemetry-table td{border-bottom:1px solid var(--glass-border);color:var(--text-primary);padding:1rem;font-size:.9rem}.telemetry-table tbody tr{transition:background-color var(--transition-speed)}.telemetry-table tbody tr:hover{background-color:var(--card-bg)}.telemetry-table tbody tr.new-event-flash{animation:2s ease-out flash-row}@keyframes flash-row{0%{background-color:#00d4ff40}to{background-color:#0000}}.badge{text-transform:uppercase;border-radius:50px;align-items:center;padding:.25rem .75rem;font-size:.8rem;font-weight:600;display:inline-flex}.badge-success{background:var(--success-glow);color:var(--success);border:1px solid #10b9814d}.badge-warning{background:var(--warning-glow);color:var(--warning);border:1px solid #f59e0b4d}.badge-danger{background:var(--danger-glow);color:var(--danger);border:1px solid #ef44444d}.badge-muted{background:var(--input-bg);color:var(--text-secondary);border:1px solid var(--glass-border);transition:background var(--transition-speed), color var(--transition-speed)}.filter-bar{flex-wrap:wrap;align-items:flex-end;gap:1rem;margin-bottom:1.5rem;display:flex}.filter-group{flex-direction:column;gap:.4rem;min-width:180px;display:flex}.filter-group label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.ws-status{background:var(--input-bg);border:1px solid var(--glass-border);transition:background var(--transition-speed), border var(--transition-speed);border-radius:50px;align-items:center;gap:.6rem;padding:.4rem .8rem;font-size:.85rem;font-weight:500;display:flex}.pulse-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.pulse-dot.connected{background-color:var(--success);animation:2s infinite pulse-green;box-shadow:0 0 #10b981b3}.pulse-dot.disconnected{background-color:var(--danger);animation:2s infinite pulse-red;box-shadow:0 0 #ef4444b3}@keyframes pulse-green{0%{transform:scale(.95);box-shadow:0 0 #10b981b3}70%{transform:scale(1);box-shadow:0 0 0 6px #10b98100}to{transform:scale(.95);box-shadow:0 0 #10b98100}}@keyframes pulse-red{0%{transform:scale(.95);box-shadow:0 0 #ef4444b3}70%{transform:scale(1);box-shadow:0 0 0 6px #ef444400}to{transform:scale(.95);box-shadow:0 0 #ef444400}}.simulator-panel{background:#00d4ff05;border:1px dashed #00d4ff4d;margin-top:1.5rem}.simulator-title{color:var(--primary);font-family:var(--font-title);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.1rem;font-weight:600;display:flex}.simulator-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:1rem;display:grid}.data-card{background:var(--card-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);transition:background var(--transition-speed), border var(--transition-speed);flex-direction:column;gap:.75rem;padding:1.25rem;display:flex;position:relative;overflow:hidden}.data-card:before{content:"";background:var(--primary);width:4px;height:100%;position:absolute;top:0;left:0}.data-card.admin-card:before{background:var(--info)}.data-card-header{justify-content:space-between;align-items:flex-start;display:flex}.data-card-title{font-family:var(--font-title);font-size:1.1rem;font-weight:700}.data-card-subtitle{color:var(--text-secondary);font-size:.85rem}.data-card-details{flex-direction:column;gap:.35rem;font-size:.85rem;display:flex}.data-card-detail-item{justify-content:space-between;display:flex}.data-card-detail-label{color:var(--text-muted)}.data-card-detail-value{color:var(--text-primary);font-weight:500}.alert-banner{border-radius:var(--radius-sm);align-items:center;gap:.5rem;margin-bottom:1.25rem;padding:.75rem 1rem;font-size:.9rem;display:flex}.alert-banner.error{color:var(--danger);background:#ef44441a;border:1px solid #ef444433}.alert-banner.success{color:var(--success);background:#10b9811a;border:1px solid #10b98133}.empty-state{text-align:center;color:var(--text-secondary);flex-direction:column;align-items:center;gap:1rem;padding:3rem 1.5rem;display:flex}.empty-state-icon{color:var(--text-muted)}.empty-state-title{font-family:var(--font-title);color:var(--text-primary);font-size:1.2rem;font-weight:600}.stats-row{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;display:grid}.stat-widget{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.stat-info{flex-direction:column;gap:.25rem;display:flex}.stat-label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.stat-value{font-family:var(--font-title);color:var(--text-primary);font-size:1.8rem;font-weight:800}.stat-icon-wrapper{border-radius:var(--radius-sm);border:1px solid var(--glass-border);width:48px;height:48px;color:var(--primary);background:#ffffff08;justify-content:center;align-items:center;display:flex}.stat-widget.success .stat-icon-wrapper{color:var(--success);background:var(--success-glow)}.stat-widget.warning .stat-icon-wrapper{color:var(--warning);background:var(--warning-glow)}.stat-widget.danger .stat-icon-wrapper{color:var(--danger);background:var(--danger-glow)}
