import time
import threading
import random

# Shared global lock and timestamp across all threads
_last_call = 0.0
_lock = threading.Lock()

# Adjust this if needed; around 50–100 ms is safe for Gemini
MIN_INTERVAL = 0.07  # seconds (70 ms)

def global_throttle():
    """Ensure a minimum interval between ANY two LLM API calls."""
    global _last_call
    with _lock:
        now = time.time()
        elapsed = now - _last_call
        if elapsed < MIN_INTERVAL:
            time.sleep(MIN_INTERVAL - elapsed)
        _last_call = time.time()