@import 'tailwindcss';
@import 'tw-animate-css';
@import './shadcn.css';

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

@theme inline {
  --font-heading: var(--font-playfair), Georgia, 'Times New Roman', serif;
  --font-sans: var(--font-inter), system-ui, sans-serif;
  --font-mono: ui-monospace, monospace;
  --color-sidebar-ring: var(--sidebar-ring);
  --color-sidebar-border: var(--sidebar-border);
  --color-sidebar-accent-foreground: var(--sidebar-accent-foreground);
  --color-sidebar-accent: var(--sidebar-accent);
  --color-sidebar-primary-foreground: var(--sidebar-primary-foreground);
  --color-sidebar-primary: var(--sidebar-primary);
  --color-sidebar-foreground: var(--sidebar-foreground);
  --color-sidebar: var(--sidebar);
  --color-chart-5: var(--chart-5);
  --color-chart-4: var(--chart-4);
  --color-chart-3: var(--chart-3);
  --color-chart-2: var(--chart-2);
  --color-chart-1: var(--chart-1);
  --color-ring: var(--ring);
  --color-input: var(--input);
  --color-border: var(--border);
  --color-destructive: var(--destructive);
  --color-accent-foreground: var(--accent-foreground);
  --color-accent: var(--accent);
  --color-muted-foreground: var(--muted-foreground);
  --color-muted: var(--muted);
  --color-secondary-foreground: var(--secondary-foreground);
  --color-secondary: var(--secondary);
  --color-primary-foreground: var(--primary-foreground);
  --color-primary: var(--primary);
  --color-popover-foreground: var(--popover-foreground);
  --color-popover: var(--popover);
  --color-card-foreground: var(--card-foreground);
  --color-card: var(--card);
  --color-foreground: var(--foreground);
  --color-background: var(--background);
  --radius-sm: calc(var(--radius) * 0.6);
  --radius-md: calc(var(--radius) * 0.8);
  --radius-lg: var(--radius);
  --radius-xl: calc(var(--radius) * 1.4);
  --radius-2xl: calc(var(--radius) * 1.8);
  --radius-3xl: calc(var(--radius) * 2.2);
  --radius-4xl: calc(var(--radius) * 2.6);
}

:root {
  color-scheme: light;
  --background: oklch(0.995 0.002 15);
  --foreground: oklch(0.15 0.01 15);
  --card: oklch(1 0 0);
  --card-foreground: oklch(0.15 0.01 15);
  --popover: oklch(1 0 0);
  --popover-foreground: oklch(0.15 0.01 15);
  --primary: oklch(0.38 0.14 15);
  --primary-foreground: oklch(0.98 0 0);
  --secondary: oklch(0.48 0.18 20);
  --secondary-foreground: oklch(0.98 0 0);
  --muted: oklch(0.96 0.005 15);
  --muted-foreground: oklch(0.48 0.02 15);
  --accent: oklch(0.52 0.2 25);
  --accent-foreground: oklch(0.98 0 0);
  --destructive: oklch(0.577 0.245 27.325);
  --border: oklch(0.91 0.01 15);
  --input: oklch(0.94 0.005 15);
  --ring: oklch(0.52 0.2 25);
  --chart-1: oklch(0.38 0.14 15);
  --chart-2: oklch(0.52 0.2 25);
  --chart-3: oklch(0.48 0.18 20);
  --chart-4: oklch(0.48 0.02 15);
  --chart-5: oklch(0.35 0.04 15);
  --radius: 0.625rem;
  --sidebar: oklch(0.98 0 0);
  --sidebar-foreground: oklch(0.15 0.01 15);
  --sidebar-primary: oklch(0.38 0.14 15);
  --sidebar-primary-foreground: oklch(0.98 0 0);
  --sidebar-accent: oklch(0.52 0.2 25);
  --sidebar-accent-foreground: oklch(0.98 0 0);
  --sidebar-border: oklch(0.91 0.01 15);
  --sidebar-ring: oklch(0.52 0.2 25);
}

@layer base {
  * {
    @apply border-border outline-ring/50;
  }
  body {
    @apply bg-background text-foreground;
  }
  html {
    @apply font-sans scroll-smooth;
  }
  h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
  }
}

@layer utilities {
  .section-padding {
    @apply py-20 md:py-28;
  }
  .container-wide {
    @apply max-w-7xl mx-auto px-4 sm:px-6 lg:px-8;
  }
  .text-balance {
    text-wrap: balance;
  }
  .no-scrollbar {
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .no-scrollbar::-webkit-scrollbar {
    display: none;
  }
}

@keyframes marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.animate-marquee {
  animation: marquee 40s linear infinite;
}

.animate-marquee:hover {
  animation-play-state: paused;
}

@keyframes shimmer {
  0%, 100% { opacity: 0.4; }
  50% { opacity: 1; }
}

@keyframes fade-up {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

.animate-fade-up {
  animation: fade-up 0.6s ease-out forwards;
}
