/**
 * Ferni Design Tokens
 * CSS Custom Properties implementing brand guidelines
 *
 * 🎨 AUTO-GENERATED FROM design-system/tokens/
 * Do not edit directly - run: pnpm tokens:sync
 * Generated: 2026-01-10T19:02:53.619Z
 */

:root {
  /* ============================================
     COLORS - Background
     ============================================ */
  --color-bg-primary: var(--color-paper);
  --color-bg-secondary: var(--color-paper-warm);
  --color-bg-elevated: var(--color-paper-cream);
  --color-bg-glass: rgba(139, 119, 91, 0.03);
  --color-bg-overlay: rgba(250, 248, 245, 0.95);

  /* ============================================
     COLORS - Text
     ============================================ */
  --color-text-primary: var(--color-ink);
  --color-text-secondary: var(--color-ink-light);
  --color-text-muted: var(--color-stone-dark);
  --color-text-dimmed: #756a5e;
  --color-text-inverse: var(--color-paper);

  /* ============================================
     COLORS - Accent
     ============================================ */
  --color-accent: var(--color-accent);
  --color-accent-hover: var(--color-ferni-light);
  --color-accent-pressed: var(--color-ferni-dark);
  --color-accent-glow: rgba(61, 90, 69, 0.15);
  --color-accent-subtle: rgba(61, 90, 69, 0.05);

  /* ============================================
     COLORS - Borders
     ============================================ */
  --color-border-subtle: rgba(44, 37, 32, 0.05);
  --color-border-medium: rgba(44, 37, 32, 0.10);
  --color-border-strong: rgba(44, 37, 32, 0.18);

  /* ============================================
     COLORS - Semantic
     ============================================ */
  --color-success: var(--color-success-dark);
  --color-success-bg: rgba(61, 122, 82, 0.18);
  --color-error: #b5453a;
  --color-error-bg: rgba(181, 69, 58, 0.18);
  --color-warning: #a67c35;
  --color-warning-bg: rgba(166, 124, 53, 0.18);

  --color-success-light: #a5c99a;

  /* ============================================
     COLORS - Dark Theme / Cedar Night Accents
     Used for dark sections and dark mode
     ============================================ */
  --color-accent-gold: #d4a84a;
  --color-accent-gold-hover: #e0bc6a;
  --color-cedar: var(--color-bg-elevated);
  --color-cedar-dark: var(--color-cedar);

  /* ============================================
     COLORS - Personas
     Theme-aware: --color-{persona}-text adapts
     to light/dark mode for WCAG AA contrast
     ============================================ */
  --color-ferni: var(--color-ferni);
  --color-ferni-secondary: var(--color-ferni-secondary);
  --color-ferni-glow: rgba(74, 103, 65, 0.28);
  --color-ferni-text: var(--color-ferni);
  --color-ferni-subtle: rgba(74, 103, 65, 0.06);

  --color-jack: #9a7b5a;
  --color-jack-secondary: #7d6348;
  --color-jack-glow: rgba(154, 123, 90, 0.28);
  --color-jack-text: #9a7b5a;
  --color-jack-subtle: rgba(154, 123, 90, 0.06);

  --color-peter: var(--color-peter);
  --color-peter-secondary: var(--color-peter-secondary);
  --color-peter-glow: rgba(58, 107, 115, 0.28);
  --color-peter-text: var(--color-peter);
  --color-peter-subtle: rgba(58, 107, 115, 0.06);

  --color-alex: var(--color-alex);
  --color-alex-secondary: var(--color-alex-secondary);
  --color-alex-glow: rgba(90, 107, 138, 0.28);
  --color-alex-text: var(--color-alex);
  --color-alex-subtle: rgba(90, 107, 138, 0.06);

  --color-maya: var(--color-maya);
  --color-maya-secondary: #8a635a;
  --color-maya-glow: rgba(166, 122, 106, 0.28);
  --color-maya-text: var(--color-maya);
  --color-maya-subtle: rgba(166, 122, 106, 0.06);

  --color-jordan: var(--color-jordan);
  --color-jordan-secondary: #a86d55;
  --color-jordan-glow: rgba(196, 133, 106, 0.28);
  --color-jordan-text: var(--color-jordan);
  --color-jordan-subtle: rgba(196, 133, 106, 0.06);

  --color-nayan: var(--color-nayan);
  --color-nayan-secondary: #9a7a52;
  --color-nayan-glow: rgba(184, 149, 106, 0.28);
  --color-nayan-text: var(--color-nayan);
  --color-nayan-subtle: rgba(184, 149, 106, 0.06);

  --color-eli: var(--color-eli);
  --color-eli-secondary: var(--color-eli-dark);
  --color-eli-glow: rgba(107, 91, 149, 0.28);
  --color-eli-text: var(--color-eli);
  --color-eli-subtle: rgba(107, 91, 149, 0.06);

  --color-marcus: var(--color-marcus);
  --color-marcus-secondary: var(--color-forest-dark);
  --color-marcus-glow: rgba(45, 90, 74, 0.28);
  --color-marcus-text: var(--color-marcus);
  --color-marcus-subtle: rgba(45, 90, 74, 0.06);

  --color-kenji: var(--color-kenji);
  --color-kenji-secondary: var(--color-gray-900);
  --color-kenji-glow: rgba(44, 62, 80, 0.28);
  --color-kenji-text: var(--color-kenji);
  --color-kenji-subtle: rgba(44, 62, 80, 0.06);

  --color-carmen: var(--color-carmen);
  --color-carmen-secondary: #A67B5B;
  --color-carmen-glow: rgba(212, 163, 115, 0.28);
  --color-carmen-text: var(--color-carmen);
  --color-carmen-subtle: rgba(212, 163, 115, 0.06);

  --color-amara: var(--color-amara);
  --color-amara-secondary: var(--color-eli);
  --color-amara-glow: rgba(123, 107, 168, 0.28);
  --color-amara-text: var(--color-amara);
  --color-amara-subtle: rgba(123, 107, 168, 0.06);

  --color-sasha: var(--color-sasha);
  --color-sasha-secondary: #B85C3C;
  --color-sasha-glow: rgba(224, 123, 83, 0.28);
  --color-sasha-text: var(--color-sasha);
  --color-sasha-subtle: rgba(224, 123, 83, 0.06);

  --color-ray: var(--color-ray);
  --color-ray-secondary: var(--color-gray-800);
  --color-ray-glow: rgba(74, 85, 104, 0.28);
  --color-ray-text: var(--color-ray);
  --color-ray-subtle: rgba(74, 85, 104, 0.06);

  /* ============================================
     COLORS - Natural Palette
     Japanese garden inspired earthy tones
     ============================================ */
  --color-wood: var(--color-wood);
  --color-wood-light: #d4c4b0;
  --color-wood-dark: var(--color-wood-dark);
  --color-bamboo: #7a8f5a;
  --color-bamboo-light: #9aaf7a;
  --color-stone: #8a8075;
  --color-stone-light: #a8a095;
  --color-sand: #e8e0d5;
  --color-sand-light: #f5f0e8;
  --color-moss: var(--color-moss);
  --color-moss-light: var(--color-moss-light);
  --color-paper: var(--color-paper);
  --color-paper-cream: var(--color-paper-cream);
  --color-paper-warm: var(--color-paper-warm);
  --color-ink: var(--color-ink);
  --color-ink-light: var(--color-ink-light);
  --color-tea: #c4a77d;
  --color-tea-light: #d8c4a0;
  --color-forest-green: var(--color-accent);
  --color-warm-amber: #a67c35;
  --color-warm-amber-light: #c49a50;
  --color-highlight: var(--color-highlight);
  --color-highlight-glow: rgba(255, 248, 230, 0.5);

  /* ============================================
     COLORS - Cinematic (Hero Sections)
     Storytelling and dramatic reveals
     ============================================ */
  --color-cinematic-primary: var(--cinematic-black-primary);
  --color-cinematic-deep: var(--cinematic-black-deep);
  --color-cinematic-rich: var(--cinematic-black-rich);
  --color-cinematic-text-hero: #ffffff;
  --color-cinematic-text-hero-subtle: rgba(255, 255, 255, 0.9);
  --color-cinematic-text-hero-muted: rgba(255, 255, 255, 0.7);
  --color-cinematic-glow-warm: rgba(212, 168, 74, 0.4);
  --color-cinematic-glow-cool: rgba(125, 166, 207, 0.4);
  --color-cinematic-glow-magic: rgba(168, 139, 250, 0.35);

  /* ============================================
     COLORS - Comparison
     Before/After, Good/Bad features
     ============================================ */
  --color-comparison-before-background: var(--color-paper-warm);
  --color-comparison-before-border: rgba(44, 37, 32, 0.08);
  --color-comparison-before-text: #756a5e;
  --color-comparison-after-background: rgba(61, 90, 69, 0.06);
  --color-comparison-after-border: rgba(61, 90, 69, 0.15);
  --color-comparison-after-text: var(--color-accent);
  --color-comparison-after-glow: rgba(61, 90, 69, 0.12);
  --color-comparison-bad-background: rgba(181, 69, 58, 0.06);
  --color-comparison-bad-border: rgba(181, 69, 58, 0.15);
  --color-comparison-bad-text: #b5453a;
  --color-comparison-bad-hover: rgba(181, 69, 58, 0.12);
  --color-comparison-good-background: rgba(61, 122, 82, 0.06);
  --color-comparison-good-border: rgba(61, 122, 82, 0.15);
  --color-comparison-good-text: var(--color-success-dark);
  --color-comparison-good-hover: rgba(61, 122, 82, 0.12);

  /* ============================================
     SPACING
     ============================================ */
  --space-0: 0;
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-7: 1.75rem;
  --space-8: 2rem;
  --space-9: 2.25rem;
  --space-10: 2.5rem;
  --space-11: 2.75rem;
  --space-12: 3rem;
  --space-14: 3.5rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;
  --space-28: 7rem;
  --space-32: 8rem;
  --space-36: 9rem;
  --space-40: 10rem;
  --space-44: 11rem;
  --space-48: 12rem;
  --space-52: 13rem;
  --space-56: 14rem;
  --space-60: 15rem;
  --space-64: 16rem;
  --space-72: 18rem;
  --space-80: 20rem;
  --space-96: 24rem;
  --space-px: 1px;
  --space-0_5: 0.125rem;
  --space-1_5: 0.375rem;
  --space-2_5: 0.625rem;
  --space-3_5: 0.875rem;

  /* ============================================
     BORDER RADIUS
     ============================================ */
  --radius-none: 0;
  --radius-xs: 0.25rem;
  --radius-sm: 0.5rem;
  --radius-md: 0.75rem;
  --radius-lg: 1rem;
  --radius-xl: 1.25rem;
  --radius-2xl: 1.5rem;
  --radius-3xl: 2rem;
  --radius-full: 9999px;

  /* ============================================
     SHADOWS
     ============================================ */
  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.04);
  --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.06);
  --shadow-md: 0 4px 8px rgba(0, 0, 0, 0.08), 0 2px 4px rgba(0, 0, 0, 0.04);
  --shadow-lg: 0 8px 16px rgba(0, 0, 0, 0.08), 0 4px 8px rgba(0, 0, 0, 0.04);
  --shadow-xl: 0 16px 32px rgba(0, 0, 0, 0.1), 0 8px 16px rgba(0, 0, 0, 0.05);
  --shadow-2xl: 0 24px 48px rgba(0, 0, 0, 0.12), 0 12px 24px rgba(0, 0, 0, 0.06);
  --shadow-glow: 0 0 20px var(--color-accent-glow);
  --shadow-inner: inset 0 2px 4px rgba(0, 0, 0, 0.04);

  /* ============================================
     TYPOGRAPHY - Fonts
     ============================================ */
  --font-_comment: All themes now use consistent brand fonts per FERNI-BRAND-GUIDELINES.md;
  --font-display: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'SF Pro Display', sans-serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'SF Pro Text', sans-serif;
  --font-accent: 'Sora', 'Plus Jakarta Sans', sans-serif;
  --font-mono: 'JetBrains Mono', 'SF Mono', 'Fira Code', monospace;
  --font-_googleFontsImport: undefined;

  /* ============================================
     TYPOGRAPHY - Sizes
     ============================================ */
  --text-2xs: 0.625rem;
  --text-xs: 0.75rem;
  --text-sm: 0.8125rem;
  --text-base: 0.9375rem;
  --text-lg: 1.0625rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 1.875rem;
  --text-4xl: 2.25rem;
  --text-5xl: 3rem;
  --text-6xl: 3.75rem;

  /* ============================================
     TYPOGRAPHY - Weights
     ============================================ */
  --font-weight-light: 300;
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --font-weight-extrabold: 800;

  /* ============================================
     ANIMATION - Easings
     ============================================ */
  --ease-linear: linear;
  --ease-ease-in: cubic-bezier(0.4, 0, 1, 1);
  --ease-ease-out: cubic-bezier(0, 0, 0.2, 1);
  --ease-ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-ease-out-back: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-ease-in-out-quint: cubic-bezier(0.83, 0, 0.17, 1);
  --ease-spring: cubic-bezier(0.5, 1.5, 0.5, 1);
  --ease-spring-bouncy: cubic-bezier(0.68, -0.55, 0.265, 1.55);
  --ease-smooth: cubic-bezier(0.45, 0, 0.55, 1);
  --ease-organic: cubic-bezier(0.4, 0.2, 0.2, 1.1);
  --ease-elastic: cubic-bezier(0.68, -0.6, 0.32, 1.6);
  --ease-anticipate: cubic-bezier(0.38, -0.4, 0.88, 0.65);
  --ease-decelerate: cubic-bezier(0.0, 0.0, 0.2, 1);
  --ease-gentle: cubic-bezier(0.25, 0.1, 0.25, 1);
  --ease-playful: cubic-bezier(0.175, 0.885, 0.32, 1.275);

  /* ============================================
     ANIMATION - Durations
     ============================================ */
  --duration-instant: 0ms;
  --duration-fastest: 50ms;
  --duration-faster: 100ms;
  --duration-fast: 150ms;
  --duration-normal: 200ms;
  --duration-slow: 300ms;
  --duration-slower: 400ms;
  --duration-slowest: 500ms;
  --duration-deliberate: 700ms;
  --duration-dramatic: 1000ms;
  --duration-glacial: 1500ms;
  --duration-meditative: 3000ms;
  --duration-ambient: 8000ms;

}

/* ============================================================================
   DARK THEME OVERRIDES
   Midnight theme (Cedar Night) - warm cedar tones under moonlight
   All persona text colors are WCAG AA compliant (4.5:1+ contrast)
   ============================================================================ */

@media (prefers-color-scheme: dark) {
  :root {
    /* Background */
    --color-bg-primary: var(--color-cedar);
    --color-bg-secondary: var(--color-bg-secondary);
    --color-bg-elevated: var(--color-bg-elevated);
    --color-bg-glass: rgba(230, 195, 160, 0.08);
    --color-bg-overlay: rgba(88, 72, 64, 0.95);

    /* Text */
    --color-text-primary: #faf6f0;
    --color-text-secondary: var(--color-sand);
    --color-text-muted: #e8e2da;
    --color-text-dimmed: #ddd6cc;
    --color-text-inverse: var(--color-ink-deep);

    /* Accent */
    --color-accent: #d4a84a;
    --color-accent-hover: #e0bc6a;
    --color-accent-pressed: #c49a3a;
    --color-accent-glow: rgba(212, 168, 74, 0.22);
    --color-accent-subtle: rgba(212, 168, 74, 0.08);

    /* Borders */
    --color-border-subtle: rgba(215, 185, 145, 0.12);
    --color-border-medium: rgba(215, 185, 145, 0.20);
    --color-border-strong: rgba(215, 185, 145, 0.30);

    /* Semantic */
    --color-success: var(--color-success);
    --color-success-bg: rgba(107, 196, 143, 0.22);
    --color-error: var(--color-error);
    --color-error-bg: rgba(224, 117, 117, 0.22);
    --color-warning: #e0b860;
    --color-warning-bg: rgba(224, 184, 96, 0.22);

    /* Persona Text Colors - WCAG AA on dark backgrounds */
    --color-ferni-text: #a5c99a;
    --color-jack-text: #d4c4a8;
    --color-peter-text: #8bc4cf;
    --color-alex-text: #a8b8d8;
    --color-maya-text: #e0b8a8;
    --color-jordan-text: #f0c0a0;
    --color-nayan-text: #e8d0a8;
    --color-eli-text: #b8a8d8;
    --color-marcus-text: #88c4a8;
    --color-kenji-text: #90b0c8;
    --color-carmen-text: #f0d0a8;
    --color-amara-text: #c0b0d8;
    --color-sasha-text: #f8b898;
    --color-ray-text: #a0b0c0;
  }
}

[data-theme="dark"] {
  /* Background */
  --color-bg-primary: var(--color-cedar);
  --color-bg-secondary: var(--color-bg-secondary);
  --color-bg-elevated: var(--color-bg-elevated);
  --color-bg-glass: rgba(230, 195, 160, 0.08);
  --color-bg-overlay: rgba(88, 72, 64, 0.95);

  /* Text */
  --color-text-primary: #faf6f0;
  --color-text-secondary: var(--color-sand);
  --color-text-muted: #e8e2da;
  --color-text-dimmed: #ddd6cc;
  --color-text-inverse: var(--color-ink-deep);

  /* Accent */
  --color-accent: #d4a84a;
  --color-accent-hover: #e0bc6a;
  --color-accent-pressed: #c49a3a;
  --color-accent-glow: rgba(212, 168, 74, 0.22);
  --color-accent-subtle: rgba(212, 168, 74, 0.08);

  /* Borders */
  --color-border-subtle: rgba(215, 185, 145, 0.12);
  --color-border-medium: rgba(215, 185, 145, 0.20);
  --color-border-strong: rgba(215, 185, 145, 0.30);

  /* Semantic */
  --color-success: var(--color-success);
  --color-success-bg: rgba(107, 196, 143, 0.22);
  --color-error: var(--color-error);
  --color-error-bg: rgba(224, 117, 117, 0.22);
  --color-warning: #e0b860;
  --color-warning-bg: rgba(224, 184, 96, 0.22);

  /* Persona Text Colors - WCAG AA on dark backgrounds */
  --color-ferni-text: #a5c99a;
  --color-jack-text: #d4c4a8;
  --color-peter-text: #8bc4cf;
  --color-alex-text: #a8b8d8;
  --color-maya-text: #e0b8a8;
  --color-jordan-text: #f0c0a0;
  --color-nayan-text: #e8d0a8;
  --color-eli-text: #b8a8d8;
  --color-marcus-text: #88c4a8;
  --color-kenji-text: #90b0c8;
  --color-carmen-text: #f0d0a8;
  --color-amara-text: #c0b0d8;
  --color-sasha-text: #f8b898;
  --color-ray-text: #a0b0c0;
}