:root{--bg: #0f1724;--fg: #e6eef8;--accent: #7dd3fc}*{box-sizing:border-box}html,body,#root{height:100%;max-width:100%;overflow-x:hidden}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-x:none}a{color:var(--accent)}.app-container{padding:16px}.btn-mic{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:999px;border:none;margin-left:8px;background:linear-gradient(135deg,#1ecfff,#4b7bff);box-shadow:0 0 14px #1ecfffcc;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,filter .12s ease}.btn-mic:hover{transform:translateY(-1px) scale(1.03);box-shadow:0 0 18px #1ecffff2;filter:brightness(1.05)}.btn-mic:active{transform:translateY(0) scale(.97);box-shadow:0 0 8px #1ecfff99}.btn-mic-icon{font-size:18px;line-height:1;color:#02050a}.nossen-mic-btn{background:#fff;border:2px solid #38bdf8;border-radius:50%;color:#222;transition:box-shadow .2s;box-shadow:0 2px 8px #0002}.nossen-mic-btn:hover{border-color:#3c4a6a;background:#1b2135;transform:translateY(-1px)}.nossen-mic-btn.on,.nossen-mic-btn.listening{background:#38bdf8;color:#fff;border-color:#0ea5e9;box-shadow:0 0 14px #1ecfff66}.nossen-mic-btn.listening{animation:nossen-mic-pulse 1.2s infinite}@keyframes nossen-mic-pulse{0%{box-shadow:0 0 #1ecfffcc}70%{box-shadow:0 0 0 10px #1ecfff00}to{box-shadow:0 0 #1ecfff00}}.row{display:flex;margin-bottom:8px}.row.assistant{justify-content:flex-start}.row.user{justify-content:flex-end}.row .bubble{max-width:70%;padding:8px 12px;border-radius:12px;font-size:14px;line-height:1.4}.row.assistant .bubble{background:#111827;color:#e5e7eb;border-top-left-radius:4px}.row.user .bubble{background:#38bdf8;color:#020617;border-top-right-radius:4px}.a11-avatar-wrapper{position:relative;display:inline-block;width:124px;height:124px}.a11-avatar{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;transition:opacity .16s linear}.a11-avatar--visible{opacity:1}.a11-avatar--hidden{opacity:0}#copy-button{position:absolute;top:8px;right:8px;width:32px;height:32px;border:none;background:var(--accent);color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;box-shadow:0 4px 12px #0003}#copy-button:hover{background:#7dd3fce6}@media (max-width: 600px){:root{--bg: #071021}.app-container{padding:12px}.chat-message{font-size:15px;line-height:1.3}}:root{--panel-bg:#0e0f12;--panel:#0f1115;--muted:#8892a6;--border:#1f232b;--accent-2:#2563eb}.app{display:grid;grid-template-columns:280px 1fr;grid-template-rows:auto 1fr auto;height:100vh}.header{grid-column:1/-1;display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--panel);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:2;max-width:100%;overflow-x:clip}.header{display:flex;align-items:center;gap:12px}.header>div,.header>*{display:flex;align-items:center}.header .title{margin-right:8px}.header select,.header .btn,.header .status{vertical-align:middle}.sidebar{border-right:1px solid var(--border);background:#0c0d11;display:flex;flex-direction:column}.sidebar .tools{display:flex;gap:8px;padding:10px;border-bottom:1px solid var(--border);align-items:center}.btn{background:var(--accent);border:0;color:#fff;border-radius:8px;padding:8px 10px;font-weight:600;cursor:pointer;height:36px;line-height:1}.btn.secondary{background:#1b1e27}.btn.ghost{background:transparent;color:#cbd5e1;border:1px solid var(--border);height:36px;line-height:1}.chats{flex:1;overflow:auto}.chat-item{padding:10px 12px;border-bottom:1px solid var(--border);cursor:pointer;display:flex;align-items:center;gap:8px}.chat-item.active{background:#11141a}.chat-item .name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-item .time{color:var(--muted);font-size:12px}.main{display:flex;flex-direction:column;min-width:0;max-width:100%;overflow-x:hidden}.scroll-frame{flex:1;min-height:0;margin:12px;border:1px solid var(--border);border-radius:12px;background:#0d0f13;overflow-y:auto;overflow-x:hidden;box-shadow:0 0 0 1px #0003 inset;overscroll-behavior-x:none;touch-action:pan-y}.log{flex:1;padding:16px;max-width:100%;overflow-x:hidden}.message{max-width:900px;margin:0 auto 14px;padding:12px 14px;border-radius:10px;line-height:1.6;border:1px solid var(--border);overflow-x:hidden;word-break:break-word}.message.user{background:var(--bubble-user)}.message.assistant{background:var(--bubble-ai)}.message .role{font-weight:700;color:#9fb3c8;margin-bottom:6px}.message img{display:block;max-width:100%;height:auto;border-radius:12px;border:1px solid #1f2937;margin-top:10px}.composer{padding:12px;border-top:1px solid var(--border);background:var(--panel)}.composer .row{display:flex;gap:10px;max-width:900px;margin:0 auto;align-items:center;min-width:0;width:100%}.composer textarea{flex:1;min-width:0;width:100%;resize:vertical;max-height:35vh;background:#0d0f13;color:var(--text);border:1px solid var(--border);border-radius:10px;padding:10px}.composer .send{width:44px;display:flex;align-items:center;justify-content:center;font-size:20px;height:40px;padding:8px 12px;border-radius:8px}.hint{font-size:12px;color:var(--muted);text-align:center;margin:4px auto}.attachments{display:flex;flex-wrap:wrap;gap:6px;max-width:900px;margin:6px auto 0}.attachment-chip{background:#141823;border:1px solid var(--border);color:#cbd5e1;border-radius:12px;padding:4px 8px;font-size:12px;display:flex;align-items:center;gap:6px}.attachment-chip .remove{cursor:pointer;color:#f87171}.status{margin-left:auto;color:var(--muted)}.status.ok{color:#13c47f}.status.bad{color:#f97316}.footer{grid-column:1/-1;padding:8px 12px;color:var(--muted);border-top:1px solid var(--border);background:#0c0d11}.a11-avatar{width:200px;height:200px;border-radius:12px;overflow:hidden;position:relative;margin:0 auto}.a11-avatar img{position:absolute;width:100%;height:100%;object-fit:cover;transition:opacity .8s ease-in-out}.import-abs{position:absolute;left:16px;top:12px;z-index:50}.nossen-mic-btn.floating-voice{position:fixed;right:20px;bottom:28px;width:56px;height:56px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:20px;z-index:60;box-shadow:0 8px 28px #0009}.a11-avatar-wrapper img{display:block}@media (max-width: 900px){.app{grid-template-columns:1fr}.sidebar{display:none}.import-abs{left:8px;top:8px}.nossen-mic-btn.floating-voice{right:12px;bottom:16px;width:48px;height:48px}}.import-inline{height:40px;padding:8px 12px;margin-left:4px}.nossen-mic-btn.inline{height:40px;width:40px;padding:0;border-radius:8px}.composer .row textarea{flex:1 1 auto}.composer .row .send-button{margin-left:8px}.import-bottom-left,.import-abs{display:none!important}.composer{padding-bottom:12px}.tts-banner{display:inline-flex;align-items:center;gap:8px;margin-left:12px;color:var(--muted);font-size:12px}.tts-banner .btn.ghost{padding:6px 8px;border-radius:6px}#a11-avatar-idle,#a11-avatar-gif{position:absolute;left:0;top:0;width:124px;height:124px;border-radius:50%;display:block;pointer-events:none;transition:opacity .1s ease-out}#a11-avatar-idle{opacity:1}#a11-avatar-gif{opacity:0}.a11-shell,.a11-body{width:100%;max-width:100%;overflow-x:hidden}.send-button{width:44px;min-width:44px;height:44px;border-radius:10px;border:1px solid #1f2937;background:linear-gradient(135deg,#38bdf8,#60a5fa);color:#04131c;font-size:18px;font-weight:700;cursor:pointer}.send-button:disabled{opacity:.45;cursor:not-allowed}.image-preview-trigger{display:inline-flex;flex-direction:column;gap:8px;padding:0;border:none;background:transparent;cursor:zoom-in;text-align:left;color:inherit}.image-preview-trigger:hover span,.image-preview-trigger:focus-visible span{color:#bfdbfe!important;text-decoration:underline}.image-preview-trigger:focus-visible{outline:2px solid #60a5fa;outline-offset:4px;border-radius:12px}.image-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#020617d6;display:flex;align-items:center;justify-content:center;padding:20px}.image-preview-modal{position:relative;max-width:min(96vw,1200px);max-height:92vh;display:flex;align-items:center;justify-content:center}.image-preview-modal-image{display:block;max-width:100%;max-height:92vh;width:auto;height:auto;border-radius:16px;border:1px solid #334155;box-shadow:0 24px 80px #0000008c;background:#020617}.image-preview-close{position:absolute;top:12px;right:12px;width:40px;height:40px;border-radius:999px;border:1px solid #334155;background:#0f172ae6;color:#e2e8f0;font-size:24px;line-height:1;cursor:pointer}@media (max-width: 900px){html,body,#root{overflow-y:hidden;overflow-x:hidden;width:100%;max-width:100%;overscroll-behavior-x:none}.header{gap:10px;width:100%;max-width:100%}.main{overflow:hidden}.scroll-frame{margin:8px!important;border-radius:10px}.log{padding:12px}.message{max-width:100%;margin:0 0 10px;padding:10px 12px}.message .role{font-size:12px;margin-bottom:4px}.composer{padding:8px 10px calc(10px + env(safe-area-inset-bottom))}.composer .row{gap:8px;align-items:flex-end;max-width:none;min-width:0;width:100%}.composer textarea{min-width:0;width:100%;min-height:48px;max-height:20vh;resize:none;font-size:16px;line-height:1.45;padding:12px}.hint,.footer{display:none}}
