@import "tailwindcss";
@import "tw-animate-css";
@import "shadcn/tailwind.css";

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

@theme inline {
  --color-background: var(--background);
  --color-foreground: var(--foreground);
  --font-sans: var(--font-inter);
  --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);
  --radius-sm: calc(var(--radius) - 4px);
  --radius-md: calc(var(--radius) - 2px);
  --radius-lg: var(--radius);
  --radius-xl: calc(var(--radius) + 4px);
  --radius-2xl: calc(var(--radius) + 8px);
  --radius-3xl: calc(var(--radius) + 12px);
  --radius-4xl: calc(var(--radius) + 16px);
  --shadow-soft: 0 4px 20px -2px rgba(0, 0, 0, 0.05);
  --shadow-card: 0 10px 40px -4px rgba(0, 0, 0, 0.06);
}

:root {
  --radius: 0.75rem;
  --background: oklch(0.99 0.005 240);
  --foreground: oklch(0.15 0.02 240);
  --card: oklch(1 0 0);
  --card-foreground: oklch(0.15 0.02 240);
  --popover: oklch(1 0 0);
  --popover-foreground: oklch(0.15 0.02 240);
  --primary: oklch(0.55 0.2 240);
  --primary-foreground: oklch(0.99 0 0);
  --secondary: oklch(0.96 0.01 240);
  --secondary-foreground: oklch(0.15 0.02 240);
  --muted: oklch(0.96 0.01 240);
  --muted-foreground: oklch(0.5 0.02 240);
  --accent: oklch(0.96 0.01 240);
  --accent-foreground: oklch(0.15 0.02 240);
  --destructive: oklch(0.6 0.2 25);
  --border: oklch(0.92 0.01 240);
  --input: oklch(0.92 0.01 240);
  --ring: oklch(0.55 0.2 240);
  --sidebar: oklch(1 0 0);
  --sidebar-foreground: oklch(0.15 0.02 240);
  --sidebar-accent: oklch(0.96 0.01 240);
  --sidebar-border: oklch(0.92 0.01 240);
}

.dark {
  /* Rich Midnight Palette - Deep Navy Black (Premium Feel) */
  --background: oklch(0.12 0.02 250);
  --foreground: oklch(0.95 0.01 250);

  /* Elevated surfaces with slightly more chroma for depth */
  --card: oklch(0.16 0.025 250);
  --card-foreground: oklch(0.95 0.01 250);

  --popover: oklch(0.16 0.025 250);
  --popover-foreground: oklch(0.95 0.01 250);

  /* Vibrant but not harsh primary */
  --primary: oklch(0.65 0.18 250);
  --primary-foreground: oklch(0.12 0.02 250);

  --secondary: oklch(0.22 0.03 245);
  --secondary-foreground: oklch(0.92 0.01 245);

  --muted: oklch(0.19 0.02 245);
  --muted-foreground: oklch(0.65 0.02 245);

  --accent: oklch(0.24 0.04 250);
  --accent-foreground: oklch(0.92 0.01 245);

  --destructive: oklch(0.45 0.18 25);

  /* Ultra-soft elegant borders */
  --border: oklch(0.25 0.03 250 / 0.5);
  --input: oklch(0.25 0.03 250 / 0.3);
  --ring: oklch(0.65 0.18 250 / 0.4);

  /* Sidebar specifically for dark mode */
  --sidebar: oklch(0.1 0.015 250);
  --sidebar-foreground: oklch(0.9 0.01 250);
  --sidebar-accent: oklch(0.18 0.03 250);
  --sidebar-border: oklch(0.2 0.02 250 / 0.5);
}

@layer base {
  * {
    @apply border-border outline-ring/50 transition-colors duration-300;
  }

  body {
    @apply bg-background text-foreground transition-colors duration-300;
  }
}

/* Glassmorphism & Effects */
.sidebar-glass {
  background-color: oklch(1 0 0 / 0.8);
  backdrop-filter: blur(20px);
}

.dark .sidebar-glass {
  background-color: oklch(0.1 0.01 250 / 0.8);
}

.nav-item-active {
  background-color: oklch(var(--primary) / 0.1);
  color: oklch(var(--primary));
}

.dark .nav-item-active {
  background-color: oklch(var(--primary) / 0.2);
}

.nav-item-hover {
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.nav-item-hover:hover {
  background-color: oklch(var(--muted) / 0.5);
  transform: translateX(4px);
}

/* Modal and Card Polish */
.shadow-card {
  box-shadow: 0 10px 40px -10px rgba(0, 0, 0, 0.05);
}

.dark .shadow-card {
  box-shadow: 0 20px 50px -20px rgba(0, 0, 0, 0.6);
}

.dark .card-header {
  background-color: oklch(var(--muted) / 0.3);
  border-bottom: 1px solid oklch(var(--border));
}

.dark input,
.dark textarea,
.dark select {
  background-color: oklch(var(--muted) / 0.4);
  border: 1px solid oklch(var(--border));
}

.dark input:focus,
.dark textarea:focus,
.dark select:focus {
  border-color: oklch(var(--primary) / 0.5);
}

@keyframes float {
  0% {
    transform: translateY(0px);
  }

  50% {
    transform: translateY(-5px);
  }

  100% {
    transform: translateY(0px);
  }
}

.animate-float {
  animation: float 3s ease-in-out infinite;
}

/* ── Browser autofill override ─────────────────────────────────────────────
   Chrome/Edge/Safari replace the input background with their own grey/yellow
   when credentials are auto-filled. The ONLY reliable fix is the
   -webkit-box-shadow inset trick — it paints over their background.
───────────────────────────────────────────────────────────────────────────── */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
  /* Paint a white "fake" background using an inset box shadow */
  -webkit-box-shadow: 0 0 0 9999px #ffffff inset !important;
  /* Keep text dark and readable */
  -webkit-text-fill-color: #1e293b !important;
  /* Smooth transition so it doesn't flash */
  transition: background-color 9999s ease-in-out 0s;
  /* Keep the border visible */
  border-color: #cbd5e1 !important;
  border-radius: inherit;
}

input:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 9999px #ffffff inset, 0 0 0 2px rgba(99, 102, 241, 0.2) !important;
  border-color: #6366f1 !important;
}