*,:before,:after{box-sizing:border-box}:root{--font-heading:"Poppins", "Noto Sans SC", system-ui, sans-serif;--font-body:"Lato", "Noto Sans SC", system-ui, sans-serif;--accent:#7c6fe0;--accent-green:#83ffc1;--accent-pink:#ff94db;--accent-yellow:#ffe780;font-family:var(--font-body);color:#1a1a1a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;font-size:16px;line-height:1.5}body{margin:0}#root{width:100%;min-height:100svh}h1,h2,h3{font-family:var(--font-heading);color:#111;margin:0;font-weight:700}p{margin:0}button{font-family:inherit}:root{--lp-bg:#f5f2e8;--lp-bg-warm:#ede9dc;--lp-bg-card:#fff;--lp-ink:#2d2a26;--lp-ink-2:#4a4640;--lp-muted:#8a857d;--lp-accent:#7c6fe0;--lp-accent-soft:#b8a9e8;--lp-coral:#f4a89a;--lp-sage:#a8d8b9;--lp-peach:#f8d5c8;--lp-lavender:#e8e0f4;--font-display:"Poppins", "Noto Sans SC", system-ui, sans-serif;--font-body:"Lato", "Noto Sans SC", system-ui, sans-serif;--r-sm:12px;--r-md:20px;--r-lg:28px;--r-xl:40px;--gut:clamp(20px, 6vw, 100px);--max-w:1120px}.lp{background:var(--lp-bg);color:var(--lp-ink);font-family:var(--font-body);min-height:100vh;overflow-x:hidden}.lp *,.lp :before,.lp :after{box-sizing:border-box;margin:0}.reveal{opacity:0;transition:opacity .7s cubic-bezier(.23,1,.32,1),transform .7s cubic-bezier(.23,1,.32,1);transform:translateY(32px)}.reveal.revealed{opacity:1;transform:translateY(0)}.lp-auth-error{z-index:1000;color:#fff;background:#d94f4f;justify-content:center;align-items:center;gap:12px;padding:12px 20px;font-size:14px;display:flex;position:fixed;top:0;left:0;right:0}.lp-auth-error button{color:#fff;cursor:pointer;background:0 0;border:none;font-size:20px}.lp-nav{z-index:100;padding:0 var(--gut);transition:background .35s,box-shadow .35s,-webkit-backdrop-filter .35s,backdrop-filter .35s;position:fixed;top:0;left:0;right:0}.lp-nav--scrolled{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#f5f2e8eb;box-shadow:0 1px #0000000f}.lp-nav-inner{max-width:var(--max-w);justify-content:space-between;align-items:center;height:64px;margin:0 auto;display:flex}.lp-logo{font-family:var(--font-display);color:var(--lp-ink);letter-spacing:-.02em;font-size:22px;font-weight:700;text-decoration:none}.lp-nav-links{align-items:center;gap:8px;display:flex}.lp-nav-link{cursor:pointer;font-family:var(--font-body);color:var(--lp-ink-2);background:0 0;border:none;border-radius:999px;padding:8px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:background .2s,color .2s}.lp-nav-link:hover{color:var(--lp-ink);background:#0000000d}.lp-nav-lang{font-weight:700}.lp-nav-auth-area{margin-left:4px}.lp-nav-user{position:relative}.lp-nav-avatar-btn{cursor:pointer;background:0 0;border:none;border-radius:999px;align-items:center;gap:8px;padding:4px 8px;transition:background .2s;display:flex}.lp-nav-avatar-btn:hover{background:#0000000d}.lp-nav-avatar{border-radius:50%;width:28px;height:28px}.lp-nav-avatar-fallback{background:var(--lp-accent-soft);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}.lp-nav-username{color:var(--lp-ink-2);font-size:13px;font-weight:500}.lp-nav-dropdown{background:var(--lp-bg-card);border-radius:var(--r-sm);min-width:160px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 30px #0000001f}.lp-nav-dropdown-item{width:100%;color:var(--lp-ink-2);text-align:left;cursor:pointer;background:0 0;border:none;padding:10px 16px;font-size:14px;text-decoration:none;transition:background .15s;display:block}.lp-nav-dropdown-item:hover{background:#0000000a}.lp-nav-dropdown-item--danger{color:#d94f4f}.lp-nav-signin-btn{color:#fff;background:var(--lp-accent);border-radius:999px;padding:8px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:opacity .2s}.lp-nav-signin-btn:hover{opacity:.88}.lp-nav-burger{cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:36px;height:36px;display:none}.lp-nav-burger span{background:var(--lp-ink);border-radius:2px;width:20px;height:2px;display:block}.lp-mobile-menu{background:#f5f2e8f5;flex-direction:column;gap:4px;padding:8px 16px 16px;display:none}.lp-mobile-menu button,.lp-mobile-menu a{cursor:pointer;font-family:var(--font-body);color:var(--lp-ink-2);text-align:left;background:0 0;border:none;padding:10px 0;font-size:15px;font-weight:500;text-decoration:none}@media (width<=720px){.lp-nav-links{display:none}.lp-nav-burger,.lp-mobile-menu{display:flex}}.lp-hero{justify-content:center;align-items:center;min-height:100dvh;display:flex;position:relative;overflow:hidden}.lp-hero-bg{z-index:0;background:var(--lp-bg);position:absolute;inset:0}.lp-hero-video{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.lp-hero-overlay{background:linear-gradient(#2d2a2659 0%,#2d2a268c 50%,#2d2a26b3 100%);position:absolute;inset:0}.lp-hero--no-video .lp-hero-overlay{background:0 0}.lp-hero--no-video .lp-hero-h1{color:var(--lp-ink)}.lp-hero--no-video .lp-hero-sub{color:var(--lp-ink-2)}.lp-hero--no-video .lp-btn--hero{background:var(--lp-accent);color:#fff;box-shadow:0 4px 20px #7c6fe04d}.lp-hero--no-video .lp-btn--hero:hover{box-shadow:0 6px 28px #7c6fe066}.lp-hero--no-video .lp-btn--hero-ghost{color:var(--lp-ink-2);border-color:#0000001f}.lp-hero--no-video .lp-btn--hero-ghost:hover{color:var(--lp-ink);border-color:#00000040}.lp-hero--no-video .lp-scroll-hint span{border-color:#00000026}.lp-hero--no-video .lp-scroll-hint span:after{background:#00000040}.lp-hero-inner{z-index:1;max-width:var(--max-w);width:100%;padding:100px var(--gut) 80px;align-items:center;gap:clamp(40px,6vw,100px);display:flex;position:relative}.lp-hero-content{flex:1;max-width:560px}.lp-hero-h1{font-family:var(--font-display);letter-spacing:-.03em;color:#fff;font-size:clamp(42px,6.5vw,72px);font-weight:800;line-height:1.06}.lp-hero-h1-em{background:linear-gradient(135deg, var(--lp-accent-soft) 0%, var(--lp-coral) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.lp-hero-sub{color:#ffffffc7;max-width:460px;margin-top:20px;font-size:clamp(16px,2vw,20px);line-height:1.6}.lp-hero-actions{flex-wrap:wrap;gap:12px;margin-top:36px;display:flex}.lp-btn--hero{color:var(--lp-ink);background:#fff;box-shadow:0 4px 20px #00000026}.lp-btn--hero:hover{box-shadow:0 6px 28px #00000038}.lp-btn--hero-ghost{color:#ffffffd9;background:0 0;border:1.5px solid #ffffff4d}.lp-btn--hero-ghost:hover{color:#fff;border-color:#fff9}.lp-scroll-hint{z-index:1;position:absolute;bottom:28px;left:50%;transform:translate(-50%)}.lp-scroll-hint span{border:2px solid #ffffff59;border-radius:999px;width:24px;height:40px;display:block;position:relative}.lp-scroll-hint span:after{content:"";background:#ffffff80;border-radius:4px;width:4px;height:8px;animation:2s ease-in-out infinite scroll-dot;position:absolute;top:8px;left:50%;transform:translate(-50%)}@keyframes scroll-dot{0%,to{opacity:1;transform:translate(-50%)translateY(0)}50%{opacity:.3;transform:translate(-50%)translateY(10px)}}.lp-hero-visual{flex:none;justify-content:center;align-items:center;display:flex}.lp-creature{flex-direction:column;align-items:center;width:280px;height:300px;display:flex;position:relative}.lp-creature-body{background:linear-gradient(160deg, var(--lp-accent-soft) 0%, var(--lp-lavender) 100%);border-radius:50% 50% 48% 48%/50% 50% 42% 42%;width:220px;height:220px;animation:4s ease-in-out infinite creature-float;position:relative;box-shadow:0 20px 60px #7c6fe02e}.lp-creature-face{width:120px;height:70px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.lp-creature-eye{background:#fff;border-radius:50%;width:32px;height:36px;animation:4s ease-in-out infinite creature-blink;position:absolute;top:8px}.lp-creature-eye--l{left:12px}.lp-creature-eye--r{right:12px}.lp-creature-pupil{background:var(--lp-ink);border-radius:50%;width:14px;height:16px;position:absolute;bottom:8px;left:50%;transform:translate(-50%)}.lp-creature-pupil:after{content:"";background:#fff;border-radius:50%;width:5px;height:5px;position:absolute;top:3px;right:3px}.lp-creature-mouth{border-bottom:3px solid var(--lp-ink);border-radius:0 0 50% 50%;width:20px;height:10px;position:absolute;bottom:6px;left:50%;transform:translate(-50%)}.lp-creature-cheek{background:var(--lp-coral);opacity:.45;border-radius:50%;width:28px;height:18px;position:absolute;top:55%}.lp-creature-cheek--l{left:14px}.lp-creature-cheek--r{right:14px}.lp-creature-shadow{background:radial-gradient(#0000001a 0%,#0000 70%);width:120px;height:16px;margin-top:16px;animation:4s ease-in-out infinite creature-shadow}@keyframes creature-float{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}@keyframes creature-shadow{0%,to{opacity:1;transform:scaleX(1)}50%{opacity:.6;transform:scaleX(.82)}}@keyframes creature-blink{0%,42%,46%,to{transform:scaleY(1)}44%{transform:scaleY(.08)}}@media (width<=720px){.lp-hero-inner{text-align:center;flex-direction:column-reverse;padding-top:120px}.lp-hero-sub{margin-left:auto;margin-right:auto}.lp-hero-actions{justify-content:center}.lp-creature{width:200px;height:220px}.lp-creature-body{width:160px;height:160px}}.lp-section{max-width:var(--max-w);padding:clamp(60px, 10vw, 120px) var(--gut);margin:0 auto}.lp-eyebrow{font-family:var(--font-body);letter-spacing:.12em;text-transform:uppercase;color:var(--lp-accent);margin-bottom:14px;font-size:12px;font-weight:700}.lp-h2{font-family:var(--font-display);letter-spacing:-.03em;color:var(--lp-ink);margin-bottom:20px;font-size:clamp(32px,4.5vw,52px);font-weight:700;line-height:1.1}.lp-h2-em{color:var(--lp-accent)}.lp-body{color:var(--lp-ink-2);max-width:560px;font-size:clamp(16px,1.8vw,19px);line-height:1.65}.lp-btn{font-family:var(--font-body);cursor:pointer;border:none;border-radius:999px;justify-content:center;align-items:center;padding:14px 32px;font-size:15px;font-weight:600;text-decoration:none;transition:transform .2s,box-shadow .2s,opacity .2s;display:inline-flex}.lp-btn:hover{transform:translateY(-1px)}.lp-btn:active{transform:translateY(0)}.lp-btn--primary{background:var(--lp-accent);color:#fff;box-shadow:0 4px 20px #7c6fe04d}.lp-btn--primary:hover{box-shadow:0 6px 28px #7c6fe066}.lp-btn--ghost{color:var(--lp-ink-2);background:0 0;border:1.5px solid #0000001f}.lp-btn--ghost:hover{color:var(--lp-ink);border-color:#00000040}.lp-btn--outline{color:var(--lp-ink);border:2px solid var(--lp-ink);background:0 0}.lp-btn--outline:hover{background:var(--lp-ink);color:var(--lp-bg)}.lp-opensource{text-align:center}.lp-opensource .lp-body{margin:0 auto 36px}.lp-opensource-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.lp-footer{padding:32px var(--gut);border-top:1px solid #0000000f}.lp-footer-inner{max-width:var(--max-w);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin:0 auto;display:flex}.lp-footer-links{color:var(--lp-muted);gap:20px;font-size:13px;display:flex}.lp-footer-links a{color:var(--lp-muted);text-decoration:none}.lp-footer-links a:hover{color:var(--lp-ink)}.lp-footer-copy{color:var(--lp-muted);font-size:13px}@media (width<=720px){.lp-footer-inner{text-align:center;flex-direction:column;align-items:center}}.pp-page{color:#fff;min-height:100vh;font-family:var(--font-body), system-ui, sans-serif;background:#0a0a0a;justify-content:center;align-items:center;display:flex}.pp-inner{text-align:center}.pp-back{color:#fff6;font-size:14px;text-decoration:none}.pp-title{font-family:var(--font-heading), system-ui, sans-serif;margin:24px 0 8px;font-size:32px}.pp-coming-soon{color:#fff6;margin-bottom:24px}.pp-cta{color:#fff;background:#2563eb;border-radius:99px;padding:10px 24px;font-weight:700;text-decoration:none;display:inline-block}.signin-page{background:#f5f2e8;grid-template-columns:1fr 1fr;min-height:100vh;font-family:Lato,Noto Sans SC,system-ui,sans-serif;display:grid}.signin-left{box-sizing:border-box;border-right:1px solid #0000000f;justify-content:center;align-items:center;padding:48px 40px;display:flex;position:relative}.signin-left:before{content:"";pointer-events:none;background:radial-gradient(circle,#7c6fe00f 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;top:20%;left:-10%}.signin-form-wrap{flex-direction:column;gap:28px;width:100%;max-width:360px;display:flex}.signin-logo{align-items:center;gap:10px;text-decoration:none;display:flex}.signin-logo-icon{font-size:24px}.signin-logo-name{color:#2d2a26;letter-spacing:-.02em;font-family:Poppins,Noto Sans SC,system-ui,sans-serif;font-size:22px;font-weight:700}.signin-copy{flex-direction:column;gap:8px;display:flex}.signin-h1{color:#2d2a26;letter-spacing:-.03em;margin:0;font-family:Poppins,Noto Sans SC,system-ui,sans-serif;font-size:32px;font-weight:700;line-height:1.1}.signin-sub{color:#4a4640;max-width:32ch;margin:0;font-size:14px;font-weight:500;line-height:1.6}.signin-btns{flex-direction:column;gap:10px;display:flex}.signin-btn{cursor:pointer;letter-spacing:.01em;box-sizing:border-box;border:none;border-radius:999px;justify-content:center;align-items:center;gap:10px;width:100%;padding:14px 20px;font-family:Lato,Noto Sans SC,system-ui,sans-serif;font-size:14px;font-weight:700;transition:transform .15s,box-shadow .15s;display:flex}.signin-btn:hover{transform:translateY(-2px)}.signin-btn--github{color:#fff;background:#2d2a26;box-shadow:0 4px 20px #0000001a}.signin-btn--github:hover{box-shadow:0 8px 28px #00000029}.signin-btn--google{color:#2d2a26;box-shadow:none;background:#fff;border:1px solid #00000014}.signin-btn--google:hover{background:#00000008}.signin-hint{color:#8a857d;text-align:center;margin:0;font-size:13px;font-weight:500}.signin-skip{color:#7c6fe0;font-weight:700;text-decoration:none;transition:opacity .15s}.signin-skip:hover{opacity:.8}.signin-tos{color:#8a857d;text-align:center;margin:0;font-size:11px;line-height:1.6}.signin-tos-link{color:#4a4640;cursor:pointer;transition:color .15s}.signin-tos-link:hover{color:#2d2a26}.signin-no-supabase{color:#8a857d;text-align:center;border:1px solid #0000000f;border-radius:12px;padding:16px;font-size:13px}.signin-right{box-sizing:border-box;background:#ede9dc;justify-content:center;align-items:center;padding:48px 40px;display:flex;position:relative;overflow:hidden}.signin-right:before{content:"";pointer-events:none;background-image:radial-gradient(circle,#0000000a 1px,#0000 1px);background-size:28px 28px;position:absolute;inset:0}.signin-right:after{content:"";pointer-events:none;background:radial-gradient(circle,#7c6fe00f 0%,#0000 65%);border-radius:50%;width:500px;height:500px;position:absolute;bottom:-100px;right:-100px}.signin-right-inner{z-index:1;flex-direction:column;align-items:center;gap:28px;width:100%;max-width:480px;display:flex;position:relative}.signin-right-label{color:#7c6fe0;letter-spacing:.12em;text-transform:uppercase;margin:0;font-family:Poppins,Noto Sans SC,system-ui,sans-serif;font-size:13px;font-weight:700}.signin-states-grid{grid-template-columns:repeat(3,1fr);gap:12px;width:100%;display:grid}.signin-state-card{cursor:default;background:#fff;border:1px solid #0000000f;border-radius:20px;transition:transform .2s,border-color .2s,box-shadow .2s;overflow:hidden}.signin-state-card:hover{border-color:#0000001f;transform:translateY(-4px)scale(1.02);box-shadow:0 8px 24px #0000000f}.signin-state-img{aspect-ratio:1;background:#00000005;justify-content:center;align-items:center;display:flex;position:relative}.signin-state-img:before{content:"";background:radial-gradient(circle at 50% 60%, var(--glow,#7c6fe0) 0%, transparent 65%);opacity:.12;position:absolute;inset:0}.signin-state-emoji{z-index:1;filter:drop-shadow(0 4px 12px var(--glow,transparent));font-size:40px;position:relative}.signin-state-info{border-top:1px solid #0000000f;flex-direction:column;gap:2px;padding:10px 14px 12px;display:flex}.signin-state-name{color:#2d2a26;letter-spacing:-.01em;font-family:Poppins,Noto Sans SC,system-ui,sans-serif;font-size:13px;font-weight:700}.signin-state-en{color:#8a857d;letter-spacing:.05em;text-transform:uppercase;font-size:10px;font-weight:600}.signin-right-sub{color:#8a857d;text-align:center;max-width:36ch;margin:0;font-size:13px;font-weight:500;line-height:1.6}@media (width<=860px){.signin-page{grid-template-columns:1fr}.signin-right{display:none}.signin-left{border-right:none;min-height:100vh;padding:40px 24px}}.chat-page{color:#1a1a1a;background:#fffbf5;height:100vh;display:flex}.chat-page.dark{color:#e8e8e8;background:#111}.chat-sidebar{background:#fff;border-right:1px solid #eee;flex-direction:column;flex-shrink:0;width:260px;display:flex}.dark .chat-sidebar{background:#1a1a1a;border-color:#222}.chat-new-btn{color:#333;cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font-heading);background:0 0;border:1.5px solid #e5e7eb;border-radius:12px;margin:16px;padding:10px;transition:all .15s}.chat-new-btn:hover{background:#f8f8f8}.dark .chat-new-btn{color:#ccc;border-color:#333}.dark .chat-new-btn:hover{background:#222}.chat-conv-list{flex:1;padding:0 8px;overflow-y:auto}.chat-conv-item{cursor:pointer;border-radius:10px;align-items:center;gap:8px;padding:10px 12px;transition:background .15s;display:flex}.chat-conv-item:hover{background:#f5f5f5}.chat-conv-item.active{background:#efe8ff}.dark .chat-conv-item:hover{background:#222}.dark .chat-conv-item.active{background:#2a2040}.chat-conv-title{color:#666;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;overflow:hidden}.chat-conv-item.active .chat-conv-title{color:#333;font-weight:600}.dark .chat-conv-title{color:#999}.dark .chat-conv-item.active .chat-conv-title{color:#eee}.chat-conv-del{color:#ccc;cursor:pointer;opacity:0;background:0 0;border:none;padding:0 4px;font-size:16px;line-height:1;transition:opacity .15s}.chat-conv-item:hover .chat-conv-del{opacity:1}.chat-conv-del:hover{color:#ff6b6b}.chat-main{flex-direction:column;flex:1;min-width:0;display:flex}.chat-header{border-bottom:1px solid #eee;flex-shrink:0;align-items:center;gap:12px;height:56px;padding:0 20px;display:flex}.dark .chat-header{border-color:#222}.chat-menu-btn{color:#999;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:20px;display:none}.chat-header-title{font-family:var(--font-heading);color:#333;font-size:18px;font-weight:700}.dark .chat-header-title{color:#eee}.chat-theme-btn,.chat-memory-btn{cursor:pointer;opacity:.5;background:0 0;border:none;border-radius:8px;padding:4px 8px;font-size:18px;transition:all .15s}.chat-theme-btn:hover,.chat-memory-btn:hover{opacity:1;background:#f0f0f0}.dark .chat-theme-btn:hover,.dark .chat-memory-btn:hover{background:#333}.chat-memory-btn{margin-left:auto}.chat-messages{flex-direction:column;flex:1;gap:16px;padding:24px 20px;display:flex;overflow-y:auto}.chat-empty{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.chat-empty-emoji{margin-bottom:16px;font-size:48px}.chat-empty p{color:#333;margin:0;font-size:18px;font-weight:600}.chat-empty-sub{color:#999!important;margin-top:8px!important;font-size:14px!important;font-weight:400!important}.dark .chat-empty p{color:#ddd}.dark .chat-empty-sub{color:#666!important}.chat-bubble{align-items:flex-start;gap:10px;max-width:80%;display:flex}.chat-bubble.user{flex-direction:row-reverse;align-self:flex-end}.chat-bubble.assistant{align-self:flex-start}.chat-avatar{background:#f0f0f0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:20px;display:flex}.dark .chat-avatar{background:#2a2a2a}.chat-bubble-content{white-space:pre-wrap;word-break:break-word;border-radius:18px;padding:10px 16px;font-size:15px;line-height:1.6}.chat-bubble.user .chat-bubble-content{background:var(--accent,#8b8bff);color:#fff;border-bottom-right-radius:4px}.chat-bubble.assistant .chat-bubble-content{color:#1a1a1a;background:#f5f0ea;border-bottom-left-radius:4px}.dark .chat-bubble.assistant .chat-bubble-content{color:#ddd;background:#222}.chat-typing{gap:4px;display:flex;padding:14px 20px!important}.chat-typing span{background:#999;border-radius:50%;width:6px;height:6px;animation:1.4s infinite chatTyping}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes chatTyping{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.chat-input-wrap{align-items:flex-end;gap:8px;padding:12px 20px 24px;display:flex}.chat-input{resize:none;color:#1a1a1a;background:#fff;border:1.5px solid #e5e7eb;border-radius:16px;outline:none;flex:1;max-height:120px;padding:12px 16px;font-family:inherit;font-size:15px;line-height:1.5;transition:border-color .15s}.chat-input:focus{border-color:var(--accent,#8b8bff)}.chat-input::placeholder{color:#bbb}.dark .chat-input{color:#eee;background:#1a1a1a;border-color:#333}.dark .chat-input:focus{border-color:var(--accent,#8b8bff)}.dark .chat-input::placeholder{color:#555}.chat-send-btn{background:var(--accent,#8b8bff);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;width:40px;height:40px;font-size:18px;font-weight:700;transition:background .15s,opacity .15s}.chat-send-btn:disabled{opacity:.3;cursor:default}.chat-send-btn:not(:disabled):hover{filter:brightness(.9)}.chat-memory-panel{background:#fff;border-left:1px solid #eee;flex-direction:column;flex-shrink:0;width:320px;display:flex;overflow:hidden}.dark .chat-memory-panel{background:#1a1a1a;border-color:#222}.chat-memory-header{font-family:var(--font-heading);color:#333;border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:16px;font-size:14px;font-weight:600;display:flex}.dark .chat-memory-header{color:#ccc;border-color:#222}.chat-memory-actions{align-items:center;gap:8px;display:flex}.chat-memory-consolidate{color:#888;cursor:pointer;background:0 0;border:1px solid #ddd;border-radius:8px;padding:5px 10px;font-family:inherit;font-size:12px;transition:all .15s}.chat-memory-consolidate:hover:not(:disabled){color:#333;background:#f8f8f8}.chat-memory-consolidate:disabled{opacity:.3;cursor:default}.dark .chat-memory-consolidate{color:#888;border-color:#333}.chat-memory-close{color:#ccc;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:18px}.chat-memory-list{flex-direction:column;flex:1;gap:8px;padding:12px;display:flex;overflow-y:auto}.chat-memory-empty{color:#bbb;text-align:center;padding:40px 16px;font-size:13px}.chat-memory-item{background:#faf8f5;border:1px solid #eee;border-radius:12px;padding:10px 12px}.dark .chat-memory-item{background:#222;border-color:#333}.chat-memory-item-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.chat-memory-type{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.05em;border-radius:6px;flex-shrink:0;padding:2px 6px;font-size:10px;font-weight:600}.chat-memory-type--user{color:#3b82f6;background:#e8f0fe}.chat-memory-type--feedback{color:#a855f7;background:#f3e8ff}.chat-memory-type--life{color:#22c55e;background:#e8faf0}.chat-memory-type--reference{color:#f59e0b;background:#fef3e2}.dark .chat-memory-type--user{color:#60a5fa;background:#1e3a5f}.dark .chat-memory-type--feedback{color:#c084fc;background:#3b1f4e}.dark .chat-memory-type--life{color:#86efac;background:#1f3d1f}.dark .chat-memory-type--reference{color:#fbbf24;background:#3d3015}.chat-memory-name{color:#333;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:600;overflow:hidden}.dark .chat-memory-name{color:#ccc}.chat-memory-del{color:#ddd;cursor:pointer;opacity:0;background:0 0;border:none;padding:0 2px;font-size:14px;transition:opacity .15s}.chat-memory-item:hover .chat-memory-del{opacity:1}.chat-memory-del:hover{color:#ff6b6b}.chat-memory-content{color:#888;word-break:break-word;margin:0;font-size:12px;line-height:1.5}.chat-login{color:#888;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;display:flex}.chat-login-btn{background:var(--accent,#8b8bff);color:#fff;font-size:14px;font-weight:700;font-family:var(--font-heading);border-radius:99px;padding:10px 28px;text-decoration:none}.chat-relationship{background:#faf8f5;border:1px solid #eee;border-radius:12px;margin:0 16px 12px;padding:12px}.dark .chat-relationship{background:#222;border-color:#333}.chat-relationship-stage{align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.chat-relationship-emoji{font-size:16px}.chat-relationship-label{color:#333}.dark .chat-relationship-label{color:#ddd}.chat-relationship-trust{color:#999;font-size:11px;font-weight:400}.chat-relationship-bar{background:#e5e7eb;border-radius:2px;height:4px;margin-top:8px;overflow:hidden}.dark .chat-relationship-bar{background:#333}.chat-relationship-fill{background:linear-gradient(90deg,#8b8bff,#a855f7,#f59e0b);border-radius:2px;height:100%;transition:width .5s}.chat-relationship-hint{color:#999;margin:6px 0 0;font-size:11px;line-height:1.4}.chat-onboarding{margin-top:24px}.chat-onboarding-title{color:#999;margin-bottom:12px;font-size:13px;font-weight:400}.chat-onboarding-suggestions{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.chat-suggestion{color:#666;cursor:pointer;background:0 0;border:1.5px solid #e5e7eb;border-radius:99px;padding:8px 16px;font-family:inherit;font-size:13px;transition:all .15s}.chat-suggestion:hover{color:#333;background:#f5f0ea;border-color:#d5d0ca}.dark .chat-suggestion{color:#999;border-color:#333}.dark .chat-suggestion:hover{color:#eee;background:#222;border-color:#555}.chat-checkin{align-items:flex-start;gap:10px;max-width:80%;margin:auto 0;padding:16px;display:flex}.chat-checkin-content{background:linear-gradient(135deg,#f5f0ea,#efe8ff);border-radius:18px 18px 18px 4px;padding:14px 18px}.dark .chat-checkin-content{background:linear-gradient(135deg,#222,#2a2040)}.chat-checkin-content p{margin:0;font-size:15px;line-height:1.6}@media (width<=768px){.chat-sidebar{z-index:200;box-shadow:none;transition:left .25s;position:fixed;top:0;bottom:0;left:-280px}.chat-sidebar.open{left:0;box-shadow:20px 0 60px #00000026}.dark .chat-sidebar.open{box-shadow:20px 0 60px #00000080}.chat-menu-btn{display:block}.chat-bubble{max-width:90%}.chat-memory-panel{z-index:200;width:85%;max-width:320px;position:fixed;top:0;bottom:0;right:0;box-shadow:-20px 0 60px #00000026}.dark .chat-memory-panel{box-shadow:-20px 0 60px #00000080}}.blog-page{background:#f5f2e8;min-height:100vh}.blog-nav{justify-content:space-between;align-items:center;max-width:1120px;height:64px;margin:0 auto;padding:0 clamp(20px,6vw,100px);display:flex}.blog-nav-logo{color:#2d2a26;letter-spacing:-.02em;font-family:Poppins,Noto Sans SC,system-ui,sans-serif;font-size:22px;font-weight:700;text-decoration:none}.blog-nav-right{align-items:center;gap:8px;display:flex}.blog-nav-link{color:#4a4640;border-radius:999px;padding:8px 14px;font-family:Lato,Noto Sans SC,system-ui,sans-serif;font-size:14px;font-weight:500;text-decoration:none;transition:background .2s,color .2s}.blog-nav-link:hover{color:#2d2a26;background:#0000000d}.blog-nav-cta{color:#fff;background:#7c6fe0;border-radius:999px;padding:8px 20px;font-family:Lato,Noto Sans SC,system-ui,sans-serif;font-size:14px;font-weight:600;text-decoration:none;transition:opacity .2s}.blog-nav-cta:hover{opacity:.88}.blog-hero{max-width:1120px;margin:0 auto;padding:80px clamp(20px,6vw,100px) 48px}.blog-eyebrow{text-transform:uppercase;letter-spacing:.12em;color:#7c6fe0;margin:0 0 14px;font-family:Lato,Noto Sans SC,system-ui,sans-serif;font-size:12px;font-weight:700}.blog-h1{letter-spacing:-.03em;color:#2d2a26;margin:0 0 16px;font-family:Poppins,Noto Sans SC,system-ui,sans-serif;font-size:clamp(32px,5vw,52px);font-weight:700;line-height:1.1}.blog-intro{color:#4a4640;max-width:480px;margin:0;font-size:16px;line-height:1.65}.blog-list{flex-direction:column;gap:16px;max-width:1120px;margin:0 auto;padding:0 clamp(20px,6vw,100px) 100px;display:flex}.blog-card{color:inherit;background:#fff;border:1px solid #0000000d;border-radius:28px;text-decoration:none;transition:transform .3s,box-shadow .3s,border-color .3s;display:block;overflow:hidden}.blog-card:hover{border-color:#00000014;transform:translateY(-2px);box-shadow:0 12px 40px #0000000f}.blog-card-inner{padding:32px 36px}.blog-card-tag{text-transform:uppercase;letter-spacing:.08em;color:#7c6fe0;background:#e8e0f4;border-radius:999px;margin-bottom:16px;padding:5px 12px;font-family:Lato,Noto Sans SC,system-ui,sans-serif;font-size:11px;font-weight:700;display:inline-block}.blog-card-title{letter-spacing:-.02em;color:#2d2a26;margin:0 0 8px;font-family:Poppins,Noto Sans SC,system-ui,sans-serif;font-size:clamp(20px,3vw,26px);font-weight:700;line-height:1.3}.blog-card-sub{color:#4a4640;margin:0;font-size:15px;line-height:1.6}.blog-card-footer{border-top:1px solid #0000000f;justify-content:space-between;align-items:center;margin-top:20px;padding-top:16px;display:flex}.blog-card-date{color:#8a857d;font-size:13px;font-weight:500}.blog-card-arrow{color:#8a857d;font-size:13px;font-weight:600;transition:color .2s}.blog-card:hover .blog-card-arrow{color:#7c6fe0}@media (width<=600px){.blog-nav{padding:0 20px}.blog-hero{padding:60px 20px 32px}.blog-list{padding:0 20px 60px}.blog-card-inner{padding:20px 24px}.blog-card{border-radius:20px}}.bp-page{background:#f5f2e8;min-height:100vh}.bp-inner{max-width:760px;margin:0 auto;padding:40px 24px 100px}.bp-back{color:#4a4640;font-size:14px;font-weight:500;text-decoration:none;transition:color .2s}.bp-back:hover{color:#2d2a26}.bp-meta{align-items:center;gap:12px;margin-top:32px;display:flex}.bp-tag{color:#7c6fe0;text-transform:uppercase;letter-spacing:.06em;background:#e8e0f4;border-radius:999px;padding:4px 12px;font-size:12px;font-weight:700}.bp-date{color:#8a857d;font-size:13px}.bp-title{letter-spacing:-.03em;color:#2d2a26;margin:12px 0 8px;font-family:Poppins,Noto Sans SC,system-ui,sans-serif;font-size:clamp(28px,5vw,42px);font-weight:800;line-height:1.15}.bp-subtitle{color:#4a4640;margin:0 0 40px;font-size:18px;line-height:1.6}.bp-content{color:#2d2a26;font-size:17px;line-height:1.8}.bp-content h2{letter-spacing:-.02em;color:#2d2a26;margin:56px 0 16px;font-family:Poppins,Noto Sans SC,system-ui,sans-serif;font-size:24px;font-weight:700}.bp-content p{margin:0 0 20px}.bp-content ul{margin:0 0 24px;padding-left:24px}.bp-content li{margin-bottom:8px}.bp-content strong{color:#2d2a26}.bp-content code{background:#ede9dc;border-radius:4px;padding:2px 6px;font-size:14px}.bp-lead{color:#2d2a26;border-left:3px solid #7c6fe0;margin:0 0 32px;padding-left:20px;font-size:20px;line-height:1.7}.bp-callout{background:#ede9dc;border:1px solid #0000000f;border-radius:20px;align-items:flex-start;gap:14px;margin:24px 0 32px;padding:20px;display:flex}.bp-callout-icon{flex-shrink:0;margin-top:2px;font-size:24px}.bp-callout p{color:#4a4640;margin:0;font-size:15px}.bp-gallery{background:#0d1117;border:1px solid #00000014;border-radius:20px;margin:24px 0 40px;overflow:hidden}.bp-gallery-grid{background:#21262d;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1px;display:grid}.bp-species-btn{cursor:pointer;color:#8b949e;background:#0d1117;border:none;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;transition:background .15s;display:flex}.bp-species-btn:hover{background:#161b22}.bp-species-btn--active{color:#e6edf3;background:#1c2128}.bp-species-name{white-space:nowrap;font-size:11px;font-weight:600}.bp-species-detail{color:#e6edf3;border-top:1px solid #21262d;align-items:center;gap:24px;padding:24px;display:flex}.bp-species-info h3{color:#e6edf3;margin:0 0 8px;font-size:18px}.bp-species-id{color:#8b949e;font-size:14px;font-weight:400}.bp-species-info p{color:#8b949e;margin:0;font-size:14px;line-height:1.5}.bp-ascii{color:#e6edf3;white-space:pre;-webkit-user-select:none;user-select:none;margin:0;font-family:Space Mono,Courier New,monospace;font-size:14px;line-height:1.2}.bp-ascii--sm{font-size:9px;line-height:1.1}.bp-feature-grid{grid-template-columns:1fr 1fr;gap:16px;margin:24px 0 32px;display:grid}.bp-feature{background:#fff;border:1px solid #0000000f;border-radius:20px;padding:20px;transition:transform .25s,box-shadow .25s}.bp-feature:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000000d}.bp-feature-icon{margin-bottom:8px;font-size:28px;display:block}.bp-feature h3{color:#2d2a26;margin:0 0 10px;font-size:16px;font-weight:700}.bp-feature p{color:#4a4640;margin:0;font-size:14px;line-height:1.5}.bp-eyes-row,.bp-hats-row{flex-wrap:wrap;gap:8px;display:flex}.bp-eye-chip{color:#e6edf3;background:#0d1117;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-family:Space Mono,monospace;font-size:18px;display:flex}.bp-hat-chip pre{color:#e6edf3;background:#0d1117;border-radius:6px;margin:0;padding:6px 8px;font-family:Space Mono,monospace;font-size:10px;line-height:1}.bp-rarity-table{background:#fff;border:1px solid #0000000f;border-radius:20px;margin:24px 0 32px;padding:20px}.bp-rarity-row{grid-template-columns:80px 100px 50px 1fr;align-items:center;gap:12px;padding:8px 0;display:grid}.bp-rarity-stars{font-size:14px}.bp-rarity-name{color:#2d2a26;font-size:14px;font-weight:700}.bp-rarity-chance{color:#8a857d;text-align:right;font-size:13px}.bp-rarity-bar{background:#ede9dc;border-radius:4px;height:8px;overflow:hidden}.bp-rarity-fill{border-radius:4px;height:100%;transition:width .5s}.bp-rarity-note{color:#8a857d;text-align:center;margin:12px 0 0;font-size:13px}.bp-reaction-grid{grid-template-columns:1fr 1fr 1fr;gap:12px;margin:24px 0 32px;display:grid}.bp-reaction-card{text-align:center;background:#fff;border:1px solid #0000000f;border-radius:20px;flex-direction:column;align-items:center;gap:6px;padding:20px 12px;display:flex}.bp-reaction-emoji{font-size:32px}.bp-reaction-card strong{color:#2d2a26;font-size:14px}.bp-reaction-text{color:#8a857d;font-family:Space Mono,monospace;font-size:12px;font-style:italic}.bp-compare-table{border:1px solid #0000000f;border-radius:20px;margin:24px 0 32px;overflow:hidden}.bp-compare-header,.bp-compare-row{grid-template-columns:80px 1fr 1fr;gap:0;display:grid}.bp-compare-header{color:#2d2a26;background:#ede9dc;font-size:14px;font-weight:700}.bp-compare-header span,.bp-compare-row span{border-bottom:1px solid #0000000f;padding:12px 16px;font-size:14px}.bp-compare-label{color:#4a4640;background:#f5f2e8;font-weight:600}.bp-compare-highlight{color:#7c6fe0;font-weight:500}.bp-demo-wrap{background:#0d1117;border:1px solid #00000014;border-radius:20px;margin:24px 0 40px;overflow:hidden}.bp-demo-btn{color:#e6edf3;cursor:pointer;background:#0d1117;border:none;width:100%;padding:56px 24px;font-size:18px;font-weight:600;transition:background .2s;display:block}.bp-demo-btn:hover{background:#161b22}.bp-demo-iframe{background:#0d1117;border:none;width:100%;height:750px}.bp-cta{text-align:center;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:56px;display:flex}.bp-cta-btn{color:#fff;background:#7c6fe0;border-radius:999px;padding:14px 32px;font-size:16px;font-weight:700;text-decoration:none;transition:transform .2s,box-shadow .2s;display:inline-block;box-shadow:0 4px 20px #7c6fe04d}.bp-cta-btn:hover{transform:translateY(-1px);box-shadow:0 6px 28px #7c6fe066}.bp-cta-ghost{color:#2d2a26;background:0 0;border:2px solid #2d2a26;border-radius:999px;padding:14px 32px;font-size:16px;font-weight:600;text-decoration:none;transition:background .2s,color .2s;display:inline-block}.bp-cta-ghost:hover{color:#f5f2e8;background:#2d2a26}@media (width<=700px){.bp-feature-grid{grid-template-columns:1fr}.bp-reaction-grid{grid-template-columns:1fr 1fr}.bp-gallery-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}.bp-demo-iframe{height:550px}.bp-species-detail{flex-direction:column}.bp-compare-header,.bp-compare-row{grid-template-columns:70px 1fr 1fr}.bp-rarity-row{grid-template-columns:60px 80px 40px 1fr}}.app{min-height:100vh;position:relative}.bg-grid{pointer-events:none;z-index:0;background-image:radial-gradient(circle,#ffffff06 1px,#0000 1px);background-size:32px 32px;position:fixed;inset:0}.app>:not(.bg-grid):not(.settings-overlay):not(.modal-overlay){z-index:1;position:relative}
