:root{--canvas: #f0f2f6;--bg: #ffffff;--surface2: #f8f9fb;--surface3: #f0f2f5;--border: #e4e7ec;--border2: #d1d6df;--cyan: #0ea5c9;--cyan-light: #e0f5fb;--cyan-mid: rgba(14, 165, 201, .12);--green: #16a34a;--green-light: #dcfce7;--text: #1a2232;--text-mid: #4b5768;--muted: #8c96a6;--red: #dc2626;--red-light: #fee2e2;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--radius-sm: 4px;--radius: 6px;--radius-lg: 10px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%}body{font-family:var(--font-sans);font-size:14px;color:var(--text);background:var(--canvas);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code,pre,.mono{font-family:var(--font-mono)}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius);font-family:var(--font-sans);font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:background .15s,border-color .15s,opacity .15s;white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--cyan);color:#fff;border-color:var(--cyan)}.btn-primary:hover:not(:disabled){background:#0891b2;border-color:#0891b2}.btn-ghost{background:transparent;color:var(--text-mid);border-color:var(--border)}.btn-ghost:hover:not(:disabled){background:var(--surface2);border-color:var(--border2)}.btn-outline{background:transparent;color:var(--cyan);border-color:var(--cyan)}.btn-outline:hover:not(:disabled){background:var(--cyan-light)}.input{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-sans);font-size:13px;color:var(--text);background:var(--bg);outline:none;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-mid)}.input::placeholder{color:var(--muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0f1973;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .12s ease}.modal{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;width:100%;max-width:440px;box-shadow:0 20px 60px #00000026;animation:slideUp .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--cyan);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-page{min-height:100dvh;background:#f6f7f9;color:#111827;font-family:var(--font-sans);padding:32px 24px}.dashboard-shell{max-width:1440px;margin:0 auto}.dashboard-topbar,.dashboard-heading,.dashboard-heading-actions,.dashboard-filterbar,.dashboard-add-actions,.dashboard-row-actions,.dashboard-summary{display:flex;align-items:center}.dashboard-topbar{justify-content:space-between;margin-bottom:24px}.dashboard-heading{justify-content:space-between;gap:24px;margin-bottom:22px}.dashboard-heading h1{margin:0;font-size:30px;line-height:1.2;font-weight:650;letter-spacing:0}.dashboard-heading p{margin:6px 0 0;color:#6b7280;font-size:14px}.dashboard-heading-actions{gap:8px;flex-wrap:wrap;justify-content:flex-end}.dashboard-live-state{display:inline-flex;align-items:center;gap:8px;color:#6b7280;font-size:13px;font-weight:600}.dashboard-live-state span{width:9px;height:9px;border-radius:999px;background:#9ca3af}.dashboard-live-state[data-connected=true]{color:#047857}.dashboard-live-state[data-connected=true] span{background:#10b981;box-shadow:0 0 0 4px #10b98124}.dashboard-card{border:1px solid #e5e7eb;border-radius:8px;background:#fff;box-shadow:0 1px 2px #0f172a0a;padding:0}.dashboard-card-header{display:flex;flex-direction:row;justify-content:space-between;gap:16px;border-bottom:1px solid #e5e7eb;padding:18px 20px}.dashboard-card-header [data-slot=card-title]{font-size:18px;font-weight:650}.dashboard-card-header [data-slot=card-description]{margin-top:3px;color:#6b7280}.dashboard-card-content{padding:16px 20px 20px}.dashboard-summary{align-self:start;gap:8px;color:#6b7280;font-size:12px}.dashboard-summary span{border:1px solid #e5e7eb;border-radius:999px;padding:3px 9px;background:#f9fafb}.dashboard-filterbar{gap:10px;flex-wrap:wrap;margin-bottom:14px}.dashboard-search{position:relative;flex:1 1 360px}.dashboard-search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#6b7280;pointer-events:none}.dashboard-search [data-slot=input]{padding-left:34px}.dashboard-add-form{display:grid;grid-template-columns:minmax(180px,1fr) minmax(160px,.8fr) 150px minmax(140px,.8fr) auto;gap:10px;align-items:center;border:1px solid #e5e7eb;background:#f9fafb;border-radius:8px;padding:12px;margin-bottom:14px}.dashboard-add-actions{gap:8px;justify-content:flex-end}.dashboard-table-wrap{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.dashboard-table{min-width:1180px;border-collapse:collapse}.dashboard-table thead{background:#f9fafb}.dashboard-table th,.dashboard-table td{border-bottom:1px solid #e5e7eb}.dashboard-table th{height:42px;padding:0 10px;color:#6b7280;font-size:12px;font-weight:600}.dashboard-table td{padding:9px 10px;vertical-align:middle}.dashboard-table tbody tr:hover{background:#fafafa}.dashboard-expand-col{width:42px}.dashboard-actions-col{width:190px}.dashboard-sort-button{display:inline-flex;align-items:center;gap:6px;border:0;background:transparent;color:inherit;font:inherit;cursor:pointer;padding:0}.dashboard-sort-button svg{color:#9ca3af}.dashboard-sort-button svg.is-active{color:#111827}.dashboard-select,.dashboard-page [data-slot=input]{width:100%;height:34px;min-width:0;border:1px solid #d1d5db;border-radius:7px;background:#fff;color:#111827;font:400 13px/1 var(--font-sans);outline:none}.dashboard-page [data-slot=input]{padding:0 10px}.dashboard-select{padding:0 30px 0 10px}.dashboard-select:focus,.dashboard-page [data-slot=input]:focus{border-color:#0ea5c9;box-shadow:0 0 0 3px #0ea5c924}.dashboard-select:disabled,.dashboard-page [data-slot=input]:disabled,.dashboard-textarea:disabled{color:#6b7280;background:#f3f4f6}.dashboard-page [data-slot=button]{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:34px;border-radius:7px;border:1px solid transparent;padding:0 12px;font:600 13px/1 var(--font-sans);cursor:pointer;transition:background .14s,border-color .14s,color .14s,opacity .14s}.dashboard-page [data-slot=button][data-size=icon-sm]{width:30px;height:30px;padding:0}.dashboard-page [data-slot=button][data-variant=default]{background:#111827;color:#fff}.dashboard-page [data-slot=button][data-variant=default]:hover{background:#1f2937}.dashboard-page [data-slot=button][data-variant=outline],.dashboard-page [data-slot=button][data-variant=ghost]{background:#fff;border-color:#d1d5db;color:#374151}.dashboard-page [data-slot=button][data-variant=outline]:hover,.dashboard-page [data-slot=button][data-variant=ghost]:hover{background:#f3f4f6}.dashboard-page [data-slot=button][data-variant=destructive]{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.dashboard-page [data-slot=button][data-variant=destructive]:hover{background:#fee2e2}.dashboard-page [data-slot=button]:disabled{cursor:not-allowed;opacity:.5}.dashboard-row-actions{gap:7px}.dashboard-channel-cell{min-width:230px}.dashboard-channel-cell small{display:block;max-width:260px;margin-top:4px;overflow:hidden;color:#6b7280;font-family:var(--font-mono);font-size:11px;text-overflow:ellipsis}.dashboard-mono,.dashboard-timestamp{font-family:var(--font-mono);font-size:12px}.dashboard-timestamp{color:#374151}.dashboard-badge{height:24px;border-radius:999px;border:1px solid #e5e7eb;padding:0 9px;background:#fff;color:#374151;text-transform:capitalize}.dashboard-status-dot{width:7px;height:7px;border-radius:999px;background:currentColor}.dashboard-badge-live{color:#047857;border-color:#bbf7d0;background:#f0fdf4}.dashboard-badge-stale{color:#b45309;border-color:#fde68a;background:#fffbeb}.dashboard-badge-silent{color:#6b7280;border-color:#e5e7eb;background:#f9fafb}.dashboard-visibility-private{color:#374151;border-color:#e5e7eb;background:#f9fafb}.dashboard-visibility-registered{color:#0369a1;border-color:#bae6fd;background:#f0f9ff}.dashboard-visibility-public{color:#047857;border-color:#bbf7d0;background:#f0fdf4}.dashboard-visibility-semiprivate{color:#6d28d9;border-color:#ddd6fe;background:#f5f3ff}.dashboard-relation{color:#374151;background:#fff}.dashboard-subrow td{background:#fbfbfc}.dashboard-details{display:grid;grid-template-columns:1fr 1fr minmax(320px,1.4fr);gap:16px;padding:8px 4px 10px 46px}.dashboard-details h3{margin:0 0 9px;font-size:13px;font-weight:650}.dashboard-details dl{display:grid;gap:7px;margin:0}.dashboard-details dl div{display:flex;gap:10px;justify-content:space-between;border-bottom:1px solid #e5e7eb;padding-bottom:7px}.dashboard-details dt{color:#6b7280}.dashboard-details dd{margin:0;color:#111827}.dashboard-textarea{width:100%;min-height:92px;resize:vertical;border:1px solid #d1d5db;border-radius:7px;padding:9px 10px;color:#111827;font:400 13px/1.4 var(--font-sans);outline:none}.dashboard-details pre{max-height:220px;overflow:auto;margin:0;border:1px solid #e5e7eb;border-radius:7px;background:#fff;padding:10px;color:#374151;font:12px/1.45 var(--font-mono)}.dashboard-error{border:1px solid #fecaca;border-radius:7px;background:#fef2f2;color:#b91c1c;padding:10px 12px;margin-bottom:12px;font-size:13px}.dashboard-empty{display:flex;min-height:130px;align-items:center;justify-content:center;color:#6b7280;font-size:14px}.dashboard-spin{animation:dashboard-spin .8s linear infinite}@keyframes dashboard-spin{to{transform:rotate(360deg)}}@media(max-width:900px){.dashboard-page{padding:20px 12px}.dashboard-heading,.dashboard-card-header{align-items:flex-start;flex-direction:column}.dashboard-heading-actions,.dashboard-summary{justify-content:flex-start}.dashboard-add-form,.dashboard-details{grid-template-columns:1fr}.dashboard-details{padding-left:4px}}
