@import "tailwindcss";
@import "tw-animate-css";

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

/* Updated theme for Costifys brand - primary green #00A86B, accent gold #FFC106 */
:root {
  --background: oklch(1 0 0);
  --foreground: oklch(0.09 0 0);
  --card: oklch(1 0 0);
  --card-foreground: oklch(0.09 0 0);
  --popover: oklch(1 0 0);
  --popover-foreground: oklch(0.09 0 0);
  --primary: oklch(0.62 0.17 160);
  --primary-foreground: oklch(1 0 0);
  --secondary: oklch(0.97 0.005 90);
  --secondary-foreground: oklch(0.09 0 0);
  --muted: oklch(0.96 0.005 90);
  --muted-foreground: oklch(0.5 0 0);
  --accent: oklch(0.85 0.16 85);
  --accent-foreground: oklch(0.09 0 0);
  --destructive: oklch(0.577 0.245 27.325);
  --destructive-foreground: oklch(0.577 0.245 27.325);
  --border: oklch(0.92 0 0);
  --input: oklch(0.92 0 0);
  --ring: oklch(0.62 0.17 160);
  --chart-1: oklch(0.62 0.17 160);
  --chart-2: oklch(0.85 0.16 85);
  --chart-3: oklch(0.55 0.12 160);
  --chart-4: oklch(0.75 0.14 85);
  --chart-5: oklch(0.5 0.1 160);
  --radius: 0.75rem;
  --sidebar: oklch(0.985 0 0);
  --sidebar-foreground: oklch(0.145 0 0);
  --sidebar-primary: oklch(0.62 0.17 160);
  --sidebar-primary-foreground: oklch(1 0 0);
  --sidebar-accent: oklch(0.97 0.005 90);
  --sidebar-accent-foreground: oklch(0.09 0 0);
  --sidebar-border: oklch(0.922 0 0);
  --sidebar-ring: oklch(0.62 0.17 160);
}

.dark {
  --background: oklch(0.145 0 0);
  --foreground: oklch(0.985 0 0);
  --card: oklch(0.18 0 0);
  --card-foreground: oklch(0.985 0 0);
  --popover: oklch(0.18 0 0);
  --popover-foreground: oklch(0.985 0 0);
  --primary: oklch(0.62 0.17 160);
  --primary-foreground: oklch(1 0 0);
  --secondary: oklch(0.25 0 0);
  --secondary-foreground: oklch(0.985 0 0);
  --muted: oklch(0.25 0 0);
  --muted-foreground: oklch(0.65 0 0);
  --accent: oklch(0.85 0.16 85);
  --accent-foreground: oklch(0.15 0 0);
  --destructive: oklch(0.396 0.141 25.723);
  --destructive-foreground: oklch(0.637 0.237 25.331);
  --border: oklch(0.25 0 0);
  --input: oklch(0.25 0 0);
  --ring: oklch(0.62 0.17 160);
  --chart-1: oklch(0.62 0.17 160);
  --chart-2: oklch(0.85 0.16 85);
  --chart-3: oklch(0.55 0.12 160);
  --chart-4: oklch(0.75 0.14 85);
  --chart-5: oklch(0.5 0.1 160);
  --sidebar: oklch(0.205 0 0);
  --sidebar-foreground: oklch(0.985 0 0);
  --sidebar-primary: oklch(0.62 0.17 160);
  --sidebar-primary-foreground: oklch(1 0 0);
  --sidebar-accent: oklch(0.25 0 0);
  --sidebar-accent-foreground: oklch(0.985 0 0);
  --sidebar-border: oklch(0.25 0 0);
  --sidebar-ring: oklch(0.62 0.17 160);
}

@theme inline {
  --font-sans: "Inter", "Inter Fallback", sans-serif;
  --font-mono: "Geist Mono", "Geist Mono Fallback";
  
  --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-chart-1: var(--chart-1);
  --color-chart-2: var(--chart-2);
  --color-chart-3: var(--chart-3);
  --color-chart-4: var(--chart-4);
  --color-chart-5: var(--chart-5);
  --radius-sm: calc(var(--radius) - 4px);
  --radius-md: calc(var(--radius) - 2px);
  --radius-lg: var(--radius);
  --radius-xl: calc(var(--radius) + 4px);
  --color-sidebar: var(--sidebar);
  --color-sidebar-foreground: var(--sidebar-foreground);
  --color-sidebar-primary: var(--sidebar-primary);
  --color-sidebar-primary-foreground: var(--sidebar-primary-foreground);
  --color-sidebar-accent: var(--sidebar-accent);
  --color-sidebar-accent-foreground: var(--sidebar-accent-foreground);
  --color-sidebar-border: var(--sidebar-border);
  --color-sidebar-ring: var(--sidebar-ring);
}

@layer base {
  * {
    @apply border-border outline-ring/50;
  }
  body {
    @apply bg-background text-foreground antialiased;
    font-feature-settings: "rlig" 1, "calt" 1;
  }
  
  /* Attio-inspired typography */
  h1, h2, h3, h4, h5, h6 {
    @apply font-semibold tracking-tight;
    color: oklch(0.09 0 0);
  }
  
  h1 {
    @apply text-5xl md:text-6xl lg:text-7xl;
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.1;
  }
  
  h2 {
    @apply text-3xl md:text-4xl lg:text-5xl;
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.2;
  }
  
  h3 {
    @apply text-2xl md:text-3xl;
    font-weight: 600;
    letter-spacing: -0.01em;
    line-height: 1.3;
  }
  
  p {
    @apply text-base md:text-lg;
    line-height: 1.6;
  }
  
  .text-muted-foreground {
    color: oklch(0.5 0 0);
  }
}


@layer utilities {
  @keyframes gradient {
    0%, 100% {
      background-position: 0% 50%;
    }
    50% {
      background-position: 100% 50%;
    }
  }
  
  .animate-gradient {
    animation: gradient 4s ease infinite;
  }
  
  @keyframes fade-in-up {
    0% {
      opacity: 0;
      transform: translateY(10px);
    }
    100% {
      opacity: 1;
      transform: translateY(0);
    }
  }
  
  .animate-fade-in-up {
    animation: fade-in-up 0.6s ease-out;
  }
  
  /* Dotted grid background pattern */
  .bg-dot-pattern {
    background-image: radial-gradient(circle, oklch(0.62 0.17 160 / 0.15) 1px, transparent 1px);
    background-size: 24px 24px;
  }
  
  .dark .bg-dot-pattern {
    background-image: radial-gradient(circle, oklch(0.62 0.17 160 / 0.25) 1px, transparent 1px);
  }
  
  /* Animated slant lines for progress bars */
  @keyframes slant-lines {
    0% {
      background-position: 0 0;
    }
    100% {
      background-position: 40px 0;
    }
  }
  
  .animate-slant-lines {
    background-image: repeating-linear-gradient(
      45deg,
      transparent,
      transparent 10px,
      rgba(255, 255, 255, 0.1) 10px,
      rgba(255, 255, 255, 0.1) 20px
    );
    background-size: 40px 40px;
    animation: slant-lines 1s linear infinite;
  }
}
