:root{--bg:#0c0c0f;--surface:#16161a;--border:#2a2a30;--text:#eaeaea;--text-muted:#9898a0;--accent:#7c5cff;--accent-hover:#9b82ff}*{box-sizing:border-box}body,html{height:100%;margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,sans-serif}.site-header{border-bottom:1px solid var(--border)}.site-header-inner{max-width:64rem;margin:0 auto;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between}.site-logo{font-weight:700;font-size:1.25rem;color:var(--text);text-decoration:none}.site-logo:hover{color:var(--accent)}.site-nav a{color:var(--text-muted);text-decoration:none;font-size:.9rem}.site-nav a:hover{color:var(--text)}.site-main{max-width:64rem;margin:0 auto;padding:0 1.5rem 3rem}.hero{padding:3rem 0 2.5rem}.hero-inner{max-width:36rem}.hero-title{font-size:2rem;font-weight:700;margin:0 0 .75rem;line-height:1.2}.hero-subtitle{color:var(--text-muted);font-size:1.05rem;line-height:1.6;margin:0}.content-section{padding:2rem 0}.content-inner{max-width:42rem}.section-title{font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.section-text{color:var(--text-muted);font-size:.95rem;margin:0 0 1.25rem;line-height:1.5}.site-footer{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border)}.site-footer-inner{max-width:64rem;margin:0 auto}.site-footer p{margin:0;font-size:.85rem;color:var(--text-muted)}.chat-placeholder{background:var(--surface);border:2px dashed var(--border);border-radius:12px;min-height:280px;display:flex;align-items:center;justify-content:center}.chat-placeholder-inner{text-align:center;padding:1.5rem}.chat-placeholder-icon{font-size:2rem;display:block;margin-bottom:.5rem;opacity:.7}.chat-placeholder-text{font-size:1rem;color:var(--text-muted);margin:0 0 .5rem}.chat-placeholder-hint{font-size:.75rem;color:var(--text-muted);opacity:.8;margin:0}.chat-placeholder-hint code{background:var(--border);padding:.1em .35em;border-radius:4px;font-size:.9em}.main{min-height:100%;padding:1.5rem}.container{max-width:42rem;margin:0 auto}.title{font-size:1.5rem;font-weight:700;margin:0 0 .25rem}.subtitle{color:var(--text-muted);font-size:.9rem;margin:0 0 1.5rem}.chat{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;min-height:420px}.messages{flex:1 1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem}.placeholder{color:var(--text-muted);font-size:.9rem;margin:auto}.message{padding:.6rem .75rem;border-radius:8px;max-width:90%}.message--user{background:var(--border);align-self:flex-end}.message--assistant{background:rgba(124,92,255,.12);align-self:flex-start}.message-role{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);display:block;margin-bottom:.25rem}.message-content{font-size:.95rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.form{display:flex;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--border)}.input{flex:1 1;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:.6rem .75rem;color:var(--text);font-size:.95rem}.input::placeholder{color:var(--text-muted)}.input:disabled{opacity:.7;cursor:not-allowed}.button{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:.6rem 1rem;font-weight:600;cursor:pointer}.button:hover:not(:disabled){background:var(--accent-hover)}.button:disabled{opacity:.7;cursor:not-allowed}.error{padding:.5rem 1rem;background:rgba(220,60,60,.15);color:#e88;font-size:.85rem;border-top:1px solid rgba(220,60,60,.3)}.embed-main{min-height:100vh;padding:.75rem}.embed-main .chat{min-height:380px}