:root{--bg: oklch(.98 .005 90);--panel: oklch(.96 .006 85);--ink: oklch(.18 .01 80);--ink-soft: oklch(.38 .008 80);--ink-mute: oklch(.58 .006 80);--line: oklch(.9 .006 85);--line-strong: oklch(.82 .008 80);--accent: oklch(.62 .15 55);--accent-soft: oklch(.93 .04 60);--bubble-user: oklch(.94 .012 80);--sans: "Inter", system-ui, sans-serif;--mono: "JetBrains Mono", ui-monospace, monospace;--serif: "Instrument Serif", "Iowan Old Style", serif}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--sans);color:var(--ink);background:var(--bg);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;overflow:hidden}button{font-family:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}textarea,input{font-family:inherit;color:inherit}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 1px 1px,oklch(.2 .01 80 / .025) 1px,transparent 0);background-size:4px 4px;pointer-events:none;z-index:1}.app{display:grid;grid-template-columns:280px 1fr;height:100vh;position:relative;z-index:2}.sidebar{border-right:1px solid var(--line);background:var(--panel);display:flex;flex-direction:column;min-width:0;min-height:0;height:100vh}.brand{padding:22px 22px 18px;border-bottom:1px solid var(--line);display:flex;align-items:baseline;gap:10px}.brand-mark{width:28px;height:28px;border:1.5px solid var(--ink);border-radius:50%;position:relative;flex:0 0 auto;align-self:center;background:radial-gradient(circle at 60% 40%,var(--accent) 0 3px,transparent 3.5px),radial-gradient(circle at 35% 62%,var(--ink) 0 2px,transparent 2.5px)}.brand-title{font-family:var(--serif);font-size:22px;letter-spacing:-.01em;line-height:1}.brand-title em{color:var(--accent);font-style:italic}.brand-sub{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-mute);margin-left:auto}.lang-switch{margin:14px 14px 0;display:flex;border:1px solid var(--line);border-radius:10px;padding:3px;background:var(--bg)}.lang-switch button{flex:1;padding:6px 0;font-family:var(--mono);font-size:18px;letter-spacing:.12em;color:var(--ink-mute);border-radius:7px;transition:background .15s,color .15s}.lang-switch button:hover{color:var(--ink)}.lang-switch button.sel{background:var(--accent);color:var(--bg)}.new-chat{margin:14px;padding:12px 14px;border:1px solid var(--accent);border-radius:10px;background:var(--accent);color:var(--bg);display:flex;align-items:center;gap:10px;font-weight:500;font-size:13.5px;transition:transform .08s ease,background .15s ease}.new-chat:hover{background:#ac5700;background:oklch(.55 .14 55);border-color:#ac5700;border-color:oklch(.55 .14 55)}.new-chat:active{transform:translateY(1px)}.new-chat .plus{width:18px;height:18px;border-radius:50%;border:1px solid currentColor;display:grid;place-items:center;font-family:var(--mono);font-size:13px;line-height:1}.new-chat .kbd{margin-left:auto;font-family:var(--mono);font-size:10.5px;opacity:.6;border:1px solid oklch(.98 .005 90 / .3);padding:2px 5px;border-radius:4px}.section-label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-mute);padding:14px 22px 8px}.chat-list{flex:1;overflow-y:auto;padding:0 10px 16px}.chat-item{width:100%;text-align:left;padding:10px 12px;border-radius:8px;display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--ink-soft);margin-bottom:2px;position:relative;transition:background .12s}.chat-item:hover{background:#ebe7e2;color:var(--ink)}.chat-item.active{background:var(--bg);color:var(--ink);box-shadow:0 0 0 1px var(--line-strong),0 1px 2px #1816110a}.chat-item.active:before{content:"";position:absolute;left:-10px;top:50%;transform:translateY(-50%);width:3px;height:18px;border-radius:2px;background:var(--accent)}.chat-dot{width:6px;height:6px;border-radius:50%;background:var(--line-strong);flex:0 0 auto}.chat-item.active .chat-dot{background:var(--accent)}.chat-title{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-time{font-family:var(--mono);font-size:10px;color:var(--ink-mute);flex:0 0 auto}.chat-item .del{opacity:0;font-family:var(--mono);font-size:11px;color:var(--ink-mute);padding:2px 4px;border-radius:4px}.chat-item:hover .del{opacity:1}.chat-item .del:hover{background:#dbd7d0;color:var(--ink)}.sidebar-foot{border-top:1px solid var(--line);padding:12px 18px;display:flex;flex-direction:row;align-items:center;gap:10px;font-size:12.5px;color:var(--ink-soft)}.avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-family:var(--mono);font-size:11px;font-weight:500;border:1px solid oklch(.62 .15 55 / .3)}.signout-btn{width:auto;background:none;border:1px solid var(--border);border-radius:8px;cursor:pointer;padding:8px 12px;font-size:12px;color:var(--ink-mute);text-align:left;transition:color .15s,border-color .15s}.signout-btn:hover{color:var(--ink);border-color:var(--ink-mute)}.foot-status{margin-left:0;font-family:var(--mono);font-size:10px;color:var(--ink-mute);display:flex;align-items:center;gap:6px}.pulse{width:6px;height:6px;border-radius:50%;background:#4aa651;box-shadow:0 0 #4aa65180;animation:pulse 2s infinite}.pulse.offline{background:#de3b3d;box-shadow:none;animation:none}@keyframes pulse{0%{box-shadow:0 0 #4aa65180}70%{box-shadow:0 0 0 6px #4aa65100}to{box-shadow:0 0 #4aa65100}}.main{display:flex;flex-direction:column;min-width:0;min-height:0;height:100vh;position:relative}.topbar{padding:16px 28px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;background:var(--bg)}.crumbs{font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:.04em}.crumbs b{color:var(--ink);font-weight:500}.top-actions{margin-left:auto;display:flex;gap:6px}.icon-btn{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;color:var(--ink-soft);transition:background .12s,color .12s}.icon-btn:hover{background:var(--panel);color:var(--ink)}.convo-wrap{flex:1;overflow-y:auto;scroll-behavior:smooth}.convo{max-width:760px;margin:0 auto;padding:36px 28px 40px}.day-sep{text-align:center;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;color:var(--ink-mute);text-transform:uppercase;margin:8px 0 28px;display:flex;align-items:center;gap:12px}.day-sep:before,.day-sep:after{content:"";flex:1;height:1px;background:var(--line)}.msg{display:flex;gap:14px;margin-bottom:26px;animation:fadein .4s ease both}@keyframes fadein{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.msg-avatar{width:32px;height:32px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-family:var(--mono);font-size:11px;font-weight:500}.msg.ai .msg-avatar{background:var(--bg);border:1px solid var(--ink);position:relative;overflow:hidden}.msg.ai .msg-avatar:before{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:50%;background:radial-gradient(circle at 62% 38%,var(--accent) 0 2.5px,transparent 3px),radial-gradient(circle at 36% 64%,var(--ink) 0 1.5px,transparent 2px)}.msg.user .msg-avatar{background:var(--accent-soft);color:var(--accent);border:1px solid oklch(.62 .15 55 / .25)}.msg-body{flex:1;min-width:0}.msg-meta{display:flex;align-items:baseline;gap:10px;margin-bottom:6px}.msg-name{font-weight:500;font-size:13.5px}.msg-name em{font-family:var(--serif);font-style:italic;font-weight:400;font-size:15px;color:var(--accent)}.msg-time{font-family:var(--mono);font-size:10.5px;color:var(--ink-mute);letter-spacing:.05em}.msg-content{font-size:15px;line-height:1.62;color:var(--ink);text-wrap:pretty}.msg-content p{margin:0 0 10px}.msg-content p:last-child{margin-bottom:0}.msg-actions{display:flex;gap:4px;margin-top:6px;opacity:0;transition:opacity .15s}.msg:hover .msg-actions{opacity:1}.msg-action{width:24px;height:24px;display:grid;place-items:center;color:var(--ink-mute);border-radius:6px;transition:color .12s,background .12s}.msg-action:hover{color:var(--ink);background:var(--panel)}.msg.user .msg-actions{justify-content:flex-end}.msg-edit textarea{width:100%;font-family:inherit;font-size:inherit;color:var(--ink);background:var(--bg);border:1px solid var(--line-strong);border-radius:10px;padding:8px 12px;resize:none;outline:none;line-height:1.55}.msg-edit textarea:focus{border-color:var(--accent)}.msg-edit-actions{display:flex;gap:6px;justify-content:flex-end;margin-top:6px}.msg-btn{font-size:12px;padding:6px 12px;border-radius:7px;border:1px solid var(--line-strong);transition:background .12s,color .12s,border-color .12s}.msg-btn.ghost{color:var(--ink-mute);background:none}.msg-btn.ghost:hover{color:var(--ink)}.msg-btn.primary{color:var(--bg);background:var(--accent);border-color:var(--accent)}.msg-btn.primary:hover{background:#ac5700;background:oklch(.55 .14 55);border-color:#ac5700;border-color:oklch(.55 .14 55)}.msg-content h1,.msg-content h2,.msg-content h3,.msg-content h4{font-family:var(--serif);font-weight:600;line-height:1.25;margin:18px 0 8px;color:var(--ink);letter-spacing:-.01em}.msg-content h1{font-size:22px}.msg-content h2{font-size:19px}.msg-content h3{font-size:16.5px}.msg-content h4{font-size:15px}.msg-content h1:first-child,.msg-content h2:first-child,.msg-content h3:first-child,.msg-content h4:first-child{margin-top:0}.msg-content ul,.msg-content ol{margin:0 0 10px;padding-left:22px}.msg-content li{margin:2px 0}.msg-content li>p{margin:0}.msg-content strong{font-weight:600;color:var(--ink)}.msg-content em{font-style:italic}.msg-content a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.msg-content blockquote{margin:8px 0;padding:4px 14px;border-left:3px solid var(--line-strong);color:var(--ink-soft);font-style:italic}.msg-content hr{border:0;border-top:1px solid var(--line);margin:16px 0}.msg-content table{border-collapse:collapse;margin:10px 0;font-size:13.5px}.msg-content th,.msg-content td{border:1px solid var(--line);padding:6px 10px;text-align:left}.msg-content th{background:var(--panel);font-weight:600}.msg-content :not(pre)>code{font-family:var(--mono);font-size:13px;background:var(--panel);padding:1px 5px;border-radius:4px;border:1px solid var(--line)}.msg-content pre{font-family:var(--mono);font-size:13px;background:#100d09;color:#e7e4df;padding:14px 16px;border-radius:10px;overflow-x:auto;margin:8px 0 10px;line-height:1.6}.msg-content pre code{background:transparent;border:0;padding:0;color:inherit;font-size:inherit}.msg-content pre .k{color:#e89960}.msg-content pre .s{color:#7bc27e}.msg-content pre .c{color:#75716b;font-style:italic}.msg.user .msg-content{background:var(--bubble-user);border:1px solid var(--line);border-radius:12px;padding:10px 14px;display:inline-block}.attach-img{max-width:260px;border-radius:10px;border:1px solid var(--line);display:block;margin-bottom:8px}.voice-pill{display:inline-flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--line-strong);border-radius:999px;padding:6px 14px 6px 8px;font-family:var(--mono);font-size:11.5px;color:var(--ink-soft)}.voice-bars{display:flex;gap:2px;align-items:center;height:18px}.voice-bars span{display:block;width:2px;background:var(--accent);border-radius:1px}.voice-pill.playable{cursor:pointer;transition:background .12s}.voice-pill.playable:hover{background:var(--panel)}.voice-play{width:22px;height:22px;border-radius:50%;background:var(--accent);color:var(--bg);display:grid;place-items:center;flex:0 0 auto}.voice-dur{font-family:var(--mono);font-size:10.5px;color:var(--ink-mute)}.play-btn{width:22px;height:22px;border-radius:50%;background:var(--accent);color:var(--bg);display:grid;place-items:center;flex:0 0 auto}.typing{display:inline-flex;align-items:center;gap:6px;padding:8px 0}.typing span{width:6px;height:6px;border-radius:50%;background:var(--ink-mute);animation:dot 1.2s infinite ease-in-out}.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}@keyframes dot{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.empty{max-width:680px;margin:0 auto;padding:80px 28px 40px;text-align:center}.empty-eyebrow{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.2em;color:var(--ink-mute);margin-bottom:18px}.empty h1{font-family:var(--serif);font-weight:400;font-size:56px;line-height:1.02;letter-spacing:-.02em;margin:0 0 18px}.empty h1 em{color:var(--accent);font-style:italic}.empty p{color:var(--ink-soft);font-size:16px;max-width:520px;margin:0 auto 40px;text-wrap:balance}.suggestions{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;max-width:640px;margin:0 auto;text-align:left}.sugg{border:1px solid var(--line);background:var(--panel);border-radius:12px;padding:14px 16px;transition:all .15s;display:flex;gap:12px;align-items:flex-start}.sugg:hover{border-color:var(--line-strong);background:var(--bg);transform:translateY(-1px);box-shadow:0 2px 8px #1816110a}.sugg-ic{font-family:var(--mono);font-size:10px;color:var(--accent);border:1px solid oklch(.62 .15 55 / .3);background:var(--accent-soft);border-radius:6px;padding:3px 6px;flex:0 0 auto;margin-top:1px}.sugg-body{flex:1;min-width:0}.sugg-title{font-weight:500;font-size:13.5px;margin-bottom:2px}.sugg-desc{font-size:12.5px;color:var(--ink-mute);line-height:1.45}.composer-wrap{padding:14px 28px 22px;background:linear-gradient(to top,var(--bg) 60%,transparent);position:relative}.composer{max-width:760px;margin:0 auto;border:1px solid var(--line-strong);border-radius:18px;background:var(--bg);box-shadow:0 2px #18161105,0 8px 32px #1816110d;transition:border-color .15s,box-shadow .15s}.composer:focus-within{border-color:var(--ink);box-shadow:0 2px #18161105,0 8px 32px #18161114}.composer.recording{border-color:var(--accent);box-shadow:0 0 0 4px #c9690c1a}.attach-preview{padding:12px 14px 0;display:flex;flex-wrap:wrap;gap:8px}.attach-preview:empty{display:none}.preview-item{position:relative;border-radius:10px;border:1px solid var(--line);overflow:hidden;background:var(--panel)}.preview-item img{display:block;width:64px;height:64px;object-fit:cover}.preview-item.voice{padding:8px 12px 8px 10px;display:flex;align-items:center;gap:10px;height:64px;font-family:var(--mono);font-size:11px;color:var(--ink-soft)}.preview-remove{position:absolute;top:4px;right:4px;width:18px;height:18px;border-radius:50%;background:#181611b3;color:var(--bg);display:grid;place-items:center;font-size:11px;line-height:1}.composer-row{display:flex;align-items:center;gap:8px;padding:10px 12px 10px 16px}.composer.size-md .composer-row,.composer.size-lg .composer-row{align-items:flex-start}.composer textarea{flex:1;border:0;outline:0;resize:none;background:transparent;font-size:15px;line-height:1.5;padding:8px 0;max-height:180px;min-height:26px;transition:min-height .15s,max-height .15s}.composer.size-sm textarea{min-height:26px;max-height:26px;overflow-y:auto}.composer.size-md textarea{min-height:120px;max-height:180px}.composer.size-lg textarea{min-height:340px;max-height:60vh}.composer textarea::placeholder{color:var(--ink-mute)}.tool-btn{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;color:var(--ink-soft);transition:background .12s,color .12s,transform .08s;flex:0 0 auto}.tool-btn:hover{background:var(--panel);color:var(--ink)}.tool-btn.active{color:var(--accent);background:var(--accent-soft)}.tool-btn:active{transform:scale(.94)}.send-btn{width:36px;height:36px;border-radius:10px;background:var(--ink);color:var(--bg);display:grid;place-items:center;transition:background .12s,transform .08s;flex:0 0 auto}.send-btn:disabled{background:var(--line-strong);cursor:not-allowed;color:var(--ink-mute)}.send-btn:not(:disabled):hover{background:var(--accent)}.send-btn:active{transform:scale(.94)}.composer-foot{display:flex;align-items:center;gap:14px;padding:0 16px 10px;font-family:var(--mono);font-size:10.5px;color:var(--ink-mute);letter-spacing:.04em}.composer-foot .sep{opacity:.4}.composer-foot .hint b{color:var(--ink-soft);font-weight:500}.rec-overlay{position:absolute;top:14px;right:28px;bottom:22px;left:28px;max-width:760px;margin:0 auto;border-radius:18px;background:var(--bg);border:1px solid var(--accent);box-shadow:0 0 0 4px #c9690c14;display:flex;align-items:center;padding:0 16px;gap:14px;z-index:5}.rec-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);animation:rec 1s infinite}@keyframes rec{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.rec-time{font-family:var(--mono);font-size:13px;color:var(--ink);min-width:50px}.rec-wave{flex:1;height:40px;display:flex;align-items:center;gap:2px;overflow:hidden}.rec-wave span{display:block;width:3px;border-radius:2px;background:var(--accent);opacity:.7}.rec-cancel,.rec-stop{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:8px 14px;border-radius:10px}.rec-cancel{color:var(--ink-soft)}.rec-cancel:hover{background:var(--panel);color:var(--ink)}.rec-stop{background:var(--ink);color:var(--bg)}.rec-stop:hover{background:var(--accent)}.tweaks{position:fixed;right:20px;bottom:110px;width:280px;background:var(--bg);border:1px solid var(--line-strong);border-radius:14px;padding:14px 16px 16px;box-shadow:0 12px 40px #1816111f;z-index:50}.tweaks h4{margin:0 0 12px;font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-mute);font-weight:500}.tweak-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;font-size:12.5px}.tweak-row:last-child{margin-bottom:0}.swatches{display:flex;gap:6px}.swatch{width:22px;height:22px;border-radius:6px;border:1px solid var(--line);cursor:pointer;transition:transform .1s}.swatch:hover{transform:scale(1.1)}.swatch.sel{box-shadow:0 0 0 2px var(--bg),0 0 0 3px var(--ink)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:5px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--ink-mute)}@media(max-width:780px){.app{grid-template-columns:1fr}.sidebar{display:none}}.login-wrap{height:100vh;display:grid;place-items:center;position:relative;z-index:2}.login-toolbar-left{position:absolute;top:24px;left:28px}.login-toolbar-right{position:absolute;top:24px;right:28px}.login-toolbar-left .lang-switch{margin:0;padding:6px;gap:4px;border-radius:14px}.login-toolbar-left .lang-switch button{flex:0 0 auto;padding:5px 12px;font-size:15px;line-height:1;border-radius:10px}.login-card{width:100%;max-width:380px;padding:40px 36px 36px;background:var(--panel);border:1px solid var(--line-strong);border-radius:20px;box-shadow:0 8px 40px #18161112}.login-brand{display:flex;align-items:center;gap:10px;margin-bottom:28px}.login-sub{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-mute);margin:0 0 24px}.login-form{display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-label{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-mute)}.login-input{background:var(--bg);border:1px solid var(--line-strong);border-radius:10px;padding:10px 14px;font-size:14px;color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s}.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #c9690c1f}.login-input-wrap{position:relative;display:block}.login-input-wrap .login-input{width:100%;padding-right:40px}.pw-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:28px;height:28px;display:grid;place-items:center;color:var(--ink-mute);border-radius:6px;transition:color .12s,background .12s}.pw-toggle:hover{color:var(--ink);background:var(--panel)}.login-error{font-size:12.5px;color:#c53637;font-family:var(--mono)}.login-submit{margin-top:4px;padding:12px 14px;background:var(--accent);color:var(--bg);border:none;border-radius:10px;font-weight:500;font-size:14px;cursor:pointer;transition:background .15s,transform .08s}.login-submit:hover:not(:disabled){background:#ac5700;background:oklch(.55 .14 55)}.login-submit:active{transform:translateY(1px)}.login-submit:disabled{background:var(--line-strong);color:var(--ink-mute);cursor:not-allowed}
