*{box-sizing:border-box}html,body,#root{height:100%;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#0f172a;color:#e2e8f0}.app{display:flex;flex-direction:column;height:100%;max-width:1200px;margin:0 auto;padding:24px 16px;gap:16px}.main-layout{flex:1;min-height:0;display:flex;gap:16px;align-items:stretch}.sidebar{flex:0 0 320px;display:flex;flex-direction:column;gap:12px;overflow-y:auto;min-height:0}.main{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;gap:12px}@media (max-width: 900px){.app{height:auto;min-height:100%}.main-layout{flex:0 0 auto;flex-direction:column;min-height:0}.sidebar{flex:0 0 auto;overflow:visible}.main{flex:0 0 auto}}.brand{display:flex;align-items:center;gap:10px}.brand-logo{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.brand-logo svg{display:block}.header h1{margin:0;font-size:20px;letter-spacing:-.01em}.header p{margin:0;font-size:13px;color:#94a3b8}.header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.header-actions{display:flex;align-items:center;gap:8px}.voice-toggle{background:transparent;color:#cbd5e1;border:1px solid #334155;border-radius:999px;padding:7px 14px;font-weight:600;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:border-color .15s,color .15s,background .15s;white-space:nowrap;font-family:inherit}.voice-toggle:hover{border-color:#64748b;color:#f1f5f9}.voice-toggle.on{border-color:#38bdf8;color:#38bdf8;background:#38bdf81a}.voice-icon{font-size:14px}.demo-btn{background:linear-gradient(135deg,#38bdf8,#818cf8);color:#0f172a;border:none;border-radius:999px;padding:8px 16px;font-weight:600;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:opacity .15s,transform .05s;white-space:nowrap}.demo-btn:hover:not(:disabled){opacity:.9}.demo-btn:active:not(:disabled){transform:translateY(1px)}.demo-btn:disabled{opacity:.4;cursor:not-allowed}.demo-btn.stop{background:linear-gradient(135deg,#f87171,#ef4444);color:#fff}.demo-play{font-size:10px}.topics{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.topic{background:#1e293b;border:1px solid #334155;border-radius:10px;padding:12px 10px;cursor:pointer;color:inherit;text-align:left;font:inherit;transition:border-color .15s,transform .05s}.topic:hover:not(:disabled){border-color:#64748b}.topic:active:not(:disabled){transform:translateY(1px)}.topic.active{border-color:#38bdf8;background:#0c4a6e}.topic:disabled{opacity:.5;cursor:wait}.topic-head{display:flex;align-items:center;gap:8px;margin-bottom:4px}.topic-icon{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;flex-shrink:0}.topic .label{font-weight:600;font-size:14px}.topic .blurb{font-size:12px;color:#94a3b8}.chat{flex:1;min-height:0;display:flex;flex-direction:column;background:#1e293b;border:1px solid #334155;border-radius:12px;overflow:hidden}.explainer{padding:16px 18px;border:1px solid #334155;border-radius:12px;background:linear-gradient(135deg,#38bdf81a,#a78bfa1a)}.explainer-title{margin:0 0 10px;font-size:18px;font-weight:700;letter-spacing:-.01em;color:#f1f5f9}.explainer-summary{display:flex;align-items:flex-start;gap:12px;width:100%;margin:-6px -6px 8px;padding:6px;background:transparent;border:none;border-radius:8px;color:inherit;font:inherit;text-align:left;cursor:pointer;transition:background .15s;-webkit-tap-highlight-color:rgba(56,189,248,.15)}.explainer-summary:hover,.explainer-summary:active{background:#38bdf814}.explainer-summary:focus-visible{outline:2px solid #38bdf8;outline-offset:2px}.explainer:not(.open) .explainer-points{display:none}.explainer-problem{flex:1;display:flex;flex-direction:column;gap:8px;font-size:14px;line-height:1.5;color:#cbd5e1}.explainer-answer-text{color:#fbbf24;font-weight:600}.explainer-chevron{flex-shrink:0;display:block;color:#38bdf8;margin-top:2px;transition:transform .2s ease}.explainer.open .explainer-chevron{transform:rotate(180deg)}.tagline{margin:0;font-size:16px;color:#cbd5e1;line-height:1.4}.explainer-points{display:grid;grid-template-columns:1fr;gap:10px}.explainer-point{display:flex;align-items:flex-start;gap:10px;background:#0f172a8c;border:1px solid #334155;border-radius:10px;padding:12px}.explainer-icon{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:#0f172acc;border:1px solid #334155}.explainer-point strong{display:block;font-size:13.5px;color:#f1f5f9;margin-bottom:3px;line-height:1.25}.explainer-point p{margin:0;font-size:12.5px;color:#94a3b8;line-height:1.4}.messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:14px}.empty{margin:auto;color:#64748b;text-align:center;padding:40px 20px;font-size:14px}.msg-wrap{display:flex;flex-direction:column;gap:8px;max-width:85%}.msg-wrap.assistant{align-self:flex-start}.msg-wrap.user{align-self:flex-end}.illustration{background:#0f172a;border:1px solid #334155;border-radius:10px;padding:12px;max-width:340px;animation:illu-enter .4s ease-out both}.illustration svg{display:block;width:100%;height:auto}@keyframes illu-enter{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.illustration .anim-draw{stroke-dasharray:1;stroke-dashoffset:1;animation:illu-draw .55s ease-out both}.illustration .anim-fade{opacity:0;animation:illu-fade .35s ease-out both}.illustration .anim-pop{opacity:0;transform:scale(0);transform-origin:center;transform-box:fill-box;animation:illu-pop .35s cubic-bezier(.34,1.56,.64,1) both}@keyframes illu-draw{to{stroke-dashoffset:0}}@keyframes illu-fade{to{opacity:1}}@keyframes illu-pop{to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion: reduce){.illustration,.illustration .anim-draw,.illustration .anim-fade,.illustration .anim-pop{animation:none}.illustration .anim-draw{stroke-dashoffset:0}.illustration .anim-fade,.illustration .anim-pop{opacity:1;transform:none}}.msg{padding:10px 14px;border-radius:12px;line-height:1.5;font-size:14.5px;white-space:pre-wrap;word-wrap:break-word;position:relative}.msg.speaking{box-shadow:0 0 0 2px #38bdf880}.speak-btn{position:absolute;bottom:-10px;right:-8px;background:#1e293b;color:#94a3b8;border:1px solid #334155;border-radius:999px;width:26px;height:26px;font-size:12px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:color .15s,border-color .15s}.speak-btn:hover{color:#38bdf8;border-color:#38bdf8}.msg.assistant{background:#0f172a;border:1px solid #334155;align-self:flex-start;border-bottom-left-radius:4px}.msg.user{background:#0284c7;color:#f0f9ff;align-self:flex-end;border-bottom-right-radius:4px}.msg.thinking{color:#94a3b8;font-style:italic}.caret{display:inline-block;width:2px;height:1em;margin-left:2px;vertical-align:text-bottom;background:currentColor;animation:caret-blink 1s steps(2,start) infinite}@keyframes caret-blink{to{visibility:hidden}}.composer{display:flex;gap:8px;padding:12px;border-top:1px solid #334155;background:#0f172a}.mic-btn{flex-shrink:0;background:#1e293b;color:#cbd5e1;border:1px solid #334155;border-radius:8px;width:44px;height:44px;font-size:18px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s,color .15s}.mic-btn:hover:not(:disabled){border-color:#64748b;color:#f1f5f9}.mic-btn:disabled{opacity:.4;cursor:not-allowed}.mic-btn.listening{background:#be123c;border-color:#f43f5e;color:#fff;animation:mic-pulse 1.2s ease-in-out infinite}@keyframes mic-pulse{0%,to{box-shadow:0 0 #f43f5e99}50%{box-shadow:0 0 0 6px #f43f5e00}}.composer textarea{flex:1;resize:none;background:#1e293b;border:1px solid #334155;border-radius:8px;color:inherit;padding:10px 12px;font:inherit;font-size:14.5px;min-height:44px;max-height:140px;outline:none}.composer textarea:focus{border-color:#38bdf8}.composer button{background:#38bdf8;color:#0f172a;border:none;border-radius:8px;padding:0 18px;font-weight:600;cursor:pointer;font-size:14px}.composer button:disabled{background:#334155;color:#64748b;cursor:not-allowed}@media (max-width: 640px){.topics{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){.chat{flex:0 0 auto;height:80vh;height:80dvh;min-height:520px;scroll-margin-top:8px}}
