:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.app-container,.error-container{min-height:100vh;width:100vw;display:flex;justify-content:center;align-items:center;background-color:#f2f4f7;color:#1f2937;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:2.2rem}.status-panel{display:flex;flex-direction:column;align-items:center;gap:24px;padding:44px 48px;background-color:#fff;border-radius:18px;box-shadow:0 14px 40px #0f172a1f;width:min(680px,88vw)}.icon-status{width:100%;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}.status-icon-large{width:260px;height:260px;border-radius:50%;object-fit:cover;box-shadow:0 16px 45px #0f172a33;transition:filter .3s ease,opacity .3s ease,box-shadow .3s ease}.status-icon-large.connected{animation:gentleFloat 4s ease-in-out infinite;filter:none;opacity:1}.status-icon-large.connecting{filter:grayscale(1);opacity:.6;animation:pulse 1.5s infinite}.status-icon-large.disconnected{filter:grayscale(1);opacity:.55}.status-icon-large.error{filter:grayscale(1);opacity:.5;box-shadow:0 0 0 4px #dc262640}.status-state{font-size:3.4rem;font-weight:700}.status-state.disconnected{color:#dc2626}.status-state.connecting{color:#f59e0b}.status-state.connected{color:#0f9d58}.status-state.error{color:#b91c1c}.scenario-label{font-size:1.1rem;color:#64748b;margin-top:4px}.message-stack{width:100%;display:flex;flex-direction:column;gap:12px}.message-box{padding:14px 18px;border-radius:12px;border:1px solid transparent;background:#f8fafc}.message-box.warn{border-color:#fcd34d;background:#fffbeb;color:#92400e}.message-box.error{border-color:#fca5a5;background:#fef2f2;color:#991b1b}.message-title{font-weight:600;margin-bottom:6px}.message-body{font-size:2rem}.debug-panel{width:100%;background:#f8fafc;border-radius:14px;padding:18px;color:#475569}.debug-title{font-weight:700;margin-bottom:10px;font-size:2.2rem}.debug-grid{display:grid;grid-template-columns:minmax(160px,220px) 1fr;gap:8px 16px;font-size:1.9rem;margin-bottom:16px}.debug-row{display:contents}.debug-key{font-weight:600;color:#1f2937}.debug-value{color:#334155;word-break:break-all}.debug-block{margin-top:12px}.debug-subtitle{font-weight:600;margin-bottom:6px;font-size:2rem}.debug-mono{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:1.7rem;white-space:pre-wrap;background:#fff;border-radius:10px;padding:12px;border:1px solid #e2e8f0}@keyframes pulse{0%{opacity:1}50%{opacity:.4}to{opacity:1}}@keyframes gentlePulse{0%{transform:scale(1);box-shadow:0 0 #00c85166}50%{transform:scale(1.05);box-shadow:0 0 20px 10px #00c85133}to{transform:scale(1);box-shadow:0 0 #00c85166}}@keyframes gentleFloat{0%{transform:translateY(0)}50%{transform:translateY(-6px)}to{transform:translateY(0)}}
