@import "tailwindcss" source(none);
@source "../src";
@import "tw-animate-css";

@custom-variant dark (&:is(.dark *));

@font-face {
  font-family: swap;
}

@theme inline {
  --font-serif: "Berita", "Playfair Display", Georgia, serif;
  --font-sans: "Inter", system-ui, sans-serif;

  --radius-sm: calc(var(--radius) - 4px);
  --radius-md: calc(var(--radius) - 2px);
  --radius-lg: var(--radius);
  --radius-xl: calc(var(--radius) + 4px);

  --color-background: var(--background);
  --color-foreground: var(--foreground);
  --color-card: var(--card);
  --color-card-foreground: var(--card-foreground);
  --color-popover: var(--popover);
  --color-popover-foreground: var(--popover-foreground);
  --color-primary: var(--primary);
  --color-primary-foreground: var(--primary-foreground);
  --color-secondary: var(--secondary);
  --color-secondary-foreground: var(--secondary-foreground);
  --color-muted: var(--muted);
  --color-muted-foreground: var(--muted-foreground);
  --color-accent: var(--accent);
  --color-accent-foreground: var(--accent-foreground);
  --color-destructive: var(--destructive);
  --color-destructive-foreground: var(--destructive-foreground);
  --color-border: var(--border);
  --color-input: var(--input);
  --color-ring: var(--ring);

  --color-gold: var(--gold);
  --color-gold-soft: var(--gold-soft);
  --color-copper: var(--copper);
  --color-cream: var(--cream);
  --color-charcoal: var(--charcoal);
  --color-ink: var(--ink);
}

:root {
  --radius: 0.25rem;

  /* Brand palette — Black, Gold, Cream, Charcoal, Copper */
  --ink: oklch(0.12 0 0); /* #0A0A0A deep black */
  --charcoal: oklch(0.26 0 0); /* #2C2C2C soft anthracite */
  --cream: oklch(0.95 0.02 80); /* #F5F0E8 warm white */
  --gold: oklch(0.76 0.13 85); /* #C9A84C rich gold */
  --gold-soft: oklch(0.85 0.1 85);
  --copper: oklch(0.62 0.13 50); /* #B87333 copper */

  --background: var(--ink);
  --foreground: var(--cream);
  --card: oklch(0.16 0 0);
  --card-foreground: var(--cream);
  --popover: var(--ink);
  --popover-foreground: var(--cream);
  --primary: var(--gold);
  --primary-foreground: var(--ink);
  --secondary: var(--charcoal);
  --secondary-foreground: var(--cream);
  --muted: oklch(0.2 0 0);
  --muted-foreground: oklch(0.7 0.02 80);
  --accent: var(--gold);
  --accent-foreground: var(--ink);
  --destructive: oklch(0.577 0.245 27.325);
  --destructive-foreground: var(--cream);
  --border: oklch(0.3 0.02 85 / 30%);
  --input: oklch(0.25 0 0);
  --ring: var(--gold);

  --gradient-gold: linear-gradient(135deg, var(--gold) 0%, var(--copper) 100%);
  --gradient-dark: linear-gradient(180deg, oklch(0.1 0 0) 0%, oklch(0.16 0.01 80) 100%);
  --shadow-gold: 0 10px 40px -10px color-mix(in oklab, var(--gold) 40%, transparent);
  --shadow-elegant: 0 20px 60px -20px oklch(0 0 0 / 0.6);
}

.dark {
  color-scheme: dark;
}

@layer base {
  * {
    border-color: var(--color-border);
  }

  html {
    scroll-behavior: smooth;
  }

  body {
    background-color: var(--color-background);
    color: var(--color-foreground);
    font-family: var(--font-sans);
    -webkit-font-smoothing: antialiased;
  }

  h1,
  h2,
  h3,
  h4 {
    font-family: var(--font-serif);
    font-weight: 400;
    letter-spacing: -0.01em;
  }
  .font-serif {
    font-weight: 400;
  }

  ::selection {
    background: var(--gold);
    color: var(--ink);
  }
}

@layer utilities {
  .font-serif {
    font-family: var(--font-serif);
  }
  .font-sans {
    font-family: var(--font-sans);
  }

  .text-gold {
    color: var(--gold);
  }
  .bg-ink {
    background-color: var(--ink);
  }
  .bg-cream {
    background-color: var(--cream);
  }
  .bg-charcoal {
    background-color: var(--charcoal);
  }
  .bg-gold {
    background-color: var(--gold);
  }
  .border-gold {
    border-color: var(--gold);
  }

  .gradient-gold {
    background-image: var(--gradient-gold);
  }
  .gradient-dark-bg {
    background-image: var(--gradient-dark);
  }
  .text-gradient-gold {
    background-image: var(--gradient-gold);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
  }

  .shadow-gold {
    box-shadow: var(--shadow-gold);
  }
  .shadow-elegant {
    box-shadow: var(--shadow-elegant);
  }

  .gold-divider {
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--gold), transparent);
  }

  .grid-pattern {
    background-image:
      linear-gradient(var(--gold) 1px, transparent 1px),
      linear-gradient(90deg, var(--gold) 1px, transparent 1px);
    background-size: 60px 60px;
    opacity: 0.04;
  }

  /* Sparkle particles */
  @keyframes drift-up {
    0% {
      transform: translateY(100vh) translateX(0) scale(0.5);
      opacity: 0;
    }
    10% {
      opacity: 1;
    }
    90% {
      opacity: 0.6;
    }
    100% {
      transform: translateY(-10vh) translateX(var(--drift-x, 20px)) scale(1);
      opacity: 0;
    }
  }
  .particle {
    position: absolute;
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: radial-gradient(circle, var(--gold) 0%, transparent 70%);
    animation: drift-up var(--dur, 12s) linear infinite;
    animation-delay: var(--delay, 0s);
    box-shadow: 0 0 8px var(--gold);
  }

  @keyframes bounce-arrow {
    0%,
    100% {
      transform: translateY(0);
    }
    50% {
      transform: translateY(8px);
    }
  }
  .animate-bounce-arrow {
    animation: bounce-arrow 2s ease-in-out infinite;
  }

  @keyframes shimmer {
    0% {
      background-position: -200% 0;
    }
    100% {
      background-position: 200% 0;
    }
  }
  .shimmer-on-hover {
    position: relative;
    overflow: hidden;
  }
  .shimmer-on-hover::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
      110deg,
      transparent 30%,
      color-mix(in oklab, var(--gold) 30%, transparent) 50%,
      transparent 70%
    );
    background-size: 200% 100%;
    opacity: 0;
    transition: opacity 0.4s;
  }
  .shimmer-on-hover:hover::before {
    opacity: 1;
    animation: shimmer 1.4s ease;
  }

  @keyframes glow-pulse {
    0%,
    100% {
      box-shadow: 0 0 20px color-mix(in oklab, var(--gold) 30%, transparent);
    }
    50% {
      box-shadow: 0 0 35px color-mix(in oklab, var(--gold) 60%, transparent);
    }
  }
  .glow-pulse {
    animation: glow-pulse 3s ease-in-out infinite;
  }

  .text-balance {
    text-wrap: balance;
  }
}
