*,*:before,*:after{box-sizing:border-box}html{overflow:hidden;height:100%}body{margin:0;padding:0;overflow:hidden;position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;font-family:Lato,system-ui,-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif;background:linear-gradient(135deg,#ddfee1,#cef2ff,#ebd5ff,#ffdfeb,#ddfee1);background-size:400% 400%;animation:gradientShift 15s ease infinite;color:#1a1a1a;overscroll-behavior:none}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}#root{height:100vh;height:100dvh;display:flex;align-items:center;justify-content:center;padding:16px;padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right));padding-top:max(16px,env(safe-area-inset-top));padding-bottom:max(16px,env(safe-area-inset-bottom));overflow:hidden;position:relative}@media (max-width: 480px),(max-height: 700px){#root{height:var(--visual-viewport-height, 100dvh);min-height:var(--visual-viewport-height, 100dvh);max-height:var(--visual-viewport-height, 100dvh);align-items:center;justify-content:center;padding:12px;overflow:hidden}}.chat-shell{width:100%;max-width:480px;height:640px;min-height:360px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:24px;border:1px solid rgba(255,255,255,.5);box-shadow:0 20px 80px #00000026;display:flex;flex-direction:column;overflow:hidden}@media (max-width: 480px),(max-height: 700px){.chat-shell{height:100%;max-height:100%;border-radius:16px;box-shadow:0 10px 40px #0000001f;background:#fff}.chat-body{padding-bottom:20px}.chat-footer{padding-left:10px;padding-right:10px;padding-top:6px;padding-bottom:max(6px,env(safe-area-inset-bottom));background:#fff;margin-bottom:0}.chat-dob-placeholder{font-size:14px;color:#000000bf}.chat-input-row{padding-left:4px;padding-right:8px;gap:6px}.chat-send-button{padding-left:10px;padding-right:10px}}.chat-progress-bar{height:3px;background:#d61b5626;flex-shrink:0;overflow:hidden}.chat-progress-bar-fill{height:100%;background:#d61b56b3;border-radius:0 2px 2px 0;transition:width .35s ease-out}.chat-header{padding:16px 20px;border-bottom:1px solid rgba(0,0,0,.08);display:flex;align-items:center;gap:12px;background:#fffc;flex-shrink:0}.chat-header-avatar{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.chat-header-avatar svg,.chat-header-avatar img{width:100%;height:100%;object-fit:contain}.chat-header-meta{display:flex;flex-direction:column;gap:2px}.chat-header-title{font-size:14px;font-weight:600}.chat-body{flex:1;min-height:0;min-width:0;padding:16px 16px 8px;display:flex;flex-direction:column;gap:8px;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.chat-bubble-row{display:flex;margin-bottom:4px}.chat-bubble-row.bot{justify-content:flex-start}.chat-bubble-row.user{justify-content:flex-end}.chat-bubble-row.progress-indicator{justify-content:center}.chat-bubble{max-width:80%;padding:10px 12px;border-radius:18px;font-size:14px;line-height:1.4;word-wrap:break-word;white-space:pre-wrap}.chat-bubble a{color:#2563eb;text-decoration:underline;text-underline-offset:2px}.chat-bubble a:visited{color:#1d4ed8}.chat-bubble.progress-indicator{max-width:auto;background:transparent;border:none;padding:8px 0;font-size:12px;color:#00000080;font-weight:500}.chat-bubble.bot{background:#d61b561a;border:1px solid rgba(214,27,86,.2);color:#1a1a1a;border-bottom-left-radius:4px;animation:fadeIn .3s ease-in}.chat-bubble.user{background:#0000000d;border:1px solid rgba(0,0,0,.1);color:#1a1a1a;border-bottom-right-radius:4px;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.chat-footer{width:100%;max-width:100%;padding:6px 12px 8px;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex-shrink:0;min-width:0;overflow:hidden;box-sizing:border-box}.chat-input-row{display:flex;align-items:center;gap:6px;width:100%;max-width:100%;min-width:0;background:#ffffffe6;border-radius:999px;padding:4px 6px 4px 10px;border:1px solid rgba(0,0,0,.1);overflow:hidden;box-sizing:border-box}.chat-input-row input{flex:1;min-width:0;width:0;border:none;outline:none;background:transparent;color:#1a1a1a;font-size:14px;scroll-margin-bottom:30vh;overflow:hidden}.chat-input-row input::placeholder{color:#9ca3af}.chat-send-button{flex-shrink:0;border:none;outline:none;border-radius:999px;padding:7px 12px;font-size:13px;font-weight:600;background:#d61b56;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s ease;white-space:nowrap}.chat-send-button:hover:not(:disabled){background:#b81548;transform:translateY(-1px);box-shadow:0 4px 12px #d61b564d}.chat-send-button:active:not(:disabled){transform:translateY(0)}.chat-send-button:disabled,.chat-send-button.disabled{background:#d1d5db;color:#6b7280;opacity:1;cursor:not-allowed}.chat-send-button.enabled,.chat-send-button.idle{background:#d61b56;color:#fff;opacity:1;cursor:pointer}.chat-system-note{font-size:11px;color:#6b7280;text-align:center;margin-top:4px}.typing-indicator{display:flex;align-items:center;gap:6px;padding:10px 14px 12px;margin:4px 0}.typing-indicator .typing-dot{width:8px;height:8px;border-radius:50%;background:#d61b5680;animation:typingBounce .6s ease-in-out infinite both}.typing-indicator .typing-dot:nth-child(1){animation-delay:0s}.typing-indicator .typing-dot:nth-child(2){animation-delay:.15s}.typing-indicator .typing-dot:nth-child(3){animation-delay:.3s}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-8px)}}.chat-retry-row{display:flex;justify-content:center;margin:6px 0 2px}.chat-retry-button{border:none;outline:none;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;background:#d61b561f;color:#1a1a1a;border:1px solid rgba(214,27,86,.2);cursor:pointer;transition:all .2s ease}.chat-retry-button:hover{background:#d61b562e;border-color:#d61b564d;transform:translateY(-1px)}.chat-retry-button:active{transform:translateY(0)}.chat-options-row{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 4px}.chat-option-button{border:none;outline:none;padding:6px 12px;border-radius:999px;font-size:12px;background:#ebd5ff;border:1px solid rgba(235,213,255,.8);color:#1a1a1a;font-weight:500;cursor:pointer;transition:all .2s ease}.chat-option-button:hover:not(:disabled){background:#e0c7ff;border-color:#ebd5ff;transform:translateY(-1px)}.chat-option-button:active:not(:disabled){transform:translateY(0)}.chat-option-button:disabled{opacity:.6;cursor:default}.chat-dob-block{margin:8px 0 4px}.chat-dob-row{display:flex;align-items:center;gap:8px}.chat-dob-input-wrap{position:relative;flex:1;display:flex;align-items:center}.chat-dob-input{flex:1;width:100%;padding:6px 10px;border-radius:999px;border:1px solid rgba(0,0,0,.1);background:#ffffffe6;color:#1a1a1a;font-size:12px;position:relative;z-index:1}.chat-dob-placeholder{position:absolute;left:14px;right:36px;top:50%;transform:translateY(-50%);pointer-events:none;font-size:13px;color:#000000b3;line-height:1.2}.chat-dob-input::-webkit-calendar-picker-indicator{position:relative;z-index:2;opacity:.6;cursor:pointer}.chat-dob-error{margin-top:6px;font-size:12px;color:#c53030}.chat-dob-confirm{border:none;outline:none;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;background:#d61b56;color:#fff;cursor:pointer;transition:all .2s ease}.chat-dob-confirm:hover:not(:disabled){background:#b81548;transform:translateY(-1px);box-shadow:0 4px 12px #d61b564d}.chat-dob-confirm:active:not(:disabled){transform:translateY(0)}.chat-dob-confirm:disabled{opacity:.6;cursor:default}.chat-phone-row{display:flex;align-items:center;gap:8px;margin:8px 0 4px;scroll-margin-bottom:24px}.chat-phone-cc-select{min-width:100px;padding:6px 8px;border-radius:999px;border:1px solid rgba(0,0,0,.1);background:#ffffffe6;color:#1a1a1a;font-size:12px;cursor:pointer;outline:none;transition:all .2s ease}.chat-phone-cc-select:hover:not(:disabled){border-color:#d61b564d}.chat-phone-cc-select:disabled{opacity:.6;cursor:default}.chat-phone-cc-select option{background:#fffffffa;color:#1a1a1a}.chat-phone-input{flex:1;padding:6px 10px;border-radius:999px;border:1px solid rgba(0,0,0,.1);background:#ffffffe6;color:#1a1a1a;font-size:12px}.chat-phone-input::placeholder{color:#9ca3af}@media (max-width: 480px),(max-height: 700px){.chat-input-row input,.chat-phone-input{font-size:16px}}
