*{box-sizing:border-box}html{height:100%;font-family:-apple-system,Helvetica Neue,Arial,sans-serif!important}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;vertical-align:middle;line-height:1}body{margin:0;min-height:100%;min-height:100dvh;font-family:-apple-system,Helvetica Neue,Arial,sans-serif!important;background:var(--chat-theme-color, #071e55);color:#111;-webkit-font-smoothing:antialiased;overflow-x:hidden}#app{min-height:100svh;min-height:100dvh;display:flex;justify-content:center;align-items:stretch;width:100%;padding:0}.phone-shell{width:100%;max-width:100%;flex:1 1 auto;min-height:0;height:100svh;height:100dvh;background:var(--chat-theme-color, #071e55);display:flex;flex-direction:column;overflow:hidden}@media screen and (min-width: 1000px){.phone-shell{width:468px;max-width:468px;margin:0 auto;border-left:1px solid var(--chat-theme-color, #071e56);border-right:1px solid var(--chat-theme-color, #071e56);border-top:none;border-bottom:none}}.top-nav{flex-shrink:0;z-index:50;display:grid;grid-template-columns:40px 1fr auto;align-items:center;gap:8px;padding:max(10px,env(safe-area-inset-top)) max(12px,env(safe-area-inset-right)) 10px max(12px,env(safe-area-inset-left));background:var(--chat-theme-color, #071e55)}.back-btn{width:40px;height:40px;border-radius:50%;border:0;padding:0;display:inline-flex;align-items:center;justify-content:center;background:transparent;background-image:radial-gradient(circle at center,#ffffff24,#ffffff0f);cursor:pointer;color:#fff;line-height:0}.back-btn:active{transform:scale(.96)}.back-ico{font-size:20px;line-height:1;width:100%;height:100%;display:inline-flex;align-items:center;justify-content:center;vertical-align:unset}.header-center{display:flex;align-items:center;justify-content:center;gap:6px;min-width:0}.title-text{margin:0;font-size:1.125rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-dot{flex-shrink:0;width:8px;height:8px;border-radius:50%;background:#0f0;box-shadow:0 0 0 1px #00000026}.status-dot.is-offline{background:#94a3b8}.header-brand{height:1.125rem;width:auto;display:block;object-fit:contain}.chat-canvas{flex:1 1 auto;min-height:0;padding:12px max(12px,env(safe-area-inset-right)) 12px max(12px,env(safe-area-inset-left));overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;scrollbar-width:none;background:#f5f5f5}.chat-canvas::-webkit-scrollbar{display:none}.day-chip-wrap{width:100%;display:flex;justify-content:center;margin:0 0 14px}.day-chip{width:100%;margin-top:8px;font-size:14px;font-weight:400;color:gray;text-align:center}.msg-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:14px}.msg-row-left{flex-direction:row;justify-content:flex-start}.msg-row-right{flex-direction:row;justify-content:flex-end}.msg-avatar{flex-shrink:0;width:32px;height:32px;border-radius:50%;object-fit:cover}.msg-stack{display:flex;flex-direction:column;align-items:flex-start;gap:4px;min-width:0;max-width:calc(100% - 40px)}.msg-stack-end{align-items:flex-end}.author{color:#a0a0a0;font-size:.82rem;line-height:30px;font-weight:600;padding-left:2px}.bubble{position:relative;padding:10px 12px;border-radius:6px;font-family:inherit;font-size:14px;line-height:22px;font-weight:450;box-sizing:border-box;width:fit-content;max-width:min(100%,360px);min-width:0;word-break:break-word;animation:enter .35s ease-out}.bubble.assistant:before{content:"";position:absolute;top:10px;left:-5px;width:0;height:0;border-style:solid;border-width:6px 6px 6px 0;border-color:transparent #fff transparent transparent}.bubble.user:before{content:"";position:absolute;top:10px;right:-5px;width:0;height:0;border-style:solid;border-width:6px 0 6px 6px;border-color:transparent transparent transparent #95ec69}.bubble p{margin:0;font-weight:450;white-space:pre-wrap;max-height:154px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.bubble p::-webkit-scrollbar{width:5px}.bubble p::-webkit-scrollbar-thumb{background:#0003;border-radius:4px}.typing-dots{display:inline-flex;align-items:center;gap:6px;min-height:18px}.typing-dots span{width:7px;height:7px;border-radius:50%;background:#00000059;animation:breathe 1.2s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.18s}.typing-dots span:nth-child(3){animation-delay:.36s}.bubble.assistant{background:#fff;color:#111;border:none;box-shadow:0 1px #0000000f}.bubble.user{background:#95ec69;color:#111;border:none;box-shadow:none}.bubble-image{display:block;width:100%;max-width:240px;height:auto;max-height:200px;object-fit:cover;border-radius:4px;margin-bottom:8px}.msg-system{margin:8px auto 14px;max-width:92%;text-align:center;background:#0000000f;color:#555;border-radius:8px;padding:8px 12px;font-size:12px;border:none}.composer{flex-shrink:0;display:flex;align-items:flex-end;gap:10px;padding:10px max(12px,env(safe-area-inset-right)) max(12px,env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-left));background:var(--chat-theme-color, #071e55)}.upload-btn{position:relative;flex-shrink:0;width:40px;height:40px;border-radius:50%;cursor:pointer;display:block;background-color:#fff;background-image:url(/webp/uploadImg_b.png);background-repeat:no-repeat;background-position:center;background-size:60% 60%;box-shadow:0 1px 2px #0000001f}.upload-btn input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;font-size:0}.input-shell{flex:1;min-width:0;background:#fff;border-radius:999px;padding:8px 14px;box-shadow:none}.message-input{display:block;width:100%;min-height:22px;max-height:120px;border:0;resize:none;outline:none;background:transparent;color:#111;font-family:inherit;font-size:15px;line-height:1.4;overflow-y:auto}.message-input::placeholder{color:#999}.send-circle{flex-shrink:0;width:40px;height:40px;border-radius:50%;border:0;padding:0;cursor:pointer;display:block;background-color:#fff;background-image:url(/webp/send_b.png);background-repeat:no-repeat;background-position:center;background-size:60% 60%;box-shadow:0 1px 2px #0000001f;transition:opacity .15s ease,transform .12s ease}.send-circle:hover:not(:disabled){transform:scale(1.03)}.send-circle:disabled{opacity:.55;cursor:not-allowed}@keyframes enter{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes breathe{0%,to{opacity:.35;transform:translateY(0) scale(.92)}50%{opacity:1;transform:translateY(-1px) scale(1)}}
