/* ============================================================
   GadgetCheck / 数码验机助手 — Design Tokens
   Style: Dark Mode Tech Lab
   Pattern: Bento Grid + Tool-First
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Space+Grotesk:wght@500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  /* ─── Color System ─── */
  --color-primary: #06B6D4;          /* Cyan 500 - 科技精准 */
  --color-primary-light: #22D3EE;    /* Cyan 400 */
  --color-primary-dark: #0891B2;     /* Cyan 600 */
  --color-primary-glow: rgba(6, 182, 212, 0.15);

  --color-accent: #8B5CF6;           /* Violet 500 - 高级功能 */
  --color-accent-light: #A78BFA;     /* Violet 400 */

  --color-secondary: #10B981;        /* Emerald 500 - 安全/通过 */

  /* 背景层级 */
  --color-bg-base: #0B1120;          /* 最深底色 */
  --color-bg-surface: #111827;       /* 卡片/面板 */
  --color-bg-elevated: #1E293B;      /* 悬浮/弹出 */
  --color-bg-muted: #1E2A3A;         /* 输入框/表单 */

  /* 文字 */
  --color-text-primary: #F1F5F9;     /* Slate 100 */
  --color-text-secondary: #94A3B8;   /* Slate 400 */
  --color-text-muted: #64748B;       /* Slate 500 */
  --color-text-inverse: #0F172A;     /* 深色文字用于亮色背景 */

  /* 边框 */
  --color-border: #1E293B;           /* Slate 800 */
  --color-border-hover: #334155;     /* Slate 700 */
  --color-border-focus: var(--color-primary);

  /* 风险等级语义色 */
  --color-risk-low: #10B981;         /* 绿 - 低风险 */
  --color-risk-medium: #F59E0B;      /* 琥珀 - 中风险 */
  --color-risk-high: #EF4444;        /* 红 - 高风险 */
  --color-risk-critical: #991B1B;    /* 深红 - 极高风险 */

  /* 功能色 */
  --color-success: #10B981;
  --color-warning: #F59E0B;
  --color-error: #EF4444;
  --color-info: #06B6D4;

  /* ─── Typography ─── */
  --font-heading: 'Space Grotesk', -apple-system, 'PingFang SC', 'Noto Sans SC', sans-serif;
  --font-body: 'Inter', -apple-system, 'PingFang SC', 'Noto Sans SC', 'Microsoft YaHei', sans-serif;
  --font-mono: 'JetBrains Mono', 'Fira Code', monospace;

  /* 字号 (规范: 正文 14px, H1 32px) */
  --text-xs: 0.75rem;     /* 12px */
  --text-sm: 0.8125rem;   /* 13px */
  --text-base: 0.875rem;  /* 14px - 正文默认 */
  --text-md: 1rem;        /* 16px */
  --text-lg: 1.125rem;    /* 18px */
  --text-xl: 1.25rem;     /* 20px */
  --text-2xl: 1.5rem;     /* 24px */
  --text-3xl: 2rem;       /* 32px - H1 */

  --leading-tight: 1.3;
  --leading-normal: 1.6;
  --leading-relaxed: 1.75;

  --weight-normal: 400;
  --weight-medium: 500;
  --weight-semibold: 600;
  --weight-bold: 700;

  /* ─── Spacing (4px grid) ─── */
  --space-1: 0.25rem;   /* 4px */
  --space-2: 0.5rem;    /* 8px */
  --space-3: 0.75rem;   /* 12px */
  --space-4: 1rem;      /* 16px */
  --space-5: 1.25rem;   /* 20px */
  --space-6: 1.5rem;    /* 24px */
  --space-8: 2rem;      /* 32px */
  --space-10: 2.5rem;   /* 40px */
  --space-12: 3rem;     /* 48px */
  --space-16: 4rem;     /* 64px */

  /* ─── Border Radius ─── */
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-xl: 20px;
  --radius-full: 9999px;

  /* ─── Shadows & Effects ─── */
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.3);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4);
  --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.5);
  --shadow-glow: 0 0 20px var(--color-primary-glow);
  --shadow-card: 0 2px 8px rgba(0, 0, 0, 0.3), 0 0 1px rgba(6, 182, 212, 0.1);

  /* Glassmorphism */
  --glass-bg: rgba(17, 24, 39, 0.7);
  --glass-border: rgba(255, 255, 255, 0.06);
  --glass-blur: blur(12px);

  /* ─── Transitions ─── */
  --transition-fast: 150ms ease;
  --transition-base: 250ms ease;
  --transition-slow: 400ms ease;
  --transition-spring: 300ms cubic-bezier(0.34, 1.56, 0.64, 1);

  /* ─── Z-Index Scale ─── */
  --z-base: 0;
  --z-dropdown: 10;
  --z-sticky: 20;
  --z-overlay: 40;
  --z-modal: 100;
  --z-toast: 1000;

  /* ─── Layout ─── */
  --container-max: 1200px;
  --container-padding: var(--space-4);
  --nav-height: 60px;
  --bottom-bar-height: 64px;

  /* ─── Breakpoints (reference) ─── */
  /* sm: 640px, md: 768px, lg: 1024px, xl: 1440px */
}

/* ─── Reduced Motion ─── */
@media (prefers-reduced-motion: reduce) {
  :root {
    --transition-fast: 0ms;
    --transition-base: 0ms;
    --transition-slow: 0ms;
    --transition-spring: 0ms;
  }
}
