:root{--bg-0: #0a0b1a;--bg-1: #11132a;--bg-2: #1a1d3a;--line: #2a2e55;--ink-0: #e8e9f5;--ink-1: #a4a8c6;--ink-2: #6b6f92;--gold: #f5c84a;--teal: #4ad9d9;--magenta: #d94aa8;--err: #ff6b6b;--radius: 14px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:ui-sans-serif,system-ui,SF Pro Text,Helvetica Neue,Arial,sans-serif;background:radial-gradient(ellipse at top,#1a1d3a,#0a0b1a 60%);color:var(--ink-0);overflow:hidden}button{font:inherit;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}.login-shell{display:grid;place-items:center;height:100vh;padding:24px}.login-card{width:100%;max-width:380px;background:linear-gradient(180deg,var(--bg-1),var(--bg-0));border:1px solid var(--line);border-radius:var(--radius);padding:32px;display:flex;flex-direction:column;gap:14px;box-shadow:0 20px 60px #0006,inset 0 1px #ffffff0a}.login-card h1{margin:0;text-align:center;font-size:32px;letter-spacing:.04em;background:linear-gradient(90deg,var(--gold),var(--teal));-webkit-background-clip:text;background-clip:text;color:transparent}.login-card .sub{text-align:center;color:var(--ink-2);margin:-6px 0 8px;font-size:14px}.lamp{text-align:center;font-size:38px}.lamp.big{font-size:56px}.login-card input{background:var(--bg-0);border:1px solid var(--line);color:var(--ink-0);padding:12px 14px;border-radius:10px;outline:none;font-size:15px}.login-card input:focus{border-color:var(--teal)}.login-card button[type=submit]{background:linear-gradient(90deg,var(--gold),var(--magenta));color:var(--bg-0);font-weight:600;border:0;padding:12px;border-radius:10px;margin-top:4px;letter-spacing:.02em}.err{color:var(--err);font-size:13px;text-align:center}.chat-shell{display:grid;grid-template-columns:280px 1fr;height:100vh}@media (max-width: 720px){.chat-shell{grid-template-columns:1fr}.sidebar{display:none}}.sidebar{background:var(--bg-0);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:16px 12px;gap:12px;min-height:0}.brand{display:flex;align-items:center;gap:8px;font-weight:700;font-size:20px;padding:4px 6px 8px;letter-spacing:.04em}.brand .lamp{font-size:22px}.new-btn{background:var(--bg-2);color:var(--ink-0);border:1px solid var(--line);padding:10px 12px;border-radius:10px;text-align:left}.new-btn:hover{border-color:var(--teal)}.sessions{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px;padding-right:2px}.session{background:transparent;color:var(--ink-1);border:1px solid transparent;padding:8px 10px;border-radius:8px;text-align:left}.session:hover{background:var(--bg-1);color:var(--ink-0)}.session.active{background:var(--bg-2);color:var(--ink-0);border-color:var(--line)}.session .prev{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session .meta{font-size:11px;color:var(--ink-2);margin-top:2px}.empty{color:var(--ink-2);font-size:13px;padding:8px}.footer{display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--line);padding-top:12px}.footer select{background:var(--bg-1);color:var(--ink-0);border:1px solid var(--line);padding:8px;border-radius:8px;font-size:13px}.footer .logout{background:transparent;color:var(--ink-2);border:1px solid var(--line);padding:7px;border-radius:8px;font-size:12px}.footer .logout:hover{color:var(--err);border-color:var(--err)}.main{display:flex;flex-direction:column;min-height:0}.messages{flex:1;overflow-y:auto;padding:24px clamp(16px,4vw,40px) 8px;display:flex;flex-direction:column;gap:14px}.welcome{margin:auto;text-align:center;color:var(--ink-2)}.welcome p{margin-top:12px;font-size:16px}.msg{display:flex}.msg.user{justify-content:flex-end}.msg.assistant{justify-content:flex-start}.msg .bubble{max-width:min(680px,85%);padding:12px 16px;border-radius:16px;white-space:pre-wrap;line-height:1.5;font-size:15px;border:1px solid var(--line)}.msg.user .bubble{background:linear-gradient(180deg,var(--bg-2),#1d2148);border-color:#2e336d}.msg.assistant .bubble{background:var(--bg-1)}.msg.assistant.err .bubble{border-color:var(--err);color:var(--err)}.bubble.typing{display:inline-flex;gap:5px;align-items:center;padding:14px 16px}.bubble.typing span{width:6px;height:6px;border-radius:50%;background:var(--ink-2);animation:blink 1.2s infinite}.bubble.typing span:nth-child(2){animation-delay:.15s}.bubble.typing span:nth-child(3){animation-delay:.3s}@keyframes blink{0%,60%,to{opacity:.25}30%{opacity:1}}.banner-err{color:var(--err);font-size:13px;padding:8px 16px;text-align:center;border-top:1px solid var(--line)}.composer{border-top:1px solid var(--line);padding:14px clamp(12px,3vw,24px);display:flex;gap:10px;align-items:flex-end;background:var(--bg-0)}.composer textarea{flex:1;resize:none;max-height:160px;background:var(--bg-1);color:var(--ink-0);border:1px solid var(--line);border-radius:12px;padding:12px 14px;font:inherit;font-size:15px;outline:none;line-height:1.4}.composer textarea:focus{border-color:var(--teal)}.composer button{background:linear-gradient(90deg,var(--gold),var(--magenta));color:var(--bg-0);font-weight:600;border:0;padding:12px 18px;border-radius:12px;letter-spacing:.02em}
