/**
 * Paaple Design Tokens
 *
 * CSS 변수 기반 디자인 시스템
 * 모든 토큰은 --pp- 접두사 사용
 *
 * @version 1.0.0
 * @date 2025-10-23
 */

:root {
  /* ============================================
     색상 (Colors)
     ============================================ */

  /* 브랜드 색상 */
  --pp-primary: #996AFF; /* oklch(68.5% 0.234 293) - 브랜드 메인 색상 */
  --pp-secondary: #ED4198; /* oklch(66% 0.215 343) - 브랜드 보조 색상 */
  --pp-brand: linear-gradient(135deg, #996AFF, #ED4198);
  --pp-brand-solid: #996AFF; /* oklch(68.5% 0.234 293) - 단색이 필요한 곳에 사용 (테두리, 텍스트 등) */
  --pp-brand-hover: linear-gradient(135deg, #652DC4, #AA0062);
  --pp-brand-active: linear-gradient(135deg, #BA8DFF, #FF67B9); /* oklch(78% 0.20 293), oklch(75% 0.22 343) */
  --pp-brand-light: #FBD2FF;

  /* 상태 색상 */
  --pp-danger: #EC3B50;
  --pp-danger-hover: #D63444;
  --pp-danger-light: #FDEEF0;

  --pp-alarm: #FF6B35;
  --pp-alarm-hover: #FF5722;
  --pp-alarm-light: #FFF3EF;

  --pp-success: #10B981;
  --pp-success-hover: #0E9F6E;
  --pp-success-light: #E6F7F0;

  --pp-warning: #F59E0B;
  --pp-warning-hover: #D97706;
  --pp-warning-light: #FEF3E2;

  --pp-info: #3B82F6;
  --pp-info-hover: #2563EB;
  --pp-info-light: #EFF6FF;

  /* 배지 그라데이션 */
  --pp-badge-hot: linear-gradient(135deg, #f093fb, #f5576c);
  --pp-badge-category: linear-gradient(135deg, #4facfe, #00f2fe);
  --pp-badge-popular: linear-gradient(135deg, #fa709a, #fee140);
  --pp-badge-new: linear-gradient(135deg, #a8edea, #fed6e3);

  /* 오버레이 */
  --pp-backdrop-overlay: rgba(0, 0, 0, 0.5);
  --pp-backdrop-overlay-light: rgba(0, 0, 0, 0.3);
  --pp-gradient-dark-overlay: linear-gradient(180deg, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0) 100%);

  /* 배경 색상 */
  --pp-background: #FFFFFF; /* 메인 배경색 (body에 사용) */
  --pp-bg: #FFFFFF;
  --pp-bg-secondary: #F9FAFB;
  --pp-panel: #EAEEF4;
  --pp-surface: #F9FAFB;

  /* 텍스트 색상 */
  --pp-text: #1F2937;
  --pp-text-secondary: #6B7280;
  --pp-text-tertiary: #9CA3AF;
  --pp-text-disabled: #D1D5DB;
  --pp-text-inverted: #FFFFFF;

  /* 테두리 색상 */
  --pp-border: #E5E7EB;
  --pp-border-hover: #D1D5DB;
  --pp-border-focus: var(--pp-brand-solid);

  /* Focus Ring */
  --pp-focus-ring: 0 0 0 3px rgba(153, 106, 255, 0.2);
  --pp-focus-ring-light: 0 0 0 3px rgba(153, 106, 255, 0.1);

  /* ============================================
     간격 (Spacing)
     ============================================ */

  --pp-spacing-xs: 4px;
  --pp-spacing-sm: 8px;
  --pp-spacing-md: 16px;
  --pp-spacing-lg: 24px;
  --pp-spacing-xl: 32px;
  --pp-spacing-2xl: 48px;
  --pp-spacing-3xl: 64px;

  /* ============================================
     타이포그래피 (Typography)
     ============================================ */

  /* 폰트 패밀리 */
  --pp-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Apple SD Gothic Neo', 'Noto Sans KR', sans-serif;
  --pp-font-family-mono: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, monospace;

  /* 폰트 크기 */
  --pp-font-size-2xs: 10px;
  --pp-font-size-xs: 12px;
  --pp-font-size-sm: 14px;
  --pp-font-size-md: 16px;
  --pp-font-size-lg: 18px;
  --pp-font-size-xl: 20px;
  --pp-font-size-2xl: 24px;
  --pp-font-size-3xl: 30px;
  --pp-font-size-4xl: 36px;

  /* 줄 높이 */
  --pp-line-height-tight: 1.25;
  --pp-line-height-normal: 1.5;
  --pp-line-height-relaxed: 1.75;

  /* 폰트 두께 */
  --pp-font-weight-light: 300;
  --pp-font-weight-normal: 400;
  --pp-font-weight-medium: 500;
  --pp-font-weight-semibold: 600;
  --pp-font-weight-bold: 700;
  --pp-font-weight-extrabold: 800;

  /* ============================================
     반경 (Border Radius)
     ============================================ */

  --pp-radius-none: 0;
  --pp-radius-sm: 2px;
  --pp-radius: 4px;
  --pp-radius-md: 6px;
  --pp-radius-lg: 8px;
  --pp-radius-xl: 12px;
  --pp-radius-2xl: 16px;
  --pp-radius-full: 9999px;

  /* ============================================
     그림자 (Shadows)
     ============================================ */

  --pp-shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --pp-shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1);
  --pp-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
  --pp-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
  --pp-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
  --pp-shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  --pp-shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, 0.05);

  /* ============================================
     Z-Index
     ============================================ */

  --pp-z-base: 0;
  --pp-z-dropdown: 1000;
  --pp-z-sticky: 1100;
  --pp-z-fixed: 1200;
  --pp-z-modal-backdrop: 1300;
  --pp-z-modal: 1400;
  --pp-z-popover: 1500;
  --pp-z-tooltip: 1600;

  /* ============================================
     전환 (Transitions)
     ============================================ */

  --pp-transition-fast: 150ms;
  --pp-transition-base: 200ms;
  --pp-transition-slow: 300ms;
  --pp-transition-slower: 500ms;

  --pp-ease-in: cubic-bezier(0.4, 0, 1, 1);
  --pp-ease-out: cubic-bezier(0, 0, 0.2, 1);
  --pp-ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);

  /* ============================================
     레이아웃
     ============================================ */

  --pp-container-max-width: 1200px;
  --pp-header-height: 56px;
  --pp-footer-height: 64px;
}

/* ============================================
   다크 모드 (Dark Mode)
   ============================================ */

/* Auto 모드: OS 설정 따름 (기본값) */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    /* 배경 색상 */
    --pp-background: #1F2937;
    --pp-bg: #1F2937;
    --pp-bg-secondary: #111827;
    --pp-panel: #374151;
    --pp-surface: #1F2937;

    /* 텍스트 색상 */
    --pp-text: #F9FAFB;
    --pp-text-secondary: #D1D5DB;
    --pp-text-tertiary: #9CA3AF;
    --pp-text-disabled: #6B7280;
    --pp-text-inverted: #1F2937;

    /* 테두리 색상 */
    --pp-border: #374151;
    --pp-border-hover: #4B5563;

    /* Focus Ring (다크 모드에서는 더 밝게) */
    --pp-focus-ring: 0 0 0 3px rgba(153, 106, 255, 0.4);
    --pp-focus-ring-light: 0 0 0 3px rgba(153, 106, 255, 0.3);
  }
}

/* 수동 다크 모드 (data-theme="dark") */
:root[data-theme="dark"] {
  /* 배경 색상 */
  --pp-background: #1F2937;
  --pp-bg: #1F2937;
  --pp-bg-secondary: #111827;
  --pp-panel: #374151;
  --pp-surface: #1F2937;

  /* 텍스트 색상 */
  --pp-text: #F9FAFB;
  --pp-text-secondary: #D1D5DB;
  --pp-text-tertiary: #9CA3AF;
  --pp-text-disabled: #6B7280;
  --pp-text-inverted: #1F2937;

  /* 테두리 색상 */
  --pp-border: #374151;
  --pp-border-hover: #4B5563;

  /* Focus Ring (다크 모드에서는 더 밝게) */
  --pp-focus-ring: 0 0 0 3px rgba(153, 106, 255, 0.4);
  --pp-focus-ring-light: 0 0 0 3px rgba(153, 106, 255, 0.3);
}

/* 수동 라이트 모드 (data-theme="light") - 기본값 사용 */
:root[data-theme="light"] {
  /* 라이트 모드는 기본 :root 값 사용 (명시적으로 오버라이드 불필요) */
}

/* ============================================
   글로벌 스타일 (Optional)
   ============================================ */

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: var(--pp-font-family);
  font-size: var(--pp-font-size-md);
  line-height: var(--pp-line-height-normal);
  color: var(--pp-text);
  background-color: var(--pp-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
