/* tokens.css — 디자인 토큰 단일 소스 */

:root {
  /* ─── Color: Neutral (Ink) ─── */
  --ink-900: #0f172a;
  --ink-700: #1e293b;
  --ink-500: #475569;
  --ink-300: #64748b; /* WCAG AA 대비 확보 (4.5:1, paper 배경) */
  --ink-100: #e2e8f0;
  --ink-050: #f1f5f9;

  /* ─── Color: Surface (Paper) ─── */
  --paper: #ffffff;
  --paper-2: #f1f5f9;
  --paper-3: #ffffff;

  /* ─── Color: Brand ─── */
  --day-gold: #3182f6;
  --day-gold-hover: #1e6fe5;
  --day-gold-soft: #93c5fd;
  --day-gold-tint: rgba(49, 130, 246, 0.12);

  /* Brand navy from logo */
  --brand-navy: #2b3c67;
  --brand-navy-hover: #1f2d4f;

  /* ─── Color: Status ─── */
  --success: #2e7d5b;
  --warn: #b8762f;
  --error: #a23a2e;

  /* ─── Semantic Aliases ─── */
  --color-bg: var(--paper);
  --color-bg-alt: var(--paper-2);
  --color-bg-white: var(--paper-3);
  --color-text: var(--ink-900);
  --color-text-muted: var(--ink-500);
  --color-text-subtle: var(--ink-300);
  --color-text-inverse: var(--paper-3);
  --color-border: rgba(15, 17, 21, 0.1);
  --color-border-strong: rgba(15, 17, 21, 0.2);
  --color-primary: var(--ink-900);
  --color-accent: var(--day-gold);
  --color-accent-hover: var(--day-gold-hover);

  /* ─── Typography: Families ─── */
  --font-sans:
    'Pretendard Variable', 'Pretendard', -apple-system, BlinkMacSystemFont,
    'Apple SD Gothic Neo', 'Noto Sans KR', sans-serif;
  --font-serif: 'Noto Serif KR', 'Nanum Myeongjo', Georgia, serif;

  /* ─── Typography: Scale (desktop) ─── */
  --fs-display: 4.5rem; /* 72px */
  --fs-h1: 3rem; /* 48px */
  --fs-h2: 2.375rem; /* 38px */
  --fs-h3: 1.875rem; /* 30px */
  --fs-lg: 1.3125rem; /* 21px */
  --fs-base: 1.125rem; /* 18px */
  --fs-sm: 1rem; /* 16px */
  --fs-xs: 0.875rem; /* 14px */

  /* ─── Typography: Line Heights ─── */
  --lh-tight: 1.15;
  --lh-snug: 1.3;
  --lh-normal: 1.6;
  --lh-relaxed: 1.75;

  /* ─── Typography: Weights ─── */
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;

  /* ─── Typography: Letter Spacing ─── */
  --tracking-tight: -0.02em;
  --tracking-normal: 0;
  --tracking-wide: 0.04em;
  --tracking-wider: 0.08em;

  /* ─── Spacing (4px base) ─── */
  --space-1: 0.25rem; /* 4 */
  --space-2: 0.5rem; /* 8 */
  --space-3: 0.75rem; /* 12 */
  --space-4: 1rem; /* 16 */
  --space-5: 1.5rem; /* 24 */
  --space-6: 2rem; /* 32 */
  --space-7: 3rem; /* 48 */
  --space-8: 4rem; /* 64 */
  --space-10: 6rem; /* 96 */
  --space-12: 8rem; /* 128 */
  --space-14: 10rem; /* 160 */

  /* ─── Radius ─── */
  --radius-none: 0;
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-pill: 999px;

  /* ─── Shadow (warm tint) ─── */
  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.06);
  --shadow-md: 0 6px 16px rgba(15, 23, 42, 0.08);
  --shadow-lg: 0 20px 40px rgba(15, 23, 42, 0.12);
  --shadow-xl: 0 32px 64px rgba(15, 23, 42, 0.16);

  /* ─── Motion ─── */
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in-out: cubic-bezier(0.65, 0.05, 0.36, 1);
  --dur-fast: 180ms;
  --dur-base: 320ms;
  --dur-slow: 640ms;
  --transition-base: var(--dur-base) var(--ease-out);

  /* ─── Layout ─── */
  --container-max: 1200px;
  --container-narrow: 880px;
  --container-wide: 1360px;
  --header-h: 80px;
  --header-h-scrolled: 56px;

  /* ─── Legacy Token Bridge ─── */
  /* Phase 3에서 서브 페이지 리빌드 후 제거 예정.
     현재 main.css가 참조 중인 구 토큰들을 새 토큰에 매핑. */
  --fs-md: var(--fs-lg);               /* 구 1.125rem ≈ 새 fs-lg 1.125rem */
  --fs-xl: 1.5rem;                   /* lg와 h3 사이 중간값 */
  --fs-2xl: var(--fs-h3);              /* 구 1.953rem → 새 1.5rem (타이포 스케일 재조정 용인) */
  --color-surface: var(--paper-2);
  --color-bg-paper: var(--paper-3);
  --color-accent-soft: var(--day-gold-soft);
}

/* Responsive type scale */
@media (max-width: 768px) {
  :root {
    --fs-display: 2.25rem; /* 36 */
    --fs-h1: 1.875rem; /* 30 */
    --fs-h2: 1.5rem; /* 24 */
    --fs-h3: 1.25rem; /* 20 */
    --fs-lg: 1.0625rem; /* 17 */
    --fs-base: 1rem; /* 16 */
    --fs-sm: 0.875rem; /* 14 */
    --fs-xs: 0.8125rem; /* 13 */
    --fs-xl: 1.25rem; /* 20 */
  }
}
