class bcolors:
    HEADER = '\033[95m'  # Magenta
    OKBLUE = '\033[94m'
    OKCYAN = '\033[96m'
    OKGREEN = '\033[92m'
    WARNING = '\033[93m'  # Yellow
    FAIL = '\033[91m'  # Red
    ENDC = '\033[0m'
    BOLD = '\033[1m'
    UNDERLINE = '\033[4m'


class VSSMLogger:
    def __init__(self, logging_enabled: bool = True):
        self.logging_enabled = logging_enabled

    def log(self, message: str, level: str = 'INFO'):
        if self.logging_enabled:
            """Prints a colorful, formatted log message to the console."""
            if level.upper() == 'STEP':
                print(f"{bcolors.HEADER}{bcolors.BOLD}[STEP] {message}{bcolors.ENDC}")
            elif level.upper() == 'ACTION':
                print(f"  {bcolors.OKCYAN}↪ [ACTION] {message}{bcolors.ENDC}")
            elif level.upper() == 'SUCCESS':
                print(f"    {bcolors.OKGREEN}✓ [SUCCESS] {message}{bcolors.ENDC}")
            elif level.upper() == 'FAIL':
                print(f"    {bcolors.FAIL}✗ [FAIL] {message}{bcolors.ENDC}")
            elif level.upper() == 'INFO':
                print(f"    {bcolors.WARNING}• [INFO] {message}{bcolors.ENDC}")
            elif level.upper() == 'DEBUG':
                print(f"      {bcolors.OKBLUE}DEBUG: {message}{bcolors.ENDC}")
            else:
                print(message)