*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc}#root{height:100vh;display:flex;flex-direction:column}.app{height:100vh;display:flex;flex-direction:column;background-color:#f8fafc}.demo-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;min-height:80px;box-shadow:0 1px 3px #0000001a}.demo-header h1{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.header-controls{display:flex;align-items:center;gap:1rem}.role-buttons{display:flex;gap:.75rem;align-items:center}.action-buttons{display:flex;gap:.5rem;align-items:center}.reset-button,.logout-button{padding:.5rem 1rem;border:1px solid #e2e8f0;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;background:#fff;color:#64748b}.reset-button:hover{background:#f8fafc;border-color:#cbd5e1;color:#475569}.logout-button{background:#fef2f2;border-color:#fecaca;color:#dc2626}.logout-button:hover{background:#fee2e2;border-color:#fca5a5;color:#b91c1c}.role-button{padding:.5rem 1rem;border:2px solid transparent;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;background:#fff;color:#64748b;border-color:#e2e8f0}.role-button:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px)}.role-button:disabled{opacity:.5;cursor:not-allowed;background:#f1f5f9;color:#94a3b8;border-color:#e2e8f0}.role-button.active{background:var(--role-color);color:#fff;border-color:var(--role-color);box-shadow:0 4px 6px -1px #0000001a}.role-button.active:hover{background:var(--role-color);opacity:.9;transform:translateY(-1px)}.role-button.logged-in{border-color:#10b981;background:#f0fdf4;color:#166534}.role-button.logged-in.active{background:var(--role-color);color:#fff;border-color:var(--role-color)}.login-indicator{margin-left:.5rem;font-size:.75rem;font-weight:700}.iframe-container{flex:1;margin:1rem;border-radius:.75rem;overflow:hidden;box-shadow:0 10px 15px -3px #0000001a;background:#fff}.iframe-container iframe{width:100%;height:100%;border:none;display:block}.loading{display:flex;justify-content:center;align-items:center;height:100%;background:#f8fafc;color:#64748b;font-size:1.125rem}@media (max-width: 768px){.demo-header{padding:.5rem 1rem;flex-direction:column;gap:.75rem;min-height:auto}.demo-header h1{font-size:1.125rem;text-align:center}.header-controls{flex-direction:column;gap:.75rem;width:100%}.role-buttons{gap:.375rem;justify-content:center;flex-wrap:wrap}.role-button{padding:.375rem .75rem;font-size:.75rem}.action-buttons{gap:.375rem;justify-content:center;flex-wrap:wrap}.reset-button,.logout-button{padding:.375rem .75rem;font-size:.75rem}.iframe-container{margin:.5rem;height:calc(100vh - 160px)}}
