:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;color:#1a1a1a;background:#f4f6f8}*{box-sizing:border-box}body{margin:0}a{color:#2563eb}.container{max-width:720px;margin:0 auto;padding:1.5rem}.card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 1px 3px #00000014;margin-bottom:1rem}h1{font-size:1.5rem;margin:0 0 1rem}label{display:block;font-size:.875rem;font-weight:600;margin-bottom:.35rem}input{width:100%;padding:.6rem .75rem;border:1px solid #d1d5db;border-radius:8px;margin-bottom:.75rem}button,.btn{display:inline-block;padding:.6rem 1rem;border:none;border-radius:8px;background:#2563eb;color:#fff;font-weight:600;cursor:pointer;text-decoration:none}button:disabled{opacity:.5;cursor:not-allowed}button.secondary{background:#6b7280}button.danger{background:#dc2626}.nav{display:flex;gap:1rem;align-items:center;margin-bottom:1rem;flex-wrap:wrap}.badge{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.75rem;font-weight:600}.badge.online{background:#d1fae5;color:#065f46}.badge.offline{background:#fee2e2;color:#991b1b}.preview{width:100%;max-height:70vh;object-fit:contain;border-radius:8px;background:#111}.error{color:#b91c1c;font-size:.875rem}.muted{color:#6b7280;font-size:.875rem}.row{display:flex;gap:.75rem;flex-wrap:wrap}
