*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-start:#0c0d16;--bg-end:#121528;--panel:#121423;--panel-border:#1d2032;--text-main:#e8ebf7;--text-sub:#9aa1bd;--accent:#b18cff;--accent-strong:#7a4bff;--bubble-ai:#6f5bd7;--bubble-user:#3568e8}body{background:radial-gradient(120% 120% at 20% 20%, #1a1d2d 0%, #0b0c14 45%, #0b0c14 100%), linear-gradient(160deg, var(--bg-start), var(--bg-end));color:var(--text-main);flex-direction:column;min-height:100vh;font-family:Google Sans,Inter,system-ui,-apple-system,sans-serif;display:flex;overflow:hidden}#topbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--panel-border);z-index:10;background:#0e101ab3;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 22px;display:flex}.brand{align-items:center;gap:10px;display:flex}.brand-icon{color:#fff;letter-spacing:.5px;background:linear-gradient(135deg,#7f5af0,#b18cff);border-radius:12px;place-items:center;width:38px;height:38px;font-weight:800;display:grid;box-shadow:0 10px 30px #7f5af059}.brand-text{flex-direction:column;line-height:1.1;display:flex}.brand-name{color:#f4f5ff;font-size:1rem;font-weight:700}.brand-sub{color:var(--text-sub);font-size:.8rem}.top-meta{color:var(--text-sub);align-items:center;gap:10px;font-size:.86rem;display:flex}.pill{border:1px solid var(--panel-border);color:#c5c9de;background:#191c2c;border-radius:999px;align-items:center;gap:6px;padding:8px 12px;font-weight:600;display:inline-flex}.pill.live{color:#ff7b7b;background:#ff50501f;border-color:#ff505059}.pill.role{color:#d6dcff}.pill.timer{color:#7ae2a5}#main{flex:1;grid-template-columns:1fr 360px;min-height:0;display:grid}#stage{place-items:center;padding:32px;display:grid;position:relative;overflow:hidden}#stage:before{content:"";filter:blur(8px);z-index:0;background:radial-gradient(circle,#704fff24 0%,#14102500 60%);width:420px;height:420px;position:absolute}.stage-center{z-index:1;text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex;position:relative}.avatar-shell{background:radial-gradient(circle at 30% 30%,#8c6bff 0%,#5c3dcf 55%,#3b2a7c 100%);border-radius:50%;place-items:center;width:136px;height:136px;display:grid;position:relative;box-shadow:0 0 0 12px #7f5af014,0 0 0 32px #7f5af00a,0 15px 50px #00000073}.avatar-shell:after{content:"";filter:blur(10px);background:radial-gradient(circle,#7f5af040,#7f5af000);border-radius:50%;position:absolute;inset:-12px}.avatar-circle{color:#fff;background:linear-gradient(135deg,#7a4bff,#b18cff);border-radius:50%;place-items:center;width:86px;height:86px;display:grid;box-shadow:0 8px 18px #7f5af073}.avatar-circle svg{width:40px;height:40px}#agentTile.speaking .avatar-circle{transition:box-shadow .18s,transform .18s;transform:translateY(-1px);box-shadow:0 8px 18px #7f5af08c,0 0 0 8px #7f5af026}.waveform{align-items:flex-end;gap:6px;height:40px;margin-top:4px;display:flex}.waveform span{opacity:.88;width:7px;height:calc(8px + var(--h,20px));transform-origin:bottom;animation:1.1s ease-in-out infinite alternate bob;animation-delay:calc(-1 * var(--h) / 60);background:#c9b7ff;border-radius:6px}.waveform span:nth-child(odd){opacity:.76}.waveform span:nth-child(4n){animation-duration:1.4s}.waveform span:nth-child(3n){animation-duration:1.2s}#agentTile.speaking .waveform span{opacity:1;animation-duration:.9s}@keyframes bob{0%{transform:scaleY(.55)}50%{transform:scaleY(1)}to{transform:scaleY(.7)}}.agent-name{color:#dfe3ff;letter-spacing:.2px;font-size:.95rem;font-weight:700}.agent-status{color:var(--text-sub);font-size:.85rem}.self-tile{aspect-ratio:16/10;border:1px solid var(--panel-border);background:#0f111c;border-radius:14px;justify-content:center;align-items:center;width:240px;display:flex;position:absolute;bottom:36px;right:36px;overflow:hidden;box-shadow:0 12px 28px #00000073}.self-tile video{object-fit:cover;width:100%;height:100%}.self-tile.speaking{border-color:#60d8a4;box-shadow:0 0 0 8px #60d8a41f,0 12px 28px #00000073}.tile-label{color:#e5e7f5;background:#0000008c;border-radius:10px;align-items:center;gap:6px;padding:6px 10px;font-size:.82rem;display:inline-flex;position:absolute;bottom:10px;left:10px}.cam-off-overlay{background:#111422;flex-direction:column;justify-content:center;align-items:center;gap:10px;display:flex;position:absolute;inset:0}.cam-off-text{color:#7a8199;font-size:.82rem}.tile-avatar{color:#fff;background:#4f46e5;border-radius:50%;place-items:center;width:64px;height:64px;font-size:1.6rem;font-weight:700;display:grid}#transcriptPanel{background:var(--panel);border-left:1px solid var(--panel-border);flex-direction:column;min-width:0;display:flex}.panel-header{color:#d6daf0;border-bottom:1px solid var(--panel-border);justify-content:space-between;align-items:center;padding:16px 18px;font-size:.95rem;display:flex}.status-dot{color:#6be1a6;align-items:center;gap:6px;font-size:.8rem;display:inline-flex}.status-dot:before{content:"";background:#6be1a6;border-radius:50%;width:8px;height:8px;box-shadow:0 0 0 6px #6be1a624}#transcriptFeed{scroll-behavior:smooth;flex-direction:column;flex:1;gap:10px;padding:14px 14px 12px;display:flex;overflow-y:auto}#transcriptFeed::-webkit-scrollbar{width:6px}#transcriptFeed::-webkit-scrollbar-thumb{background:#1f2334;border-radius:8px}.transcript-entry{flex-direction:column;gap:6px;display:flex}.transcript-entry .speaker{letter-spacing:.4px;text-transform:uppercase;color:var(--text-sub);font-size:.78rem;font-weight:700}.transcript-entry.agent .speaker{color:#bba8ff}.transcript-entry.user .speaker{color:#9bc5ff}.transcript-entry .text{color:#f5f7ff;border-radius:14px;max-width:94%;padding:12px 14px;font-size:.93rem;line-height:1.5}.transcript-entry.agent .text{background:var(--bubble-ai)}.transcript-entry.user .text{background:var(--bubble-user);margin-left:auto}.live-indicator{border-top:1px solid var(--panel-border);color:var(--text-sub);min-height:44px;padding:12px 16px;font-size:.86rem}.live-indicator span{color:var(--accent)}#controls{border-top:1px solid var(--panel-border);background:#101220;flex-shrink:0;justify-content:center;align-items:center;gap:14px;padding:14px 22px;display:flex}.ctrl-btn{color:#eef1ff;cursor:pointer;background:#1a1d2c;border:1px solid #22273a;border-radius:50%;place-items:center;width:52px;height:52px;transition:transform .12s,background .12s,box-shadow .12s;display:grid}.ctrl-btn svg{fill:currentColor;width:22px;height:22px}.ctrl-btn:hover{transform:translateY(-1px)}.ctrl-btn.active{background:#4f46e5;border-color:#4f46e5;box-shadow:0 10px 22px #4f46e540}.ctrl-btn.danger{background:#dc2626;border-color:#dc2626;box-shadow:0 10px 22px #dc262640}.ctrl-btn.danger:hover{background:#b91c1c}.ctrl-btn.off{color:#9aa1bd;background:#2b3043}#statusOverlay{z-index:100;background:#0f1117;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:fixed;inset:0}#statusOverlay .spinner{border:3px solid #2a2d3a;border-top-color:#4f46e5;border-radius:50%;width:44px;height:44px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}#statusOverlay p{color:#94a3b8;font-size:.95rem}#statusOverlay .logo-big{color:#a78bfa;margin-bottom:8px;font-size:1.6rem;font-weight:700}#endedScreen{z-index:100;background:#0f1117;flex-direction:column;justify-content:center;align-items:center;gap:14px;display:none;position:fixed;inset:0}#endedScreen h2{color:#a78bfa;font-size:1.5rem}#endedScreen p{color:#94a3b8;font-size:.95rem}#permError{z-index:100;text-align:center;background:#0f1117;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:24px;display:none;position:fixed;inset:0}#permError h2{color:#f87171}#permError p{color:#94a3b8;max-width:400px;line-height:1.6}#permError button{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:8px;margin-top:8px;padding:10px 28px;font-size:.95rem}#expiredScreen{color:#e2e8f0;z-index:9999;text-align:center;background:#0f172acc;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:24px;display:flex;position:fixed;inset:0}#consentScreen{z-index:200;text-align:center;background:#0f1117;flex-direction:column;justify-content:center;align-items:center;gap:20px;padding:32px;display:flex;position:fixed;inset:0}.consent-logo{color:#a78bfa;font-size:1.6rem;font-weight:700}.consent-body{color:#94a3b8;max-width:480px;font-size:.95rem;line-height:1.7}.consent-list{text-align:left;flex-direction:column;gap:8px;margin-top:12px;padding-left:18px;display:flex}.consent-list strong{color:#fff}#consentBtn{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:8px;padding:12px 36px;font-size:1rem;font-weight:600}#consentBtn:hover{background:#4338ca}
