*{box-sizing:border-box}:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,#24304f,#0d1020 58%);color:#f8fafc}button,textarea{font:inherit}.app-shell{width:min(920px,100%);min-height:100vh;margin:0 auto;padding:28px 18px;display:flex;flex-direction:column;gap:18px}.hero{padding:24px;border:1px solid rgba(199,210,254,.2);border-radius:28px;background:#0f1220c7;box-shadow:0 24px 80px #00000059}.eyebrow{margin:0 0 8px;color:#a5b4fc;letter-spacing:.12em;text-transform:uppercase;font-size:.78rem}h1{margin:0;font-size:clamp(2.2rem,8vw,4.5rem);line-height:.94}.subhead{max-width:620px;color:#cbd5e1;font-size:1.05rem}.status{display:inline-flex;padding:8px 12px;border-radius:999px;background:#94a3b829;color:#cbd5e1}.status.online{background:#22c55e29;color:#86efac}.status.offline{background:#f8717129;color:#fecaca}.voice-placeholder{display:flex;flex-direction:column;gap:6px;padding:16px 18px;border-radius:20px;border:1px dashed rgba(165,180,252,.45);background:#1e293b85;color:#cbd5e1}.voice-placeholder strong{color:#e0e7ff}.chat-panel{flex:1;display:flex;flex-direction:column;gap:12px}.bubble{max-width:86%;padding:14px 16px;border-radius:20px;background:#1e293beb;border:1px solid rgba(148,163,184,.14)}.bubble.nathan{align-self:flex-end;background:#3730a3}.bubble.horatio{align-self:flex-start;background:#172554}.bubble.system{align-self:center;background:#0f172adb;color:#cbd5e1}.speaker{display:block;font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:#c4b5fd;margin-bottom:5px}.bubble p{margin:0;white-space:pre-wrap;line-height:1.45}.error{padding:12px 14px;border-radius:14px;background:#7f1d1de6;color:#fee2e2}.composer{position:sticky;bottom:0;display:grid;grid-template-columns:1fr auto;gap:10px;padding:12px;border-radius:22px;background:#0f1220eb;border:1px solid rgba(199,210,254,.22);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}textarea{width:100%;resize:vertical;min-height:58px;border:1px solid rgba(148,163,184,.28);border-radius:16px;padding:12px;background:#0f172ae6;color:#fff}button{border:0;border-radius:16px;padding:0 20px;background:#818cf8;color:#111827;font-weight:800;cursor:pointer}button:disabled{opacity:.55;cursor:not-allowed}@media(max-width:640px){.composer{grid-template-columns:1fr}button{min-height:48px}.bubble{max-width:94%}}
