/* ================================================================
   tokens.css — AI末日議會 Design Tokens
   ================================================================ */

:root {

  /* ── 色彩：品牌核心 ── */
  --color-blood-red: #ff003c;
  --color-dark-red: #1a0005;
  --color-cyber-cyan: #00f3ff;
  --color-cyber-magenta: #ff00e6;
  --color-online-green: #00ff66;

  /* ── 色彩：背景層級 ── */
  --color-bg-void: #020002;
  --color-bg-primary: #000000;
  --color-bg-surface: rgba(20, 0, 0, 0.4);
  --color-bg-elevated: rgba(40, 0, 5, 0.6);
  --color-bg-overlay: rgba(0, 0, 0, 0.85);
  --color-bg-input: rgba(10, 0, 0, 0.6);
  --color-bg-vignette: radial-gradient(circle at center, rgba(30, 0, 0, 0.8) 0%, rgba(0, 0, 0, 1) 80%);

  /* ── 色彩：文字 ── */
  --color-text-primary: #ffffff;
  --color-text-secondary: rgba(255, 255, 255, 0.7);
  --color-text-muted: rgba(255, 255, 255, 0.4);
  --color-text-disabled: rgba(255, 255, 255, 0.2);
  --color-text-accent: var(--color-cyber-cyan);
  --color-text-danger: var(--color-blood-red);

  /* ── 色彩：邊框 ── */
  --color-border-subtle: rgba(255, 0, 60, 0.1);
  --color-border-default: rgba(255, 0, 60, 0.2);
  --color-border-strong: rgba(255, 0, 60, 0.5);
  --color-border-active: rgba(255, 0, 60, 0.8);
  --color-border-focus: var(--color-blood-red);
  --color-border-muted: #333333;

  /* ── 色彩：語意 ── */
  --color-success: var(--color-online-green);
  --color-warning: #ff9500;
  --color-error: var(--color-blood-red);
  --color-info: var(--color-cyber-cyan);

  /* ── 字體家族 ── */
  --font-display: 'Anton', sans-serif;
  --font-ui: 'Oswald', sans-serif;
  --font-mono: 'Courier New', monospace;

  /* ── 字體大小 ── */
  --text-2xs: 0.625rem;
  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 2rem;
  --text-4xl: 2.5rem;
  --text-5xl: 3rem;
  --text-hero: 4rem;

  /* ── 字體粗細 ── */
  --weight-normal: 400;
  --weight-medium: 500;
  --weight-bold: 700;

  /* ── 行高 ── */
  --leading-tight: 1.1;
  --leading-normal: 1.4;
  --leading-relaxed: 1.6;

  /* ── 字距 ── */
  --tracking-tight: -0.02em;
  --tracking-normal: 0;
  --tracking-wide: 0.05em;
  --tracking-wider: 0.1em;
  --tracking-widest: 0.2em;
  --tracking-ultra: 0.3em;

  /* ── 間距（4px base grid） ── */
  --space-0: 0;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;

  /* ── 圓角 ── */
  --radius-none: 0;
  --radius-sm: 2px;
  --radius-md: 4px;
  --radius-lg: 8px;
  --radius-xl: 12px;
  --radius-full: 9999px;

  /* ── 陰影 & 光暈 ── */
  --shadow-none: none;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.5);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.6);
  --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.7);
  --shadow-glow-red: 0 0 20px rgba(255, 0, 60, 0.3);
  --shadow-glow-red-lg: 0 0 50px 20px rgba(255, 0, 60, 0.8);
  --shadow-glow-cyan: 0 0 20px rgba(0, 243, 255, 0.3);
  --shadow-glow-green: 0 0 20px rgba(0, 255, 102, 0.3);
  --shadow-glow-white: 0 0 20px rgba(255, 255, 255, 0.5);
  --shadow-inset-red: inset 0 0 10px rgba(255, 0, 60, 0.2);
  --shadow-inset-dark: inset 0 0 100px rgba(0, 0, 0, 0.9);
  --shadow-vignette: 0 0 100px rgba(255, 0, 60, 0.1) inset;

  /* ── 動畫時長 ── */
  --duration-instant: 50ms;
  --duration-fast: 150ms;
  --duration-normal: 300ms;
  --duration-slow: 600ms;
  --duration-slower: 800ms;
  --duration-crawl: 1200ms;

  /* ── 動畫曲線 ── */
  --ease-default: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-in: cubic-bezier(0.4, 0, 1, 1);
  --ease-out: cubic-bezier(0, 0, 0.2, 1);
  --ease-bounce: cubic-bezier(0.25, 1, 0.5, 1);
  --ease-crash: cubic-bezier(0.36, 0.07, 0.19, 0.97);

  /* ── Z 軸層級 ── */
  --z-base: 1;
  --z-cell: 10;
  --z-player-id: 10;
  --z-grid: 20;
  --z-corner: 40;
  --z-ui-overlay: 50;
  --z-crt: 50;
  --z-banner: 100;
  --z-nav: 200;
  --z-modal: 500;
  --z-hover-cell: 999;
  --z-flying: 1000;
  --z-toast: 1100;

  /* ── 佈局 ── */
  --nav-height: 56px;
  --nav-height-lg: 64px;
  --content-max-width: 480px;
  --matrix-aspect: 16 / 9;
  --grid-cols: 16;
  --grid-rows: 7;
  --grid-gap: 0.5vh;
}