:root{font-family:Helvetica Neue,Arial,sans-serif;line-height:1.5;color:#0f172a;background-color:#f8fafc}*{box-sizing:border-box}body{margin:0}a{color:inherit;text-decoration:none}.app-shell{min-height:100vh;background:radial-gradient(circle at 10% 20%,#e0f2fe,transparent 30%),radial-gradient(circle at 90% 10%,#fef3c7,transparent 28%),radial-gradient(circle at 80% 80%,#e0f2fe,transparent 30%),#f8fafc;display:flex;align-items:flex-start;justify-content:center;padding:40px 16px}.card{width:min(960px,100%);background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 10px 40px #0f172a14;overflow:hidden}.card-header{padding:24px 32px 16px;border-bottom:1px solid #e2e8f0}.header-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.card-title{margin:0;font-size:28px;font-weight:700;letter-spacing:-.01em}.card-subtitle{margin:6px 0 0;color:#475569}.card-body{padding:32px;display:flex;gap:32px;flex-wrap:wrap}.card-body section{flex:1 1 260px}.register-body,.connect-body{flex-direction:column}.full-width{flex:1 1 100%}.field{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}label{font-weight:600}input{padding:12px 14px;border:1px solid #cbd5e1;border-radius:10px;font-size:15px;transition:border-color .2s,box-shadow .2s}input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb33}select{padding:12px 14px;border:1px solid #cbd5e1;border-radius:10px;font-size:15px;transition:border-color .2s,box-shadow .2s;background:#fff}select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb33}.actions{display:flex;gap:12px;margin-top:8px}.actions-left{justify-content:flex-start}.pad-bottom{padding-bottom:20px}.pad-top{padding-top:20px}.actions-spread{justify-content:flex-end}.section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.inline-row{display:flex;gap:16px;flex-wrap:wrap}.inline-action{display:flex;align-items:flex-end}button{cursor:pointer;border:none;border-radius:10px;font-weight:700;padding:12px 16px;font-size:15px;display:inline-flex;align-items:center;gap:8px;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease}button.primary{background:linear-gradient(120deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 8px 24px #2563eb59}button.secondary{background:#e2e8f0;color:#0f172a}button:active{transform:translateY(1px);filter:brightness(.97)}button:disabled{cursor:not-allowed;box-shadow:none}button.primary:disabled{background:#cbd5e1;color:#94a3b8;cursor:not-allowed;opacity:.7}button.secondary:disabled{background:#f1f5f9;color:#94a3b8;cursor:not-allowed;opacity:.5}.notice{padding:14px 16px;border-radius:10px;background:#f8fafc;border:1px dashed #cbd5e1;color:#475569}.notice.notice-alert{background:#fef2f2;border-color:#ef4444;color:#b91c1c}.notice-header{display:flex;align-items:center;justify-content:space-between;gap:12px;font-weight:700}.notice pre{margin:8px 0 0;white-space:pre-wrap;font-family:monospace}.notice-alert{background:#fff1f2;border-color:#fca5a5;color:#b91c1c}.pre-wrap{white-space:pre-wrap}.nav-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:12px}.nav-buttons.column{display:flex;flex-direction:column;align-items:flex-start}.nav-buttons a{display:inline-flex;width:auto}.panel{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:16px}.panel h3{margin-top:0;margin-bottom:10px}.muted{color:#64748b}.table-wrapper{overscroll-behavior:contain}.table-scroll{max-height:280px;overflow-y:auto}.table{width:100%;border-collapse:collapse}.table-scroll thead th{position:sticky;top:0;background:#f8fafc;z-index:1}.table th,.table td{padding:10px 12px;border-bottom:1px solid #e2e8f0;text-align:left;font-size:14px}.table th{color:#475569;font-weight:700}.selected-row{background:#e0f2fe}
