*,:before,:after{box-sizing:border-box}html,body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none;margin:0;padding:0;background:#0a0a1a!important}#root{width:100%;height:100dvh;overflow:hidden}input,button,textarea{font-family:inherit}.chat-mode{background:#0a0a1a;flex-direction:column;height:100dvh;font-family:Inter,-apple-system,sans-serif;display:flex}.chat-header{padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top));background:#0f0f24;border-bottom:1px solid #1a1a3a;flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.chat-header-left{align-items:center;gap:8px;display:flex}.jarvis-orb{width:40px;height:40px}.chat-title{letter-spacing:2px;color:#e0e0e0;margin:0;font-family:Space Grotesk,sans-serif;font-size:18px;font-weight:600}.chat-header-actions{gap:8px;display:flex}.mute-btn,.mode-switch-btn{color:#888;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:8px;display:flex}.mute-btn:active,.mode-switch-btn:active{background:#1a1a3a}.mute-btn.muted{color:#555}.chat-messages{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;gap:8px;padding:16px;display:flex;overflow-y:auto}.message{max-width:80%;display:flex}.message.user{align-self:flex-end}.message.jarvis{align-self:flex-start}.bubble{word-wrap:break-word;border-radius:18px;padding:10px 14px;position:relative}.message.user .bubble{color:#fff;background:#007aff;border-bottom-right-radius:4px}.message.jarvis .bubble{color:#d0d0e0;background:#1a1a3a;border-bottom-left-radius:4px}.bubble p{white-space:pre-wrap;margin:0;font-size:16px;line-height:1.4}.timestamp{opacity:.6;margin-top:4px;font-size:11px;display:block}.message.user .timestamp{text-align:right;color:#ffffffb3}.message.jarvis .timestamp{color:#666}.bubble.typing{align-items:center;gap:4px;padding:14px 18px;display:flex}.dot{background:#999;border-radius:50%;width:8px;height:8px;animation:1.4s infinite typing}.dot:nth-child(2){animation-delay:.2s}.dot:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.chat-input-bar{padding:8px 12px;padding-bottom:calc(8px + env(safe-area-inset-bottom));background:#0f0f24;border-top:1px solid #1a1a3a;align-items:center;gap:8px;display:flex;position:fixed;bottom:0;left:0;right:0}.chat-input{color:#e0e0e0;-webkit-appearance:none;background:#141428;border:1px solid #2a2a4a;border-radius:20px;outline:none;flex:1;padding:10px 16px;font-family:Inter,sans-serif;font-size:16px}.chat-input:focus{border-color:#007aff}.send-btn{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#007aff;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.send-btn:disabled{color:#444;background:#1a1a3a}.send-btn:active:not(:disabled){background:#0066d6}.voice-mode{color:#fff;background:#0a0a1a;flex-direction:column;height:100dvh;font-family:Space Grotesk,sans-serif;display:flex}.voice-header{padding:16px 20px;padding-top:calc(16px + env(safe-area-inset-top));flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.voice-title{letter-spacing:6px;color:#ffffffe6;margin:0;font-family:Space Grotesk,sans-serif;font-size:22px;font-weight:600}.voice-header-actions{align-items:center;gap:10px;display:flex}.voice-mode-btn{color:#fffc;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffff1a;border:1px solid #fff3;border-radius:16px;padding:6px 16px;font-family:Space Grotesk,sans-serif;font-size:14px}.voice-mode-btn:active{background:#fff3}.voice-mute-btn{color:#ffffffb3;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;padding:8px;display:flex}.voice-mute-btn.muted{color:#ffffff4d}.voice-content{padding:20px;padding-bottom:calc(40px + env(safe-area-inset-bottom));flex-direction:column;flex:1;justify-content:center;align-items:center;gap:24px;display:flex}.visualizer-container{justify-content:center;align-items:center;width:200px;height:200px;display:flex;position:relative}.visualizer-canvas{width:200px;height:200px}.voice-loading{color:#64a0ffb3;letter-spacing:2px;text-transform:uppercase;font-size:14px;position:absolute}.voice-transcript{text-align:center;color:#ffffff80;max-width:300px;min-height:48px;margin:0;font-family:Inter,sans-serif;font-size:15px;line-height:1.5}.mic-button{color:#ffffffe6;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#64a0ff1a;border:2px solid #64a0ff66;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;transition:all .3s;display:flex}.mic-button:active:not(:disabled){transform:scale(.95)}.mic-button:disabled{opacity:.4}.mic-button.listening{background:#64a0ff4d;border-color:#64a0ffcc;animation:2s infinite pulse;box-shadow:0 0 30px #64a0ff4d}@keyframes pulse{0%{box-shadow:0 0 20px #64a0ff33}50%{box-shadow:0 0 40px #64a0ff66}to{box-shadow:0 0 20px #64a0ff33}}.app-container{width:100%;height:100dvh}.mode-transition{animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}
