:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;--ink: #f5f3ec;--muted: #aeb7bd;--panel: #111821;--panel-strong: #18222d;--line: rgba(255, 255, 255, .12);--teal: #2ac6a6;--coral: #ff6b57;--gold: #f0b84f;--sky: #7dd8ff}*{box-sizing:border-box}html,body,#app{width:100%;height:100%;margin:0}body{min-width:320px;overflow:hidden;background:linear-gradient(135deg,#19222cf5,#0b0e13fa),repeating-linear-gradient(90deg,rgba(255,255,255,.03) 0 1px,transparent 1px 92px);color:var(--ink)}button,textarea{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:progress;opacity:.65}.game-shell{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,430px);width:100%;height:100%}.stage{position:relative;min-width:0;overflow:hidden;background:linear-gradient(180deg,#151d2666,#090c11e0),linear-gradient(115deg,rgba(42,198,166,.12),transparent 42%),linear-gradient(245deg,rgba(240,184,79,.14),transparent 46%)}.stage:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:54px 54px;-webkit-mask-image:linear-gradient(to bottom,transparent,black 16%,black 76%,transparent);mask-image:linear-gradient(to bottom,transparent,black 16%,black 76%,transparent);pointer-events:none}.avatar-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.stage-topbar{position:absolute;z-index:2;top:28px;left:28px;right:28px;display:flex;align-items:flex-start;justify-content:space-between;gap:18px;pointer-events:none}.eyebrow{margin:0 0 7px;color:var(--gold);font-size:.76rem;font-weight:800;text-transform:uppercase}h1,h2{margin:0;letter-spacing:0}h1{max-width:12ch;font-size:clamp(2.15rem,6vw,5.1rem);line-height:.94}h2{font-size:1rem;line-height:1.2}.status-pill,.stage-readout{display:inline-flex;align-items:center;gap:9px;min-height:36px;border:1px solid var(--line);border-radius:8px;background:#0b0e13ad;box-shadow:0 18px 44px #00000040;color:var(--ink);font-size:.9rem;font-weight:800;white-space:nowrap}.status-pill{padding:0 12px}.status-dot{width:9px;height:9px;border-radius:50%;background:var(--muted)}.status-pill[data-state=connecting] .status-dot{background:var(--gold)}.status-pill[data-state=connected] .status-dot{background:var(--teal);box-shadow:0 0 18px var(--teal)}.status-pill[data-state=error] .status-dot{background:var(--coral)}.stage-readout{position:absolute;z-index:2;left:28px;bottom:28px;padding:0 13px}.stage-readout span+span{color:var(--sky)}.control-panel{display:flex;min-width:0;min-height:0;flex-direction:column;gap:18px;border-left:1px solid var(--line);background:linear-gradient(180deg,#111821fa,#0a0d12fa),linear-gradient(90deg,rgba(255,107,87,.08),transparent);padding:24px}.section-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:13px}.section-heading .eyebrow{margin-bottom:4px}.role-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.role-button{display:grid;min-height:82px;grid-template-rows:auto 1fr;gap:10px;border:1px solid var(--line);border-radius:8px;background:#ffffff0b;color:var(--ink);padding:10px;text-align:left}.role-button.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 18%,rgba(255,255,255,.05))}.role-swatch{display:block;width:18px;height:18px;border-radius:50%;background:var(--accent);box-shadow:0 0 22px color-mix(in srgb,var(--accent) 75%,transparent)}.role-button strong,.role-button small{display:block;overflow-wrap:anywhere}.role-button strong{font-size:.9rem;line-height:1.05}.role-button small{margin-top:4px;color:var(--muted);font-size:.76rem}.voice-section{display:grid;grid-template-columns:1fr auto;gap:8px}.primary-action,.secondary-action,.send-button,.starter-chip{min-height:42px;border-radius:8px;transition:transform .16s ease,border-color .16s ease,background .16s ease}.primary-action:hover,.secondary-action:hover,.send-button:hover,.starter-chip:hover,.role-button:hover{transform:translateY(-1px)}.primary-action{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--ink);color:#10141b;font-weight:900}.primary-action.active{background:var(--coral);color:#180d0a}.button-icon{font-size:.76rem}.secondary-action,.starter-chip{border:1px solid var(--line);background:#ffffff0e;color:var(--ink);font-weight:800}.secondary-action{padding:0 14px}.starter-list{display:flex;flex-wrap:wrap;gap:8px}.starter-chip{max-width:100%;padding:0 12px;color:#dceef1;font-size:.86rem}.chat-log{display:flex;min-height:0;flex:1;flex-direction:column;gap:10px;overflow-y:auto;padding-right:4px}.message{width:min(92%,34rem);border:1px solid var(--line);border-radius:8px;padding:11px 12px;background:#ffffff0e}.message.user{align-self:flex-end;border-color:#7dd8ff59;background:#7dd8ff1f}.message.assistant{align-self:flex-start;border-color:#2ac6a647}.message.system{width:100%;border-color:#f0b84f42;background:#f0b84f14;color:#f6dca5}.message-speaker{display:block;margin-bottom:6px;color:var(--muted);font-size:.74rem;font-weight:900;text-transform:uppercase}.message p{margin:0;color:var(--ink);font-size:.94rem;line-height:1.45;overflow-wrap:anywhere}.message.system p{color:#f6dca5}.composer{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;padding-top:2px}textarea{min-height:52px;max-height:130px;resize:vertical;border:1px solid var(--line);border-radius:8px;outline:0;background:#00000038;color:var(--ink);line-height:1.35;padding:12px}textarea:focus{border-color:var(--sky);box-shadow:0 0 0 3px #7dd8ff1f}.send-button{align-self:stretch;min-width:76px;padding:0 14px;background:var(--teal);color:#06120f;font-weight:900}@media (max-width: 980px){body{overflow:auto}.game-shell{min-height:100%;grid-template-columns:1fr;grid-template-rows:minmax(460px,55vh) minmax(520px,auto)}.control-panel{border-left:0;border-top:1px solid var(--line)}h1{font-size:3rem}}@media (max-width: 560px){.game-shell{grid-template-rows:minmax(390px,48vh) minmax(560px,auto)}.stage-topbar{top:16px;left:16px;right:16px}h1{max-width:9ch;font-size:2.2rem}.status-pill{min-height:32px;padding:0 9px;font-size:.8rem}.stage-readout{left:16px;bottom:16px;max-width:calc(100% - 32px);flex-wrap:wrap;white-space:normal}.control-panel{padding:16px}.role-list{grid-template-columns:1fr}.role-button{min-height:62px;grid-template-columns:auto 1fr;grid-template-rows:1fr;align-items:center}.voice-section,.composer{grid-template-columns:1fr}.secondary-action,.send-button{min-height:44px}}
