*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:#f5f5f5;color:#333;line-height:1.6}.app{max-width:800px;margin:0 auto;padding:20px}.app-header{text-align:center;margin-bottom:30px}.app-header h1{font-size:1.8rem;color:#1976d2;margin-bottom:8px}.app-header p{color:#666;font-size:.95rem}.voice-input-panel{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:24px}.voice-input-panel.unsupported{text-align:center;padding:40px}.unsupported-message h3{color:#f44336;margin-bottom:12px}.unsupported-message p{color:#666}.main-control{display:flex;flex-direction:column;align-items:center;gap:16px;margin-bottom:24px}.mic-button{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100px;height:100px;border:none;border-radius:50%;background:#1976d2;color:#fff;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #1976d266}.mic-button:hover{background:#1565c0;transform:scale(1.05)}.mic-button.listening{background:#f44336;box-shadow:0 4px 15px #f4433666;animation:pulse 1.5s infinite}@keyframes pulse{0%{box-shadow:0 0 #f4433666}70%{box-shadow:0 0 0 20px #f4433600}to{box-shadow:0 0 #f4433600}}.mic-icon{width:40px;height:40px;margin-bottom:4px}.mic-label{font-size:.85rem;font-weight:500}.wave-animation{display:flex;align-items:center;gap:4px;height:30px}.wave{display:inline-block;width:4px;height:100%;background:#1976d2;border-radius:2px;animation:wave 1s ease-in-out infinite}.wave:nth-child(1){animation-delay:0s}.wave:nth-child(2){animation-delay:.1s}.wave:nth-child(3){animation-delay:.2s}.wave:nth-child(4){animation-delay:.3s}.wave:nth-child(5){animation-delay:.4s}@keyframes wave{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1)}}.provider-info{font-size:.85rem;color:#666;margin-top:8px}.status-display{background:#f8f9fa;border-radius:8px;padding:16px;margin-bottom:20px}.status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.status-header h3{font-size:1rem;color:#333}.listening-indicator{font-size:.85rem;padding:4px 12px;border-radius:20px;background:#e0e0e0;color:#666}.listening-indicator.active{background:#4caf50;color:#fff;animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.7}}.status-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px}.status-item{text-align:center;padding:12px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.status-label{display:block;font-size:.75rem;color:#999;margin-bottom:4px}.status-value{display:block;font-size:1.2rem;font-weight:600;color:#1976d2}.interim-transcript{padding:12px;background:#fff3e0;border-radius:6px;margin-bottom:8px}.interim-label{font-size:.85rem;color:#f57c00;margin-right:8px}.interim-text{color:#e65100}.last-result{padding:12px;background:#e3f2fd;border-radius:6px}.last-label{font-size:.85rem;color:#1976d2;margin-right:8px}.last-value{font-weight:600;color:#0d47a1}.last-confidence{font-size:.85rem;color:#64b5f6;margin-left:8px}.error-message{padding:12px;background:#ffebee;border-radius:6px;color:#c62828;margin-top:8px}.command-log{margin-bottom:20px}.log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.log-header h3{font-size:1rem;color:#333}.clear-button{padding:6px 16px;border:1px solid #ddd;border-radius:4px;background:#fff;color:#666;cursor:pointer;font-size:.85rem;transition:all .2s}.clear-button:hover:not(:disabled){background:#f5f5f5;border-color:#ccc}.clear-button:disabled{opacity:.5;cursor:not-allowed}.log-list{max-height:200px;overflow-y:auto;background:#fafafa;border-radius:8px;padding:8px}.log-empty{text-align:center;color:#999;padding:20px}.log-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border-radius:6px;margin-bottom:4px;box-shadow:0 1px 2px #0000000d}.log-item:last-child{margin-bottom:0}.log-type{font-size:.75rem;padding:2px 8px;border-radius:4px;color:#fff;font-weight:500}.log-value{flex:1;font-weight:500}.log-raw{font-size:.75rem;color:#999}.usage-guide{padding:16px;background:#e8f5e9;border-radius:8px}.usage-guide h4{font-size:.95rem;color:#2e7d32;margin-bottom:8px}.usage-guide ul{margin-left:20px}.usage-guide li{font-size:.9rem;color:#555;margin-bottom:4px}@media (max-width: 600px){.app{padding:12px}.status-grid{grid-template-columns:1fr}.voice-input-panel{padding:16px}}
