:root{--font-display:"Outfit", sans-serif;--font-body:"Noto Sans SC", sans-serif;--radius-sm:12px;--radius:18px;--radius-lg:24px;--radius-full:9999px;--transition:.35s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg:#0f0f12;--surface:#ffffff0d;--surface-hover:#ffffff14;--border:#ffffff14;--text:#f0f0f2;--text-dim:#f0f0f280;--accent:#f5b842;--accent-soft:#f5b8421f;--accent-mid:#f5b84238;--shadow:0 4px 20px #0000004d;--shadow-hover:0 8px 40px #0006}[data-theme=light]{--bg:#f8f6f1;--surface:#fff9;--surface-hover:#ffffffd9;--border:#0000000f;--text:#1a1a1a;--text-dim:#1a1a1a73;--accent:#ef9f27;--accent-soft:#ef9f271a;--accent-mid:#ef9f2733;--shadow:0 4px 20px #00000014;--shadow-hover:0 8px 40px #0000001f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100dvh;font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent;font-size:16px;line-height:1.6;transition:background .4s,color .4s;overflow-x:hidden}::-webkit-scrollbar{background:0 0;width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:999px}::selection{background:var(--accent-mid);color:var(--text)}#bg{z-index:0;background:var(--bg);transition:background .4s;position:fixed;inset:0}#bg:before{content:"";background:radial-gradient(ellipse 80% 50% at 10% 0%, var(--accent-soft) 0%, transparent 50%), radial-gradient(ellipse 60% 40% at 90% 100%, var(--accent-soft) 0%, transparent 50%);opacity:.6;z-index:0;pointer-events:none;position:fixed;inset:0}#bg:after{content:"";background-image:radial-gradient(var(--border) 1px, transparent 1px);opacity:.5;z-index:0;pointer-events:none;background-size:28px 28px;position:fixed;inset:0}#bg-img,#bg-grad{display:none}.bg-blobs{z-index:0;pointer-events:none;position:fixed;inset:0;overflow:hidden}.bg-blob{filter:blur(80px);opacity:.5;border-radius:50%;position:absolute}.bg-blob-1{background:linear-gradient(135deg, var(--accent), var(--accent-mid));width:400px;height:400px;animation:25s ease-in-out infinite blobFloat1;top:-100px;right:-80px}.bg-blob-2{background:linear-gradient(135deg,#0d9488,#0f766e);width:300px;height:300px;animation:30s ease-in-out infinite blobFloat2;bottom:-80px;left:5%}@keyframes blobFloat1{0%,to{transform:translate(0)scale(1)}25%{transform:translate(-40px,60px)scale(1.1)}50%{transform:translate(20px,40px)scale(.9)}75%{transform:translate(-20px,-20px)scale(1.05)}}@keyframes blobFloat2{0%,to{transform:translate(0)scale(1)}30%{transform:translate(50px,-30px)scale(1.15)}60%{transform:translate(-30px,40px)scale(.85)}80%{transform:translate(30px,20px)scale(1.1)}}#app{z-index:1;flex-direction:column;height:100dvh;display:flex;position:relative;overflow:hidden}.theme-toggle-track{background:var(--surface);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);cursor:pointer;touch-action:manipulation;-webkit-appearance:none;border-radius:10px;flex-shrink:0;width:36px;height:20px;transition:all .3s;position:relative}.theme-toggle-track:hover{border-color:var(--accent-mid);box-shadow:0 0 12px var(--accent-soft)}.theme-toggle-knob{background:linear-gradient(135deg, var(--accent), var(--accent-mid));width:14px;height:14px;box-shadow:0 2px 6px var(--accent-soft);border-radius:50%;transition:transform .35s cubic-bezier(.4,0,.2,1);display:block;position:absolute;top:2px;left:2px}.theme-toggle-track.light .theme-toggle-knob{transform:translate(16px)}header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:48px 18px 14px;display:flex;position:relative}.hdr-left{align-items:center;gap:12px;display:flex}.hdr-right{align-items:center;gap:10px;display:flex}.hdr-ava{border:2px solid var(--border);width:42px;height:42px;box-shadow:var(--shadow);border-radius:50%;flex-shrink:0;transition:border-color .3s;overflow:hidden}.hdr-ava:hover{border-color:var(--accent-mid)}.hdr-ava img{object-fit:cover;width:100%;height:100%;display:block}.hdr-name{font-family:var(--font-display);color:var(--text);letter-spacing:.04em;font-size:16px;font-weight:600}.hdr-sub{color:var(--text-dim);margin-top:2px;font-size:11px}.usage-pill{color:var(--text-dim);background:var(--surface);border:1px solid var(--border);letter-spacing:.03em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:20px;padding:5px 11px;font-size:11px;transition:color .3s,border-color .3s}.usage-pill.warn{color:var(--accent);border-color:var(--accent-mid)}.icon-btn{background:var(--surface);border:1px solid var(--border);width:34px;height:34px;color:var(--text);cursor:pointer;touch-action:manipulation;-webkit-appearance:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:50%;justify-content:center;align-items:center;font-size:15px;text-decoration:none;transition:all .3s;display:flex}.icon-btn:hover{background:var(--surface-hover);border-color:var(--accent-mid);color:var(--accent);transform:translateY(-2px)}.icon-btn:active{transform:scale(.92)}#messages{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex-direction:column;flex:1;gap:6px;padding:16px 18px 8px;display:flex;overflow:hidden auto}#messages::-webkit-scrollbar{display:none}.msg-row{flex-direction:column;gap:0;animation:.35s cubic-bezier(.4,0,.2,1) fadeUp;display:flex}.msg-row.user{align-items:flex-end}.msg-row.assistant{align-items:flex-start}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.ai-row{align-items:flex-end;gap:10px;max-width:86%;display:flex}.ai-ava{border:1.5px solid var(--border);border-radius:50%;flex-shrink:0;width:30px;height:30px;transition:border-color .3s;overflow:hidden}.ai-ava:hover{border-color:var(--accent-mid)}.ai-ava img{object-fit:cover;width:100%;height:100%;display:block}.ai-ava.hidden{visibility:hidden}.bubble{border-radius:var(--radius);word-break:break-word;white-space:pre-wrap;-webkit-backdrop-filter:blur(24px);margin-bottom:4px;padding:12px 16px;font-size:15px;line-height:1.7;transition:transform .3s,box-shadow .3s}.user .bubble{background:var(--surface);border:1px solid var(--border);color:var(--text);box-shadow:var(--shadow);border-bottom-right-radius:4px;max-width:78vw}.user .bubble:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.ai-bubbles-wrap .bubble{background:var(--surface);border:1px solid var(--border);color:var(--text);box-shadow:var(--shadow);border-bottom-left-radius:4px}.ai-bubbles-wrap .bubble:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.act{color:var(--accent);font-size:13.5px;font-style:italic}.ts{color:var(--text-dim);text-align:center;letter-spacing:.04em;margin:6px 0 2px;font-size:11px}.err{color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:10px 14px;font-size:12px}.summary-tag{color:var(--text-dim);text-align:center;letter-spacing:.06em;margin:8px 0;font-size:11px}.think-wrap{max-width:calc(86% - 40px);margin-bottom:6px;margin-left:40px}.think-toggle{color:var(--text-dim);cursor:pointer;touch-action:manipulation;-webkit-user-select:none;user-select:none;border-radius:var(--radius-full);background:var(--surface);border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);align-items:center;gap:6px;padding:4px 10px;font-size:11.5px;transition:all .3s;display:inline-flex}.think-toggle:hover{border-color:var(--accent-mid);color:var(--accent)}.t-arrow{opacity:.5;width:12px;height:12px;transition:transform .25s}.think-toggle.open .t-arrow{transform:rotate(90deg)}.t-dot{background:var(--accent);opacity:.65;border-radius:50%;width:5px;height:5px;animation:1.2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.think-body{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-dim);white-space:pre-wrap;word-break:break-word;-webkit-overflow-scrolling:touch;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);max-height:220px;margin-top:8px;padding:12px 14px;font-size:12px;line-height:1.72;display:none;overflow-y:auto}.think-body.open{display:block}.typing-bubble{align-items:flex-end;gap:10px;max-width:86%;margin-bottom:4px;animation:.3s fadeUp;display:flex}.typing-bubble .bub{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom-left-radius:4px;align-items:center;gap:5px;padding:14px 18px;display:flex}.typing-bubble .bub span{background:var(--accent);border-radius:50%;width:5px;height:5px;animation:1.2s ease-in-out infinite pulse}.typing-bubble .bub span:nth-child(2){animation-delay:.15s}.typing-bubble .bub span:nth-child(3){animation-delay:.3s}footer{padding:10px 16px 20px;padding-bottom:max(20px, env(safe-area-inset-bottom));border-top:1px solid var(--border);background:linear-gradient(to top, var(--bg) 60%, transparent);flex-shrink:0;position:relative}.toolbar{align-items:flex-end;gap:10px;display:flex}.inp-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-full);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);flex:1;padding:12px 18px;transition:border-color .3s,box-shadow .3s}.inp-wrap:focus-within{border-color:var(--accent-mid);box-shadow:0 0 0 3px var(--accent-soft)}#input{width:100%;font-family:var(--font-body);color:var(--text);resize:none;-webkit-appearance:none;background:0 0;border:none;outline:none;max-height:100px;font-size:16px;line-height:1.5;display:block}#input::placeholder{color:var(--text-dim)}.send-btn{background:var(--surface);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);cursor:pointer;touch-action:manipulation;-webkit-appearance:none;width:44px;height:44px;box-shadow:var(--shadow);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .3s;display:flex}.send-btn:hover:not(:disabled){background:linear-gradient(135deg, var(--accent), var(--accent-mid));box-shadow:var(--shadow-hover), 0 0 20px var(--accent-soft);border-color:#0000;transform:scale(1.08)}.send-btn:active{transform:scale(.92)}.send-btn:disabled{opacity:.3;box-shadow:none}.send-btn svg{width:18px;height:18px;stroke:var(--text)}.send-btn:hover:not(:disabled) svg{stroke:#fff}#welcome{pointer-events:none;flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:10px;padding:0 24px 28px;display:flex}#welcome .w-ava{border:2px solid var(--border);width:72px;height:72px;box-shadow:var(--shadow);border-radius:50%;margin-bottom:6px;transition:border-color .3s,box-shadow .3s;overflow:hidden}#welcome .w-ava:hover{border-color:var(--accent-mid);box-shadow:0 0 30px var(--accent-soft)}#welcome .w-ava img{object-fit:cover;width:100%;height:100%;display:block}#welcome .wname{font-family:var(--font-display);color:var(--text);letter-spacing:.1em;font-size:28px;font-weight:700}#welcome .wsub{color:var(--text-dim);letter-spacing:.08em;font-size:13px}.select-page{background:var(--bg);min-height:100dvh;color:var(--text);position:relative}.sel-nav{z-index:10;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);background:#0f0f12b3;justify-content:space-between;align-items:center;height:60px;padding:0 24px;display:flex;position:fixed;top:0;left:0;right:0}[data-theme=light] .sel-nav{background:#f8f6f1b3}.sel-logo{font-family:var(--font-display);letter-spacing:.08em;color:var(--text);align-items:center;font-size:18px;font-weight:600;display:flex;position:relative}.sel-logo-icon{border-radius:4px;flex-shrink:0;width:20px;height:20px;margin:0;display:block;position:absolute;top:50%;left:-9px;transform:translateY(-50%)}.sel-logo-text{margin-left:26px}.sel-icon-btn{background:var(--surface);border:1px solid var(--border);width:36px;height:36px;color:var(--text);cursor:pointer;touch-action:manipulation;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:50%;justify-content:center;align-items:center;font-size:15px;transition:all .3s;display:flex}.sel-icon-btn:hover{background:var(--surface-hover);border-color:var(--accent-mid);color:var(--accent)}.sel-icon-btn:active{transform:scale(.92)}.sel-main{flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:100dvh;padding:100px 20px 40px;display:flex}.sel-title{font-family:var(--font-display);letter-spacing:.15em;color:var(--text-dim);text-transform:uppercase;margin-bottom:8px;font-size:13px}.cards{justify-content:center;gap:24px;width:100%;max-width:600px;display:flex}.card{border-radius:var(--radius-lg);cursor:pointer;aspect-ratio:3/4;background:var(--surface);border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);flex:1;min-width:140px;max-width:260px;transition:transform .4s,border-color .3s,box-shadow .3s;position:relative;overflow:hidden}.card:hover{border-color:var(--accent-mid);box-shadow:0 20px 50px var(--shadow), 0 0 40px var(--accent-soft);transform:scale(1.03)translateY(-4px)}.card:active{transform:scale(.97)}.card:before{content:"";opacity:0;z-index:1;pointer-events:none;background:linear-gradient(135deg,#ffffff0f 0%,#0000 50%);transition:opacity .4s;position:absolute;inset:0}.card:hover:before{opacity:1}.card-img{opacity:.7;background-position:top;background-size:cover;transition:opacity .4s;position:absolute;inset:0}.card:hover .card-img{opacity:.85}.card-overlay{background:linear-gradient(to bottom, transparent 35%, var(--bg) 100%);position:absolute;inset:0}.card-info{z-index:2;padding:24px 20px;position:absolute;bottom:0;left:0;right:0}.card-name{font-family:var(--font-display);color:var(--text);letter-spacing:.04em;margin-bottom:4px;font-size:22px;font-weight:700}.card-desc{color:var(--text-dim);letter-spacing:.05em;margin-bottom:16px;font-size:12px}.card-btn{font-size:12px;font-family:var(--font-body);border-radius:var(--radius-full);border:1px solid var(--border);background:var(--surface);-webkit-backdrop-filter:blur(12px);color:var(--text);cursor:pointer;letter-spacing:.04em;touch-action:manipulation;padding:8px 18px;transition:all .3s;display:inline-block}.card:hover .card-btn{background:var(--surface-hover);border-color:var(--accent-mid);color:var(--accent);box-shadow:0 4px 15px var(--accent-soft)}@media (width<=400px){.cards{flex-direction:column;align-items:center}.card{width:100%;max-width:320px}}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0f0f1299;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}[data-theme=light] .modal-overlay{background:#f8f6f199}.modal-overlay.hidden{display:none}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);width:100%;max-width:340px;box-shadow:var(--shadow-hover);flex-direction:column;align-items:center;gap:28px;padding:40px 32px;display:flex}.modal-title{font-family:var(--font-display);color:var(--text);letter-spacing:.06em;font-size:22px;font-weight:700}.modal-sub{color:var(--text-dim);text-align:center;letter-spacing:.03em;margin-top:-20px;font-size:13px}.modal-btns{gap:12px;width:100%;display:flex}.modal-btn{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);color:var(--text);font-family:var(--font-body);cursor:pointer;touch-action:manipulation;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex:1;padding:14px 0;font-size:15px;transition:all .3s}.modal-btn:hover{border-color:var(--accent-mid);background:var(--surface-hover)}.modal-btn:active{transform:scale(.96)}.modal-btn.selected{background:linear-gradient(135deg, var(--accent), var(--accent-mid));color:#fff;box-shadow:0 4px 15px var(--accent-soft);border-color:#0000}.sel-nav-right{align-items:center;gap:10px;display:flex}.user-pill{background:var(--surface);border:1px solid var(--border);color:var(--text);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:20px;align-items:center;gap:8px;padding:6px 14px;font-size:13px;display:flex}.user-pill button{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:0;font-size:12px}.user-pill button:hover{color:var(--accent)}.login-modal-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.login-modal{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);width:90%;max-width:360px;box-shadow:var(--shadow-hover);padding:28px;animation:.25s scaleIn}.login-modal h3{font-family:var(--font-display);color:var(--text);text-align:center;margin-bottom:20px;font-size:20px;font-weight:600}.login-modal input{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);width:100%;color:var(--text);outline:none;margin-bottom:12px;padding:12px 16px;font-size:15px;transition:border-color .3s}.login-modal input:focus{border-color:var(--accent-mid)}.login-modal .gender-select{color:var(--text);gap:20px;margin-bottom:12px;font-size:14px;display:flex}.login-modal .gender-select label{cursor:pointer;align-items:center;gap:6px;display:flex}.login-modal .error{color:#ef4444;text-align:center;margin-bottom:12px;font-size:13px}.login-modal button[type=submit]{border-radius:var(--radius);background:linear-gradient(135deg, var(--accent), var(--accent-mid));color:#fff;cursor:pointer;border:none;width:100%;padding:14px;font-size:15px;font-weight:600;transition:opacity .3s,transform .2s}.login-modal button[type=submit]:hover{opacity:.9}.login-modal button[type=submit]:active{transform:scale(.98)}.login-modal button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.login-modal .link{text-align:center;width:100%;color:var(--accent);cursor:pointer;background:0 0;border:none;margin-top:14px;font-size:13px;display:block}.login-modal .link:hover{text-decoration:underline}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
