/* ═══════════════════════════════════════════════
   Inoqta Remote Control — Design System v2
   Premium dark glassmorphism UI
═══════════════════════════════════════════════ */

/* ── Tokens ─────────────────────────────────── */
:root {
  --font-ui:   'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'JetBrains Mono', 'Courier New', monospace;

  /* Background layers */
  --bg-0:  #060610;
  --bg-1:  #0b0c1a;
  --bg-2:  #10111f;
  --bg-3:  #181927;

  /* Glass surface */
  --glass: rgba(14, 15, 26, 0.7);
  --glass-b: rgba(255,255,255,0.07);
  --glass-b-h: rgba(255,255,255,0.14);

  /* Text */
  --text-1: #f1f2f6;
  --text-2: #9da3b4;
  --text-3: #5d6378;

  /* Brand accent */
  --indigo: #6366f1;
  --violet: #8b5cf6;
  --pink:   #ec4899;
  --cyan:   #22d3ee;
  --green:  #10b981;
  --amber:  #f59e0b;
  --red:    #ef4444;
  --blue:   #3b82f6;

  --grad-brand: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #ec4899 100%);
  --grad-green: linear-gradient(135deg, #10b981 0%, #059669 100%);
  --grad-blue:  linear-gradient(135deg, #3b82f6 0%, #6366f1 100%);
  --grad-amber: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);

  /* Radii */
  --r-xs: 4px;
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 18px;
  --r-xl: 24px;
  --r-full: 9999px;

  /* Shadows */
  --sh-sm:  0 2px 8px rgba(0,0,0,0.25);
  --sh-md:  0 8px 28px rgba(0,0,0,0.4);
  --sh-lg:  0 20px 60px rgba(0,0,0,0.55);
  --sh-glow: 0 0 24px rgba(99,102,241,0.25);

  /* Transitions */
  --t-fast:   0.14s ease;
  --t-normal: 0.26s cubic-bezier(0.4,0,0.2,1);
}

/* ── Reset ──────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin:0; padding:0; }

html, body {
  width:100%; height:100%;
  font-family: var(--font-ui);
  background: var(--bg-0);
  color: var(--text-1);
  overflow: hidden;
  font-size: 15px;
  -webkit-font-smoothing: antialiased;
}

/* Scrollbars */
::-webkit-scrollbar { width:6px; height:6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--bg-3); border-radius: var(--r-full); }
::-webkit-scrollbar-thumb:hover { background: var(--text-3); }

/* ── Ambient orbs ────────────────────────────── */
.bg-orb {
  position:fixed; border-radius:50%;
  filter: blur(130px); opacity:0.38;
  pointer-events:none; z-index:0;
  will-change: transform;
}
.orb-1 {
  width:55vw; height:55vw;
  top:-15%; left:-5%;
  background: radial-gradient(circle, rgba(99,102,241,0.5) 0%, transparent 70%);
  animation: orbFloat1 22s infinite alternate ease-in-out;
}
.orb-2 {
  width:40vw; height:40vw;
  bottom:-10%; right:5%;
  background: radial-gradient(circle, rgba(236,72,153,0.4) 0%, transparent 75%);
  animation: orbFloat2 28s infinite alternate ease-in-out;
}
.orb-3 {
  width:30vw; height:30vw;
  top:40%; left:50%;
  background: radial-gradient(circle, rgba(34,211,238,0.15) 0%, transparent 70%);
  animation: orbFloat3 18s infinite alternate ease-in-out;
}
@keyframes orbFloat1 { to { transform: translate(60px, 40px) scale(1.08); } }
@keyframes orbFloat2 { to { transform: translate(-80px, -50px) scale(0.92); } }
@keyframes orbFloat3 { to { transform: translate(-40px, 60px) scale(1.12); } }

/* ── Glass utility ───────────────────────────── */
.glass {
  background: var(--glass);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border: 1px solid var(--glass-b);
  box-shadow: var(--sh-md);
}

/* ── App shell ───────────────────────────────── */
#app {
  position:relative; z-index:1;
  display:flex; width:100%; height:100%;
}

.view {
  display:flex; width:100%; height:100%;
  transition: opacity var(--t-normal);
}
.hidden { display:none !important; }
.active { display:flex !important; }

/* ════════════════════════════════════════════════
   LOGIN VIEW
════════════════════════════════════════════════ */
#login-view { align-items:stretch; }

.login-split {
  display:flex; width:100%; height:100%;
}

/* Left brand panel */
.login-brand-panel {
  flex: 0 0 420px;
  background: linear-gradient(160deg, rgba(99,102,241,0.18) 0%, rgba(139,92,246,0.08) 50%, rgba(236,72,153,0.12) 100%);
  border-right: 1px solid var(--glass-b);
  display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
}
.login-brand-panel::before {
  content:''; position:absolute; inset:0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%236366f1' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.login-brand-inner {
  position:relative; z-index:1;
  display:flex; flex-direction:column; align-items:center; gap:16px;
  padding:40px;
}
.brand-icon-lg {
  font-size:52px;
  background: var(--grad-brand);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  animation: iconPulse 3s ease-in-out infinite;
}
@keyframes iconPulse {
  0%,100% { filter: drop-shadow(0 0 6px rgba(99,102,241,0.4)); }
  50% { filter: drop-shadow(0 0 20px rgba(168,85,247,0.7)); }
}
.brand-wordmark {
  font-size:32px; font-weight:800; letter-spacing:2px;
}
.brand-wordmark span { font-weight:300; opacity:0.7; }
.brand-tagline {
  font-size:13px; letter-spacing:2px; text-transform:uppercase;
  color: var(--text-2); margin-top:4px;
}
.brand-features {
  margin-top:32px; display:flex; flex-direction:column; gap:14px; width:100%;
}
.brand-feat {
  display:flex; align-items:center; gap:12px;
  font-size:14px; color: var(--text-2);
}
.brand-feat i {
  width:32px; height:32px; border-radius:var(--r-sm);
  background: rgba(99,102,241,0.15);
  border:1px solid rgba(99,102,241,0.25);
  display:flex; align-items:center; justify-content:center;
  font-size:14px; color: var(--indigo); flex-shrink:0;
}

/* Right form panel */
.login-form-panel {
  flex:1; display:flex; align-items:center; justify-content:center;
  padding:40px;
}
.login-card {
  width:100%; max-width:420px;
  border-radius:var(--r-xl); padding:40px;
  position:relative; overflow:hidden;
}
.login-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background: var(--grad-brand);
}
.login-card-header { margin-bottom:28px; }
.login-card-header h2 { font-size:24px; font-weight:700; margin-bottom:6px; }
.login-card-header p { font-size:14px; color:var(--text-2); }

/* Auth switch link */
.auth-switch {
  text-align:center; margin-top:20px;
  font-size:14px; color:var(--text-2);
}
.auth-switch a {
  color:var(--violet); font-weight:600;
  text-decoration:none; margin-left:4px;
  transition: color var(--t-fast);
}
.auth-switch a:hover { color:var(--pink); }

/* Password toggle */
.password-wrap { position:relative; }
.password-wrap input { padding-right:44px !important; width:100%; }
.toggle-pass {
  position:absolute; right:12px; top:50%; transform:translateY(-50%);
  background:none; border:none; cursor:pointer;
  color:var(--text-3); font-size:15px;
  transition: color var(--t-fast);
}
.toggle-pass:hover { color:var(--text-1); }

/* ════════════════════════════════════════════════
   FORMS & FIELDS (shared)
════════════════════════════════════════════════ */
.field-group {
  display:flex; flex-direction:column; gap:7px;
  margin-bottom:18px;
}
.field-group label {
  font-size:13px; font-weight:500; color:var(--text-2);
  display:flex; align-items:center; gap:7px;
}
input[type="text"], input[type="password"], select, textarea {
  font-family: var(--font-ui);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--glass-b);
  color: var(--text-1);
  padding: 10px 14px;
  border-radius: var(--r-md);
  font-size: 14px;
  width:100%;
  transition: all var(--t-fast);
  outline:none;
}
input[type="text"]:focus, input[type="password"]:focus, select:focus, textarea:focus {
  border-color: var(--indigo);
  background: rgba(99,102,241,0.06);
  box-shadow: 0 0 0 3px rgba(99,102,241,0.12);
}
select { appearance:none; cursor:pointer; }
option { background: var(--bg-2); }
textarea { resize:vertical; }

.inline-form {
  display:flex; flex-wrap:wrap; gap:14px; align-items:flex-end;
}
.inline-field { margin-bottom:0; }

/* ── Alerts ─────────────────────────────────── */
.alert {
  border-radius:var(--r-sm); padding:10px 14px;
  font-size:13px; font-weight:500;
  display:flex; align-items:center; gap:8px;
}
.alert-error {
  background: rgba(239,68,68,0.12);
  border:1px solid rgba(239,68,68,0.25);
  color: #fca5a5;
}
.alert-success {
  background: rgba(16,185,129,0.1);
  border:1px solid rgba(16,185,129,0.2);
  color: #6ee7b7;
}

/* ── Buttons ─────────────────────────────────── */
.btn {
  font-family: var(--font-ui); font-weight:600; font-size:14px;
  padding:9px 20px; border-radius:var(--r-md);
  border:none; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  transition: all var(--t-fast); white-space:nowrap;
  text-decoration:none;
}
.btn-block { width:100%; }
.btn-primary {
  background: var(--grad-brand); color:#fff;
  box-shadow: 0 2px 12px rgba(99,102,241,0.3);
}
.btn-primary:hover { filter:brightness(1.1); box-shadow:0 4px 20px rgba(99,102,241,0.45); transform:translateY(-1px); }
.btn-primary:active { transform:translateY(0); }

.btn-secondary {
  background: rgba(255,255,255,0.06); border:1px solid var(--glass-b);
  color: var(--text-1);
}
.btn-secondary:hover { background:rgba(255,255,255,0.12); border-color:var(--glass-b-h); }

.btn-accent {
  background: rgba(99,102,241,0.15); border:1px solid rgba(99,102,241,0.3);
  color: #a5b4fc;
}
.btn-accent:hover { background:rgba(99,102,241,0.25); border-color:rgba(99,102,241,0.5); color:#fff; }

.btn-danger {
  background: rgba(239,68,68,0.12); border:1px solid rgba(239,68,68,0.25);
  color:#fca5a5;
}
.btn-danger:hover { background:rgba(239,68,68,0.22); }

.btn-sm { font-size:12px; padding:5px 12px; border-radius:var(--r-sm); }

.btn-icon-sm {
  width:28px; height:28px; border-radius:var(--r-sm);
  background:transparent; border:none; cursor:pointer;
  color:var(--text-3); font-size:14px;
  display:flex; align-items:center; justify-content:center;
  transition: all var(--t-fast);
}
.btn-icon-sm:hover { background:rgba(255,255,255,0.08); color:var(--text-1); }

/* ════════════════════════════════════════════════
   DASHBOARD LAYOUT
════════════════════════════════════════════════ */
#dashboard-view { flex-direction:row; overflow:hidden; }

/* ── Sidebar ─────────────────────────────────── */
.sidebar {
  width:240px; flex-shrink:0;
  display:flex; flex-direction:column;
  border-radius:0; border-top:none; border-bottom:none; border-left:none;
  z-index:10;
}
.sidebar-brand {
  padding:22px 20px;
  border-bottom:1px solid var(--glass-b);
  display:flex; align-items:center; gap:12px;
}
.brand-mark {
  width:36px; height:36px; border-radius:var(--r-sm);
  background: var(--grad-brand);
  display:flex; align-items:center; justify-content:center;
  font-size:16px; color:#fff; flex-shrink:0;
}
.brand-text { display:flex; flex-direction:column; }
.brand-name { font-size:15px; font-weight:800; letter-spacing:1.5px; line-height:1; }
.brand-sub { font-size:11px; color:var(--text-3); font-weight:400; }

.sidebar-nav {
  flex:1; padding:16px 12px; overflow-y:auto;
  display:flex; flex-direction:column; gap:3px;
}
.nav-section-label {
  font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:1px; color:var(--text-3);
  padding:12px 8px 6px;
}
.nav-item {
  display:flex; align-items:center; gap:10px;
  padding:9px 12px; border-radius:var(--r-md);
  font-size:14px; font-weight:500; color:var(--text-2);
  text-decoration:none; cursor:pointer;
  transition: all var(--t-fast); position:relative;
}
.nav-item i { width:18px; text-align:center; font-size:15px; flex-shrink:0; }
.nav-item span:first-of-type { flex:1; }
.nav-item:hover { background:rgba(255,255,255,0.05); color:var(--text-1); }
.nav-item.active {
  background: rgba(99,102,241,0.14);
  color:#fff;
  border-left:2px solid var(--indigo);
  padding-left:10px;
}
.nav-item.active i { color: var(--indigo); }

.nav-badge {
  font-size:11px; font-weight:700;
  background: var(--green); color:#fff;
  padding:1px 7px; border-radius:var(--r-full);
  min-width:20px; text-align:center;
}

.sidebar-footer {
  padding:16px; border-top:1px solid var(--glass-b);
  display:flex; align-items:center; justify-content:space-between; gap:8px;
}
.user-chip { display:flex; align-items:center; gap:10px; overflow:hidden; }
.user-avatar {
  width:34px; height:34px; border-radius:var(--r-sm);
  background: var(--grad-blue); display:flex;
  align-items:center; justify-content:center;
  font-size:14px; color:#fff; flex-shrink:0;
}
.user-meta { display:flex; flex-direction:column; overflow:hidden; }
.user-name { font-size:13px; font-weight:600; truncate:ellipsis; }
.user-role-label { font-size:11px; color:var(--text-3); }
.btn-logout {
  width:32px; height:32px; border-radius:var(--r-sm);
  background:none; border:none; cursor:pointer;
  color:var(--text-3); font-size:15px;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; transition: all var(--t-fast);
}
.btn-logout:hover { color:var(--red); background:rgba(239,68,68,0.1); }

/* ── Main content ────────────────────────────── */
.main-content {
  flex:1; overflow-y:auto; padding:32px 36px;
  display:flex; flex-direction:column; gap:0;
}

/* ── Section layout ──────────────────────────── */
.tab-section { display:flex; flex-direction:column; gap:24px; animation:tabFade 0.3s ease; }
@keyframes tabFade { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }

.section-header {
  display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.section-title { font-size:22px; font-weight:700; letter-spacing:-0.3px; }
.section-desc { font-size:13px; color:var(--text-2); margin-top:3px; }
.section-actions { display:flex; align-items:center; gap:10px; flex-shrink:0; }

/* ── Stats row ───────────────────────────────── */
.stats-row {
  display:flex; gap:16px;
}
.stat-card {
  flex:1; padding:18px 20px; border-radius:var(--r-lg);
  display:flex; align-items:center; gap:16px;
  transition: border-color var(--t-normal);
}
.stat-card:hover { border-color:var(--glass-b-h); }
.stat-icon {
  width:46px; height:46px; border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center;
  font-size:19px; color:#fff; flex-shrink:0;
}
.stat-icon.blue { background:var(--grad-blue); }
.stat-icon.green { background:var(--grad-green); }
.stat-icon.orange { background:var(--grad-amber); }
.stat-body { display:flex; flex-direction:column; }
.stat-num { font-size:26px; font-weight:800; line-height:1; }
.stat-lbl { font-size:12px; color:var(--text-2); margin-top:3px; }

/* ── Filter bar ──────────────────────────────── */
.filter-bar { display:flex; align-items:center; gap:12px; }
.search-wrap { position:relative; flex:1; max-width:380px; }
.search-icon {
  position:absolute; left:12px; top:50%; transform:translateY(-50%);
  color:var(--text-3); font-size:13px;
}
.search-wrap input {
  padding-left:36px;
  border-radius:var(--r-full) !important;
  font-size:13px;
}
.view-toggle { display:flex; gap:4px; }
.view-btn {
  width:34px; height:34px; border-radius:var(--r-sm);
  background:rgba(255,255,255,0.05); border:1px solid var(--glass-b);
  color:var(--text-3); cursor:pointer; font-size:14px;
  display:flex; align-items:center; justify-content:center;
  transition: all var(--t-fast);
}
.view-btn:hover { background:rgba(255,255,255,0.1); color:var(--text-1); }
.view-btn.active { background:rgba(99,102,241,0.15); border-color:rgba(99,102,241,0.35); color:var(--indigo); }

/* Server status dot */
.server-status {
  display:flex; align-items:center; gap:7px;
  font-size:13px; font-weight:500; color:var(--text-2);
}

/* ── Online / offline dots ───────────────────── */
.dot-online {
  width:8px; height:8px; border-radius:50%;
  background:var(--green); display:inline-block;
  box-shadow:0 0 8px var(--green);
  animation: dotPulse 2s infinite;
}
.dot-offline { background:var(--text-3); }
@keyframes dotPulse {
  0%,100% { opacity:1; transform:scale(1); }
  50% { opacity:0.6; transform:scale(1.3); }
}

/* ═══════════════════════════════════════════════
   DEVICE CARDS (grid)
═══════════════════════════════════════════════ */
.device-grid {
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(310px,1fr));
  gap:16px;
}
.device-list { display:flex; flex-direction:column; gap:10px; }

/* Device Card */
.device-card {
  background: var(--glass);
  backdrop-filter: blur(18px); -webkit-backdrop-filter:blur(18px);
  border:1px solid var(--glass-b); border-radius:var(--r-lg);
  padding:20px; cursor:default;
  transition: all var(--t-normal);
  position:relative; overflow:hidden;
}
.device-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, var(--indigo) 0%, var(--violet) 50%, transparent 100%);
  transform:scaleX(0); transform-origin:left;
  transition: transform var(--t-normal);
}
.device-card.online::before { transform:scaleX(1); }
.device-card:hover { border-color:var(--glass-b-h); transform:translateY(-2px); box-shadow:var(--sh-lg); }

.device-card-top {
  display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:16px;
}
.device-info { display:flex; align-items:center; gap:12px; min-width:0; }
.device-os-icon {
  width:40px; height:40px; border-radius:var(--r-sm);
  background:rgba(0,120,212,0.12); border:1px solid rgba(0,120,212,0.2);
  display:flex; align-items:center; justify-content:center;
  font-size:18px; color:#60a5fa; flex-shrink:0;
}
.device-name-group { min-width:0; }
.device-name {
  font-size:15px; font-weight:700;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.device-ip {
  font-size:12px; color:var(--text-3); font-family:var(--font-mono);
  margin-top:2px;
}
.device-status-pill {
  font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:0.5px;
  padding:3px 10px; border-radius:var(--r-full);
  display:inline-flex; align-items:center; gap:5px; flex-shrink:0;
}
.pill-online { background:rgba(16,185,129,0.12); color:#34d399; border:1px solid rgba(16,185,129,0.25); }
.pill-offline { background:rgba(107,114,128,0.1); color:var(--text-3); border:1px solid rgba(107,114,128,0.2); }

/* TeamViewer-style credentials */
.device-credentials {
  background:rgba(0,0,0,0.25); border:1px solid var(--glass-b);
  border-radius:var(--r-md); padding:12px 14px;
  margin-bottom:14px; display:flex; gap:16px;
}
.cred-item { flex:1; display:flex; flex-direction:column; gap:3px; }
.cred-label { font-size:10px; font-weight:600; text-transform:uppercase; letter-spacing:1px; color:var(--text-3); }
.cred-value {
  font-family:var(--font-mono); font-size:18px; font-weight:700;
  letter-spacing:3px; color:var(--text-1); line-height:1;
}
.cred-pass { font-size:16px; letter-spacing:4px; }
.cred-offline { color:var(--text-3); letter-spacing:1px; font-size:13px; }

/* Hardware info line */
.device-hw { display:flex; gap:12px; margin-bottom:14px; }
.hw-pill {
  display:flex; align-items:center; gap:5px;
  font-size:11px; color:var(--text-2);
  background:rgba(255,255,255,0.04); border:1px solid var(--glass-b);
  padding:3px 9px; border-radius:var(--r-sm);
}
.hw-pill i { font-size:11px; color:var(--text-3); }

/* Group tag */
.device-group-tag {
  display:inline-flex; align-items:center; gap:5px;
  font-size:11px; font-weight:500; color:var(--violet);
  background:rgba(139,92,246,0.1); border:1px solid rgba(139,92,246,0.2);
  padding:2px 8px; border-radius:var(--r-sm); margin-bottom:14px;
}

/* Card actions */
.device-actions { display:flex; gap:7px; flex-wrap:wrap; }
.daction {
  font-family:var(--font-ui); font-size:12px; font-weight:600;
  padding:6px 12px; border-radius:var(--r-sm);
  border:none; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  transition: all var(--t-fast); flex:1; white-space:nowrap;
}
.daction-connect {
  background:var(--grad-blue); color:#fff;
  box-shadow:0 2px 10px rgba(59,130,246,0.25);
}
.daction-connect:hover { filter:brightness(1.1); box-shadow:0 4px 16px rgba(59,130,246,0.4); }
.daction-connect:disabled { opacity:0.4; cursor:not-allowed; filter:none; box-shadow:none; }
.daction-secondary {
  background:rgba(255,255,255,0.05); border:1px solid var(--glass-b);
  color:var(--text-2);
}
.daction-secondary:hover { background:rgba(255,255,255,0.1); color:var(--text-1); }
.daction-secondary:disabled { opacity:0.4; cursor:not-allowed; }
.daction-edit {
  background:rgba(139,92,246,0.1); border:1px solid rgba(139,92,246,0.2);
  color:#c4b5fd;
}
.daction-edit:hover { background:rgba(139,92,246,0.2); }
.daction-del {
  background:rgba(239,68,68,0.08); border:1px solid rgba(239,68,68,0.2);
  color:#fca5a5;
}
.daction-del:hover { background:rgba(239,68,68,0.18); }

/* Empty state */
.empty-state-box {
  grid-column:1/-1; padding:60px 20px;
  display:flex; flex-direction:column; align-items:center; gap:12px;
  text-align:center;
}
.empty-icon { font-size:44px; color:var(--text-3); }
.empty-title { font-size:16px; font-weight:600; }
.empty-desc { font-size:13px; color:var(--text-3); max-width:320px; }

/* ── Device list view ────────────────────────── */
.device-list-row {
  background:var(--glass); backdrop-filter:blur(14px);
  border:1px solid var(--glass-b); border-radius:var(--r-md);
  padding:14px 18px; display:flex; align-items:center; gap:14px;
  transition: all var(--t-fast);
}
.device-list-row:hover { border-color:var(--glass-b-h); background:rgba(14,15,26,0.85); }

/* ═══════════════════════════════════════════════
   DATA TABLES
═══════════════════════════════════════════════ */
.table-wrap { border-radius:var(--r-lg); overflow:hidden; }
.data-table { width:100%; border-collapse:collapse; }
.data-table th {
  background:rgba(255,255,255,0.025);
  padding:13px 18px; font-size:11px; font-weight:600;
  text-transform:uppercase; letter-spacing:0.6px;
  color:var(--text-3); border-bottom:1px solid var(--glass-b);
}
.data-table td {
  padding:14px 18px; font-size:13px;
  border-bottom:1px solid rgba(255,255,255,0.025);
  vertical-align:middle; color:var(--text-1);
}
.data-table tr:last-child td { border-bottom:none; }
.data-table tr:hover td { background:rgba(255,255,255,0.02); }
.tr-empty td { padding:50px 20px; text-align:center; color:var(--text-3); }
.tr-empty .empty-icon { font-size:32px; margin-bottom:10px; }
.tar { text-align:right; }

/* Role / status badges */
.badge {
  display:inline-flex; align-items:center; gap:5px;
  font-size:11px; font-weight:600; text-transform:uppercase;
  padding:3px 9px; border-radius:var(--r-full);
}
.badge-online { background:rgba(16,185,129,0.12); color:#34d399; border:1px solid rgba(16,185,129,0.2); }
.badge-offline { background:rgba(107,114,128,0.1); color:var(--text-3); border:1px solid rgba(107,114,128,0.2); }
.badge-admin { background:rgba(99,102,241,0.12); color:#a5b4fc; border:1px solid rgba(99,102,241,0.2); }

/* ── Settings ────────────────────────────────── */
.settings-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
@media (max-width:900px) { .settings-grid { grid-template-columns:1fr; } }
.settings-card-head {
  display:flex; align-items:center; gap:10px; margin-bottom:4px;
}
.settings-card-head i { color:var(--indigo); font-size:16px; }
.settings-card-head h3 { font-size:16px; font-weight:700; }
.code-block {
  background:var(--bg-0); border:1px solid var(--glass-b);
  border-radius:var(--r-md); padding:14px 16px;
  display:flex; gap:12px; align-items:center; justify-content:space-between;
}
.code-block code {
  font-family:var(--font-mono); font-size:12px;
  color:#f472b6; word-break:break-all; flex:1;
}
.btn-copy {
  background:var(--bg-3); border:1px solid var(--glass-b);
  color:var(--text-1); padding:5px 11px; border-radius:var(--r-sm);
  cursor:pointer; font-size:12px; white-space:nowrap;
  transition: all var(--t-fast); flex-shrink:0;
}
.btn-copy:hover { background:var(--text-3); }
.card { border-radius:var(--r-lg); }

/* ════════════════════════════════════════════════
   REMOTE SESSION VIEW
════════════════════════════════════════════════ */
#remote-view {
  flex-direction:column; position:absolute; inset:0; z-index:100;
  background:var(--bg-0);
}

/* Floating toolbar */
.remote-bar {
  height:52px; flex-shrink:0;
  background:rgba(11,12,26,0.92);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--glass-b);
  display:flex; align-items:center; justify-content:space-between; gap:8px;
  padding:0 16px; z-index:110; user-select:none;
}
.remote-bar-left { display:flex; align-items:center; gap:10px; flex-shrink:0; }
.remote-device-name { font-size:14px; font-weight:700; }
.connected-badge {
  display:flex; align-items:center; gap:5px;
  font-size:11px; color:#34d399;
  background:rgba(16,185,129,0.1); border:1px solid rgba(16,185,129,0.2);
  padding:2px 8px; border-radius:var(--r-full);
}
.remote-bar-center {
  display:flex; align-items:center; gap:6px; overflow-x:auto;
  scrollbar-width:none;
}
.remote-bar-center::-webkit-scrollbar { display:none; }
.remote-bar-right { display:flex; align-items:center; flex-shrink:0; }

/* Remote toolbar buttons */
.rbar-btn {
  background:rgba(255,255,255,0.06); border:1px solid var(--glass-b);
  color:var(--text-1); border-radius:var(--r-sm);
  padding:5px 10px; font-size:12px; font-weight:500;
  cursor:pointer; display:flex; align-items:center; gap:5px;
  transition: all var(--t-fast); font-family:var(--font-ui);
  white-space:nowrap;
}
.rbar-btn:hover { background:rgba(255,255,255,0.12); border-color:var(--glass-b-h); }
.rbar-tool i { font-size:13px; }
.rbar-sep { width:1px; height:22px; background:var(--glass-b); margin:0 4px; flex-shrink:0; }
.rbar-control { display:flex; align-items:center; gap:5px; font-size:12px; color:var(--text-2); }
.rbar-control i { font-size:12px; }
.rbar-select {
  background:rgba(255,255,255,0.06); border:1px solid var(--glass-b);
  color:var(--text-1); padding:3px 8px; border-radius:var(--r-sm);
  font-size:12px; cursor:pointer; width:auto;
}

/* Performance stats */
.perf-stats { display:flex; gap:10px; }
.perf-stat {
  display:flex; align-items:center; gap:4px;
  font-size:11px; color:var(--text-3); font-family:var(--font-mono);
}
.perf-stat i { font-size:10px; }

/* Remote workspace */
.remote-workspace {
  flex:1; display:flex; overflow:hidden; position:relative;
}
.viewport-wrap {
  flex:1; overflow:auto; display:flex;
  justify-content:center; align-items:center;
  background:#020207; position:relative;
}
#screen-canvas {
  display:block; outline:none; cursor:crosshair;
  box-shadow:0 0 60px rgba(0,0,0,0.9);
}
.scale-fit { width:100% !important; height:100% !important; object-fit:contain; }
.scale-original { width:auto !important; height:auto !important; }

/* Canvas loader */
.canvas-loader {
  position:absolute; inset:0;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:16px; color:var(--text-3); font-size:14px;
  pointer-events:none;
}
.canvas-loader.hidden { display:none; }
.loader-spinner {
  width:36px; height:36px; border-radius:50%;
  border:3px solid var(--glass-b);
  border-top-color:var(--indigo);
  animation:spin 0.8s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* Quick Actions panel */
.qactions-panel {
  width:260px; flex-shrink:0;
  display:flex; flex-direction:column;
  border-radius:0; border-top:none; border-bottom:none; border-right:none;
  animation:slideFromRight 0.22s ease;
}
@keyframes slideFromRight { from { transform:translateX(30px); opacity:0; } }
.qactions-header {
  padding:14px 16px; border-bottom:1px solid var(--glass-b);
  display:flex; align-items:center; justify-content:space-between;
  font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:0.5px;
}
.qactions-body { flex:1; overflow-y:auto; padding:12px; display:flex; flex-direction:column; gap:12px; }
.qaction-group { display:flex; flex-direction:column; gap:5px; }
.qaction-label {
  font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:1px; color:var(--text-3); margin-bottom:3px; padding:0 4px;
}
.qaction-btn {
  background:rgba(255,255,255,0.04); border:1px solid var(--glass-b);
  color:var(--text-2); padding:8px 12px; border-radius:var(--r-sm);
  font-size:12px; font-weight:500; cursor:pointer;
  display:flex; align-items:center; gap:8px;
  text-align:left; width:100%; font-family:var(--font-ui);
  transition: all var(--t-fast);
}
.qaction-btn:hover { background:rgba(255,255,255,0.1); color:var(--text-1); border-color:var(--glass-b-h); }
.qaction-btn i { width:14px; text-align:center; font-size:12px; flex-shrink:0; }
.qaction-danger { color:#fca5a5 !important; border-color:rgba(239,68,68,0.2) !important; }
.qaction-danger:hover { background:rgba(239,68,68,0.12) !important; }

/* ════════════════════════════════════════════════
   MODALS
════════════════════════════════════════════════ */
.modal-overlay {
  position:fixed; inset:0; z-index:200;
  background:rgba(0,0,0,0.65);
  backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center;
  animation:fadeInOverlay 0.18s ease;
}
@keyframes fadeInOverlay { from { opacity:0; } }
.modal-box {
  border-radius:var(--r-xl); max-width:94vw; max-height:90vh;
  display:flex; flex-direction:column;
  animation:popIn 0.22s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes popIn { from { opacity:0; transform:scale(0.94) translateY(10px); } }
.modal-head {
  padding:18px 22px; border-bottom:1px solid var(--glass-b);
  display:flex; align-items:center; justify-content:space-between;
  flex-shrink:0;
}
.modal-title {
  font-size:16px; font-weight:700;
  display:flex; align-items:center; gap:9px;
}
.modal-title i { color:var(--indigo); }
.btn-modal-close {
  width:30px; height:30px; border-radius:var(--r-sm);
  background:none; border:none; cursor:pointer;
  color:var(--text-3); font-size:16px;
  display:flex; align-items:center; justify-content:center;
  transition: all var(--t-fast);
}
.btn-modal-close:hover { background:rgba(239,68,68,0.12); color:var(--red); }
.modal-body-pad { padding:22px; overflow-y:auto; }

/* Terminal modal */
.terminal-box { width:860px; height:540px; }
.terminal-body {
  flex:1; display:flex; flex-direction:column;
  padding:16px; overflow:hidden;
}
.terminal-output {
  flex:1; background:#010104; border:1px solid rgba(255,255,255,0.05);
  border-radius:var(--r-md); padding:16px;
  font-family:var(--font-mono); font-size:13px; color:#34d399;
  overflow-y:auto; line-height:1.6; margin-bottom:12px;
}
.terminal-output .term-line { white-space:pre-wrap; margin-bottom:2px; }
.term-cmd { color:#60a5fa; }
.term-err { color:var(--red); }
.term-sys { color:var(--text-3); font-style:italic; }
.terminal-input-row {
  display:flex; align-items:center; gap:8px;
  background:#010104; border:1px solid rgba(99,102,241,0.25);
  border-radius:var(--r-md); padding:8px 14px;
}
.term-prompt { color:var(--indigo); font-family:var(--font-mono); font-size:14px; }
#terminal-input {
  flex:1; background:none; border:none; outline:none;
  font-family:var(--font-mono); font-size:13px; color:#fff;
  padding:0;
}
#terminal-input:focus { box-shadow:none; }

/* File modal */
.file-box { width:940px; height:600px; }
.breadcrumb-bar {
  display:flex; align-items:center; gap:8px;
  background:rgba(0,0,0,0.2); padding:7px 12px;
  border:1px solid var(--glass-b); border-radius:var(--r-md);
  margin-bottom:12px;
}
.breadcrumb-path { font-family:var(--font-mono); font-size:12px; color:var(--text-2); }
.file-table-wrap {
  background:rgba(0,0,0,0.18); border:1px solid var(--glass-b);
  border-radius:var(--r-md); overflow-y:auto; max-height:420px;
}
.files-tbl td i.fa-folder { color:#fbbf24; }
.files-tbl td i.fa-file { color:var(--text-3); }
.file-name-cell { display:flex; align-items:center; gap:8px; }

/* Clipboard */
.clip-label { display:flex; align-items:center; gap:6px; font-size:13px; font-weight:500; color:var(--text-2); margin-bottom:8px; }
.clip-area { width:100%; background:rgba(0,0,0,0.2); resize:none; border-radius:var(--r-md); font-family:var(--font-mono); font-size:13px; }
.clip-divider { border-bottom:1px solid var(--glass-b); }
.clipboard-panel { display:flex; flex-direction:column; gap:10px; }

/* ════════════════════════════════════════════════
   TOAST SYSTEM
════════════════════════════════════════════════ */
#toast-container {
  position:fixed; bottom:24px; right:24px;
  display:flex; flex-direction:column-reverse; gap:8px;
  z-index:300; pointer-events:none;
}
.toast {
  display:flex; align-items:center; gap:10px;
  padding:12px 18px; border-radius:var(--r-md);
  font-size:13px; font-weight:500;
  box-shadow:var(--sh-lg); pointer-events:all;
  min-width:260px; max-width:380px;
  animation:toastIn 0.28s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes toastIn { from { opacity:0; transform:translateX(40px) scale(0.9); } }
.toast.hiding { animation:toastOut 0.22s ease forwards; }
@keyframes toastOut { to { opacity:0; transform:translateX(40px); } }
.toast-success { background:rgba(16,185,129,0.15); border:1px solid rgba(16,185,129,0.3); color:#6ee7b7; }
.toast-error   { background:rgba(239,68,68,0.15); border:1px solid rgba(239,68,68,0.3); color:#fca5a5; }
.toast-info    { background:rgba(99,102,241,0.15); border:1px solid rgba(99,102,241,0.3); color:#a5b4fc; }
.toast-warn    { background:rgba(245,158,11,0.15); border:1px solid rgba(245,158,11,0.3); color:#fcd34d; }
.toast-icon { font-size:15px; flex-shrink:0; }
