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

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

/* 
Design Philosophy: Modernismo Suíço com Energia Contemporânea
- Clareza matemática através de grid rigoroso
- Hierarquia tipográfica extremamente definida
- Fotografia como elemento dominante
- Preto profundo + branco puro + azul claro vibrante
*/

@theme inline {
  --radius-sm: 0;
  --radius-md: 0;
  --radius-lg: 0;
  --radius-xl: 0;
  --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);
  --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);
  --font-display: 'Archivo Black', sans-serif;
  --font-heading: 'Archivo', sans-serif;
  --font-body: 'Work Sans', sans-serif;
}

:root {
  /* Azul claro vibrante para CTAs e energia */
  --primary: #84d1f8;
  --primary-foreground: oklch(0.99 0 0);
  --sidebar-primary: #84d1f8;
  --sidebar-primary-foreground: oklch(0.99 0 0);
  --chart-1: #84d1f8;
  --chart-2: #5fc5f0;
  --chart-3: #a8ddf9;
  --chart-4: #3ab8ec;
  --chart-5: #c1e5fb;
  --radius: 0;
  /* Branco puro para fundo */
  --background: oklch(0.99 0 0);
  /* Preto profundo para texto */
  --foreground: oklch(0.20 0.01 270);
  --card: oklch(0.99 0 0);
  --card-foreground: oklch(0.20 0.01 270);
  --popover: oklch(0.99 0 0);
  --popover-foreground: oklch(0.20 0.01 270);
  /* Cinza claro para secundário */
  --secondary: oklch(0.95 0.005 270);
  --secondary-foreground: oklch(0.20 0.01 270);
  /* Cinza médio para muted */
  --muted: oklch(0.90 0.005 270);
  --muted-foreground: oklch(0.45 0.01 270);
  /* Cinza muito claro para accent */
  --accent: oklch(0.97 0.005 270);
  --accent-foreground: oklch(0.20 0.01 270);
  --destructive: oklch(0.577 0.245 27.325);
  --destructive-foreground: oklch(0.99 0 0);
  /* Preto para bordas */
  --border: oklch(0.20 0.01 270);
  --input: oklch(0.85 0.005 270);
  --ring: #84d1f8;
  --sidebar: oklch(0.99 0 0);
  --sidebar-foreground: oklch(0.20 0.01 270);
  --sidebar-accent: oklch(0.97 0.005 270);
  --sidebar-accent-foreground: oklch(0.20 0.01 270);
  --sidebar-border: oklch(0.20 0.01 270);
  --sidebar-ring: #84d1f8;
}

.dark {
  --primary: #84d1f8;
  --primary-foreground: oklch(0.99 0 0);
  --sidebar-primary: #84d1f8;
  --sidebar-primary-foreground: oklch(0.99 0 0);
  --background: oklch(0.15 0.01 270);
  --foreground: oklch(0.95 0.005 270);
  --card: oklch(0.20 0.01 270);
  --card-foreground: oklch(0.95 0.005 270);
  --popover: oklch(0.20 0.01 270);
  --popover-foreground: oklch(0.95 0.005 270);
  --secondary: oklch(0.25 0.01 270);
  --secondary-foreground: oklch(0.90 0.005 270);
  --muted: oklch(0.30 0.01 270);
  --muted-foreground: oklch(0.65 0.01 270);
  --accent: oklch(0.25 0.01 270);
  --accent-foreground: oklch(0.95 0.005 270);
  --destructive: oklch(0.704 0.191 22.216);
  --destructive-foreground: oklch(0.99 0 0);
  --border: oklch(0.95 0.005 270);
  --input: oklch(0.30 0.01 270);
  --ring: #84d1f8;
  --chart-1: #84d1f8;
  --chart-2: #5fc5f0;
  --chart-3: #a8ddf9;
  --chart-4: #3ab8ec;
  --chart-5: #c1e5fb;
  --sidebar: oklch(0.20 0.01 270);
  --sidebar-foreground: oklch(0.95 0.005 270);
  --sidebar-accent: oklch(0.25 0.01 270);
  --sidebar-accent-foreground: oklch(0.99 0 0);
  --sidebar-border: oklch(0.95 0.005 270);
  --sidebar-ring: #84d1f8;
}

@layer base {
  * {
    @apply border-border outline-ring/50;
  }
  body {
    @apply bg-background text-foreground;
    font-family: var(--font-body);
  }
  h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: 700;
    letter-spacing: -0.02em;
  }
  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: 1400px;
    }
  }

  /* Display typography - Archivo Black */
  .text-display {
    font-family: var(--font-display);
    font-weight: 900;
    letter-spacing: -0.03em;
    line-height: 0.95;
  }

  /* Heading typography - Archivo Bold */
  .text-heading {
    font-family: var(--font-heading);
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.1;
  }

  /* Body typography - Work Sans */
  .text-body {
    font-family: var(--font-body);
    font-weight: 400;
    line-height: 1.6;
  }

  /* Linha horizontal grossa característica do Swiss Design */
  .swiss-divider {
    height: 4px;
    background-color: oklch(0.20 0.01 270);
    width: 100%;
  }

  /* Números grandes decorativos */
  .decorative-number {
    font-family: var(--font-display);
    font-size: clamp(8rem, 20vw, 16rem);
    font-weight: 900;
    line-height: 0.8;
    opacity: 0.08;
    position: absolute;
    z-index: 0;
    pointer-events: none;
  }
}

/* Animações precisas e rápidas características do Swiss Design */
@layer utilities {
  .transition-swiss {
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  }

  .transition-swiss-slow {
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  }
}
