:root{--pulse-ring-color: white}.chat-widget-wrapper{--chat-primary: #4f46e5}.chat-button{position:fixed;bottom:20px;right:20px;width:55px;height:55px;border-radius:50%;border:3px solid white;box-shadow:0 4px 12px #00000026;padding:0;overflow:visible;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.chat-button:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:3px solid var(--pulse-ring-color);opacity:0;animation:bubble-pulse-ring 3s ease-out infinite;pointer-events:none}.chat-button:hover{transform:scale(1.08);box-shadow:0 6px 20px #0003,0 0 0 4px color-mix(in srgb,var(--chat-primary) 20%,transparent)}.chat-button-avatar{width:100%;height:100%;object-fit:cover;display:block;position:relative;z-index:1;border-radius:50%}@keyframes bubble-pulse-ring{0%{transform:scale(.95);opacity:.5}to{transform:scale(1.4);opacity:0}}.chat-box{position:fixed;bottom:30px;right:20px;width:380px;height:500px;font-family:Plus Jakarta Sans,system-ui,sans-serif;background:#fff;border-radius:16px;box-shadow:0 10px 30px #0003;opacity:0;visibility:hidden;transition:opacity .32s cubic-bezier(.22,.61,.36,1),transform .32s cubic-bezier(.22,.61,.36,1),visibility .32s;display:flex;flex-direction:column;transform:translateY(24px) scale(.98);transform-origin:bottom right}.chat-box.open{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.chat-header{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid #f0f0f0;background:#fafafa;border-radius:16px 16px 0 0}.chat-bot-meta{flex:1;display:flex;flex-direction:column;align-items:flex-start;min-width:0}.chat-bot-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}.chat-bot-name{font-weight:600;font-size:15px;letter-spacing:-.01em;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-bot-status{display:inline-flex;align-items:center;gap:6px;margin-top:2px;font-size:12px;color:#6b7280}.chat-status-dot{width:8px;margin-top:2px;height:8px;border-radius:999px;background:#22c55e;box-shadow:0 0 0 3px color-mix(in srgb,#22c55e 18%,transparent);animation:chat-status-pulse 1.6s ease-out infinite}@keyframes chat-status-pulse{0%{transform:scale(1);box-shadow:0 0 0 3px color-mix(in srgb,#22c55e 22%,transparent);opacity:1}50%{transform:scale(1.3);box-shadow:0 0 0 6px color-mix(in srgb,#22c55e 0%,transparent);opacity:.5}to{transform:scale(1);box-shadow:0 0 0 3px color-mix(in srgb,#22c55e 22%,transparent);opacity:1}}.chat-header-actions{display:flex;align-items:center;gap:4px}.chat-history-btn{width:28px;height:28px;padding:0;border:none;background:transparent;color:#6b7280;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center}.chat-history-btn:hover{background:#e5e7eb;color:#374151}.chat-close{width:28px;height:28px;border:none;background:transparent;font-size:22px;line-height:1;cursor:pointer;color:#6b7280;border-radius:6px}.chat-close:hover:not(:disabled){background:#e5e7eb;color:#374151}.chat-close:disabled{opacity:.6;cursor:wait}.chat-messages{flex:1;padding:14px 16px;overflow-y:auto;font-size:14px;line-height:1.5}.chat-contact-request{padding:6px 14px 12px;background:#fafafa;border-top:1px solid #f0f0f0;font-size:12px;color:#6b7280;text-align:center}.chat-contact-trigger{padding:0;border:none;background:none;color:var(--chat-primary);font-family:inherit;font-size:12px;font-weight:500;cursor:pointer;text-decoration:none;transition:opacity .2s}.chat-contact-trigger:hover{text-decoration:underline}.chat-contact-form{display:flex;flex-direction:column;gap:8px;margin-top:6px}.chat-contact-email{width:100%;box-sizing:border-box;border:1px solid #e5e7eb;border-radius:8px;padding:8px 12px;font-family:inherit;font-size:13px;outline:none;background:#fff}.chat-contact-email:focus{border-color:var(--chat-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--chat-primary) 15%,transparent)}.chat-contact-actions{display:flex;gap:8px;justify-content:center}.chat-contact-cancel{padding:6px 12px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;font-family:inherit;font-size:12px;cursor:pointer;color:#6b7280}.chat-contact-cancel:hover:not(:disabled){background:#f3f4f6}.chat-contact-submit{padding:6px 14px;border:none;border-radius:8px;background:var(--chat-primary);color:#fff;font-family:inherit;font-size:12px;font-weight:600;cursor:pointer}.chat-contact-submit:hover:not(:disabled){filter:brightness(1.05)}.chat-contact-submit:disabled,.chat-contact-cancel:disabled{opacity:.7;cursor:not-allowed}.chat-contact-feedback{margin:0;font-size:12px}.chat-contact-feedback-ok{color:#059669}.chat-contact-feedback-err{color:#dc2626}.chat-input-wrap{display:flex;gap:10px;padding:12px 14px;border-top:1px solid #f0f0f0;background:#fafafa;border-radius:0}.chat-powered-by{padding:8px 14px 12px;background:#fafafa;border-radius:0 0 16px 16px;font-size:12px;color:#6b7280;text-align:center;border-top:1px solid #f0f0f0}.chat-powered-by a{color:var(--chat-primary);text-decoration:none;font-weight:600}.chat-powered-by a:hover{text-decoration:underline}.chat-input-wrap input{flex:1;border:1px solid #e5e7eb;border-radius:12px;padding:12px 16px;font-family:inherit;font-size:14px;background:#fff;outline:none;transition:border-color .2s,box-shadow .2s}.chat-input-wrap input::placeholder{color:#9ca3af}.chat-input-wrap input:focus{border-color:var(--chat-primary);box-shadow:0 0 0 3px #4f46e526}.chat-input-wrap button{border:none;padding:12px 18px;border-radius:12px;background:var(--chat-primary);color:#fff;font-family:inherit;font-weight:600;font-size:14px;cursor:pointer;transition:background .2s,transform .1s}.chat-input-wrap button:hover{background:#4338ca}.chat-input-wrap button:active{transform:scale(.98)}.msg-user,.msg-bot{display:flex;gap:8px;margin-bottom:10px;animation:msg-appear .35s ease-out both}.msg-user{flex-direction:row-reverse;animation-name:msg-appear-user}@keyframes msg-appear{0%{opacity:0;transform:translateY(8px) translate(-6px)}to{opacity:1;transform:translateY(0) translate(0)}}@keyframes msg-appear-user{0%{opacity:0;transform:translateY(8px) translate(6px)}to{opacity:1;transform:translateY(0) translate(0)}}.msg-bot-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0}.msg-content{display:flex;flex-direction:column;gap:2px;padding:10px 14px;border-radius:12px;max-width:75%;word-wrap:break-word}.msg-content p{margin:0 0 4px}.msg-content ul,.msg-content ol{margin:4px 0;padding-left:20px}.msg-content li{margin-bottom:2px}.msg-user .msg-content{background:var(--chat-primary);color:#fff;border-bottom-right-radius:4px}.msg-bot .msg-content{background:#f3f4f6;color:#111827;border-bottom-left-radius:4px}.msg-sender{font-size:11px;font-weight:600;color:var(--chat-primary);letter-spacing:.02em}.msg-user .msg-content span:not(.msg-sender){color:#fff}.msg-bot .msg-content span:not(.msg-sender){color:#111827}.quick-questions{display:flex;flex-direction:column;gap:8px;padding-bottom:8px;animation:quick-questions-appear .4s ease-out both}.quick-questions-label{font-size:12px;color:#6b7280;margin-bottom:4px}.quick-question-btn{text-align:left;padding:12px 14px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;font-family:inherit;font-size:13px;cursor:pointer;transition:all .15s;animation:quick-btn-appear .35s ease-out both}.quick-question-btn:nth-child(2){animation-delay:.05s}.quick-question-btn:nth-child(3){animation-delay:.1s}.quick-question-btn:nth-child(4){animation-delay:.15s}.quick-question-btn:nth-child(5){animation-delay:.2s}.quick-question-btn:nth-child(6){animation-delay:.25s}@keyframes quick-questions-appear{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes quick-btn-appear{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.quick-question-btn:hover{background:#f8f9fa;border-color:#d1d5db}.msg-bot:has(.typing-dots){animation:msg-appear .25s ease-out both}.typing-dots{display:inline-flex;align-items:center;gap:4px;padding:4px 0}.typing-dot{width:6px;height:6px;border-radius:50%;background:var(--chat-primary);animation:typing-bounce 1.4s ease-in-out infinite both}.typing-dot:nth-child(1){animation-delay:0s}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{transform:translateY(0);opacity:.5}30%{transform:translateY(-6px);opacity:1}}@media(max-width:768px){.chat-button{bottom:max(16px,env(safe-area-inset-bottom));right:max(16px,env(safe-area-inset-right));width:56px;height:56px}.chat-box{bottom:0;right:0;left:0;width:100%;height:100vh;height:100dvh;border-radius:0;box-shadow:0 -4px 24px #00000026;padding-bottom:env(safe-area-inset-bottom);transform-origin:bottom center}.chat-header{padding:12px 16px;padding-top:max(12px,env(safe-area-inset-top));border-radius:0}.chat-messages{padding:12px 14px;font-size:15px}.chat-input-wrap{padding:12px 14px;padding-bottom:max(12px,env(safe-area-inset-bottom));gap:8px}.chat-input-wrap input,.chat-input-wrap button{padding:14px 16px;font-size:16px;min-height:48px}.msg-content{max-width:85%}.quick-question-btn{padding:14px 16px;font-size:14px;min-height:48px}}@media(max-width:480px){.chat-button{bottom:max(12px,env(safe-area-inset-bottom));right:max(12px,env(safe-area-inset-right));width:52px;height:52px}.chat-bot-avatar{width:36px;height:36px}.chat-bot-name{font-size:14px}.msg-bot-avatar{width:24px;height:24px}.msg-content{padding:10px 12px;max-width:90%}}.chat-history-panel{position:absolute;top:0;left:0;right:0;bottom:0;z-index:10;background:#fff;border-radius:16px;display:flex;flex-direction:column;box-shadow:0 10px 30px #0003}.chat-history-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #f0f0f0;background:#fafafa;border-radius:16px 16px 0 0}.chat-history-title{font-weight:600;font-size:15px;color:#111827}.chat-history-close{width:28px;height:28px;border:none;background:transparent;font-size:22px;line-height:1;cursor:pointer;color:#6b7280;border-radius:6px}.chat-history-close:hover{background:#e5e7eb;color:#374151}.chat-history-list{flex:1;overflow-y:auto;padding:12px}.chat-history-empty{margin:0;padding:24px 0;text-align:center;font-size:14px;color:#6b7280}.chat-history-item{display:flex;align-items:center;gap:8px;margin-bottom:8px;border-radius:10px;border:1px solid #e5e7eb;background:#fff}.chat-history-item-btn{flex:1;min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:12px 14px;border:none;background:none;cursor:pointer;font-family:inherit;text-align:left;transition:background .15s}.chat-history-item-btn:hover{background:#f9fafb}.chat-history-item-date{font-size:11px;color:#6b7280}.chat-history-item-preview{font-size:13px;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.chat-history-item-delete{flex-shrink:0;padding:8px 12px;margin:6px 8px 6px 0;border:1px solid #e5e7eb;border-radius:8px;background:#fff;font-size:12px;color:#6b7280;cursor:pointer;font-family:inherit}.chat-history-item-delete:hover{background:#fef2f2;color:#dc2626;border-color:#fecaca}*{box-sizing:border-box;margin:0;padding:0}.squares-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:none;display:block}.homepage{position:relative;min-height:100vh}.homepage-arrow{position:fixed;right:100px;bottom:30px;width:120px;max-width:40vw;z-index:-1;pointer-events:none;opacity:1;transition:opacity .3s ease,transform .3s ease}.homepage-arrow--hidden{opacity:0;transform:translateY(10px)}.homepage-content{position:relative;z-index:1;display:flex;flex-direction:column}.homepage main{max-width:980px;margin:0 auto;padding:30px 20px 24px;color:#ffffffeb;min-height:100vh}.homepage main,.homepage h1{text-align:left}.homepage h1{margin:0;font-size:44px;line-height:1.1}.homepage-lead{margin-top:14px;font-size:18px;line-height:1.6}.homepage section{margin-top:22px}.homepage section:first-of-type{margin-top:26px}.homepage h2{margin:0 0 10px;font-size:22px}.homepage ul{margin:0;padding-left:18px;line-height:1.7}.homepage section p{margin:0;line-height:1.7}.homepage-footer{max-width:980px;margin:auto auto 0;padding:18px 20px 28px;color:#ffffffb8;font-size:13px;line-height:1.6;text-align:center}.homepage-footer p{margin:2px 0}.homepage-footer a{color:#ffffffd9;text-decoration:underline;text-underline-offset:2px}.homepage-footer a:hover{color:#fff}@media(min-width:1024px){.homepage h1{font-size:70px}.homepage-lead{font-size:20px}.homepage h2{font-size:24px}}.homepage-title-red{color:#ef4444}@media(max-width:768px){.homepage-footer{padding-bottom:50px}}
