:root{--bg: #0f1419;--surface: #1a2332;--surface-hover: #243044;--border: #2d3a4f;--text: #e7ecf3;--text-muted: #8b9cb3;--primary: #3b82f6;--primary-hover: #2563eb;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--radius: 8px;--font: system-ui, -apple-system, "Segoe UI", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;border:none;border-radius:var(--radius);padding:.5rem 1rem;background:var(--primary);color:#fff;transition:background .15s}button:hover:not(:disabled){background:var(--primary-hover)}button:disabled{opacity:.5;cursor:not-allowed}button.secondary{background:var(--surface-hover);border:1px solid var(--border)}button.secondary:hover:not(:disabled){background:var(--border)}button.danger{background:var(--danger)}input,select,textarea{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:.5rem .75rem;width:100%}input:focus,select:focus,textarea:focus{outline:2px solid var(--primary);outline-offset:1px}label{display:block;font-size:.875rem;color:var(--text-muted);margin-bottom:.25rem}.form-group{margin-bottom:1rem}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}table{width:100%;border-collapse:collapse;font-size:.875rem}th,td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}th{background:var(--surface);color:var(--text-muted);font-weight:600}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface-hover)}tr.table-row-openable{cursor:pointer}tr.table-row-openable:active td{background:var(--border)}.badge{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.75rem;font-weight:600}.badge.ma,.badge.adx{background:#1e3a5f;color:#93c5fd}.badge.mi{background:#3b2f1e;color:#fcd34d}.badge.active{background:#14532d;color:#86efac}.badge.disabled{background:#3f3f46;color:#a1a1aa}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.card h3{margin-bottom:.75rem;font-size:1rem}.stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.stat-card .value{font-size:1.75rem;font-weight:700}.stat-card .label{font-size:.8rem;color:var(--text-muted)}.actions{display:flex;gap:.5rem;flex-wrap:wrap}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.page-header h1{font-size:1.5rem}.empty{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.modal h2{margin-bottom:1rem;font-size:1.125rem}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.25rem}.url-cell{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:monospace;font-size:.8rem}.alert{padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem;font-size:.875rem}.alert.info{background:#1e3a5f;border:1px solid #2563eb}.alert.warning{background:#3b2f1e;border:1px solid var(--warning);color:#fcd34d}.alert.error{background:#3f1d1d;border:1px solid var(--danger);color:#fca5a5}.toolbar{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.filter-bar{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.filter-bar select,.filter-bar input{width:auto;min-width:160px}
