*,:before,:after{box-sizing:border-box}:root{--primary:#4f46e5;--bg:#f3f4f6;--white:#ffffffbf;--border:#fff6;--muted:#6b7280;--text:#111827;--radius:18px;--topbar-h:60px;--tabbar-h:64px;--inputbar-h:68px;--glass-shadow:0 8px 32px 0 #1f268712;--blur:blur(16px);--font-inter:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*{-webkit-tap-highlight-color:transparent;-webkit-user-select:none!important;user-select:none!important;-webkit-touch-callout:none!important}input,textarea{-webkit-user-select:text!important;user-select:text!important}button{-webkit-tap-highlight-color:transparent;touch-action:manipulation}html,body{-webkit-font-smoothing:antialiased;background:var(--bg);height:100dvh;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-inter);background:radial-gradient(circle at 100% 0,#e0e7ff,#f3f4f6 40%,#f9fafb);margin:0;padding:0;overflow:hidden}#root{height:100dvh;overflow:hidden}.app{background:var(--bg);flex-direction:column;height:100dvh;display:flex;overflow:hidden}.topbar{height:var(--topbar-h);background:var(--white);-webkit-backdrop-filter:var(--blur);border-bottom:1px solid var(--border);box-shadow:var(--glass-shadow);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 16px;display:flex}.topbar-left{align-items:center;gap:12px;display:flex}.topbar-name{color:var(--text);font-size:16px;font-weight:600}.topbar-status{color:var(--muted);font-size:12px}.topbar-right{align-items:center;gap:8px;display:flex}.btn-clear{color:#ef4444;background:#ef444414;padding:6px 10px;font-size:15px}.btn-switch{color:var(--primary);cursor:pointer;background:#534ab71a;border:none;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:500}.chat-area{-webkit-overflow-scrolling:touch;background:var(--bg);flex:1;padding:12px 16px;position:relative;overflow-y:auto}.chat-empty{height:100%;color:var(--muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:15px;display:flex}.input-bar{height:var(--inputbar-h);background:var(--white);-webkit-backdrop-filter:var(--blur);border-top:1px solid var(--border);z-index:10;padding:0 12px;padding-bottom:env(safe-area-inset-bottom,0px);flex-shrink:0;align-items:center;gap:8px;display:flex;overflow:hidden;box-shadow:0 -4px 16px #00000005}.input-tools-left,.input-tools-right{flex-shrink:0;align-items:center;gap:4px;display:flex}@keyframes mic-pulse{0%,to{box-shadow:0 4px 20px #ef444480}50%{box-shadow:0 4px 32px #ef4444cc}}.chat-input-mini{border:1.5px solid var(--border);background:var(--bg);width:80px;height:36px;color:var(--text);border-radius:18px;outline:none;padding:0 12px;font-size:14px;transition:border-color .2s}.chat-input-mini:focus{border-color:var(--primary)}.send-btn-main{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:opacity .2s,transform .1s;display:flex}.send-btn-main:disabled{opacity:.4;cursor:not-allowed}.send-btn-main:active:not(:disabled){transform:scale(.92)}.mic-btn-send{background:var(--primary);color:#fff;cursor:pointer;text-overflow:ellipsis;white-space:nowrap;border:none;border-radius:20px;max-width:200px;padding:8px 20px;font-size:14px;font-weight:600;overflow:hidden}.speaking-indicator{color:var(--primary);cursor:pointer;font-size:12px;font-weight:600;animation:1.5s ease-in-out infinite blink-text}@keyframes blink-text{0%,to{opacity:1}50%{opacity:.6}}.btn-muted{opacity:.6}.chat-input{border:1.5px solid var(--border);background:var(--bg);min-width:0;height:40px;color:var(--text);border-radius:20px;outline:none;flex:1;padding:0 14px;font-size:15px;transition:border-color .2s}.chat-input:focus{border-color:var(--primary)}.chat-input::placeholder{color:var(--muted)}.send-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:opacity .2s,transform .1s;display:flex;overflow:hidden}.tab-bar{height:calc(var(--tabbar-h) + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--white);-webkit-backdrop-filter:var(--blur);border-top:1px solid var(--border);z-index:10;flex-shrink:0;display:flex}.tab{color:var(--muted);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:0;font-size:11px;transition:color .2s;display:flex}.tab-active{color:var(--primary)}.tab-icon{font-size:20px;line-height:1}.tab-label{font-weight:500}.msg-row{align-items:flex-end;margin-bottom:12px;display:flex}.msg-user{flex-direction:row-reverse}.msg-agent{flex-direction:row}.avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:600;display:flex}.avatar-sm{width:36px;height:36px;font-size:14px}.avatar-lg{width:56px;height:56px;font-size:22px}.msg-content{flex-direction:column;max-width:75%;display:flex}.msg-user .msg-content{align-items:flex-end}.bubble{word-break:break-word;border-radius:16px;padding:10px 14px;font-size:15px;line-height:1.5}.bubble-user{background:linear-gradient(135deg, var(--primary), #6366f1);color:#fff;border:1px solid #ffffff1a;border-bottom-right-radius:4px;padding:12px 16px;box-shadow:0 4px 12px #4f46e54d}.bubble-agent{-webkit-backdrop-filter:var(--blur);color:var(--text);box-shadow:var(--glass-shadow);background:#ffffffd9;border:1px solid #ffffff80;border-bottom-left-radius:4px;padding:12px 16px}.msg-time{color:var(--muted);margin-top:4px;padding:0 4px;font-size:11px}.typing-bubble{align-items:center;gap:5px;padding:12px 16px;display:flex}.dot{background:var(--primary);border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite both bounce}.dot:nth-child(2){animation-delay:.15s}.dot:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-7px)}}.error-msg{text-align:center;color:#dc2626;background:#fee2e2;border-radius:10px;margin-bottom:12px;padding:8px 16px;font-size:13px}.picker-overlay{z-index:100;background:#0006;align-items:flex-end;display:flex;position:fixed;inset:0}.picker-sheet{background:var(--white);border-radius:20px 20px 0 0;width:100%;max-width:500px;margin:0 auto;padding:12px 20px 32px}.picker-handle{background:var(--border);border-radius:2px;width:36px;height:4px;margin:0 auto 16px}.picker-title{color:var(--text);text-align:center;margin-bottom:16px;font-size:17px;font-weight:600}.picker-item{border:1.5px solid var(--border);cursor:pointer;background:0 0;border-radius:12px;align-items:center;gap:12px;width:100%;margin-bottom:10px;padding:12px;transition:border-color .2s,background .2s;display:flex}.picker-item-active{border-color:var(--primary);background:#534ab70d}.picker-item-info{text-align:left;flex-direction:column;flex:1;display:flex}.picker-item-name{color:var(--text);font-size:15px;font-weight:500}.picker-item-desc{color:var(--muted);font-size:12px}.picker-check{color:var(--primary);font-size:18px;font-weight:600}.picker-cancel{background:var(--bg);width:100%;color:var(--muted);cursor:pointer;border:none;border-radius:12px;margin-top:4px;padding:14px;font-size:15px}.page-header{height:var(--topbar-h);background:var(--white);border-bottom:.5px solid var(--border);flex-shrink:0;align-items:center;padding:0 16px;display:flex}.page-header h2{color:var(--text);font-size:17px;font-weight:600}.page-content{background:var(--bg);flex:1;padding:12px 16px;overflow-y:auto}.card{background:var(--white);border-radius:var(--radius);align-items:center;gap:12px;margin-bottom:10px;padding:14px;display:flex;box-shadow:0 1px 4px #0000000d}.card-btn{text-align:left;cursor:pointer;border:none;width:100%}.card-body{flex-direction:column;flex:1;gap:2px;display:flex}.card-title{color:var(--text);font-size:15px;font-weight:500}.card-meta{color:var(--muted);font-size:12px}.card-icon{font-size:22px}.card-arrow{color:var(--muted);font-size:20px}.avatar-md{flex-shrink:0;width:44px;height:44px;font-size:18px}.badge{border-radius:20px;flex-shrink:0;padding:3px 10px;font-size:12px;font-weight:500}.card-add{border:1.5px dashed var(--border);box-shadow:none;background:#534ab708}.avatar-add{width:44px;height:44px;color:var(--primary);background:#534ab71a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:24px;font-weight:300;display:flex}::-webkit-scrollbar{width:0}.input-action-btn.mic-btn{flex-shrink:0;font-size:16px}.emoji-panel-wrap{bottom:calc(var(--inputbar-h) + 4px);z-index:50;justify-content:center;display:flex;position:absolute;left:0;right:0}.emoji-panel{background:var(--white);border-radius:16px;flex-direction:column;width:calc(100vw - 32px);max-width:400px;max-height:280px;display:flex;overflow:hidden;box-shadow:0 4px 20px #00000026}.emoji-tabs{border-bottom:.5px solid var(--border);flex-shrink:0;gap:2px;padding:8px 8px 4px;display:flex;overflow-x:auto}.emoji-tab{cursor:pointer;white-space:nowrap;color:var(--muted);background:0 0;border:none;border-radius:8px;padding:4px 8px;font-size:11px;transition:background .15s,color .15s}.emoji-tab-active{color:var(--primary);background:#534ab71a;font-weight:600}.emoji-grid{flex:1;grid-template-columns:repeat(8,1fr);gap:2px;padding:8px;display:grid;overflow-y:auto}.emoji-btn{aspect-ratio:1;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:100%;font-size:20px;transition:background .15s;display:flex}.emoji-btn:hover{background:#534ab71a}.file-preview-img{-o-object-fit:cover;object-fit:cover;cursor:pointer;border-radius:12px;max-width:220px;max-height:200px;display:block}.file-card{background:#534ab70f;border:1px solid #534ab726;border-radius:12px;align-items:center;gap:10px;min-width:160px;max-width:260px;padding:10px 12px;display:flex}.file-icon{flex-shrink:0;font-size:28px}.file-info{flex-direction:column;flex:1;min-width:0;display:flex}.file-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:13px;font-weight:500;overflow:hidden}.file-size{color:var(--muted);font-size:11px}.file-download{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:14px;text-decoration:none;display:flex}.ai-file-card{margin-top:8px;display:inline-block}.ai-file-card-inner{background:#534ab70f;border:1px solid #534ab726;border-radius:14px;align-items:center;gap:12px;min-width:180px;max-width:280px;padding:10px 16px;text-decoration:none;transition:all .2s;display:flex;box-shadow:0 1px 4px #534ab714}.ai-file-card-inner:hover{background:#534ab71f;border-color:#534ab74d;transform:translateY(-1px);box-shadow:0 3px 12px #534ab72e}.ai-file-thumb{-o-object-fit:cover;object-fit:cover;border:1px solid #0000000f;border-radius:8px;flex-shrink:0;width:44px;height:44px}.ai-file-icon{flex-shrink:0;font-size:32px}.ai-file-info{flex-direction:column;flex:1;min-width:0;display:flex}.ai-file-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:13px;font-weight:500;overflow:hidden}.ai-file-download-btn{color:#534ab7;margin-top:2px;font-size:12px;font-weight:600}.pending-file-img-wrap{display:inline-block;position:relative}.pending-file-img{-o-object-fit:cover;object-fit:cover;border:2px solid var(--primary);border-radius:12px;max-width:180px;max-height:160px;display:block}.pending-file-card{border:2px solid var(--primary);background:#534ab70f;border-radius:12px;align-items:center;gap:10px;min-width:160px;max-width:260px;padding:10px 12px;display:flex}.pending-remove{color:#fff;cursor:pointer;background:#ef4444;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:11px;line-height:1;display:flex;position:absolute;top:-8px;right:-8px}.pending-file-card .pending-remove{color:#ef4444;background:#ef44441a;border:none;border-radius:50%;flex-shrink:0;width:24px;height:24px;font-size:14px;position:static}.pending-label{color:var(--primary);margin-top:4px;font-size:11px;font-weight:500}.user-avatar-sm{-o-object-fit:cover;object-fit:cover;border-radius:50%;flex-shrink:0;width:28px;height:28px}.avatar-section{align-items:center;gap:16px;width:100%;display:flex}.avatar-upload-btn{cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;position:relative}.avatar-img{-o-object-fit:cover;object-fit:cover;border:3px solid var(--primary);border-radius:50%;width:72px;height:72px;display:block}.avatar-xl{width:72px;height:72px;font-size:28px}.avatar-overlay{background:var(--primary);color:#fff;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;display:flex;position:absolute;bottom:0;right:0}.avatar-hint{flex-direction:column;gap:4px;display:flex}.avatar-hint-title{color:var(--text);margin:0;font-size:15px;font-weight:500}.avatar-hint-desc{color:var(--muted);margin:0;font-size:13px}.avatar-remove{color:#ef4444;cursor:pointer;text-align:left;background:0 0;border:none;margin-top:4px;padding:0;font-size:13px}.voice-card{background:var(--white);border-radius:var(--radius);margin-bottom:10px;padding:16px;box-shadow:0 1px 4px #0000000d}.voice-card-title{color:var(--text);align-items:center;gap:6px;margin:0 0 14px;font-size:15px;font-weight:600;display:flex}.voice-row{margin-bottom:14px}.voice-row:last-child{margin-bottom:0}.voice-row-label{color:var(--muted);justify-content:space-between;align-items:center;margin-bottom:6px;font-size:13px;display:flex}.voice-row-value{color:var(--primary);font-size:13px;font-weight:600}.voice-select{border:1.5px solid var(--border);width:100%;color:var(--text);background:var(--bg);border-radius:8px;outline:none;padding:8px 12px;font-size:13px}.voice-select:focus{border-color:var(--primary)}.voice-slider{width:100%;accent-color:var(--primary);height:4px}.voice-test-btn{border:1.5px solid var(--primary);width:100%;color:var(--primary);cursor:pointer;background:#534ab712;border-radius:10px;padding:10px;font-size:14px;font-weight:600;transition:background .2s}.voice-test-btn:hover{background:#534ab724}.voice-toggle-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.voice-toggle-title{color:var(--text);font-size:14px;font-weight:500}.voice-toggle-desc{color:var(--muted);margin-top:2px;font-size:12px}.voice-toggle-btn{cursor:pointer;background:#d1d5db;border:none;border-radius:14px;flex-shrink:0;width:50px;height:28px;transition:background .2s;position:relative}.voice-toggle-btn.on{background:var(--primary)}.voice-toggle-knob{background:#fff;border-radius:50%;width:22px;height:22px;transition:transform .2s;display:block;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #00000026}.voice-toggle-btn.on .voice-toggle-knob{transform:translate(22px)}.recording-indicator{background:#fee2e2;border:1.5px solid #fca5a5;border-radius:20px;flex:1;align-items:center;gap:8px;height:40px;padding:0 12px;display:flex}.recording-dot{font-size:12px;animation:1s ease-in-out infinite pulse}@keyframes pulse{0%{box-shadow:0 0 #e24b4a66}70%{box-shadow:0 0 0 20px #e24b4a00}to{box-shadow:0 0 #e24b4a00}}.recording-time{color:#dc2626;font-variant-numeric:tabular-nums;font-size:14px;font-weight:600}.recording-stop-btn{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;margin-left:auto;padding:0;font-size:10px;display:flex}.mic-btn{font-size:16px!important}.send-btn.recording{background:#dc2626!important}.speak-btn{cursor:pointer;opacity:.5;background:0 0;border:none;margin-top:2px;padding:2px 4px;font-size:14px;transition:opacity .2s}.speak-btn:hover{opacity:1}[data-theme=dark]{--bg:#1a1a2e;--white:#16213e;--text:#e5e7eb;--muted:#9ca3af;--border:#374151;--primary:#7c6fe3}[data-theme=dark] .chat-area{background:#1a1a2e}[data-theme=dark] .input-bar{background:#16213e;border-color:#374151}[data-theme=dark] .chat-input{color:#e5e7eb;background:#0f3460;border-color:#374151}[data-theme=dark] .bubble-user{background:#7c6fe3}[data-theme=dark] .bubble-agent{background:#16213e;border:1px solid #374151}[data-theme=dark] .card,[data-theme=dark] .tab-bar,[data-theme=dark] .topbar{background:#16213e;border-color:#374151}.voice-bubble{cursor:pointer;align-items:center;gap:8px;min-width:100px;display:flex}.voice-icon{font-size:18px}.voice-text{flex:1;font-size:13px}.voice-duration{opacity:.6;font-size:11px}.voice-msg-bubble{cursor:pointer;border-radius:16px;align-items:center;gap:8px;min-width:120px;max-width:240px;padding:10px 14px;transition:background .2s;display:flex}.voice-msg-bubble:active{opacity:.8}.voice-msg-wave{flex:1;align-items:center;gap:3px;min-width:40px;display:flex}.voice-bar{opacity:.4;transform-origin:50%;background:currentColor;border-radius:2px;width:3px;height:16px}.bubble-user .voice-bar{background:#ffffffb3}.bubble-agent .voice-bar{background:var(--primary);opacity:.4}.bubble-user .voice-bar.playing{background:#fffffff2}.bubble-agent .voice-bar.playing{background:var(--primary);opacity:.9}@keyframes voice-wave{0%{height:6px}50%{height:16px}to{height:6px}}.voice-msg-bubble{cursor:pointer;align-items:center;gap:8px;min-width:100px;max-width:220px;padding:10px 14px;display:flex}.voice-msg-icon{flex-shrink:0;font-size:16px}.voice-msg-wave{flex:1;justify-content:center;align-items:center;gap:3px;display:flex}.voice-bar{opacity:.5;background:currentColor;border-radius:2px;width:3px;height:14px;transition:height .1s}.voice-msg-agent .voice-bar{background:var(--primary)}.voice-msg-user .voice-bar{background:#fff}.voice-bar.playing{opacity:.9;animation:.6s ease-in-out infinite voice-wave}.voice-msg-duration{opacity:.7;font-variant-numeric:tabular-nums;flex-shrink:0;font-size:12px}.voice-msg-agent{background:var(--white);color:var(--text);border-bottom-left-radius:4px}.voice-msg-user{background:var(--primary);color:#fff;border-bottom-right-radius:4px;flex-direction:row-reverse}.voice-transcript{color:var(--text-secondary,#6b7280);word-break:break-all;margin-top:4px;padding:0 4px;font-size:13px;line-height:1.4}.voice-msg-bubble+.voice-transcript{margin-top:2px}.input-tools-left,.input-tools-right{flex-shrink:0;align-items:center;gap:4px;display:flex}.mic-area{flex:1;justify-content:center;align-items:center;min-width:0;display:flex}.input-action-btn{width:36px;height:36px;color:var(--primary);cursor:pointer;background:#534ab714;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;transition:background .2s;display:flex}.input-action-btn:hover{background:#534ab726}.send-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:opacity .2s,transform .1s;display:flex}.send-btn:disabled{opacity:.4;cursor:not-allowed}.send-btn:not(:disabled):active{transform:scale(.95)}.mic-btn-send{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:20px;padding:8px 20px;font-size:14px;font-weight:600}.mic-btn-send:disabled{opacity:.4;cursor:not-allowed}.mic-toggle-btn{font-size:16px}.big-mic-btn{color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;background:linear-gradient(135deg,#534ab7,#7c6fe3);border:none;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:72px;height:72px;transition:transform .15s,box-shadow .15s,background .2s;display:flex;box-shadow:0 4px 16px #534ab766}.big-mic-btn:active,.big-mic-btn.recording{transform:scale(.95)}.big-mic-btn.recording{background:linear-gradient(135deg,#ef4444,#f87171);animation:1s ease-in-out infinite mic-pulse;box-shadow:0 4px 20px #ef444480}.big-mic-btn.auto-listening,.big-mic-btn.auto-listening.recording{background:linear-gradient(135deg,#f59e0b,#fbbf24);animation:1.5s ease-in-out infinite auto-pulse;box-shadow:0 4px 20px #f59e0b80}@keyframes auto-pulse{0%,to{box-shadow:0 4px 20px #f59e0b80}50%{box-shadow:0 4px 32px #f59e0bcc}}.big-mic-btn:disabled{opacity:.5;cursor:not-allowed;animation:none}.mic-icon{font-size:24px;line-height:1}.mic-label{opacity:.9;margin-top:2px;font-size:10px;font-weight:600}.mic-time{opacity:.8;font-variant-numeric:tabular-nums;margin-top:1px;font-size:9px}.page-header{flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 16px 8px;display:flex}.page-header h2{color:var(--text);margin:0;font-size:18px;font-weight:700}.add-agent-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:20px;padding:8px 18px;font-size:14px;font-weight:600;box-shadow:0 2px 8px #534ab74d}.agent-list{flex-direction:column;flex:1;gap:10px;padding:8px 16px 16px;display:flex;overflow-y:auto}.agent-card{border:1px solid var(--border);background:#fff;border-radius:14px;justify-content:space-between;align-items:center;padding:14px 16px;display:flex;box-shadow:0 1px 4px #0000000f}.agent-card-left{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.agent-card-info{flex-direction:column;min-width:0;display:flex}.agent-card-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.agent-card-meta{color:var(--muted);margin-top:2px;font-size:12px}.agent-card-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.agent-badge{white-space:nowrap;border-radius:10px;padding:3px 8px;font-size:11px;font-weight:600}.agent-actions{gap:4px;display:flex}.agent-action-btn{cursor:pointer;background:#0000000a;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:background .15s;display:flex}.agent-action-btn:hover{background:#00000014}.agent-action-btn.agent-delete:hover{background:#fee2e2}.wizard-overlay{z-index:200;background:#0006;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.wizard-sheet{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:480px;max-height:90vh;padding:12px 20px 40px;overflow-y:auto}.wizard-handle{background:#d1d5db;border-radius:2px;width:36px;height:4px;margin:0 auto 16px}.wizard-steps{justify-content:center;gap:0;margin-bottom:24px;display:flex;position:relative}.wizard-steps:before{content:"";z-index:0;background:#e5e7eb;height:2px;position:absolute;top:14px;left:20%;right:20%}.wizard-step{z-index:1;color:var(--muted);flex-direction:column;flex:1;align-items:center;gap:6px;font-size:11px;display:flex;position:relative}.wizard-step.active{color:var(--primary)}.wizard-step.done{color:#10b981}.wizard-step-dot{color:#fff;background:#e5e7eb;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.wizard-step.active .wizard-step-dot{background:var(--primary)}.wizard-step.done .wizard-step-dot{background:#10b981}.wizard-body{animation:.2s slideIn}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.wizard-title{color:var(--text);margin:0 0 6px;font-size:20px;font-weight:700}.wizard-subtitle{color:var(--muted);margin:0 0 20px;font-size:14px}.type-cards{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;display:grid}.type-card{cursor:pointer;text-align:center;background:#fff;border:2px solid #e5e7eb;border-radius:16px;flex-direction:column;align-items:center;gap:4px;padding:20px 16px;transition:border-color .15s,background .15s;display:flex}.type-card:hover{border-color:var(--primary);background:#534ab708}.type-card-icon{margin-bottom:6px;font-size:32px}.type-card-name{color:var(--text);font-size:15px;font-weight:700}.type-card-desc{color:var(--muted);font-size:12px}.type-card-examples{color:var(--primary);margin-top:4px;font-size:11px}.preset-row{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.preset-chip{cursor:pointer;color:var(--text);background:#fff;border:1.5px solid #e5e7eb;border-radius:16px;padding:5px 12px;font-size:13px;transition:all .15s}.preset-chip.active{border-color:var(--primary);color:var(--primary);background:#534ab714;font-weight:600}.wizard-field{margin-bottom:14px;position:relative}.wizard-field label{color:var(--text);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.wizard-field input{box-sizing:border-box;border:1.5px solid #e5e7eb;border-radius:10px;outline:none;width:100%;padding:10px 12px;font-size:14px;transition:border-color .15s}.wizard-field input:focus{border-color:var(--primary)}.field-hint{color:var(--primary);font-size:12px;text-decoration:none;position:absolute;top:0;right:0}.test-result{border-radius:10px;margin-bottom:14px;padding:10px 14px;font-size:13px}.test-result.success{color:#065f46;background:#d1fae5}.test-result.fail{color:#991b1b;background:#fee2e2}.test-result.testing{color:#92400e;background:#fef3c7}.wizard-btns{gap:10px;margin-top:20px;display:flex}.wizard-btn{cursor:pointer;border:none;border-radius:12px;flex:1;padding:12px;font-size:15px;font-weight:600;transition:opacity .15s}.wizard-btn:disabled{opacity:.5;cursor:not-allowed}.wizard-btn.primary{background:var(--primary);color:#fff}.wizard-btn.secondary{color:var(--text);background:#f3f4f6}.wizard-btn.test{color:#fff;background:#7c3aed}.wizard-cancel{color:#6b7280;cursor:pointer;background:#f3f4f6;border:none;border-radius:12px;width:100%;margin-top:10px;padding:12px;font-size:15px}.ollama-loading{color:var(--muted);flex-direction:column;align-items:center;gap:12px;padding:40px;font-size:14px;display:flex}.ollama-spinner{border:3px solid #e5e7eb;border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.ollama-model-grid{grid-template-columns:1fr 1fr;gap:10px;max-height:300px;margin-bottom:20px;display:grid;overflow-y:auto}.ollama-model-card{cursor:pointer;text-align:left;background:#fff;border:2px solid #e5e7eb;border-radius:12px;flex-direction:column;gap:4px;padding:14px;transition:all .15s;display:flex}.ollama-model-card:hover{border-color:var(--primary)}.ollama-model-card.selected{border-color:var(--primary);background:#534ab70d}.ollama-model-name{color:var(--text);word-break:break-all;font-size:13px;font-weight:600}.ollama-model-size{color:var(--muted);font-size:11px}.color-picker-row{margin-bottom:16px}.color-picker-row label{margin-bottom:8px;font-size:13px;font-weight:600;display:block}.color-options{gap:10px;display:flex}.color-dot{cursor:pointer;border:3px solid #0000;border-radius:50%;width:32px;height:32px;transition:transform .15s,border-color .15s}.color-dot.selected{border-color:var(--text);transform:scale(1.15)}.task-status-bar{color:var(--muted);border-bottom:.5px solid var(--border);background:#fff;flex-shrink:0;align-items:center;gap:6px;padding:10px 16px;font-size:12px;display:flex}.task-status-dot{background:#10b981;border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse-green}@keyframes pulse-green{0%,to{box-shadow:0 0 #10b98180}50%{box-shadow:0 0 0 4px #10b98100}}.task-status-sep{color:#d1d5db}.task-list{flex-direction:column;flex:1;gap:10px;padding:12px 16px;display:flex;overflow-y:auto}.task-empty{color:var(--muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.task-empty-icon{margin-bottom:12px;font-size:40px}.task-empty-sub{margin-top:4px;font-size:12px}.task-card{border:1px solid var(--border);background:#fff;border-radius:14px;justify-content:space-between;align-items:center;padding:14px 16px;display:flex;box-shadow:0 1px 4px #0000000f}.task-card-left{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.task-info{flex:1;min-width:0}.task-agent{color:var(--text);margin-bottom:4px;font-size:15px;font-weight:600}.task-meta{color:var(--muted);align-items:center;gap:4px;font-size:12px;display:flex}.task-meta-sep{color:#d1d5db}.task-state{align-items:center;gap:4px;font-weight:500;display:inline-flex}.task-state.running{color:#10b981}.task-state.idle{color:var(--muted)}.running-indicator{border:2px solid #10b981;border-top-color:#0000;border-radius:50%;width:8px;height:8px;animation:.8s linear infinite spin;display:inline-block}.running-indicator.idle{border-color:#0000 #d1d5db #d1d5db;animation:none}.task-tokens{color:var(--muted);margin-top:2px;font-size:11px}.task-card-right{flex-shrink:0}.task-live-badge{color:#10b981;background:#d1fae5;border-radius:6px;padding:2px 6px;font-size:10px;font-weight:700;animation:1.5s ease-in-out infinite pulse-badge}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.6}}.new-mic-btn{cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;touch-action:none;background:#534ab7;border:none;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:72px;height:72px;transition:all .2s;display:flex;position:relative;box-shadow:0 4px 16px #534ab759}.new-mic-btn.recording{background:#e24b4a;animation:1.2s ease-out infinite mic-pulse-new;box-shadow:0 0 #e24b4a66}.new-mic-btn.auto-listening{background:#f59e0b;animation:1.5s ease-out infinite mic-pulse-new;box-shadow:0 0 #f59e0b66}.new-mic-btn:active:not(:disabled){transform:scale(.95)}.new-mic-btn:disabled{opacity:.5;cursor:not-allowed}@keyframes mic-pulse-new{0%{box-shadow:0 0 #e24b4a66}70%{box-shadow:0 0 0 16px #e24b4a00}to{box-shadow:0 0 #e24b4a00}}.new-mic-btn.auto-listening{animation-name:mic-pulse-orange}@keyframes mic-pulse-orange{0%{box-shadow:0 0 #f59e0b66}70%{box-shadow:0 0 0 16px #f59e0b00}to{box-shadow:0 0 #f59e0b00}}.new-mic-btn .mic-label{color:#fff;font-size:10px;font-weight:500}.new-mic-btn .mic-time-rec{color:#fffc;font-variant-numeric:tabular-nums;font-size:9px}.family-overlay{z-index:100;background:#0000008c;justify-content:center;align-items:center;padding:20px;display:flex;position:absolute;inset:0}.family-sheet{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:380px;padding:28px 24px}.family-avatar{margin-bottom:12px;font-size:48px}.family-title{color:var(--text);margin:0 0 6px;font-size:18px;font-weight:700;line-height:1.4}.family-subtitle{color:#888;margin:0 0 20px;font-size:14px}.family-grid{grid-template-columns:1fr 1fr 1fr;gap:10px;display:grid}.family-member-btn{cursor:pointer;background:#f9fafb;border:1px solid #e5e7eb;border-radius:14px;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;transition:all .15s;display:flex}.family-member-btn:hover{border-color:var(--primary);background:#534ab70d}.family-member-emoji{font-size:28px}.family-member-name{color:var(--text);font-size:13px;font-weight:600}.chat-page-wrap{flex-direction:column;height:100%;display:flex;position:relative;overflow:hidden}.recording{animation:1s ease-out infinite pulse}.markdown-body{color:var(--text-primary,#1f2937);word-break:break-word;font-size:15px;line-height:1.7}.markdown-body h1,.markdown-body h2,.markdown-body h3{margin:12px 0 6px;font-weight:600;line-height:1.4}.markdown-body h1{border-bottom:1px solid #e5e7eb;padding-bottom:6px;font-size:18px}.markdown-body h2{font-size:16px}.markdown-body h3{font-size:15px}.markdown-body p{margin:6px 0}.markdown-body ul,.markdown-body ol{margin:6px 0;padding-left:20px}.markdown-body li{margin:4px 0;line-height:1.6}.markdown-body li::marker{color:#534ab7}.markdown-body strong{color:#111827;font-weight:600}.markdown-body em{color:#374151;font-style:italic}.markdown-body code{color:#7c3aed;background:#f3f4f6;border-radius:4px;padding:2px 6px;font-family:SF Mono,Consolas,monospace;font-size:13px}.markdown-body pre{color:#cdd6f4;background:#1e1e2e;border-radius:10px;margin:10px 0;padding:14px 16px;font-size:13px;line-height:1.6;overflow-x:auto}.markdown-body pre code{color:inherit;font-size:inherit;background:0 0;padding:0}.markdown-body blockquote{color:#6b7280;background:#f5f3ff;border-left:3px solid #534ab7;border-radius:0 6px 6px 0;margin:8px 0;padding:4px 12px}.markdown-body table{border-collapse:collapse;border-radius:8px;width:100%;margin:10px 0;font-size:13px;overflow:hidden}.markdown-body th{color:#534ab7;text-align:left;background:#f5f3ff;border-bottom:1px solid #e5e7eb;padding:8px 12px;font-weight:600}.markdown-body td{vertical-align:top;border-bottom:.5px solid #f3f4f6;padding:7px 12px}.markdown-body tr:last-child td{border-bottom:none}.markdown-body tr:nth-child(2n) td{background:#fafafa}.markdown-body img{border-radius:8px;max-width:100%;margin:6px 0}.markdown-body a{color:#534ab7;text-decoration:underline}.markdown-body hr{border:none;border-top:1px solid #e5e7eb;margin:12px 0}.bubble-agent .markdown-body{color:#1f2937}.bubble-agent .markdown-body strong{color:#111827}
