*,:before,:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{color:#f5f7fa;background:#0f1419;font-family:system-ui,-apple-system,sans-serif}button{font-family:inherit}.app-shell{color:#f5f7fa;background:#0f1419;flex-direction:column;min-height:100vh;font-family:system-ui,-apple-system,sans-serif;display:flex}.app-header{border-bottom:1px solid #1f2937;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1.25rem;display:flex}.app-header-brand{letter-spacing:-.01em;font-size:1.1rem;font-weight:700}.app-tabs{background:#1f2937;border-radius:999px;gap:.25rem;padding:.25rem;display:flex}.app-tab{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:999px;padding:.4rem 1rem;font-size:.9rem;font-weight:600;transition:background .15s,color .15s}.app-tab:hover{color:#f5f7fa}.app-tab-active{color:#f5f7fa;background:#0f1419}.app-user{align-items:center;gap:.6rem;display:flex}.app-avatar{object-fit:cover;background:#334155;border-radius:50%;width:28px;height:28px}.app-avatar-fallback{color:#f5f7fa;justify-content:center;align-items:center;font-size:.85rem;font-weight:600;display:inline-flex}.app-user-name{color:#cbd5e1;font-size:.9rem}.app-signout-btn{color:#cbd5e1;cursor:pointer;background:0 0;border:1px solid #334155;border-radius:999px;padding:.35rem .75rem;font-size:.8rem;font-weight:500;transition:background .15s}.app-signout-btn:hover{background:#1f2937}.app-content{flex-direction:column;flex:1;min-height:0;display:flex}.login-root{color:#f5f7fa;background:#0f1419;justify-content:center;align-items:center;min-height:100vh;padding:2rem;font-family:system-ui,-apple-system,sans-serif;display:flex}.login-card{text-align:center;background:#111827;border:1px solid #1f2937;border-radius:16px;width:100%;max-width:420px;padding:2.5rem 2rem;box-shadow:0 20px 50px #00000073}.login-wordmark{letter-spacing:-.03em;margin:0 0 .5rem;font-size:2.5rem;font-weight:800}.login-subtitle{color:#9ca3af;margin:0 0 2rem;font-size:.95rem}.login-google-button{justify-content:center;min-height:44px;display:flex}.login-error{color:#f87171;margin-top:1.25rem;font-size:.9rem}.chat-screen{flex-direction:column;flex:1;width:100%;max-width:820px;min-height:0;margin:0 auto;display:flex}.chat-messages{flex-direction:column;flex:1;gap:.6rem;padding:1.25rem 1rem;display:flex;overflow-y:auto}.chat-empty{color:#6b7280;flex:1;justify-content:center;align-items:center;min-height:200px;font-size:.95rem;display:flex}.chat-row{width:100%;display:flex}.chat-row-user{justify-content:flex-end}.chat-row-assistant{justify-content:flex-start}.chat-bubble{white-space:pre-wrap;word-wrap:break-word;border-radius:18px;max-width:78%;padding:.65rem .95rem;font-size:.95rem;line-height:1.4}.chat-bubble-user{color:#fff;background:#2563eb;border-bottom-right-radius:6px}.chat-bubble-assistant{color:#f5f7fa;background:#1f2937;border-bottom-left-radius:6px}.chat-bubble-typing{color:#9ca3af;font-style:italic}.chat-error{color:#f87171;text-align:center;background:#ef44441a;border-radius:8px;align-self:center;max-width:80%;padding:.5rem .75rem;font-size:.85rem}.chat-input-bar{background:#0f1419;border-top:1px solid #1f2937;gap:.5rem;padding:.75rem 1rem 1rem;display:flex;position:sticky;bottom:0}.chat-input{resize:none;color:#f5f7fa;background:#1f2937;border:1px solid #334155;border-radius:14px;outline:none;flex:1;max-height:160px;padding:.65rem .9rem;font-family:inherit;font-size:.95rem;line-height:1.4}.chat-input:focus{border-color:#2563eb}.chat-input:disabled{opacity:.6}.chat-send-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:14px;padding:0 1.1rem;font-weight:600;transition:background .15s}.chat-send-btn:hover:not(:disabled){background:#1d4ed8}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.voice-screen{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2rem;padding:2rem;display:flex}.call-btn{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:50%;width:180px;height:180px;font-size:1.5rem;font-weight:600;transition:transform .15s,background .15s;box-shadow:0 8px 24px #22c55e59}.call-btn:hover{background:#16a34a;transform:scale(1.03)}.call-btn:active{transform:scale(.98)}.status{flex-direction:column;align-items:center;gap:1rem;font-size:1.25rem;display:flex}.spinner{border:4px solid #ffffff26;border-top-color:#22c55e;border-radius:50%;width:48px;height:48px;animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.connected{flex-direction:column;align-items:center;gap:2rem;display:flex}.status-text{color:#22c55e;margin:0;font-size:1.5rem;font-weight:500}.controls{gap:1rem;display:flex}.mute-btn,.end-btn{cursor:pointer;border:none;border-radius:999px;padding:.9rem 1.75rem;font-size:1rem;font-weight:600;transition:background .15s}.mute-btn{color:#fff;background:#334155}.mute-btn:hover{background:#475569}.end-btn{color:#fff;background:#ef4444}.end-btn:hover{background:#dc2626}.error{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;max-width:480px;display:flex}.error-msg{color:#f87171;word-break:break-word;margin:0;font-size:1rem}
