*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{color:#333;background:#ededed;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}.auth-page{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;height:100%;display:flex}.auth-card{text-align:center;background:#fff;border-radius:12px;width:380px;max-width:90vw;padding:40px 36px;box-shadow:0 8px 32px #00000026}.auth-card h1{margin-bottom:4px;font-size:28px}.auth-card h2{color:#666;margin-bottom:24px;font-size:18px;font-weight:400}.auth-card form{flex-direction:column;gap:14px;display:flex}.auth-card input{border:1px solid #ddd;border-radius:8px;outline:none;padding:12px 14px;font-size:15px;transition:border .2s}.auth-card input:focus{border-color:#667eea}.auth-card button{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:8px;padding:12px;font-size:16px;transition:background .2s}.auth-card button:hover{background:#5a6fd6}.auth-card button:disabled{opacity:.6;cursor:default}.auth-card .error{color:#e74c3c;font-size:14px}.auth-card .link{color:#888;margin-top:16px;font-size:14px}.auth-card .link a{color:#667eea;text-decoration:none}.role-page{max-width:800px;margin:40px auto;padding:0 20px}.role-page h2{text-align:center;margin-bottom:6px}.role-page .subtitle{text-align:center;color:#888;margin-bottom:28px;font-size:14px}.role-page-actions{justify-content:center;margin-bottom:20px;display:flex}.btn-interaction-entry{color:#fff;cursor:pointer;background:#007f73;border:none;border-radius:999px;padding:10px 18px;font-size:14px;transition:filter .2s,transform .15s}.btn-interaction-entry:hover{filter:brightness(.95);transform:translateY(-1px)}.role-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.role-card{cursor:pointer;background:#fff;border-radius:12px;padding:20px;transition:transform .15s,box-shadow .15s;position:relative;box-shadow:0 2px 8px #0000000f}.role-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000001f}.btn-clear-conversations{cursor:pointer;opacity:0;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:16px;transition:opacity .15s;position:absolute;top:8px;right:8px}.role-card:hover .btn-clear-conversations{opacity:.6}.btn-clear-conversations:hover{background:#e74c3c1a;opacity:1!important}.role-avatar{background:#f0eef5;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 12px;display:flex;overflow:hidden}.role-avatar img{object-fit:cover;width:100%;height:100%}.avatar-placeholder{color:#764ba2;font-size:28px;font-weight:600}.role-info h3{text-align:center;margin-bottom:6px;font-size:16px}.role-info p{color:#888;text-align:center;font-size:13px}.role-meta{color:#aaa;justify-content:center;gap:8px;margin-top:8px;font-size:12px;display:flex}.chat-layout{flex-direction:column;height:100%;display:flex;overflow:hidden}.chat-topbar{color:#eee;background:#2e2e2e;flex-shrink:0;align-items:center;gap:8px;padding:6px 14px;display:flex}.topbar-title{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;font-weight:500;overflow:hidden}.chat-topbar .btn-icon{color:#ccc}.chat-topbar .btn-icon:hover{background:#ffffff26}.chat-body{flex:1;display:flex;overflow:hidden}.chat-touch-side{background:#fff;border-right:1px solid #e0e0e0;flex-direction:column;flex-shrink:0;width:38%;max-width:380px;display:flex;overflow:hidden}.chat-touch-side .touch-panel{flex:1}.chat-touch-side .touch-panel__stage{height:100%}.btn-icon{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;font-size:18px;transition:background .2s}.btn-icon:hover{background:#0000000f}.chat-main{background:#f5f5f5;flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.touch-panel{flex-direction:column;flex:1;display:flex;overflow:hidden}.touch-panel--empty{color:#aaa;text-align:center;justify-content:center;align-items:center;padding:20px;font-size:13px}.touch-panel__status{color:#007f73;text-align:center;background:#f0fdf6;flex-shrink:0;padding:4px 10px;font-size:12px}.touch-panel__status--error{color:#c62828;background:#fff0f0}.touch-panel--cooldown .touch-panel__stage{opacity:.7;pointer-events:none;transition:opacity .3s}.touch-panel__cooldown-hint{color:#e65100;text-align:center;background:#fff3e0;flex-shrink:0;padding:4px 10px;font-size:12px;animation:1.2s ease-in-out infinite cooldown-pulse}@keyframes cooldown-pulse{0%,to{opacity:1}50%{opacity:.5}}.touch-ripple{pointer-events:none;background:#ffffff80;border-radius:50%;width:40px;height:40px;margin-top:-20px;margin-left:-20px;animation:.5s ease-out forwards ripple-expand;position:absolute}@keyframes ripple-expand{0%{opacity:1;transform:scale(0)}to{opacity:0;transform:scale(3)}}.excitement-bar{background:#e8e8e8;flex-shrink:0;height:18px;position:relative;overflow:visible}.excitement-bar__fill{background:linear-gradient(90deg,#ffc107 0%,#ff5722 60%,#e91e63 100%);border-radius:0 4px 4px 0;height:100%;transition:width .15s ease-out}.excitement-bar__marker{pointer-events:none;background:#00000080;width:2px;height:100%;position:absolute;top:0;transform:translate(-1px)}.excitement-bar__marker:after{content:"";border-top:5px solid #00000080;border-left:4px solid #0000;border-right:4px solid #0000;width:0;height:0;position:absolute;top:-4px;left:-3px}.excitement-bar__label{color:#333;pointer-events:none;font-size:11px;font-weight:600;line-height:18px;position:absolute;top:0;right:6px}.touch-panel__stage{touch-action:manipulation;background:#fff;flex:1;position:relative;overflow:hidden}.touch-panel__stage img{object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none;width:100%;height:100%;display:block}.messages{flex-direction:column;flex:1;gap:16px;padding:20px;display:flex;overflow-y:auto}.empty-hint{text-align:center;color:#aaa;margin:auto}.empty-hint .small{margin-top:6px;font-size:13px}.empty-hint .link{color:#667eea;cursor:pointer;text-decoration:underline}.msg{gap:10px;max-width:75%;display:flex}.msg.user{flex-direction:row-reverse;align-self:flex-end}.msg.assistant{align-self:flex-start}.msg-avatar{flex-shrink:0;font-size:28px}.msg-bubble{word-break:break-word;white-space:pre-wrap;border-radius:10px;padding:10px 14px;font-size:15px;line-height:1.6}.msg.user .msg-bubble{color:#000;background:#95ec69;border-top-right-radius:2px}.msg.assistant .msg-bubble{background:#fff;border-top-left-radius:2px;box-shadow:0 1px 2px #0000000f}.msg-time{color:#00000073;margin-top:6px;font-size:12px}.typing{gap:4px;display:flex;padding:12px 18px!important}.typing span{background:#999;border-radius:50%;width:8px;height:8px;animation:1.4s infinite both blink}.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,80%,to{opacity:.3}40%{opacity:1}}.input-bar{background:#fff;border-top:1px solid #e0e0e0;gap:10px;padding:12px 16px;display:flex}.input-bar textarea{resize:none;border:1px solid #ddd;border-radius:8px;outline:none;flex:1;max-height:120px;padding:10px 14px;font-family:inherit;font-size:15px;transition:border .2s}.input-bar textarea:focus{border-color:#95ec69}.input-bar button{color:#fff;cursor:pointer;background:#07c160;border:none;border-radius:8px;padding:0 20px;font-size:20px;transition:background .2s}.input-bar button:hover{background:#06ad56}.input-bar button:disabled{cursor:default;background:#ccc}@media (width<=768px){.msg{max-width:90%}.chat-body{flex-direction:column}.chat-touch-side{border-bottom:1px solid #e0e0e0;border-right:none;width:100%;max-width:none;max-height:35vh}}@media (width<=500px){.chat-touch-side{max-height:30vh}.input-bar{gap:6px;padding:8px 10px}.input-bar textarea{padding:8px 10px;font-size:14px}}.btn-voice{cursor:pointer;background:#f0f0f0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:20px;transition:background .2s,transform .15s;display:flex}.btn-voice:hover{background:#e0e0e0}.btn-voice--recording{color:#fff;background:#f44;animation:1s infinite pulse-recording}@keyframes pulse-recording{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.btn-auto-play{cursor:pointer;background:#f0f0f0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:background .2s;display:flex}.btn-auto-play--on{background:#d4edda}.btn-immersive{cursor:pointer;background:#f0f0f0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:background .2s;display:flex}.btn-immersive--on{background:#ffe8c2}.btn-streaming-asr{cursor:pointer;background:#f0f0f0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:background .2s;display:flex}.btn-streaming-asr--on{background:#fcc;animation:1.5s infinite asr-pulse}@keyframes asr-pulse{0%,to{box-shadow:0 0 #ff3c3c66}50%{box-shadow:0 0 0 6px #ff3c3c00}}.asr-status{color:#555;background:#f8f9fa;border-radius:8px;align-items:center;gap:8px;margin:4px 12px 0;padding:6px 14px;font-size:13px;display:flex}.asr-status--speaking{color:#d63031;background:#fff0f0}.asr-status--processing{color:#e17055}.asr-partial{color:#333;text-overflow:ellipsis;white-space:nowrap;flex:1;font-style:italic;overflow:hidden}.textarea--asr-partial{font-style:italic;color:#999!important}.chat-layout--immersive{z-index:1200;background:#111;position:fixed;inset:0}.chat-layout--immersive .chat-topbar{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#141414eb}.chat-layout--immersive .chat-body{flex-direction:column}.chat-layout--immersive .chat-touch-side{background:#111;border-bottom:none;border-right:none;width:100%;max-width:none;height:100%;max-height:none}.chat-layout--immersive .chat-main{pointer-events:none;background:0 0;position:absolute;bottom:0;left:0;right:0}.immersive-voice-hint{pointer-events:none;color:#fef3d0;background:#00000073;border-radius:999px;align-self:center;margin-bottom:8px;padding:6px 10px;font-size:12px}.immersive-voice-bar{pointer-events:auto;justify-content:center;padding:8px 0 16px;display:flex}.btn-voice--immersive{background:#fffffff2;width:64px;height:64px;font-size:28px;box-shadow:0 10px 30px #00000047}.chat-layout--immersive .voice-error{pointer-events:auto;border-radius:8px;margin:0 16px 10px}.btn-replay-audio{cursor:pointer;opacity:.6;background:0 0;border:none;padding:2px 4px;font-size:16px;transition:opacity .15s}.btn-replay-audio:hover{opacity:1}.voice-error{color:#856404;text-align:center;background:#fff3cd;padding:6px 16px;font-size:13px}.imm-root{background:#0a0a0f;flex-direction:column;font-family:Segoe UI,system-ui,-apple-system,sans-serif;display:flex;position:fixed;inset:0;overflow:hidden}.imm-character-bg{z-index:0;justify-content:center;align-items:flex-end;display:flex;position:absolute;inset:0;overflow:hidden}.imm-character-img{object-fit:contain;object-position:center bottom;-webkit-user-select:none;user-select:none;pointer-events:none;filter:drop-shadow(0 0 40px #b48cff26);width:100%;height:100%;animation:4s ease-in-out infinite imm-breathe}@keyframes imm-breathe{0%,to{transform:scale(1)translateY(0)}50%{transform:scale(1.008)translateY(-2px)}}.imm-character-placeholder{color:#ffffff4d;flex-direction:column;align-items:center;gap:12px;font-size:14px;display:flex}.imm-character-placeholder span{font-size:64px}.imm-touch-layer{z-index:1;position:absolute;inset:0}.imm-touch-layer .touch-panel{background:0 0;width:100%;height:100%}.imm-touch-layer .touch-panel__stage{background:0 0;height:100%}.imm-touch-layer .touch-panel__stage img{opacity:0}.imm-touch-layer .excitement-bar{z-index:5;background:#ffffff0d;height:4px;position:absolute;bottom:0;left:0;right:0}.imm-voice-glow{pointer-events:none;z-index:2;opacity:0;height:120px;transition:opacity .6s;position:absolute;bottom:0;left:0;right:0}.imm-voice-glow--listening{opacity:1;background:radial-gradient(80% 100% at 50% 100%,#ffb4641f 0%,#0000 70%)}.imm-voice-glow--speaking{opacity:1;background:radial-gradient(80% 100% at 50% 100%,#ff783c40 0%,#ff507814 50%,#0000 70%);animation:1.2s ease-in-out infinite imm-glow-pulse}@keyframes imm-glow-pulse{0%,to{opacity:1;transform:scaleY(1)}50%{opacity:.7;transform:scaleY(1.15)}}.imm-hud-top{z-index:10;background:linear-gradient(#00000080 0%,#0000 100%);align-items:center;gap:6px;padding:8px 12px;display:flex;position:relative}.imm-spacer{flex:1}.imm-btn{-webkit-backdrop-filter:blur(8px);color:#ffffffd9;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:16px;transition:background .25s,transform .15s;display:flex}.imm-btn:hover{background:#fff3;transform:scale(1.08)}.imm-btn--active{background:#64ffb433}.imm-btn--asr-on{background:#ff50504d;animation:1.8s infinite imm-asr-ring}@keyframes imm-asr-ring{0%,to{box-shadow:0 0 #ff505066}50%{box-shadow:0 0 0 8px #ff505000}}.imm-bottom{z-index:10;pointer-events:none;background:linear-gradient(#0000 0%,#00000059 40%,#000000a6 100%);flex-direction:column;max-height:35vh;padding:0 16px 12px;display:flex;position:absolute;bottom:0;left:0;right:0}.imm-bottom>*{pointer-events:auto}.imm-asr-partial{-webkit-backdrop-filter:blur(12px);color:#ffc878e6;text-overflow:ellipsis;white-space:nowrap;background:#ffffff14;border-radius:20px;align-self:center;align-items:center;gap:8px;max-width:80%;margin-bottom:8px;padding:6px 16px;font-size:13px;font-style:italic;display:flex;overflow:hidden}.imm-asr-dot{background:#ff6b4a;border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:1s infinite imm-dot-blink}@keyframes imm-dot-blink{0%,to{opacity:1}50%{opacity:.3}}.imm-messages{flex-direction:column;gap:6px;margin-bottom:10px;display:flex;overflow:hidden}.imm-msg{align-items:flex-end;gap:6px;max-width:85%;animation:.4s ease-out imm-msg-in;display:flex}@keyframes imm-msg-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.imm-msg--user{align-self:flex-end}.imm-msg--assistant{align-self:flex-start}.imm-msg-text{word-break:break-word;white-space:pre-wrap;-webkit-backdrop-filter:blur(16px)saturate(1.4);background:#ffffff1a;border:1px solid #ffffff14;border-radius:16px;padding:8px 14px;font-size:14px;line-height:1.55}.imm-msg--user .imm-msg-text{color:#ffffffeb;background:#64c88c2e;border-color:#64c88c1f}.imm-msg--assistant .imm-msg-text{color:#fffffff2;background:#ffffff14;border-color:#ffffff0f}.imm-msg-replay{color:#ffffffb3;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;transition:background .2s;display:flex}.imm-msg-replay:hover{background:#fff3}.imm-typing{-webkit-backdrop-filter:blur(12px);background:#ffffff14;border:1px solid #ffffff0f;border-radius:16px;gap:4px;padding:10px 16px;display:flex}.imm-typing span{background:#ffffff80;border-radius:50%;width:7px;height:7px;animation:1.4s infinite both imm-typing-blink}.imm-typing span:nth-child(2){animation-delay:.2s}.imm-typing span:nth-child(3){animation-delay:.4s}@keyframes imm-typing-blink{0%,80%,to{opacity:.3;transform:scale(.85)}40%{opacity:1;transform:scale(1)}}.imm-input-bar{-webkit-backdrop-filter:blur(20px)saturate(1.3);background:#ffffff12;border:1px solid #ffffff14;border-radius:24px;align-items:center;gap:8px;padding:8px 12px;display:flex}.imm-input-bar textarea{color:#ffffffe6;resize:none;background:0 0;border:none;outline:none;flex:1;max-height:80px;padding:4px 0;font-family:inherit;font-size:14px}.imm-input-bar textarea::placeholder{color:#ffffff4d}.imm-input-btn{color:#fffc;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:background .2s;display:flex}.imm-input-btn:hover{background:#fff3}.imm-input-btn:disabled{opacity:.3;cursor:default}.imm-input-btn--rec{background:#ff3c3c66;animation:1s infinite pulse-recording}.imm-error{text-align:center;color:#ffc107;background:#ffc1071a;border-radius:12px;margin-top:6px;padding:6px 12px;font-size:12px}.imm-input-toggle{-webkit-backdrop-filter:blur(12px);color:#fff6;cursor:pointer;background:#ffffff14;border:none;border-radius:20px;align-self:center;padding:8px 20px;font-size:13px;transition:background .2s,color .2s}.imm-input-toggle:hover{color:#ffffffb3;background:#ffffff26}@media (width<=500px){.imm-bottom{padding:0 10px 8px;padding-bottom:max(8px, env(safe-area-inset-bottom))}.imm-msg-text{padding:6px 10px;font-size:13px}.imm-input-bar{padding:6px 8px}.imm-hud-top{padding-top:max(8px, env(safe-area-inset-top))}}.interaction-page{max-width:1100px;margin:24px auto;padding:0 16px 22px}.interaction-header{margin-bottom:14px}.interaction-header h2{color:#152738;margin-bottom:8px;font-size:28px}.interaction-header p{color:#4d6070;margin:0;font-size:14px}.interaction-toolbar{flex-wrap:wrap;align-items:end;gap:10px;margin-bottom:14px;display:flex}.interaction-toolbar label{color:#4d6070;flex-direction:column;flex:1;gap:4px;min-width:270px;font-size:13px;display:flex}.interaction-toolbar input{border:1px solid #ced6dd;border-radius:10px;padding:10px 12px;font-size:14px}.interaction-toolbar button{color:#fff;cursor:pointer;background:#007f73;border:none;border-radius:10px;padding:11px 16px;font-size:14px}.interaction-toolbar button:hover{filter:brightness(.95)}.interaction-toolbar button.secondary{background:#455a64}.interaction-toolbar button.primary{background:#007f73}.toolbar-checkbox{color:#203241;background:#eef3f6;border:1px solid #d4dee6;border-radius:10px;align-items:center;gap:6px;padding:10px 12px;font-size:14px;display:inline-flex}.toolbar-checkbox input{width:16px;height:16px}.import-input-hidden{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.interaction-stage-wrap{background:linear-gradient(145deg,#f4f8fa 0%,#e8eef2 100%);border:1px solid #d9e2e8;border-radius:14px;padding:14px}.interaction-stage{touch-action:manipulation;background:#fff;border-radius:12px;width:min(720px,100%);margin:0 auto;position:relative;overflow:hidden}.interaction-stage.marking{outline:3px dashed #007f73}.interaction-stage.marking .hotspot{cursor:grab}.interaction-stage.marking .hotspot.dragging{cursor:grabbing}.interaction-stage img{-webkit-user-select:none;user-select:none;pointer-events:none;width:100%;height:auto;display:block}.hotspot{color:#003c36;cursor:pointer;background:#007f7326;border:2px solid #007f73f2;border-radius:999px;justify-content:center;align-items:center;transition:transform .12s,background .12s;display:flex;position:absolute;transform:translate(-50%,-50%)}.hotspot span{white-space:nowrap;color:#fff;background:#003c36;border-radius:999px;padding:2px 8px;font-size:12px;position:absolute;top:-26px;left:50%;transform:translate(-50%)}.hotspot:hover{background:#007f7342;transform:translate(-50%,-50%)scale(1.05)}.hotspot.active{animation:.36s hotspot-pulse}@keyframes hotspot-pulse{0%{transform:translate(-50%,-50%)scale(1)}50%{transform:translate(-50%,-50%)scale(1.12)}to{transform:translate(-50%,-50%)scale(1)}}.interaction-footer{gap:8px;margin-top:14px;display:grid}.interaction-footer .status{color:#203241;font-size:14px}.interaction-footer .error{color:#c62828;font-size:14px}.hotspot-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.hotspot-list li{background:#f3f7fa;border:1px solid #dce6ec;border-radius:10px;flex-wrap:wrap;align-items:center;gap:10px;padding:8px 10px;display:flex}.hotspot-list li span{color:#203241;font-weight:600}.hotspot-list li small{color:#5f7384;flex:1;font-size:12px}.hotspot-list .danger{color:#fff;cursor:pointer;background:#cd3c3c;border:none;border-radius:8px;padding:6px 10px}@media (width<=640px){.interaction-page{margin:12px auto;padding:0 10px 14px}.interaction-header h2{font-size:24px}.interaction-toolbar{gap:8px}.interaction-toolbar button,.interaction-toolbar input{width:100%}.interaction-toolbar label{width:100%;min-width:0}.hotspot span{font-size:11px;top:-24px}}
