from __future__ import annotations
import math

def _approx_tokens_by_chars(text: str, ratio: float) -> int:
    if not text:
        return 0
    return max(1, math.ceil(len(text) / ratio))

def count_tokens(text: str, kind: str = "char_approx") -> int:
    """
    Offline token estimator (no API calls).
    Supported kinds:
      - 'qwen'      : 1 token ≈ 2.6 chars (mixed CJK/ASCII heuristic)
      - 'cl100k'    : 1 token ≈ 3.8 chars (OpenAI-ish)
      - 'char_approx': 1 token ≈ 4.0 chars (safe default)
    """
    k = (kind or "char_approx").lower()
    if k == "qwen":
        return _approx_tokens_by_chars(text, 2.6)
    if k == "cl100k":
        return _approx_tokens_by_chars(text, 3.8)
    return _approx_tokens_by_chars(text, 4.0)
