:root{--bg: #0a0a0f;--panel: #0f0f17;--bar: #15151f;--line: #23232f;--them: #1c1c27;--text: #ececf1;--muted: #8a8a99;--accent1: #8b5cf6;--accent2: #ec4899;--me: #7c4dff;--ok: #34d399;--danger: #fb7185;--grad: linear-gradient(135deg, var(--accent1), var(--accent2));--radius: 14px;--shadow: 0 30px 80px rgba(0, 0, 0, .55);font-synthesis:none}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;height:100dvh;margin:0}body{background:radial-gradient(1200px 600px at 50% -10%,#171428 0%,var(--bg) 55%);color:var(--text);font:15px/1.45 -apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;overscroll-behavior:none}button,input,textarea{font:inherit;color:var(--text)}button{cursor:pointer}::-webkit-scrollbar{width:7px}::-webkit-scrollbar-thumb{background:#262633;border-radius:8px}.btn{border:0;border-radius:12px;padding:12px 16px;font-weight:700;color:#fff;background:var(--grad);transition:transform .12s,opacity .15s;box-shadow:0 10px 30px #7c4dff59}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:default;transform:none}.btn-ghost{background:var(--bar);box-shadow:none;border:1px solid var(--line)}.icon-btn{width:42px;height:42px;border-radius:50%;border:0;background:transparent;color:var(--text);display:grid;place-items:center;transition:background .15s}.icon-btn:hover{background:#ffffff14}.avatar{border-radius:50%;flex:none;background:var(--grad);color:#fff;font-weight:800;display:grid;place-items:center}.input{width:100%;padding:13px 15px;border-radius:12px;border:1px solid var(--line);background:#13131d;outline:none;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--accent1);box-shadow:0 0 0 3px #8b5cf62e}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;background:#08080eb8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;animation:fade .18s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.app-frame{position:relative;width:min(460px,100vw);height:min(820px,100vh);height:min(820px,100dvh);margin:auto;background:var(--panel);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}.app-root{height:100%;display:flex;align-items:center;justify-content:center}@media (max-width: 480px){.app-root{height:100dvh}.app-frame{width:100vw;height:100vh;height:100dvh;border:0;border-radius:0;box-shadow:none}body{overflow:hidden}input,textarea,select,.input,.composer-input{font-size:16px}}.chat{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;min-height:0;background:var(--panel)}.chat-header{flex:none;display:flex;align-items:center;gap:11px;padding:10px 12px;background:var(--bar);border-bottom:1px solid var(--line)}.chat-id{flex:1;min-width:0}.chat-name{font-weight:700;font-size:15.5px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-status{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);line-height:1.3}.chat-status-typing{color:var(--accent1);font-style:italic}.status-dot{width:7px;height:7px;border-radius:50%;background:var(--muted);flex:none}.status-dot.on{background:var(--ok);box-shadow:0 0 0 3px #34d3992e}.chat-actions{display:flex;align-items:center;gap:2px;flex:none}.chat-actions .icon-btn{width:38px;height:38px}.chat-scroll{flex:1;min-height:0;overflow-y:auto;padding:14px 12px 8px;display:flex;flex-direction:column;gap:8px}.msg-row{display:flex;width:100%}.msg-row.mine{justify-content:flex-end}.msg-row.theirs{justify-content:flex-start}.msg-row.grouped{margin-top:-5px}.bubble{position:relative;max-width:78%;padding:8px 12px 7px;border-radius:16px;font-size:14.5px;line-height:1.4;word-wrap:break-word;overflow-wrap:anywhere;white-space:pre-wrap;animation:bubbleIn .22s cubic-bezier(.22,1,.36,1)}@keyframes bubbleIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}.bubble-me{background:var(--grad);color:#fff;border-bottom-right-radius:5px;box-shadow:0 6px 18px #7c4dff47}.msg-row.grouped.mine .bubble-me{border-top-right-radius:16px}.bubble-them{background:var(--them);color:var(--text);border-bottom-left-radius:5px}.msg-row.grouped.theirs .bubble-them{border-top-left-radius:16px}.bubble-text{display:inline}.bubble-meta{display:inline-flex;align-items:center;gap:4px;margin-left:8px;float:right;position:relative;top:6px;font-size:10.5px;-webkit-user-select:none;user-select:none}.bubble-time{opacity:.7}.bubble-me .bubble-time{color:#fff}.bubble-them .bubble-time{color:var(--muted)}.bubble-tick{opacity:.85;font-size:10.5px}.bubble-tick.failed{color:var(--danger);opacity:1}.bubble.typing{display:inline-flex;align-items:center;gap:4px;padding:12px 14px}.bubble.typing .dot{width:6px;height:6px;border-radius:50%;background:var(--muted);animation:typingBounce 1.2s infinite ease-in-out}.bubble.typing .dot:nth-child(2){animation-delay:.15s}.bubble.typing .dot:nth-child(3){animation-delay:.3s}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.45}30%{transform:translateY(-4px);opacity:1}}.chat-empty{align-items:center;justify-content:center;text-align:center;gap:6px;color:var(--muted)}.chat-empty-art{font-size:44px;margin-bottom:8px;opacity:.9;filter:drop-shadow(0 6px 18px rgba(124,77,255,.35))}.chat-empty-title{font-size:17px;font-weight:700;color:var(--text)}.chat-empty-sub{font-size:13px}.composer{flex:none;display:flex;align-items:flex-end;gap:9px;padding:10px 12px calc(10px + env(safe-area-inset-bottom,0px));background:var(--bar);border-top:1px solid var(--line)}.composer-input{flex:1;resize:none;max-height:120px;min-height:44px;padding:11px 15px;border-radius:22px;border:1px solid var(--line);background:#13131d;outline:none;line-height:1.4;transition:border-color .15s,box-shadow .15s}.composer-input:focus{border-color:var(--accent1);box-shadow:0 0 0 3px #8b5cf62e}.composer-input::placeholder{color:#55556a}.composer-send{flex:none;width:44px;height:44px;border-radius:50%;border:0;background:var(--grad);color:#fff;display:grid;place-items:center;box-shadow:0 8px 22px #7c4dff59;transition:transform .12s,opacity .15s}.composer-send:hover:not(:disabled){transform:translateY(-1px)}.composer-send:active:not(:disabled){transform:translateY(0)}.composer-send:disabled{opacity:.45;cursor:default;box-shadow:none}.call{align-items:center;padding:18px 16px calc(18px + env(safe-area-inset-bottom));background:radial-gradient(900px 500px at 50% 8%,#1b1530,#08080eeb 60%)}.call-top{width:100%;display:flex;justify-content:center;padding-top:6px}.call-timer{font-variant-numeric:tabular-nums;color:var(--muted);font-size:13px;letter-spacing:.04em}.call-stage{display:flex;flex-direction:column;align-items:center;gap:14px;margin-top:22px}.call-name{font-size:22px;font-weight:800;letter-spacing:.01em}.call-status{color:var(--muted);font-size:14px;min-height:18px;text-align:center}.call-status-err{color:var(--danger)}.orb{position:relative;width:200px;height:200px;display:grid;place-items:center;margin:6px 0 2px}.orb-ring{position:absolute;width:150px;height:150px;border-radius:50%;background:var(--grad);filter:blur(2px);transition:transform .12s ease-out,opacity .2s ease-out;will-change:transform,opacity}.orb-ring-1{width:168px;height:168px}.orb-core{position:relative;border-radius:50%;transition:transform .1s ease-out,box-shadow .12s ease-out;will-change:transform,box-shadow}.orb-core .avatar{width:140px;height:140px;font-size:56px;border:3px solid rgba(255,255,255,.08)}.orb-speaking .orb-core{animation:orbBreathe 2.4s ease-in-out infinite}@keyframes orbBreathe{0%,to{filter:brightness(1)}50%{filter:brightness(1.12)}}.ct-list{flex:1;width:100%;max-width:420px;overflow-y:auto;margin:18px 0;padding:4px;display:flex;flex-direction:column;gap:8px;-webkit-mask-image:linear-gradient(to bottom,transparent 0,#000 24px);mask-image:linear-gradient(to bottom,transparent 0,#000 24px)}.ct-empty{flex:1;display:grid;place-items:center;color:var(--muted);font-size:14px}.ct-row{display:flex}.ct-user{justify-content:flex-end}.ct-myra{justify-content:flex-start}.ct-bubble{max-width:80%;padding:9px 13px;border-radius:14px;font-size:14px;line-height:1.4;white-space:pre-wrap;word-break:break-word}.ct-user .ct-bubble{background:var(--me);color:#fff;border-bottom-right-radius:5px}.ct-myra .ct-bubble{background:var(--them);color:var(--text);border-bottom-left-radius:5px}.ct-streaming .ct-bubble{opacity:.85}.call-controls{display:flex;gap:28px;align-items:center;padding:10px 0 6px}.call-btn{width:62px;height:62px;border-radius:50%;border:1px solid var(--line);background:var(--bar);color:var(--text);display:grid;place-items:center;transition:background .15s,transform .12s,opacity .15s}.call-btn:hover{background:#ffffff14;transform:translateY(-1px)}.call-btn:active{transform:translateY(0)}.call-btn:disabled{opacity:.45;cursor:default;transform:none}.call-btn-on{background:var(--grad);border-color:transparent;color:#fff}.call-btn-end{background:var(--danger);border-color:transparent;color:#fff;box-shadow:0 10px 30px #fb718559}.call-btn-end:hover{background:#f9576f}@media (max-height: 720px){.call-stage{margin-top:10px;gap:8px}.orb{width:150px;height:150px;margin:2px 0}.orb-ring{width:118px;height:118px}.orb-ring-1{width:132px;height:132px}.orb-core .avatar{width:104px;height:104px;font-size:42px}.call-name{font-size:19px}.ct-list{margin:12px 0}.call-btn{width:56px;height:56px}.call-controls{gap:22px}}.persona-head{display:flex;align-items:center;gap:10px;padding:16px 16px 12px;border-bottom:1px solid var(--line)}.persona-head h2{margin:0;font-size:17px;font-weight:700;flex:1}.persona-body{flex:1;overflow-y:auto;padding:16px}.persona-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.persona-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;border-radius:var(--radius);cursor:pointer;background:var(--bar);border:1px solid var(--line);text-align:center;transition:border-color .15s,transform .12s,background .15s;animation:popIn .22s ease both}.persona-card:hover{transform:translateY(-2px);background:var(--them)}.persona-card.active{border-color:var(--accent1);box-shadow:0 0 0 3px #8b5cf62e;background:var(--them)}.persona-card .name{font-weight:700;font-size:14.5px}.persona-card .nature{color:var(--muted);font-size:12px}.persona-section{margin-top:22px}.persona-section h3{margin:0 0 10px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.voice-row{display:flex;flex-wrap:wrap;gap:8px}.voice-chip{padding:8px 14px;border-radius:999px;font-size:13px;font-weight:600;background:var(--bar);border:1px solid var(--line);color:var(--text);transition:border-color .15s,background .15s}.voice-chip:hover{background:var(--them)}.voice-chip.active{border-color:var(--accent1);background:var(--them);box-shadow:0 0 0 2px #8b5cf62e}.romantic-toggle{display:flex;align-items:flex-start;gap:12px;margin-top:8px;padding:14px;border-radius:var(--radius);background:var(--bar);border:1px solid var(--line);cursor:pointer}.romantic-toggle input{margin-top:3px;width:18px;height:18px;accent-color:var(--accent2);flex:none}.romantic-toggle .label{font-weight:600;font-size:14px}.romantic-toggle .hint{color:var(--muted);font-size:12px;margin-top:2px}.romantic-badge{display:inline-block;margin-left:8px;padding:1px 7px;border-radius:999px;font-size:10.5px;font-weight:800;color:#fff;background:var(--accent2);vertical-align:middle}.persona-foot{padding:14px 16px;border-top:1px solid var(--line)}.memory-head{display:flex;align-items:center;gap:10px;padding:16px 16px 12px;border-bottom:1px solid var(--line)}.memory-head h2{margin:0;font-size:17px;font-weight:700;flex:1}.memory-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.memory-card{padding:14px;border-radius:var(--radius);background:var(--bar);border:1px solid var(--line);animation:popIn .22s ease both;transition:opacity .2s}.memory-card.pinned{border-color:var(--accent1);box-shadow:0 0 0 2px #8b5cf624}.memory-card .content{font-size:14px;line-height:1.5}.memory-tags{display:flex;gap:6px;margin-bottom:8px;flex-wrap:wrap}.memory-tag{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:2px 8px;border-radius:999px;color:var(--muted);background:var(--them);border:1px solid var(--line)}.memory-tag.pin{color:#fff;background:var(--grad);border:0}.memory-actions{display:flex;gap:6px;margin-top:12px}.memory-action{flex:1;padding:7px 10px;border-radius:10px;font-size:12.5px;font-weight:600;background:transparent;border:1px solid var(--line);color:var(--muted);transition:background .15s,color .15s,border-color .15s}.memory-action:hover{background:var(--them);color:var(--text)}.memory-action.danger:hover{color:var(--danger);border-color:var(--danger)}.memory-action.active{color:var(--accent1);border-color:var(--accent1)}.memory-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--muted);text-align:center;padding:40px}.memory-empty .emoji{font-size:32px;opacity:.7}.memory-toast{position:absolute;left:50%;bottom:24px;transform:translate(-50%);background:var(--bar);border:1px solid var(--line);color:var(--text);padding:9px 16px;border-radius:999px;font-size:12.5px;z-index:30;box-shadow:var(--shadow);animation:fade .18s ease}
