:root{--bg: #0c0c0f;--bg-elevated: rgba(255, 255, 255, .035);--bg-card: rgba(255, 255, 255, .045);--bg-card-hov: rgba(255, 255, 255, .08);--border: rgba(255, 255, 255, .09);--border-hov: rgba(255, 255, 255, .16);--text: #ececf1;--text-muted: #8b8b9a;--accent: #8b7cf7;--accent-hover:#a59cf0;--accent-dim: rgba(139, 124, 247, .14);--accent-border: rgba(139, 124, 247, .35);--green: #4ade80;--green-dim: rgba(74, 222, 128, .12);--amber: #fbbf24;--amber-dim: rgba(251, 191, 36, .14);--red: #f87171;--red-dim: rgba(248, 113, 113, .14);--red-hover: #ef4444;--radius: 12px;--radius-sm: 8px;--blur: blur(20px);--shadow-card: 0 4px 24px rgba(0, 0, 0, .35);--font-mono: ui-monospace, "SF Mono", "Cascadia Code", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:15px;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:radial-gradient(ellipse 100% 60% at 50% -15%,rgba(139,124,247,.11),transparent 55%),var(--bg);color:var(--text);min-height:100dvh;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover);text-decoration:underline}.page-title{font-size:1.5rem;font-weight:700;letter-spacing:-.03em;line-height:1.2;color:var(--text)}.page-subtitle{font-size:.85rem;color:var(--text-muted);margin-top:.35rem}.section-title{font-size:1rem;font-weight:600;letter-spacing:-.02em;color:var(--text)}.font-mono{font-family:var(--font-mono)}.card{background:var(--bg-card);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow-card);transition:border-color .18s ease,background .18s ease,box-shadow .18s ease}.card:hover{border-color:var(--border-hov);background:var(--bg-card-hov)}.card.card--static:hover{border-color:var(--border);background:var(--bg-card)}.badge{display:inline-flex;align-items:center;gap:6px;font-size:.7rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:4px 10px;border-radius:99px;border:1px solid transparent}.badge.online{color:var(--green);background:var(--green-dim);border-color:#4ade8033}.badge.stale{color:var(--amber);background:var(--amber-dim);border-color:#fbbf2433}.badge.offline{color:var(--red);background:var(--red-dim);border-color:#f8717133}.badge.active{color:var(--accent);background:var(--accent-dim);border-color:var(--accent-border)}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.badge.online:before{animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.92)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font:inherit;font-size:.85rem;font-weight:500;line-height:1.25;background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent-border);border-radius:var(--radius-sm);padding:8px 16px;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease,transform .1s ease}.btn:hover:not(:disabled){background:#8b7cf738;border-color:var(--accent);color:var(--accent-hover)}.btn:active:not(:disabled){transform:scale(.98)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-ghost{background:transparent;border-color:var(--border);color:var(--text-muted)}.btn-ghost:hover:not(:disabled){background:#ffffff0f;border-color:var(--border-hov);color:var(--text)}.btn-danger{background:#f8717126;border-color:#f8717173;color:var(--red)}.btn-danger:hover:not(:disabled){background:#f8717147;border-color:var(--red);color:#fecaca}.btn-danger:focus-visible{outline-color:var(--red)}.btn-danger-solid{background:var(--red);border-color:var(--red);color:#1a0a0a;font-weight:600}.btn-danger-solid:hover:not(:disabled){background:var(--red-hover);border-color:var(--red-hover);color:#0f0505}.btn-danger-solid:focus-visible{outline-color:#fca5a5}.btn-danger-solid:disabled{opacity:.5;cursor:not-allowed}.btn-sm{font-size:.78rem;padding:5px 12px}.btn-icon{padding:8px 12px}a.btn{text-decoration:none;display:inline-flex}a.btn:hover{text-decoration:none}input[type=text],input[type=password],input[type=url]{font:inherit;font-size:.875rem;background:#ffffff0a;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;outline:none;transition:border-color .15s ease,box-shadow .15s ease;width:100%}input::placeholder{color:var(--text-muted);opacity:.75}input:hover{border-color:var(--border-hov)}input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}input:focus-visible{outline:none}.container{max-width:1120px;margin:0 auto;padding:0 1.25rem}.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(288px,1fr));gap:1rem}.flex{display:flex}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.items-center{align-items:center}.justify-between{justify-content:space-between}.text-muted{color:var(--text-muted);font-size:.85rem}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mb-4{margin-bottom:1rem}.w-full{width:100%}.flex-shrink-0{flex-shrink:0}.min-w-0{min-width:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stat-online{color:var(--green);font-weight:500}.stat-stale{color:var(--amber);font-weight:500}.stat-offline{color:var(--red);font-weight:500}.error-banner{background:var(--red-dim);border:1px solid rgba(248,113,113,.35);color:#fecaca;border-radius:var(--radius);padding:.9rem 1.1rem;margin-bottom:1rem;font-size:.875rem;line-height:1.45}.error-banner--warn{background:var(--amber-dim);border-color:#fbbf2459;color:#fde68a}.banner-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000a6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:1rem}.modal-card{max-width:420px;width:100%;padding:1.35rem 1.5rem}.modal-card h3{font-size:1.05rem;font-weight:600;letter-spacing:-.02em}.modal-actions{display:flex;justify-content:flex-end;flex-wrap:wrap;gap:.5rem}.empty-state{color:var(--text-muted);text-align:center;padding:2.5rem 1.5rem;max-width:560px;margin:0 auto}.empty-state--left{text-align:left}.empty-state-lead{margin-bottom:1rem;line-height:1.55;color:var(--text)}.empty-state-lead strong{color:var(--text);font-weight:600}.empty-state-hints{text-align:left;margin:0;padding-left:1.25rem;line-height:1.55;font-size:.9rem;color:var(--text-muted)}.empty-state-hints li{margin:.4rem 0}.empty-state-hints code{font-family:var(--font-mono);font-size:.82rem;color:var(--text);background:#ffffff0f;padding:.1em .35em;border-radius:4px}table{width:100%;border-collapse:collapse;font-size:.85rem}th{text-align:left;color:var(--text-muted);font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;padding:10px 14px;border-bottom:1px solid var(--border);background:#0003}td{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.05)}tr:last-child td{border-bottom:none}tbody tr{transition:background .12s ease}tbody tr:hover td{background:#ffffff08}.table-card{padding:0;overflow:hidden}.table-card.card:hover{border-color:var(--border);background:var(--bg-card)}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .65s linear infinite;display:inline-block;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%,to{opacity:.45}50%{opacity:.85}}.skeleton{min-height:148px;background:linear-gradient(105deg,#ffffff0a,#ffffff14,#ffffff0a 90%);animation:shimmer 1.6s ease-in-out infinite;border-radius:var(--radius)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-hov)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.setup-panel{max-width:520px;margin:4rem auto}.setup-panel h2{font-size:1.1rem;font-weight:600;letter-spacing:-.02em}.form{display:flex;flex-direction:column;gap:1rem}.form label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--text-muted)}.machine-card{display:flex;flex-direction:column;padding:0;overflow:hidden}.machine-card-body{display:block;flex:1;padding:1.25rem;color:inherit;text-decoration:none;min-width:0}.machine-card-body:hover{text-decoration:none;color:inherit}.machine-card-body:focus-visible{outline:2px solid var(--accent);outline-offset:-4px;border-radius:var(--radius-sm)}.machine-card-footer{display:flex;justify-content:flex-end;align-items:center;padding:.65rem 1.25rem;border-top:1px solid var(--border);background:#00000038}.machine-card .hostname{font-weight:600;font-size:.95rem}.meta-row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:4px}.metrics{display:grid;grid-template-columns:1fr 1fr;gap:6px}.metric{display:flex;flex-direction:column;gap:1px}.metric-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.grid-stat{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.stat-tile{padding:1rem}.stat-tile .stat-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.stat-tile .stat-value{font-size:1.2rem;font-weight:700;margin-top:4px;letter-spacing:-.02em}.stat-tile .stat-sub{font-size:.75rem;font-weight:400;color:var(--text-muted)}.relay-card .relay-title{font-size:.9rem;font-weight:600;letter-spacing:-.02em}.relay-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);transition:background .3s ease;flex-shrink:0}.relay-dot.connected{background:var(--green);animation:relay-pulse 2s ease-in-out infinite}@keyframes relay-pulse{0%,to{opacity:1}50%{opacity:.45}}.relay-log{background:#00000052;border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;max-height:320px;overflow-y:auto;font-family:var(--font-mono);font-size:.78rem;line-height:1.6}.relay-line{color:var(--text-muted);white-space:pre-wrap;word-break:break-word}.relay-line:first-child{color:var(--text)}.btn-icon-svg{width:1em;height:1em;flex-shrink:0;opacity:.9}header.svelte-11hv8t0.svelte-11hv8t0{position:sticky;top:0;z-index:100;background:#0f0f12d9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:.75rem 0}nav.svelte-11hv8t0.svelte-11hv8t0{display:flex;align-items:center;gap:2rem}.logo.svelte-11hv8t0.svelte-11hv8t0{display:flex;align-items:center;gap:8px;font-weight:700;font-size:1rem;color:var(--text);letter-spacing:-.01em}.logo.svelte-11hv8t0.svelte-11hv8t0:hover{text-decoration:none}.nav-links.svelte-11hv8t0.svelte-11hv8t0{display:flex;align-items:center;gap:.35rem}.nav-links.svelte-11hv8t0 a.svelte-11hv8t0{color:var(--text-muted);font-size:.875rem;font-weight:500;padding:6px 12px;border-radius:var(--radius-sm);transition:color .15s ease,background .15s ease}.nav-links.svelte-11hv8t0 a.svelte-11hv8t0:hover{color:var(--text);text-decoration:none;background:#ffffff0d}.nav-links.svelte-11hv8t0 a.active.svelte-11hv8t0{color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent-border)}.nav-links.svelte-11hv8t0 a.svelte-11hv8t0:focus-visible{outline:2px solid var(--accent);outline-offset:2px}main.svelte-11hv8t0.svelte-11hv8t0{padding:2rem 1rem 3rem}
