*{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-panel{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px;border-radius:20px;border:1px dashed rgba(165,180,252,.45);background:#1e293b85;color:#cbd5e1}.voice-panel div{display:flex;flex-direction:column;gap:6px}.voice-panel strong{color:#e0e7ff}.voice-panel.recording{border-color:#f87171b8;background:#7f1d1d52}.voice-panel.transcribing{border-color:#818cf8b8;background:#312e815c}.voice-button{min-height:48px;white-space:nowrap}.voice-panel.recording .voice-button{background:#fecaca;color:#7f1d1d}.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}.speech-control{display:flex;align-items:center;gap:9px;margin-top:12px;flex-wrap:wrap}.speech-artwork{width:32px;height:32px;border-radius:10px;object-fit:cover;border:1px solid rgba(226,232,240,.24);box-shadow:0 6px 18px #00000038}.listen-button{min-height:34px;padding:0 14px;border-radius:999px;background:#e2e8f0eb;color:#0f172a;font-size:.9rem}.speech-error{flex-basis:100%;color:#fecaca;font-size:.88rem}.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%}.voice-panel{align-items:stretch;flex-direction:column}.voice-button{width:100%}}
