/* ═══════════════════════════════════════════════
   DESIGN TOKENS — Single source of truth
   Load before all other stylesheets
   ═══════════════════════════════════════════════ */

:root {
  /* Colors */
  --color-ink: #2C2C2C;
  --color-stone: #57534e;
  --color-faint: #8C8578;
  --color-paper: #F0EDE8;
  --color-card: #FAFAF7;
  --color-divider: #D8D2C8;
  --color-accent: #3D5A80;
  --color-gold: #C9A96E;
  --color-moss: #6B7F5C;
  --color-terracotta: #A35A4A;
  --color-terracotta-bg: rgba(163, 90, 74, 0.07);
  --color-amber: #A07850;
  --color-amber-deep: #8A6E35;
  --color-moss-bright: #5B8C5A;
  --color-coral: #C07560;
  --color-gold-bright: #D4B87C;
  --color-paper-shimmer-lo: #EDEBE6;
  --color-paper-shimmer-hi: #F2F0EB;
  --color-pill-category: #8B7340;
  --color-pill-ippo: #7A5030;
  --color-pill-genki2: #4A6B48;
  --color-pill-supp: #5C564E;
  --color-jp-text: #523E1E;
  --color-romaji: #78716c;

  /* Border radius */
  --radius-sm: 4px;
  --radius: 8px;
  --radius-lg: 14px;
  --radius-xl: 22px;
  --radius-full: 999px;

  /* Shadows — warm sumi ink, not pure black */
  --shadow-sm: 0 1px 3px rgba(44, 44, 44, 0.04);
  --shadow: 0 2px 8px rgba(44, 44, 44, 0.07);
  --shadow-lg: 0 4px 15px rgba(44, 44, 44, 0.12);
  --shadow-subtle: 0 1px 2px rgba(44, 44, 44, 0.03);
  --shadow-rest:
    0 1px 2px rgba(44, 44, 44, 0.03),
    0 8px 28px rgba(44, 44, 44, 0.045);
  --shadow-hover:
    0 2px 4px rgba(44, 44, 44, 0.04),
    0 12px 36px rgba(44, 44, 44, 0.07);

  /* Timing */
  --duration-fast: 0.15s;
  --duration: 0.25s;
  --duration-slow: 0.4s;
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);

  /* Typography */
  --font-jp: 'Klee One', 'Noto Sans JP', serif;
  --font-ui: 'Inter', 'Noto Sans JP', sans-serif;

  /* ── Short-name aliases (shared by learn-mode + exercises quiz surfaces) ── */
  --paper: var(--color-paper);
  --ink: var(--color-ink);
  --stone: var(--color-stone);
  --faint: var(--color-faint);
  --card: var(--color-card);
  --divider: var(--color-divider);
  --accent: var(--color-accent);
  --gold: var(--color-gold);
  --moss: var(--color-moss);
  --terracotta: var(--color-terracotta);
  --terracotta-bg: var(--color-terracotta-bg);
  --amber: var(--color-amber);
  --amber-deep: var(--color-amber-deep);
  --moss-bright: var(--color-moss-bright);
  --coral: var(--color-coral);
  --gold-bright: var(--color-gold-bright);
  --jp-text: var(--color-jp-text);

  /* 4-type text system */
  --kanji-family: var(--font-jp);
  --kanji-color: var(--ink);
  --kanji-weight: 400;

  --furigana-family: 'Noto Sans JP', sans-serif;
  --furigana-color: var(--terracotta);
  --furigana-weight: 500;

  --romaji-family: var(--font-ui);
  --romaji-color: var(--color-romaji);
  --romaji-weight: 400;

  --english-family: var(--font-ui);
  --english-color: var(--stone);
  --english-weight: 500;

  /* Layout */
  --side: 20px;
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
}
