:root{--bg: #0f1218;--surface: #171b24;--surface2: #1e2430;--border: #2a3142;--text: #e8eaef;--muted: #8b93a7;--accent: #5b8def;--accent-hover: #7aa3f5;--ok: #3dd68c;--err: #f07178;--danger: #c94c54;--radius: 10px;--font: "DM Sans", system-ui, sans-serif;--mono: "JetBrains Mono", ui-monospace, monospace}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font);font-size:15px;color:var(--text);background:radial-gradient(1200px 600px at 10% -10%,#1a2240 0%,transparent 55%),var(--bg)}#root{min-height:100vh}.app{max-width:960px;margin:0 auto;padding:2rem 1.25rem 4rem}.header{margin-bottom:1.75rem}.header h1{margin:0 0 .35rem;font-size:1.75rem;font-weight:700;letter-spacing:-.02em}.sub{margin:0;color:var(--muted);font-size:.95rem;max-width:42rem}.banner{margin-top:1rem;padding:.85rem 1rem;border-radius:var(--radius);font-size:.9rem;line-height:1.5}.banner-warn{background:#f071781f;border:1px solid rgba(240,113,120,.35);color:#f5b4b8}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.35rem;margin-bottom:1rem}.panel-danger{border-color:#c94c5473;background:linear-gradient(145deg,var(--surface) 0%,#1a1518 100%)}.panel h2{margin:0 0 .85rem;font-size:1rem;font-weight:600;color:var(--text)}.field-row{display:flex;flex-direction:column;gap:.35rem}.label{font-size:.8rem;font-weight:500;color:var(--muted)}.input{width:100%;padding:.55rem .7rem;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-family:var(--font);font-size:.95rem}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #5b8def33}.input.mono{font-family:var(--mono);font-size:.88rem}.input-narrow{max-width:6rem}.input[readonly]{opacity:.85}.hint{margin:.65rem 0 0;font-size:.82rem;color:var(--muted)}.mono{font-family:var(--mono);font-size:.88em}.toolbar{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.75rem}.field-inline{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem}.field-inline .label{margin-right:.15rem}.spacer{flex:1;min-width:.5rem}.btn{font-family:var(--font);font-size:.9rem;font-weight:600;padding:.55rem 1rem;border-radius:8px;border:none;cursor:pointer;transition:background .15s,opacity .15s}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);color:#0a0c10}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:#252b38}.btn-small{padding:.4rem .75rem;font-size:.82rem;background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-small:hover:not(:disabled){border-color:var(--accent);color:var(--accent-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){filter:brightness(1.08)}.muted{margin:0 0 .85rem;color:var(--muted);font-size:.88rem}.table-wrap{overflow-x:auto;margin:0 -.15rem}.table{width:100%;border-collapse:collapse;font-size:.9rem}.table th,.table td{text-align:left;padding:.55rem .5rem;border-bottom:1px solid var(--border);vertical-align:middle}.table th{color:var(--muted);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em}.table tbody tr:hover{background:#ffffff05}.table .name{font-weight:500;min-width:10rem}.table .actions{width:1%;white-space:nowrap}.toast{position:fixed;bottom:1.25rem;right:1.25rem;max-width:min(420px,calc(100vw - 2.5rem));padding:.85rem 1rem;border-radius:var(--radius);font-size:.9rem;box-shadow:0 8px 32px #00000073;z-index:50;animation:toast-in .2s ease-out}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast-ok{background:#152a22;border:1px solid rgba(61,214,140,.45);color:#b8f0d4}.toast-err{background:#2a1518;border:1px solid rgba(240,113,120,.5);color:#f5c4c7}.toast-info{background:var(--surface);border:1px solid var(--border);color:var(--text)}@media(max-width:640px){.toolbar{flex-direction:column;align-items:stretch}.spacer{display:none}.table .name{min-width:8rem}}
