:root{--bg:#000;--ink:rgba(246,246,242,.94);--detail:rgba(246,246,242,.82);--muted:rgba(246,246,242,.72);--faint:rgba(246,246,242,.55);--hair:rgba(246,246,242,.12);--soft:rgba(246,246,242,.05);--sans:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Helvetica Neue",sans-serif;--serif:"Iowan Old Style","New York",Georgia,serif;--ease:cubic-bezier(.2,.7,.2,1)}*{box-sizing:border-box}html,body{margin:0;width:100%;height:100%;overflow:hidden;background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased}#root,#app{width:100%;height:100%}#app{opacity:1;transition:opacity .6s var(--ease)}#app.booting{opacity:0}.scene{position:relative;width:100%;height:100%;display:grid;grid-template-columns:minmax(280px,26%) 1fr}.side{position:relative;z-index:3;display:flex;flex-direction:column;min-height:0;padding:38px 30px 30px 48px;gap:22px}.about{flex:0 0 auto}.eyebrow{font-size:9.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--faint)}.profile-name{margin:8px 0 4px;font-family:var(--serif);font-weight:500;font-size:26px;line-height:1.05;letter-spacing:-.01em}.scene-label{margin:0 0 16px;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.about-grid{margin:0;padding:14px 0 0;border-top:1px solid var(--hair);display:flex;flex-direction:column;gap:10px}.about-row{display:grid;grid-template-columns:58px 1fr;gap:10px;align-items:start}.about-row dt{margin:0;font-size:9px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);padding-top:2px}.about-row dd{margin:0;font-size:12.5px;line-height:1.5;color:var(--detail)}.transcript{flex:1 1 auto;min-height:0;overflow-y:auto;padding:18px 0;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);display:flex;flex-direction:column;gap:16px;scrollbar-width:thin}.transcript::-webkit-scrollbar{width:6px}.transcript::-webkit-scrollbar-thumb{background:var(--soft);border-radius:3px}.line b{display:block;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);margin-bottom:4px}.line p{margin:0;font-size:14px;line-height:1.5}.line.you p{color:var(--muted)}.line.them p{color:var(--ink)}.talkbar{flex:0 0 auto;display:flex;align-items:center;gap:16px}.speak{appearance:none;border:1px solid var(--hair);background:var(--soft);color:var(--ink);font-family:var(--sans);font-size:13px;letter-spacing:.02em;padding:12px 30px;border-radius:999px;cursor:pointer;transition:all .25s var(--ease)}.speak:hover{border-color:#f6f6f259}.speak:disabled{opacity:.4;cursor:default}.speak.live{border-color:#78c8ffb3;background:#78c8ff14;animation:pulse 1.1s ease-in-out infinite}.speak.think{border-color:#ffdc7899;background:#ffdc780f}.speak.speak-out{border-color:#ffffff8c;background:#ffffff14}@keyframes pulse{0%,to{box-shadow:0 0 #ffffff2e}50%{box-shadow:0 0 0 8px #fff0}}.voice-status{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);min-width:120px}.voice-status.phase-listening{color:#78c8ffd9}.voice-status.phase-thinking{color:#ffdc78e6}.voice-status.phase-speaking{color:#ffffffbf}.portrait-stage{position:relative;width:100%;height:100%;min-width:0;overflow:hidden;background:radial-gradient(ellipse 140% 90% at 50% 100%,rgba(25,30,38,.4) 0%,transparent 60%),transparent;border:0;cursor:grab}#portrait-canvas{display:block;width:100%;height:100%;object-fit:cover}.portrait-stage:active{cursor:grabbing}.nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:44px;height:44px;background:0;border:0;cursor:pointer;opacity:.4;transition:opacity .25s var(--ease)}.nav:hover{opacity:.9}.nav.prev{left:16px}.nav.next{right:16px}.nav span{position:absolute;top:50%;left:50%;width:13px;height:13px;border-left:1px solid var(--ink);border-bottom:1px solid var(--ink)}.nav.prev span{transform:translate(-40%,-50%) rotate(45deg)}.nav.next span{transform:translate(-60%,-50%) rotate(-135deg)}.nope{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;gap:14px;max-width:520px;margin:auto;padding:40px;text-align:center}.nope .h{font-size:13px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}.nope p{font-size:13px;line-height:1.6;color:var(--muted)}@media(max-width:760px){.scene{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.portrait-stage{grid-row:1}.side{grid-row:2;padding:20px 24px}.nav.prev{left:8px}.nav.next{right:8px}}