:root{color-scheme:dark}body{margin:0;display:flex;place-items:center}.chat-area{flex:1;overflow-y:auto;padding:1rem 1rem 7rem;display:flex;flex-direction:column;gap:.5rem;background:#000}.message-bubble{text-align:left;margin-top:.2rem;margin-bottom:.2rem;max-width:80%;padding:.6rem .9rem;border-radius:12px;white-space:pre-wrap;word-wrap:break-word;font-size:clamp(1rem,4vw,1.25rem);font-family:Helvetica;line-height:1.4;display:inline-block;box-shadow:0 1px 3px #0006;transition:all .2s ease}.message-bubble.user{align-self:flex-end;background-color:#443579;color:#fff;border-bottom-right-radius:0;border:none}.message-bubble.agent{align-self:flex-start;background-color:#212121;color:#fff;border-bottom-left-radius:0;border:none}.message-bubble{opacity:0;transform:translateY(50px);animation:fadeIn .5s ease forwards}@keyframes fadeIn{to{opacity:1;transform:translateY(0)}}.chat-area::-webkit-scrollbar{width:6px}.chat-area::-webkit-scrollbar-thumb{background-color:#444;border-radius:4px}.chat-area::-webkit-scrollbar-track{background:#111}.menu-overlay{position:fixed;top:0;left:0;width:100vw;max-width:560px;height:100vh;height:100dvh;background:#0d0b17;transform:translate(-100%);transition:transform .45s ease;z-index:300;display:flex;align-items:stretch;justify-content:flex-start;pointer-events:none}.menu-overlay.open{transform:translate(0);pointer-events:auto}.menu-body{width:100%;height:100vh;height:100dvh;padding:5% 10%;box-sizing:border-box;display:flex;flex-direction:column;gap:2rem;background:#000;overflow:hidden}.menu-header{display:flex;align-items:center;justify-content:space-between}.menu-title{color:#fff;font-size:2rem;letter-spacing:.04em;font-family:Helvetica;text-transform:uppercase}.menu-content{display:flex;flex-direction:column;gap:1rem;flex:1;min-height:0}.menu-separator{width:100%;height:1px;background:#ffffff2e;margin:.25rem 0}.menu-conversations{display:flex;flex-direction:column;gap:.75rem;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.menu-item{width:100%;padding:1rem 1.2rem;border-radius:.8rem;border:2px solid rgba(255,255,255,.12);background:#ffffff0f;color:#fff;font-size:1.2rem;font-family:Helvetica;text-align:left;cursor:pointer;transition:background .2s,border-color .2s;-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.menu-item:hover{background:#ffffff29;border-color:#fff6}.menu-header .icon-button{width:3rem;height:3rem;background-color:red}.menu-header .icon-button .icon{width:1.7rem;height:1.7rem}.popup-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#00000073;z-index:99999;padding:1rem;box-sizing:border-box}.popup-container{width:min(24rem,calc(100vw - 2rem));aspect-ratio:1 / 1;display:flex;flex-direction:column;justify-content:space-between;padding:1.5rem;box-sizing:border-box;border-radius:1rem;border:2px solid rgba(255,255,255,.2);background:#111;color:#fff;font-family:Helvetica;text-align:center;gap:1rem}.popup-title{margin:0;font-size:1.7rem;text-transform:uppercase;letter-spacing:.03em}.popup-message{margin:0;font-size:1.15rem;line-height:1.45;flex:1;display:flex;align-items:center;justify-content:center}.popup-button{width:100%;padding:.9rem 1rem;border-radius:.8rem;border:2px solid rgba(255,255,255,.2);background:#ffffff14;color:#fff;font-size:1rem;font-family:Helvetica;cursor:pointer;transition:background .2s ease,border-color .2s ease}.popup-button:hover{background:#ffffff29;border-color:#ffffff59}.menu-login-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0d0b17;transform:translate(-100%);transition:transform .45s ease;z-index:400;display:flex;align-items:stretch;justify-content:flex-start;pointer-events:none}.menu-login-overlay.open{transform:translate(0);pointer-events:auto}.menu-login-body{width:100%;height:100vh;padding:5% 10%;box-sizing:border-box;display:flex;flex-direction:column;gap:2rem;background:#000}.menu-login-header{display:flex;align-items:center;justify-content:space-between}.menu-login-title{color:#fff;font-size:2rem;letter-spacing:.04em;font-family:Helvetica;text-transform:uppercase}.menu-login-content{display:flex;flex-direction:column;gap:1rem}.menu-login-input{width:100%;padding:1rem 1.2rem;border-radius:.8rem;border:2px solid rgba(255,255,255,.12);background:#ffffff0f;color:#fff;font-size:1.2rem;font-family:Helvetica;outline:none;box-sizing:border-box}.menu-login-input::placeholder{color:#fff9}.menu-login-input:focus{border-color:#fff6;background:#ffffff1a}.menu-login-button{width:100%;padding:1rem 1.2rem;border-radius:.8rem;border:2px solid rgba(255,255,255,.12);background:#ffffff0f;color:#fff;font-size:1.2rem;font-family:Helvetica;text-align:left;cursor:pointer;transition:background .2s,border-color .2s;-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.menu-login-button:hover{background:#ffffff29;border-color:#fff6}.menu-login-header .icon-button{width:3rem;height:3rem;background-color:red}.menu-login-header .icon-button .icon{width:1.7rem;height:1.7rem}.prompt-area{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:min(800px,95%);background:#1a1a1a;padding:.75rem;border-top-right-radius:16px;border-top-left-radius:16px;display:flex;flex-direction:row;align-items:center;gap:.5rem;box-shadow:0 0 20px #0006;z-index:100}.prompt-area textarea{flex:1;resize:none;background:#121212;color:#fff;padding:.75rem;border-radius:10px;border:1px solid #333;min-height:3rem;max-height:8rem;font-size:clamp(1rem,4vw,1.25rem);font-family:Helvetica}.prompt-area button{width:48px;height:48px;border-radius:10px;border:none;background:#4a37aa;color:#fff;font-size:2rem;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:transform .15s ease,background-color .2s ease,box-shadow .2s ease}.typing-dots{display:inline-flex;align-items:center;gap:6px;padding:6px 8px}.typing-dots span{display:inline-block;width:8px;height:8px;background:#cfcfcf;border-radius:50%;opacity:.4;transform:translateY(0);animation:typing-bounce 1s infinite ease-in-out}.typing-dots span:nth-child(2){animation-delay:.15s}.typing-dots span:nth-child(3){animation-delay:.3s}@keyframes typing-bounce{0%{transform:translateY(0);opacity:.4}50%{transform:translateY(-6px);opacity:1}to{transform:translateY(0);opacity:.4}}.prompt-area button:active{transform:scale(.92);background:#3b2b8e;box-shadow:0 2px 8px #000c}.prompt-area button{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.top-area{display:flex;align-items:center;background:#443579;padding:.7rem 1rem .7rem 1.2rem;border-top-left-radius:2.5rem;border-bottom-right-radius:2.5rem;box-shadow:0 2px 8px #0000000a;gap:.7rem;position:fixed;top:0;width:85%;left:50%;transform:translate(-50%);z-index:200}.avatar{width:2.2rem;height:2.2rem;border-radius:50%;overflow:hidden;border:2px solid #fff;box-shadow:0 1px 4px #00000014;display:flex;align-items:center;justify-content:center;background:#fff}.logo{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.logo .p1{color:#000070}.logo .p2{color:#f60}.top-title{color:#fff;font-weight:600;font-size:1.3rem;font-family:Helvetica;margin-left:.2rem;letter-spacing:.01em}.top-actions{margin-left:auto;display:flex;align-items:center;gap:.7rem}.icon-button{margin-left:auto;border:.2rem solid #fff;background:#ffffff1a;color:#fff;border-radius:50%;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 6px #0000001a;cursor:pointer;transition:background .2s,box-shadow .2s,border-color .2s;outline:none}.icon-button:hover{background:#ffffff38;box-shadow:0 2px 12px #4435792e;border-color:#e0d7fa}.icon{width:1.4rem;height:1.4rem;display:flex;align-items:center;justify-content:center}.icon-button,.icon{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}#app{height:100vh;width:100vw;display:flex;flex-direction:column;background-color:#000;padding-top:3.9rem;padding-bottom:6.1rem;box-sizing:border-box}
