*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{margin:0;overflow:hidden;background:#000;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#fff;-webkit-font-smoothing:antialiased}canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0}.loading-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;background:#000}.loading-brand{font-size:28px;font-weight:700;letter-spacing:6px;color:#fff;animation:brandGlow 2.5s ease-in-out infinite}@keyframes brandGlow{0%,to{text-shadow:0 0 8px rgba(167,139,250,.15);opacity:.7}50%{text-shadow:0 0 24px rgba(167,139,250,.4),0 0 48px rgba(167,139,250,.2);opacity:1}}.loading-wave{display:flex;align-items:center;gap:4px;height:28px}.loading-wave span{display:block;width:3px;border-radius:2px;background:#a78bfa;animation:wave 1.2s ease-in-out infinite}.loading-wave span:nth-child(1){height:8px;animation-delay:0s}.loading-wave span:nth-child(2){height:16px;animation-delay:.1s}.loading-wave span:nth-child(3){height:24px;animation-delay:.2s}.loading-wave span:nth-child(4){height:16px;animation-delay:.3s}.loading-wave span:nth-child(5){height:8px;animation-delay:.4s}@keyframes wave{0%,to{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}.loading-quote{font-size:13px;color:#ffffff80;letter-spacing:2px;animation:quoteFade 3s ease-in-out infinite}@keyframes quoteFade{0%,to{opacity:.3}50%{opacity:.7}}.chat-overlay{position:fixed;bottom:0;left:0;width:100%;max-height:40vh;z-index:10;display:flex;flex-direction:column}.messages{flex:1;overflow-y:auto;padding:12px 16px;background:transparent;display:flex;flex-direction:column;gap:8px;-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 20%);mask-image:linear-gradient(to bottom,transparent 0%,black 20%)}.bubble{max-width:75%;padding:9px 13px;border-radius:4px;font-size:15px;line-height:1.5;word-break:break-word;animation:fadeInUp .2s ease-out;position:relative}.bubble.user{align-self:flex-end;background:#07c160;color:#fff;border-radius:4px}.bubble.assistant{align-self:flex-start;background:#fff;color:#333;border-radius:4px}.input-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;padding-bottom:max(8px,env(safe-area-inset-bottom));background:#f5f5f5}.chat-input{flex:1;height:36px;padding:0 12px;border:none;border-radius:4px;background:#fff;color:#333;font-size:15px;outline:none}.chat-input::placeholder{color:#0000004d}.chat-input:focus{background:#fff;box-shadow:0 0 0 1px #0000001a}.send-btn{height:36px;padding:0 16px;border:none;border-radius:4px;background:#07c160;color:#fff;font-size:15px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s}.send-btn:hover{background:#06ad56}.send-btn:active{background:#059a4c}.img-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:4px;background:#e0e0e0;color:#666;font-size:20px;cursor:pointer;flex-shrink:0;transition:background .15s}.img-btn:active{background:#ccc}.img-preview{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f5f5f5;border-top:1px solid #e0e0e0}.img-preview img{width:60px;height:60px;object-fit:cover;border-radius:4px}.img-preview-close{color:#999;font-size:20px;cursor:pointer;padding:0 4px}.typing-bubble{padding:12px 16px}.typing-dots span{font-size:20px;line-height:1;color:#999;animation:typingDot 1.4s infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typingDot{0%,60%,to{opacity:.2}30%{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;align-items:center;justify-content:center;background:#00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.login-card{text-align:center;padding:32px 40px;border-radius:12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15)}.login-title{font-size:17px;color:#fffc;margin-bottom:24px}.login-qr{width:180px;height:180px;border-radius:8px;margin:16px 0 12px}.login-desc{font-size:14px;color:#ffffff80}.wx-login-btn{display:inline-block;padding:12px 48px;border-radius:6px;background:#07c160;color:#fff;font-size:16px;font-weight:500;text-decoration:none;transition:background .15s}.wx-login-btn:hover{background:#06ad56}
