*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}:root{--bg-primary:#0b141a;--bg-chat:#0b141a;--bg-header:#1f2c34;--bg-input:#1f2c34;--bg-msg-user:#005c4b;--bg-msg-ai:#1f2c34;--text-primary:#e9edef;--text-secondary:#8696a0;--accent:#00a884;--accent-hover:#06cf9c;--border:#2a3942;--code-bg:#111b21;--safe-bottom:env(safe-area-inset-bottom,0px)}html{height:100%;-webkit-text-size-adjust:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow:hidden;-webkit-font-smoothing:antialiased}.app,body{height:100%;height:100dvh}.app{display:flex;flex-direction:column;max-width:900px;margin:0 auto}.header{gap:12px;padding:max(10px,env(safe-area-inset-top,10px)) 16px 10px;background:var(--bg-header);border-bottom:1px solid var(--border);z-index:10}.header,.header-avatar{display:flex;align-items:center;flex-shrink:0}.header-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#00d4aa);justify-content:center;font-size:1.1rem;font-weight:700;color:#fff;transition:box-shadow .3s ease}.header-avatar--speaking{box-shadow:0 0 15px var(--accent);animation:speaking-pulse 1.5s infinite}@keyframes speaking-pulse{0%{transform:scale(1);box-shadow:0 0 10px rgba(0,168,132,.5)}50%{transform:scale(1.05);box-shadow:0 0 20px rgba(0,168,132,.8)}to{transform:scale(1);box-shadow:0 0 10px rgba(0,168,132,.5)}}.header-info h1{font-size:1rem;font-weight:600;color:var(--text-primary);line-height:1.2}.header-status{font-size:.75rem;color:var(--text-secondary);display:flex;align-items:center;gap:5px;line-height:1.2;transition:color .3s}.header-status--active{color:#f59e0b}.status-dot{width:7px;height:7px;border-radius:50%;background:var(--text-secondary);display:inline-block;flex-shrink:0;transition:background .3s}.header-status--active .status-dot{background:#f59e0b;animation:pulse-dot 1.5s infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.status-timer{background:rgba(245,158,11,.15);color:#f59e0b;padding:1px 6px;border-radius:8px;font-size:.65rem;font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.chat-area{flex:1 1;overflow-y:auto;overflow-x:hidden;padding:12px;display:flex;flex-direction:column;gap:4px;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");-webkit-overflow-scrolling:touch}.chat-area::-webkit-scrollbar{width:4px}.chat-area::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.message{max-width:88%;padding:8px 12px;border-radius:10px;font-size:.9rem;line-height:1.55;position:relative;animation:msgIn .25s ease-out;word-wrap:break-word;overflow-wrap:break-word}@keyframes msgIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.message-user{background:var(--bg-msg-user);align-self:flex-end;border-bottom-right-radius:3px}.message-ai{background:var(--bg-msg-ai);align-self:flex-start;border-bottom-left-radius:3px}.message-time{font-size:.6rem;color:var(--text-secondary);text-align:right;margin-top:3px}.message-ai .msg-name{font-size:.7rem;color:var(--accent);font-weight:600;margin-bottom:2px}.message pre{background:var(--code-bg);border:1px solid var(--border);border-radius:8px;padding:10px;margin:8px 0;overflow-x:auto;font-size:.78rem;line-height:1.45;-webkit-overflow-scrolling:touch}.message code,.message pre{font-family:JetBrains Mono,Fira Code,Courier New,monospace}.message code{font-size:.8rem}.message p code{background:var(--code-bg);padding:2px 6px;border-radius:4px;font-size:.8rem}.message p{margin-bottom:6px}.message p:last-child{margin-bottom:0}.message ol,.message ul{padding-left:18px;margin:4px 0}.message li{margin-bottom:2px}.message strong{color:#fff}.typing-container{align-self:flex-start;animation:msgIn .25s ease-out}.typing-container .msg-name{font-size:.7rem;color:var(--accent);font-weight:600;margin-bottom:4px}.typing{display:flex;gap:5px;padding:12px 16px;background:var(--bg-msg-ai);border-radius:10px;border-bottom-left-radius:3px}.typing span{width:8px;height:8px;border-radius:50%;background:var(--text-secondary);animation:bounce 1.4s ease-in-out infinite}.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}.typing-label{font-size:.65rem;color:var(--text-secondary);margin-top:4px;padding-left:4px}.input-area{display:flex;align-items:flex-end;gap:8px;padding:8px 12px;padding-bottom:max(8px,var(--safe-bottom));background:var(--bg-input);border-top:1px solid var(--border);flex-shrink:0}.input-area textarea{flex:1 1;background:var(--bg-primary);border:1px solid var(--border);border-radius:22px;padding:11px 16px;color:var(--text-primary);font-family:Inter,sans-serif;font-size:16px;resize:none;outline:none;max-height:120px;min-height:44px;line-height:1.4;transition:border-color .2s;-webkit-appearance:none}.input-area textarea:focus{border-color:var(--accent)}.input-area textarea::placeholder{color:var(--text-secondary)}.attach-btn,.mic-btn,.send-btn{width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .1s;flex-shrink:0;-webkit-appearance:none}.attach-btn{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.attach-btn:hover{background:var(--code-bg)}.attach-btn:active{transform:scale(.92)}.attach-btn:disabled{opacity:.4;cursor:not-allowed}.attach-btn svg{fill:var(--text-secondary);width:20px;height:20px}.attachment-preview{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-header);border-top:1px solid var(--border);font-size:.8rem;animation:msgIn .2s ease-out}.attachment-icon{font-size:1.2rem;flex-shrink:0}.attachment-name{color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1;min-width:0}.attachment-size{color:var(--text-secondary);font-size:.7rem;flex-shrink:0}.attachment-remove{background:rgba(239,68,68,.15);color:#ef4444;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.7rem;flex-shrink:0;transition:background .2s}.attachment-remove:hover{background:rgba(239,68,68,.3)}.send-btn{background:var(--accent)}.send-btn:hover{background:var(--accent-hover)}.send-btn:active{transform:scale(.92)}.send-btn:disabled{opacity:.4;cursor:not-allowed}.send-btn svg{fill:#fff;width:20px;height:20px}.mic-btn{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.mic-btn:hover{background:var(--code-bg)}.mic-btn svg{fill:var(--text-secondary);width:22px;height:22px}.mic-btn--recording{background:rgba(239,68,68,.1);border-color:#ef4444;animation:recording-pulse 1.5s infinite}.mic-stop-icon{width:14px;height:14px;background-color:#ef4444;border-radius:2px}@keyframes recording-pulse{0%{box-shadow:0 0 0 0 rgba(239,68,68,.4)}70%{box-shadow:0 0 0 10px rgba(239,68,68,0)}to{box-shadow:0 0 0 0 rgba(239,68,68,0)}}.send-spinner{width:20px;height:20px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.send-btn--stop{background:transparent;border:1px solid var(--border)}.send-btn--stop:hover{background:var(--code-bg)}.stop-icon{width:14px;height:14px;background-color:var(--text-secondary);border-radius:2px}.welcome{text-align:center;padding:60px 24px 40px;color:var(--text-secondary);display:flex;flex-direction:column;align-items:center;gap:4px}.welcome-icon{font-size:2.8rem;margin-bottom:8px}.welcome h2{font-size:1.4rem;color:var(--text-primary);font-weight:700}.welcome p{font-size:.85rem}.welcome-hint{margin-top:8px;font-size:.8rem;color:var(--text-secondary);max-width:280px}@media (max-width:480px){.header{padding:8px 12px;gap:10px}.header-avatar{width:38px;height:38px;font-size:1rem}.header-info h1{font-size:.95rem}.chat-area{padding:8px;gap:3px}.message{max-width:92%;padding:7px 10px;font-size:.88rem;border-radius:8px}.message pre{font-size:.72rem;padding:8px}.input-area{padding:6px 8px;gap:6px}.input-area textarea{padding:10px 14px;border-radius:20px}.mic-btn,.send-btn{width:42px;height:42px}.welcome{padding:40px 20px 30px}.welcome-icon{font-size:2.2rem}.welcome h2{font-size:1.2rem}}@media (max-width:360px){.message{max-width:95%;font-size:.84rem}.header-info h1{font-size:.88rem}.header-status{font-size:.68rem}}.login-screen{display:flex;align-items:center;justify-content:center;height:100vh;height:100dvh;background:var(--bg-primary);padding:20px}.login-box{background:var(--bg-header);padding:40px 30px;border-radius:16px;border:1px solid var(--border);width:100%;max-width:360px;text-align:center;box-shadow:0 10px 30px rgba(0,0,0,.5);animation:msgIn .3s ease-out}.login-icon{font-size:3rem;margin-bottom:16px}.login-box h2{font-size:1.4rem;color:var(--text-primary);margin-bottom:8px}.login-box p{font-size:.9rem;color:var(--text-secondary);margin-bottom:24px}.login-box form{display:flex;flex-direction:column;gap:16px}.login-box input{background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;padding:14px;color:var(--text-primary);font-size:1rem;outline:none;transition:border-color .2s;text-align:center}.login-box input:focus{border-color:var(--accent)}.login-box button{background:var(--accent);color:#fff;border:none;padding:14px;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.login-box button:hover{background:var(--accent-hover)}