* Major refactoring and optimisation. * Removed redundant code. * Removed caching for --chat conversations. * Fixing mypy typing. * Printer class to handle LLM output formatting. * Spinner and better handling when DISABLE_STREAMING is True.