@import"https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,600;0,6..72,700;1,6..72,400;1,6..72,600&family=Manrope:wght@400;500;600;700;800&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";@import"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0&display=swap";.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:20px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-smoothing:antialiased}:root{color-scheme:light}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,sans-serif;background:#f9f9fc;color:#1a1c1e;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit}:root{--surface: #f9f9fc;--surface-low: #f3f3f6;--surface-container: #eeeef0;--surface-high: #e8e8ea;--surface-highest: #e2e2e5;--surface-lowest: #ffffff;--on-surface: #1a1c1e;--on-surface-variant: #434656;--on-background: #1a1c1e;--primary: #0055ff;--primary-dark: #0041c8;--on-primary: #ffffff;--secondary-container: #e2e2e5;--on-secondary-container: #454749;--tertiary: #972500;--outline: #737688;--outline-variant: rgba(195, 197, 217, .15);--error: #ba1a1a;--error-container: #ffdad6;--max-width: 1200px;--section-pad-x: 80px;--section-pad-y: 96px}.page{min-height:100vh;background:var(--surface);color:var(--on-surface)}.topbar{position:sticky;top:0;z-index:10;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 var(--section-pad-x);height:56px;background:#f9f9fcd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(195,197,217,.2)}.brand{font-family:Manrope,sans-serif;font-weight:800;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--on-surface);text-decoration:none}.nav{display:flex;gap:28px;align-items:center}.nav a{font-family:Manrope,sans-serif;font-size:13px;font-weight:500;text-decoration:none;color:var(--on-surface-variant);letter-spacing:.01em;transition:color .15s ease}.nav a:hover{color:var(--on-surface)}.topbar-actions{display:flex;justify-content:flex-end;align-items:center}.nav-cta{font-family:Manrope,sans-serif;font-size:12px;font-weight:700;letter-spacing:.04em;text-decoration:none;color:var(--on-primary);background:linear-gradient(135deg,var(--primary-dark),var(--primary));padding:7px 16px;border-radius:9999px;display:inline-flex;align-items:center;gap:4px;transition:opacity .15s ease,transform .15s ease}.nav-cta:hover{opacity:.9;transform:translateY(-1px)}.nav-cta-arrow{font-size:11px;opacity:.8}.primary-button{display:inline-flex;align-items:center;gap:8px;text-decoration:none;font-family:Inter,sans-serif;font-weight:600;font-size:14px;padding:10px 20px;border-radius:.75rem;border:none;background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:var(--on-primary);cursor:pointer;transition:opacity .15s ease,transform .15s ease}.primary-button:hover{opacity:.9;transform:translateY(-1px)}.ghost-button{display:inline-flex;align-items:center;gap:8px;text-decoration:none;font-family:JetBrains Mono,ui-monospace,monospace;font-weight:500;font-size:13px;padding:10px 20px;border-radius:.75rem;border:1px solid var(--outline-variant);background:transparent;color:var(--primary);cursor:pointer;transition:background .15s ease,border-color .15s ease}.ghost-button:hover{background:var(--surface-container);border-color:#c3c5d966}.eyebrow{font-family:Manrope,sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:600;color:var(--on-surface-variant);display:flex;margin-bottom:16px;padding-top:10px}h1{font-family:Newsreader,Georgia,serif;font-size:clamp(2.75rem,4.5vw,4rem);font-weight:600;line-height:1.1;letter-spacing:-.02em;margin:0 0 20px;color:var(--on-surface)}h2{font-family:Newsreader,Georgia,serif;font-size:clamp(2rem,3.5vw,3rem);font-weight:600;line-height:1.15;letter-spacing:-.02em;margin:0 0 16px;color:var(--on-surface)}h3{font-family:Manrope,sans-serif;font-size:1.125rem;font-weight:700;margin:0 0 8px;color:var(--on-surface)}h4{font-family:Manrope,sans-serif;font-size:.9375rem;font-weight:600;margin:0 0 6px;color:var(--on-surface)}.lede{font-family:Inter,sans-serif;font-size:1rem;line-height:1.65;color:var(--on-surface-variant);max-width:520px;display:flex;margin:0 auto 28px}.section{padding:var(--section-pad-y) var(--section-pad-x)}.section-inner{max-width:var(--max-width);margin:0 auto}.section-header{margin-bottom:56px}.section-copy{font-size:1rem;line-height:1.6;color:var(--on-surface-variant);max-width:480px;margin:12px 0 0}.split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}.split.wide-left{grid-template-columns:55fr 45fr}.hero{background:var(--surface)}.hero-inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--section-pad-x)}.hero-body{min-height:calc(100vh - 56px);display:grid;grid-template-columns:1fr auto;align-items:center;gap:80px;padding:80px 0}.hero-body-text{display:flex;flex-direction:column;align-items:flex-start}.hero-body-text h1{text-align:left}.hero-body-text .lede{text-align:left;margin:0 0 28px}.hero-body-text .cta-row{justify-content:flex-start}.hero-headshot-wrap{flex-shrink:0;width:320px;height:380px;border-radius:16px;overflow:hidden;box-shadow:0 20px 60px #1a1c1e1a}.hero-headshot{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}.hero-experience{background:var(--surface-low);padding:var(--section-pad-y) 0}.hero-resume-cta{display:flex;justify-content:center;padding-top:56px}.hero h1 em{font-style:italic;color:var(--primary)}.cta-row{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin:0 0 40px}.stat-row{display:flex;gap:32px;padding-top:8px}.stat{display:flex;flex-direction:column;gap:2px}.stat strong{font-family:JetBrains Mono,ui-monospace,monospace;font-size:1.25rem;color:var(--on-surface)}.stat span{font-size:11px;color:var(--on-surface-variant);letter-spacing:.04em}.hero-visual{background:#1a1c1e;border-radius:16px;aspect-ratio:4/3;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;position:relative;overflow:hidden}.hero-visual-label{font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;color:#ffffff80;letter-spacing:.12em;text-transform:uppercase;background:#ffffff14;padding:6px 12px;border-radius:999px;align-self:flex-start}.hero-visual-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(0,85,255,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(0,85,255,.12) 1px,transparent 1px);background-size:40px 40px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.card{border-radius:12px;padding:24px;background:var(--surface-lowest);transition:box-shadow .2s ease,transform .2s ease}.card:hover{transform:translateY(-2px);box-shadow:0 20px 40px #1a1c1e0f}.card-meta{font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;color:var(--on-surface-variant);letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px}.card-body{font-size:.9375rem;line-height:1.6;color:var(--on-surface-variant);margin:0 0 16px}.card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.text-link{font-family:JetBrains Mono,ui-monospace,monospace;font-size:12px;text-decoration:none;color:var(--primary);white-space:nowrap}.text-link:hover{text-decoration:underline}.project-featured{background:var(--surface-lowest);border-radius:16px;overflow:hidden;margin-bottom:20px;display:grid;grid-template-columns:1fr 1fr;min-height:320px;box-shadow:0 20px 40px #1a1c1e0f}.project-featured-visual{background:#1a1c1e;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.project-featured-visual .hero-visual-grid{opacity:.6}.project-featured-num{font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;color:#fff6;letter-spacing:.12em;position:absolute;top:20px;left:20px}.project-featured-content{padding:36px;display:flex;flex-direction:column;justify-content:space-between}.chip-row{display:flex;gap:8px;flex-wrap:wrap}.chip{padding:4px 12px;border-radius:9999px;background:var(--surface-highest);font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;color:var(--on-surface-variant)}.tech-matrix{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:48px}.tech-col h3{font-family:Manrope,sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--on-surface-variant);margin-bottom:20px}.tech-list{display:flex;flex-direction:column;gap:4px}.tech-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:8px;background:var(--surface-lowest);font-family:JetBrains Mono,ui-monospace,monospace;font-size:13px;color:var(--on-surface)}.tech-item span{font-size:11px;color:var(--on-surface-variant)}.technical-snippet{background:var(--surface-highest);border-left:3px solid var(--primary);border-radius:0 8px 8px 0;padding:14px 18px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:13px;color:var(--on-surface);line-height:1.7}.contact-card{border-radius:16px;padding:56px 64px;background:var(--surface-lowest);box-shadow:0 20px 40px #1a1c1e0f}.contact-card h2 em{font-style:italic;color:var(--primary)}.footer{background:var(--surface-container);padding:20px var(--section-pad-x)}.footer-inner{max-width:var(--max-width);margin:0 auto;display:flex;justify-content:space-between;align-items:center;color:var(--on-surface-variant);font-size:13px}.ant-menu{background:transparent!important;border:none!important}.ant-menu-item{color:var(--on-surface-variant)!important}.ant-menu-item-selected,.ant-menu-item:hover{color:var(--on-surface)!important;background:transparent!important}@media(max-width:960px){:root{--section-pad-x: 24px;--section-pad-y: 64px}.split,.split.wide-left{grid-template-columns:1fr;gap:40px}center{text-align:center}.hero-body{grid-template-columns:1fr;padding:48px 0 64px;text-align:center}.hero-body-text{align-items:center;order:2}.hero-body-text h1,.hero-body-text .lede{text-align:center}.hero-body-text .cta-row{justify-content:center}.hero-headshot-wrap{order:1;width:160px;height:190px;margin:0 auto}.hero-experience{padding:48px 0}.topbar{padding:0 24px;grid-template-columns:auto 1fr auto}.nav{gap:16px;justify-content:center}.tech-matrix{grid-template-columns:1fr;gap:32px}.project-featured{grid-template-columns:1fr}.project-featured-visual{min-height:200px}.contact-card{padding:36px 24px}}@media(max-width:640px){.nav a:not(:last-child){display:none}.footer-inner{flex-direction:column;gap:10px;text-align:center}}.contact-modal-backdrop{position:fixed;inset:0;z-index:100;background:#1a1c1e73;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:24px;animation:backdrop-in .2s ease}.contact-info-card{background:var(--surface-low);border-radius:12px;padding:32px;width:100%;animation:card-in .22s ease;display:flex;flex-direction:column}.contact-modal-backdrop .contact-info-card{max-width:520px;box-shadow:0 24px 60px #1a1c1e1f}@keyframes card-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.contact-info-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px}.contact-info-title{font-family:Newsreader,Georgia,serif;font-size:clamp(1.75rem,3vw,2.25rem);font-weight:600;margin:8px 0 10px;color:var(--on-surface)}.contact-info-sub{font-family:Inter,sans-serif;font-size:.9375rem;line-height:1.6;color:var(--on-surface-variant);margin:0}.contact-info-close{background:var(--surface-container);border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--on-surface-variant);cursor:pointer;flex-shrink:0;transition:background .15s ease,color .15s ease}.contact-info-close:hover{background:var(--surface-high);color:var(--on-surface)}.contact-registry-heading{font-family:Manrope,sans-serif;font-size:1.125rem;font-weight:700;color:var(--on-surface);margin:0 0 24px}.contact-info-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px;flex:1}.contact-info-row{display:flex;align-items:center;gap:16px;padding:14px 16px;border-radius:10px;background:var(--surface-lowest);text-decoration:none;transition:transform .2s ease,background .15s ease;flex:1}.contact-info-row:hover{transform:translate(4px);background:var(--surface-lowest)}.contact-info-icon{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:8px;background:var(--surface-container);color:var(--primary);flex-shrink:0}.contact-info-text{display:flex;flex-direction:column;gap:2px}.contact-info-label{font-family:JetBrains Mono,ui-monospace,monospace;font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--on-surface-variant)}.contact-info-value{font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;color:var(--on-surface);transition:color .15s ease}.contact-info-row:hover .contact-info-value{color:var(--primary)}.contact-system-status{background:var(--surface-container);border-left:4px solid var(--primary);border-radius:0 8px 8px 0;padding:16px 20px}.contact-system-status-label{font-family:JetBrains Mono,ui-monospace,monospace;font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--on-surface-variant);margin:0 0 8px}.contact-system-status-body{font-family:Inter,sans-serif;font-size:.875rem;line-height:1.6;color:var(--on-surface-variant);font-style:italic;margin:0}.exp-list{display:flex;flex-direction:column}.exp-entry{display:grid;grid-template-columns:20px 1fr;gap:20px;padding-bottom:56px}.exp-entry:last-child{padding-bottom:0}.exp-marker{display:flex;flex-direction:column;align-items:center;padding-top:5px}.exp-dot{width:10px;height:10px;border-radius:50%;background:var(--surface-high);flex-shrink:0}.exp-dot--current{background:var(--primary)}.exp-line{flex:1;width:1px;background:var(--surface-high);margin-top:6px}.exp-entry:last-child .exp-line{display:none}.exp-content{padding-top:2px}.exp-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:14px}.exp-title-group{display:flex;flex-direction:column;gap:3px}.exp-title{font-family:Manrope,sans-serif;font-size:1rem;font-weight:700;margin:0;color:var(--on-surface)}.exp-employer{font-family:Inter,sans-serif;font-size:.875rem;font-weight:500;color:var(--primary)}.exp-location{font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;color:var(--on-surface-variant);letter-spacing:.04em}.exp-date{font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;color:var(--on-surface-variant);letter-spacing:.04em;white-space:nowrap;padding-top:2px}.exp-body{font-family:Inter,sans-serif;font-size:.9375rem;line-height:1.65;color:var(--on-surface-variant);margin:0 0 16px}.exp-bullets{font-family:Inter,sans-serif;font-size:.9375rem;line-height:1.65;color:var(--on-surface-variant);margin:0 0 16px;padding-left:18px}.exp-bullets li{margin-bottom:6px}.exp-bullets li:last-child{margin-bottom:0}.exp-projects{display:flex;flex-direction:column;gap:24px;margin-bottom:16px}.exp-project{border-left:2px solid var(--surface-high);padding-left:16px}.exp-project-name{font-family:Manrope,sans-serif;font-size:.875rem;font-weight:700;color:var(--on-surface);margin:0 0 8px}.exp-technical{margin-bottom:16px}.exp-chips{margin-top:4px}@media(max-width:640px){.exp-header{flex-direction:column;gap:6px}.exp-date{order:-1}}.resume-modal-backdrop{position:fixed;inset:0;z-index:100;background:#1a1c1e99;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:24px;animation:backdrop-in .2s ease}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.resume-modal{background:var(--surface-lowest);border-radius:16px;width:100%;max-width:860px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 32px 80px #1a1c1e33;animation:modal-in .22s ease;overflow:hidden}@keyframes modal-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.resume-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--surface-high);flex-shrink:0}.resume-modal-title{display:flex;flex-direction:column;gap:2px}.resume-modal-name{font-family:Manrope,sans-serif;font-size:1rem;font-weight:700;color:var(--on-surface)}.resume-modal-actions{display:flex;align-items:center;gap:12px}.resume-modal-download{display:inline-flex;align-items:center;gap:6px;font-size:13px;padding:8px 16px}.resume-modal-download .material-symbols-outlined{font-size:16px}.resume-modal-close{background:var(--surface-container);border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--on-surface-variant);cursor:pointer;transition:background .15s ease,color .15s ease}.resume-modal-close:hover{background:var(--surface-high);color:var(--on-surface)}.resume-modal-viewer{flex:1;overflow:hidden;background:var(--surface-low);min-height:0}.resume-modal-iframe{width:100%;height:100%;min-height:600px;border:none;display:block}@media(max-width:640px){.resume-modal-backdrop{padding:0;align-items:flex-end}.resume-modal{max-width:100%;max-height:95vh;border-radius:16px 16px 0 0}}.contact-form-card{background:var(--surface-lowest);border-radius:12px;padding:40px;box-shadow:0 12px 40px #1a1c1e0f}.contact-form-card-header{margin-bottom:36px}.contact-form-title{font-family:Manrope,sans-serif;font-size:1.5rem;font-weight:700;color:var(--on-surface);margin:0 0 8px}.contact-form-subtitle{font-family:Inter,sans-serif;font-size:.9375rem;color:var(--on-surface-variant);margin:0}.contact-form{display:flex;flex-direction:column;gap:28px}.contact-form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}.contact-form-group{display:flex;flex-direction:column}.contact-form-label{font-family:JetBrains Mono,ui-monospace,monospace;font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--on-surface-variant);margin-bottom:8px}.contact-form-input{width:100%;background:var(--surface-low);border:none;border-bottom:2px solid var(--outline-variant);border-radius:8px 8px 0 0;padding:12px 8px;font-family:Inter,sans-serif;font-size:.9375rem;color:var(--on-surface);outline:none;transition:border-color .2s ease,background .2s ease;box-sizing:border-box;resize:none}.contact-form-input::placeholder{color:var(--outline);font-size:.875rem}.contact-form-input:focus{border-bottom-color:var(--primary);background:var(--surface-container)}.contact-form-textarea{line-height:1.65}.contact-form-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:8px}.contact-form-security{font-family:JetBrains Mono,ui-monospace,monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--outline);margin:0}.contact-form-submit{display:inline-flex;align-items:center;gap:8px;white-space:nowrap}.contact-form-submit .material-symbols-outlined{font-size:18px}.contact-form-confirm{font-family:JetBrains Mono,ui-monospace,monospace;font-size:12px;color:var(--on-surface-variant);margin:0}@media(max-width:640px){.contact-form-card{padding:28px 20px}.contact-form-row{grid-template-columns:1fr}.contact-form-footer{flex-direction:column;align-items:stretch}.contact-form-submit{justify-content:center}}.contact-page{min-height:calc(100vh - 56px);padding:var(--section-pad-y) var(--section-pad-x);background:var(--surface)}.contact-page-inner{max-width:var(--max-width);margin:0 auto}.contact-hero{margin-bottom:64px}.contact-hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:var(--surface-highest);border-radius:9999px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--primary);margin-bottom:20px}.contact-hero-dot{width:6px;height:6px;border-radius:50%;background:var(--primary);flex-shrink:0}.contact-hero-title{font-family:Newsreader,Georgia,serif;font-size:clamp(3rem,6vw,5rem);font-weight:700;letter-spacing:-.02em;line-height:1.05;color:var(--on-surface);margin:0 0 20px}.contact-hero-accent{color:var(--primary)}.contact-hero-sub{font-family:Inter,sans-serif;font-size:1.125rem;line-height:1.65;color:var(--on-surface-variant);max-width:560px;margin:0}.contact-page-grid{display:grid;grid-template-columns:5fr 7fr;gap:32px;align-items:stretch}.contact-page-left,.contact-page-right{display:flex;flex-direction:column}.contact-page-left .contact-info-card,.contact-page-right .contact-form-card{flex:1}@media(max-width:960px){.contact-page-grid{grid-template-columns:1fr}}.chat-popup{position:fixed;opacity:0;pointer-events:none;width:420px;bottom:90px;right:35px;overflow:hidden;background:#f9f9fc;border-radius:16px;box-shadow:0 20px 40px #1a1c1e1a,0 4px 12px #1a1c1e0f}.container.show-chat .chat-popup{opacity:1;pointer-events:auto}.container.show-chat #chat-toggler{transform:rotate(90deg)}.chat-popup .chat-header{display:flex;padding:15px 22px;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#0041c8,#05f);color:#fff}.chat-header .header-info{display:flex;gap:10px;align-items:center}.header-info .icon-wrapper{height:35px;width:35px;padding:8px 6px 6px;flex-shrink:0;color:#05f;background:#fff;border-radius:50%}.header-info .logo-text{color:#fff;font-size:1.1rem;font-weight:600;font-family:Manrope,sans-serif;margin:0}.chat-header button{height:40px;width:40px;border:none;outline:none;color:#fff;cursor:pointer;font-size:1.2rem;padding-top:2px;margin-right:-10px;border-radius:50%;background:none;transition:background .2s ease}.chat-header button:hover{background:#ffffff26}.chat-body{height:460px;overflow-y:auto;display:flex;flex-direction:column;gap:20px;padding:25px 22px;margin-bottom:82px;scrollbar-width:thin;scrollbar-color:#b6c4ff transparent}.chat-body .message{display:flex;gap:11px;align-items:center}.chat-body .message.error .message-text{color:#ba1a1a}.chat-body .bot-message .svg{height:35px;width:35px;padding:6px;flex-shrink:0;border-radius:50%}.chat-body .message .message-text{max-width:70%;padding:12px 16px;word-wrap:break-word;white-space:pre-line;font-size:.9375rem;font-family:Inter,sans-serif;line-height:1.55}.chat-body .bot-message .message-text{background:#eeeef0;color:#1a1c1e;border-radius:15px 15px 15px 3px;color:#060911}.chat-body .user-message{flex-direction:column;align-items:flex-end;color:#fff}.chat-body .user-message .message-text{background:linear-gradient(135deg,#0041c8,#05f);color:#fff;border-radius:15px 15px 3px}.chat-footer{position:absolute;bottom:0;width:100%;background:#f9f9fc;padding:15px 22px 20px}.chat-footer .chat-form{display:flex;align-items:center;background:#fff;outline:1px solid rgba(195,197,217,.4);border-radius:32px;box-shadow:0 0 8px #1a1c1e0a}.chat-footer .chat-form:focus-within{outline:2px solid #0055ff}.chat-footer .message-input{border:none;outline:none;background:none;height:47px;padding:0 17px;font-size:.9375rem;font-family:Inter,sans-serif;color:#1a1c1e;width:100%}.chat-footer .message-input::placeholder{color:#737688}.chat-form button{height:35px;width:35px;color:#fff;flex-shrink:0;border-radius:50%;background:linear-gradient(135deg,#0041c8,#05f);cursor:pointer;border:none;outline:none;margin-right:6px;transition:opacity .2s ease;display:none}.chat-form button:hover{opacity:.85}.chat-form .message-input:valid~button{display:block}.wechat-fab{position:fixed;right:35px;bottom:24px;width:52px;height:52px;border-radius:50%;border:none;background:linear-gradient(135deg,#0041c8,#05f);color:#fff;display:grid;place-items:center;box-shadow:0 12px 24px #0055ff40;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease}.wechat-fab:hover{transform:translateY(-2px);box-shadow:0 16px 30px #0055ff59}.wechat-fab svg{font-size:22px}
