:root{--primary-green:#059669;--primary-green-dark:#047857;--primary-green-light:#10b981;--bg-white:#fff;--bg-gray-50:#f9fafb;--bg-gray-100:#f3f4f6;--border-gray-200:#e5e7eb;--border-gray-300:#d1d5db;--text-gray-900:#111827;--text-gray-700:#374151;--text-gray-500:#6b7280;--text-gray-400:#9ca3af;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);--focus-ring:0 0 0 3px rgba(5,150,105,.4);--focus-ring-offset:0 0 0 2px var(--bg-white)}*{box-sizing:border-box}html,body{height:100%}body{margin:0;background:var(--bg-gray-50);color:var(--text-gray-900);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;line-height:1.5}.skip-link{position:absolute;top:-40px;left:0;background:var(--primary-green);color:#fff;padding:8px 16px;z-index:100;text-decoration:none;font-weight:600;border-radius:0 0 8px 0;transition:top .2s}.skip-link:focus{top:0;outline:none}:focus-visible{outline:2px solid var(--primary-green);outline-offset:2px}:focus:not(:focus-visible) {outline:none}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--primary-green);outline-offset:2px;box-shadow:var(--focus-ring)}.nav a:focus-visible{outline:2px solid #fff;outline-offset:-2px;background:rgba(255,255,255,.2)}.app{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--primary-green);color:#fff;padding:0;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.brand{padding:20px;font-weight:700;font-size:20px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:8px}.nav{padding:10px 0}.nav a{display:flex;align-items:center;gap:12px;padding:12px 20px;color:rgba(255,255,255,.9);text-decoration:none;font-weight:500;transition:all .2s}.nav a:hover{background:rgba(255,255,255,.1);color:#fff}.nav a.active{background:rgba(255,255,255,.2);color:#fff;font-weight:600}.spacer{flex:1}.content{flex:1;background:var(--bg-gray-50);overflow-y:auto}.wrap{max-width:1200px;margin:0 auto;padding:24px}.page-header{margin-bottom:24px}.title{font-weight:700;font-size:24px;margin:0 0 8px;color:var(--text-gray-900)}.subtitle{color:var(--text-gray-500);margin:0}.card{background:var(--bg-white);border:1px solid var(--border-gray-200);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm);margin-bottom:16px}.card-header{margin-bottom:16px}.card-title{font-weight:600;font-size:18px;margin:0 0 4px}.card-subtitle{color:var(--text-gray-500);margin:0;font-size:14px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}.field{display:block;font-weight:500;margin:16px 0 6px;color:var(--text-gray-700)}.input,select.input{width:100%;padding:12px 16px;border-radius:8px;border:1px solid var(--border-gray-300);background:var(--bg-white);color:var(--text-gray-900);font-size:14px;transition:border-color .2s , box-shadow .2s}.input:focus,select.input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px rgba(5,150,105,.1)}.input::placeholder{color:var(--text-gray-400)}.btn{display:inline-flex;align-items:center;gap:8px;background:var(--primary-green);color:#fff;text-decoration:none;padding:12px 20px;border-radius:8px;font-weight:600;font-size:14px;border:0;cursor:pointer;transition:background-color .2s , transform .1s}.btn:hover{background:var(--primary-green-dark);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-outline{background:transparent;color:var(--primary-green);border:1px solid var(--primary-green)}.btn-outline:hover{background:var(--primary-green);color:#fff}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-gray-200)}.table th{background:var(--bg-gray-50);font-weight:600;color:var(--text-gray-700);font-size:14px;cursor:pointer}.table tbody tr:hover{background:var(--bg-gray-50)}.error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;padding:12px 16px;border-radius:8px;margin:16px 0;font-size:14px}.success{background:#f0fdf4;color:var(--primary-green-dark);border:1px solid #bbf7d0;padding:12px 16px;border-radius:8px;margin:16px 0;font-size:14px}.auth-wrap{display:flex;min-height:100vh;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,var(--primary-green) 0%,var(--primary-green-dark) 100%)}.auth-card{width:100%;max-width:400px;background:#fff;padding:32px;border-radius:16px;box-shadow:var(--shadow-lg)}.auth-title{font-size:24px;font-weight:700;margin:0 0 8px;text-align:center;color:var(--text-gray-900)}.auth-subtitle{color:var(--text-gray-500);text-align:center;margin:0 0 24px}.toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.toolbar .input{min-width:200px}@media (max-width:768px){.app{flex-direction:column}.sidebar{width:100%;position:fixed;bottom:0;left:0;flex-direction:row;height:auto;z-index:50}.brand{display:none}.nav{display:flex;width:100%;padding:0;justify-content:space-around}.nav a{flex:1;text-align:center;padding:12px 8px;font-size:12px;flex-direction:column;gap:4px}.content{padding-bottom:70px}.wrap{padding:16px}.grid{grid-template-columns:1fr}.toolbar{flex-direction:column;align-items:stretch}.toolbar .input{min-width:auto}}.nav-icon{font-size:16px}@media (min-width:769px){.nav-icon{display:none}}.metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:20px}.metric-card{background:var(--bg-white);border:1px solid var(--border-gray-200);border-radius:12px;padding:20px;transition:box-shadow .2s}.metric-card:hover{box-shadow:var(--shadow-md)}.metric-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-weight:600;color:var(--text-gray-700)}.metric-value{font-size:28px;font-weight:700;color:var(--text-gray-900);margin-bottom:4px;line-height:1}.metric-sub{color:var(--text-gray-500);font-size:14px}.progress-bar{width:100%;height:8px;background:var(--bg-gray-200);border-radius:4px;overflow:hidden;margin:8px 0}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-green),var(--primary-green-light));transition:width .3s ease}.status-online{color:var(--primary-green);display:flex;align-items:center;font-weight:500}.status-offline{color:#dc2626;display:flex;align-items:center;font-weight:500}.table-compact th,.table-compact td{padding:10px 12px;font-size:14px}.table-compact th{font-weight:600;background:var(--bg-gray-50)}[data-lucide]{stroke-width:2;flex-shrink:0}.icon-xs{width:12px;height:12px}.icon-sm{width:16px;height:16px}.icon-md{width:20px;height:20px}.icon-lg{width:24px;height:24px}.icon-xl{width:32px;height:32px}.btn [data-lucide],.nav a [data-lucide]{width:18px;height:18px}[data-tooltip]{position:relative;cursor:help}[data-tooltip]::after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translateX(-50%) translateY(-4px);padding:6px 10px;background:var(--text-gray-900);color:#fff;font-size:12px;font-weight:500;white-space:nowrap;border-radius:6px;opacity:0;visibility:hidden;transition:opacity .15s , visibility .15s;z-index:1000;pointer-events:none;max-width:250px;text-align:center}[data-tooltip]::before{content:'';position:absolute;bottom:100%;left:50%;transform:translateX(-50%) translateY(4px);border:6px solid transparent;border-top-color:var(--text-gray-900);opacity:0;visibility:hidden;transition:opacity .15s , visibility .15s;z-index:1000}[data-tooltip]:hover::after,[data-tooltip]:hover::before,[data-tooltip]:focus::after,[data-tooltip]:focus::before{opacity:1;visibility:visible}[data-tooltip-position="bottom"]::after{bottom:auto;top:100%;transform:translateX(-50%) translateY(4px)}[data-tooltip-position="bottom"]::before{bottom:auto;top:100%;transform:translateX(-50%) translateY(-8px);border-top-color:transparent;border-bottom-color:var(--text-gray-900)}[data-tooltip-position="left"]::after{bottom:auto;top:50%;left:auto;right:100%;transform:translateY(-50%) translateX(-4px)}[data-tooltip-position="right"]::after{bottom:auto;top:50%;left:100%;transform:translateY(-50%) translateX(4px)}@media (max-width:768px){.metric-grid{grid-template-columns:1fr}.metric-value{font-size:24px}.table-compact{font-size:12px}.table-compact th,.table-compact td{padding:8px 6px}}.mini-chart{display:flex;align-items:end;gap:1px;height:40px;padding:4px 0;background:var(--bg-gray-50);border-radius:4px;padding:8px 6px 4px 6px}.mini-chart-bar{flex:1;min-height:2px;border-radius:1px 1px 0 0;transition:all .2s ease;cursor:pointer}.mini-chart-bar:hover{opacity:.8;transform:scaleY(1.1)}.vm-list{max-height:120px;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--border-gray-300) transparent}.vm-list::-webkit-scrollbar{width:4px}.vm-list::-webkit-scrollbar-track{background:transparent}.vm-list::-webkit-scrollbar-thumb{background-color:var(--border-gray-300);border-radius:2px}.vm-list::-webkit-scrollbar-thumb:hover{background-color:var(--border-gray-400)}.vm-item{padding:6px 0;border-bottom:1px solid var(--border-gray-100)}.vm-item:last-child{border-bottom:none}.vm-item:hover{background:var(--bg-gray-50);margin:0 -8px;padding-left:8px;padding-right:8px;border-radius:4px}.admin-grid{display:flex;flex-direction:column;gap:32px}.admin-section{background:var(--bg-white);border-radius:16px;padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--border-gray-200)}.section-title{font-size:18px;font-weight:700;color:var(--text-gray-900);margin:0 0 20px 0;padding-bottom:12px;border-bottom:2px solid var(--bg-gray-100)}.admin-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.admin-card{display:flex;align-items:flex-start;gap:16px;padding:20px;background:var(--bg-white);border:2px solid var(--border-gray-200);border-radius:12px;text-decoration:none;color:inherit;transition:all .2s ease;position:relative;overflow:hidden}.admin-card:hover{border-color:var(--primary-green);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.admin-card:hover .admin-card-icon{transform:scale(1.1)}.admin-card-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease;position:relative}.admin-card-icon i{width:28px;height:28px;stroke-width:2;color:#fff}.admin-card-icon.nodes{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.admin-card-icon.commands{background:linear-gradient(135deg,#10b981,#047857)}.admin-card-icon.users{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.admin-card-icon.tenants{background:linear-gradient(135deg,#f59e0b,#d97706)}.admin-card-icon.memberships{background:linear-gradient(135deg,#06b6d4,#0891b2)}.admin-card-icon.oidc{background:linear-gradient(135deg,#6366f1,#4f46e5)}.admin-card-icon.guac{background:linear-gradient(135deg,#059669,#047857)}.admin-card-content{flex:1;min-width:0}.admin-card-content h3{font-size:18px;font-weight:700;color:var(--text-gray-900);margin:0 0 8px 0;line-height:1.2}.admin-card-content p{font-size:14px;color:var(--text-gray-600);margin:0 0 12px 0;line-height:1.4}.admin-card-stats{display:flex;flex-wrap:wrap;gap:12px}.stat-item{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-gray-500);font-weight:500}.stat-item i{width:14px;height:14px;stroke-width:2}@media (max-width:768px){.admin-grid{gap:20px}.admin-section{padding:16px;border-radius:12px}.admin-cards{grid-template-columns:1fr;gap:16px}.admin-card{padding:16px;gap:12px}.admin-card-icon{width:48px;height:48px}.admin-card-icon i{width:24px;height:24px}.admin-card-content h3{font-size:16px}.admin-card-content p{font-size:13px}}