*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#111827;display:flex;flex-direction:column;height:100vh;color:#f3f4f6}.key-panel{background:#1f2937;border-bottom:1px solid #374151;padding:10px 24px;display:flex;align-items:center;gap:10px;flex-shrink:0}.key-label{font-size:13px;color:#9ca3af;white-space:nowrap}.key-input{flex:1 1;padding:7px 12px;border:1.5px solid #374151;border-radius:8px;font-size:13px;font-family:monospace;outline:none;min-width:0;background:#111827;color:#f3f4f6;transition:border-color .15s}.key-input:focus{border-color:#ef4444}.key-btn{background:#b91c1c;color:white;border:none;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.key-btn:hover{background:#991b1b}.key-btn-cancel{background:#374151}.key-btn-cancel:hover{background:#4b5563}.hint-bar{background:#1f2937;border-bottom:1px solid #374151;padding:8px 24px;font-size:13px;color:#9ca3af;display:flex;gap:16px;flex-wrap:wrap;align-items:center;flex-shrink:0}.hint-bar button{background:none;border:none;color:#ef4444;cursor:pointer;font-size:13px;padding:0;font-family:inherit}.hint-bar button:hover{text-decoration:underline}.chat{flex:1 1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:16px}.message{display:flex;gap:12px;max-width:760px}.message.user{align-self:flex-end;flex-direction:row-reverse}.bubble-wrap{display:flex;flex-direction:column;gap:4px;max-width:640px}.translation{font-size:12px;font-style:italic;color:#6b7280;padding:0 4px}.translation.user{text-align:right}.avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.message.user .avatar{background:#7f1d1d}.message.assistant .avatar{background:#1f2937}.bubble{padding:12px 16px;border-radius:16px;line-height:1.6;font-size:15px}.message.user .bubble{background:#b91c1c;color:white;border-bottom-right-radius:4px}.message.assistant .bubble{background:#1f2937;border:1px solid #374151;border-bottom-left-radius:4px;color:#f3f4f6}.bubble p{margin-bottom:8px}.bubble p:last-child{margin-bottom:0}.bubble strong{font-weight:600}.bubble .correction{background:#1c1917;border-left:3px solid #ef4444}.bubble .correction,.bubble .tip{padding:8px 12px;margin:8px 0;border-radius:0 8px 8px 0;font-size:14px}.bubble .tip{background:#0c1a2e;border-left:3px solid #3b82f6}.typing-indicator{display:flex;gap:4px;padding:4px 0;align-items:center}.typing-indicator span{width:8px;height:8px;background:#4b5563;border-radius:50%;animation:bounce 1.2s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}footer{background:#1f2937;border-top:1px solid #374151;padding:16px 24px;flex-shrink:0}.input-row{display:flex;gap:10px;align-items:flex-end}.input-wrapper{flex:1 1;position:relative;background:#111827;border-radius:12px}.ghost-overlay{position:absolute;top:0;left:0;right:0;bottom:0;padding:12px 16px;border:2px solid transparent;border-radius:12px;font-size:15px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;white-space:pre-wrap;word-break:break-word;overflow:hidden;pointer-events:none}.ghost-text{color:#4b5563}.input-row textarea{width:100%;padding:12px 16px;border:2px solid #374151;border-radius:12px;font-size:15px;resize:none;min-height:48px;max-height:140px;outline:none;font-family:inherit;line-height:1.5;background:transparent;color:#f3f4f6;transition:border-color .15s;position:relative;z-index:1}.input-row textarea:focus{border-color:#ef4444}.input-row textarea::placeholder{color:#4b5563}.send-btn{background:#b91c1c;color:white;border:none;border-radius:12px;padding:12px 20px;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s,transform .1s;white-space:nowrap}.send-btn:hover{background:#991b1b}.send-btn:active{transform:scale(.97)}.send-btn:disabled{background:#374151;cursor:not-allowed;transform:none}.input-hint{margin-top:6px;display:flex;justify-content:space-between;align-items:center}.change-key-btn,.input-hint{font-size:12px;color:#4b5563}.change-key-btn{background:none;border:none;cursor:pointer;font-family:inherit;padding:0}.change-key-btn:hover{color:#9ca3af}.welcome{text-align:center;padding:40px 20px;color:#6b7280}.welcome .emoji{font-size:48px;margin-bottom:16px}.welcome h2{font-size:20px;color:#e5e7eb;margin-bottom:8px}.welcome p{font-size:14px;line-height:1.7;max-width:400px;margin:0 auto}.starter-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:20px}.chip{background:#1f2937;border:1px solid #374151;border-radius:20px;padding:8px 16px;font-size:13px;cursor:pointer;transition:all .15s;color:#9ca3af;font-family:inherit}.chip:hover{border-color:#ef4444;color:#ef4444;background:#1c0a0a}.suggestions{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.suggestion-chip{background:#1f2937;border:1px solid #374151;border-radius:16px;padding:4px 12px;font-size:13px;cursor:pointer;color:#9ca3af;font-family:inherit;transition:all .15s}.suggestion-chip:hover{border-color:#ef4444;color:#ef4444;background:#1c0a0a}.ghost-hint{font-size:11px;color:#6b7280;background:#1f2937;border:1px solid #374151;border-radius:6px;padding:3px 7px;font-family:monospace;align-self:center}