:root{--primary-color: #646cff;--bg-color: #242424;--text-color: rgba(255, 255, 255, .87);--accent-color: #535bf2;--error-color: #ff4b4b;--success-color: #4caf50}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:var(--bg-color);color:var(--text-color);font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center;width:100%}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:var(--primary-color)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.app-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;min-height:80vh}.talk-button{position:relative;width:120px;height:120px;border-radius:50%;background:linear-gradient(145deg,#2a2a2a,#323232);box-shadow:5px 5px 10px #1a1a1a,-5px -5px 10px #3e3e3e;display:flex;flex-direction:column;align-items:center;justify-content:center;border:none;color:var(--text-color);transition:all .3s ease}.talk-button:active{box-shadow:inset 5px 5px 10px #1a1a1a,inset -5px -5px 10px #3e3e3e}.talk-button.recording{background:var(--error-color);box-shadow:0 0 20px var(--error-color);animation:pulse 1.5s infinite}.talk-button.processing{opacity:.7;cursor:not-allowed}.mic-icon{margin-bottom:5px}@keyframes pulse{0%{box-shadow:0 0 #ff4b4bb3}70%{box-shadow:0 0 0 20px #ff4b4b00}to{box-shadow:0 0 #ff4b4b00}}.status-display{display:flex;flex-direction:column;align-items:center;gap:1rem;min-height:60px}.status-indicator{width:12px;height:12px;border-radius:50%;background-color:#555;transition:background-color .3s}.status-display.recording .status-indicator{background-color:var(--error-color)}.status-display.transcribing .status-indicator{background-color:var(--accent-color);animation:blink 1s infinite}.status-display.thinking .status-indicator{background-color:var(--primary-color);animation:bounce 1s infinite}.status-display.talking .status-indicator{background-color:var(--success-color)}.status-text{font-size:1.2rem;font-weight:300;margin:0}@keyframes blink{50%{opacity:.5}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}
