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

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

@theme inline {
  
  --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-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);
}

:root {
  /* Minimalismo Clínico Humanizado Palette */
  /* Base: Off-white #FAFAFA */
  /* Primary: Deep Blue #0F172A */
  /* Accent: Burgundy #7F1D1D */
  
  --background: oklch(0.98 0.002 247.839); /* #FAFAFA equivalent */
  --foreground: oklch(0.208 0.042 265.755); /* Deep Blue/Slate */
  
  --card: oklch(1 0 0);
  --card-foreground: oklch(0.208 0.042 265.755);
  
  --popover: oklch(1 0 0);
  --popover-foreground: oklch(0.208 0.042 265.755);
  
  --primary: oklch(0.396 0.141 25.723); /* Burgundy #7F1D1D */
  --primary-foreground: oklch(0.985 0 0);
  
  --secondary: oklch(0.967 0.003 264.542); /* Light Gray */
  --secondary-foreground: oklch(0.208 0.042 265.755);
  
  --muted: oklch(0.967 0.003 264.542);
  --muted-foreground: oklch(0.551 0.027 264.364);
  
  --accent: oklch(0.967 0.003 264.542);
  --accent-foreground: oklch(0.208 0.042 265.755);
  
  --destructive: oklch(0.577 0.245 27.325);
  --destructive-foreground: oklch(0.985 0 0);
  
  --border: oklch(0.92 0.004 264.542);
  --input: oklch(0.92 0.004 264.542);
  --ring: oklch(0.396 0.141 25.723); /* Burgundy ring */
  
  --radius: 0.75rem;
  
  --chart-1: oklch(0.396 0.141 25.723);
  --chart-2: oklch(0.208 0.042 265.755);
  --chart-3: oklch(0.551 0.027 264.364);
  --chart-4: oklch(0.7 0.1 25.723);
  --chart-5: oklch(0.8 0.05 265.755);
}

.dark {
  --background: oklch(0.13 0.028 261.692);
  --foreground: oklch(0.985 0 0);
  
  --card: oklch(0.13 0.028 261.692);
  --card-foreground: oklch(0.985 0 0);
  
  --popover: oklch(0.13 0.028 261.692);
  --popover-foreground: oklch(0.985 0 0);
  
  --primary: oklch(0.396 0.141 25.723);
  --primary-foreground: oklch(0.985 0 0);
  
  --secondary: oklch(0.274 0.006 286.033);
  --secondary-foreground: oklch(0.985 0 0);
  
  --muted: oklch(0.274 0.006 286.033);
  --muted-foreground: oklch(0.705 0.015 286.067);
  
  --accent: oklch(0.274 0.006 286.033);
  --accent-foreground: oklch(0.985 0 0);
  
  --destructive: oklch(0.577 0.245 27.325);
  --destructive-foreground: oklch(0.985 0 0);
  
  --border: oklch(0.274 0.006 286.033);
  --input: oklch(0.274 0.006 286.033);
  --ring: oklch(0.396 0.141 25.723);
}

@layer base {
  * {
    @apply border-border outline-ring/50;
  }
  body {
    @apply bg-background text-foreground antialiased;
    font-family: "Lato", sans-serif;
  }
  h1, h2, h3, h4, h5, h6 {
    font-family: "Lato", sans-serif;
    @apply font-bold tracking-tight;
    font-display: swap;
  }
  button:not(:disabled),
  [role="button"]:not([aria-disabled="true"]),
  [type="button"]:not(:disabled),
  [type="submit"]:not(:disabled),
  [type="reset"]:not(:disabled),
  a[href],
  select:not(:disabled),
  input[type="checkbox"]:not(:disabled),
  input[type="radio"]:not(:disabled) {
    @apply cursor-pointer;
  }
}

@layer components {
  .container {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .flex {
    min-height: 0;
    min-width: 0;
  }

  @media (min-width: 640px) {
    .container {
      padding-left: 1.5rem;
      padding-right: 1.5rem;
    }
  }

  @media (min-width: 1024px) {
    .container {
      padding-left: 2rem;
      padding-right: 2rem;
      max-width: 1280px;
    }
  }
  
  /* Custom Utilities for this project */
  .text-balance {
    text-wrap: balance;
  }
  
  .glass-panel {
    @apply bg-white/80 backdrop-blur-md border border-white/20 shadow-sm;
  }
}
