html{width:100%;height:100%}:root{--primary: #4f46e5;--primary-dark: #4338ca;--bg-main: #f1f5f9;--bg-subtle: #f8fafc;--bg-card: #ffffff;--text-main: #1e293b;--text-muted: #64748b;--text-on-dark: #ffffff;--border: #e2e8f0;--success: #10b981;--success-text: #15803d;--success-bg: #f0fdf4;--success-border: #86efac;--danger: #ef4444;--danger-text: #dc2626;--danger-bg: #fef2f2;--danger-border: #fecaca;--warning: #f59e0b;--warning-text: #92400e;--warning-bg: #fef3c7;--warning-dark: #b45309;--radius: 12px}@keyframes ws-pulse{0%,to{opacity:1}50%{opacity:.4}}.ws-reconnecting-banner{position:fixed;top:12px;left:12px;z-index:10001;pointer-events:none}.ws-reconnecting-badge{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:600;color:#f59e0b;background:#f59e0b1f;border:1px solid rgba(245,158,11,.3);border-radius:999px;padding:4px 10px;animation:ws-pulse 1.4s ease-in-out infinite}.ws-reconnecting-dot{width:6px;height:6px;border-radius:50%;background:#f59e0b;flex-shrink:0}.customer-ws-offline-banner{display:flex;align-items:flex-start;gap:12px;width:100%;margin-bottom:16px;padding:12px 14px;border-radius:12px;background:#f59e0b24;border:1px solid rgba(245,158,11,.45);color:#92400e;box-sizing:border-box}.customer-ws-offline-dot{width:10px;height:10px;margin-top:4px;border-radius:50%;background:#f59e0b;flex-shrink:0;animation:ws-pulse 1.4s ease-in-out infinite}.customer-ws-offline-text{display:flex;flex-direction:column;gap:4px;font-size:.88rem;line-height:1.4}.customer-ws-offline-text strong{font-size:.95rem;font-weight:700;color:#b45309}.customer-ws-offline-text span{font-weight:500;color:#92400e}@keyframes eb-fade-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.error-boundary-root{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-main);font-family:Inter,system-ui,sans-serif}.error-boundary-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:40px 48px;max-width:440px;width:90%;text-align:center;box-shadow:0 4px 24px #00000012;animation:eb-fade-in .35s ease both}.error-boundary-icon{font-size:2.5rem;margin-bottom:16px}.error-boundary-title{font-size:1.25rem;font-weight:700;color:var(--text-main);margin:0 0 10px}.error-boundary-desc{font-size:.95rem;color:var(--text-muted);margin:0 0 28px;line-height:1.6}.error-boundary-btn{background:var(--primary);color:#fff;border:none;border-radius:8px;padding:11px 28px;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s}.error-boundary-btn:hover{opacity:.88}:root{font-family: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;min-width:320px;min-height:100vh;width:100%;height:100%}#root{width:100%;height:100%;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}}
