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

/* Clash Grotesk Font Faces */
@font-face {
  font-family: "Clash Grotesk";
  src: url("/fonts/ClashGrotesk-Variable.woff2") format("woff2");
  font-weight: 200 700;
  font-display: swap;
  font-style: normal;
}

@font-face {
  font-family: "Clash Grotesk";
  src: url("/fonts/ClashGrotesk-Regular.woff2") format("woff2");
  font-weight: 400;
  font-display: swap;
  font-style: normal;
}

@font-face {
  font-family: "Clash Grotesk";
  src: url("/fonts/ClashGrotesk-Medium.woff2") format("woff2");
  font-weight: 500;
  font-display: swap;
  font-style: normal;
}

@font-face {
  font-family: "Clash Grotesk";
  src: url("/fonts/ClashGrotesk-Semibold.woff2") format("woff2");
  font-weight: 600;
  font-display: swap;
  font-style: normal;
}

@font-face {
  font-family: "Clash Grotesk";
  src: url("/fonts/ClashGrotesk-Bold.woff2") format("woff2");
  font-weight: 700;
  font-display: swap;
  font-style: normal;
}

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

@theme {
  --font-sans: "Clash Grotesk", system-ui, sans-serif;
}

:root {
  font-family: var(--font-sans);
  line-height: 1.5;
  font-weight: 400;

  color-scheme: light dark;
  color: rgba(255, 255, 255, 0.87);
  background-color: #242424;

  font-synthesis: none;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  --radius: 0.625rem;
  --background: oklch(1 0 0);
  --foreground: oklch(0.145 0 0);
  --card: oklch(1 0 0);
  --card-foreground: oklch(0.145 0 0);
  --popover: oklch(1 0 0);
  --popover-foreground: oklch(0.145 0 0);
  --primary: oklch(0.205 0 0);
  --primary-foreground: oklch(0.985 0 0);
  --secondary: oklch(0.97 0 0);
  --secondary-foreground: oklch(0.205 0 0);
  --muted: oklch(0.97 0 0);
  --muted-foreground: oklch(0.556 0 0);
  --accent: oklch(0.97 0 0);
  --accent-foreground: oklch(0.205 0 0);
  --destructive: oklch(0.577 0.245 27.325);
  --border: oklch(0.922 0 0);
  --input: oklch(0.922 0 0);
  --ring: oklch(0.708 0 0);
  --chart-1: oklch(0.646 0.222 41.116);
  --chart-2: oklch(0.6 0.118 184.704);
  --chart-3: oklch(0.398 0.07 227.392);
  --chart-4: oklch(0.828 0.189 84.429);
  --chart-5: oklch(0.769 0.188 70.08);
  --sidebar: oklch(0.985 0 0);
  --sidebar-foreground: oklch(0.145 0 0);
  --sidebar-primary: oklch(0.205 0 0);
  --sidebar-primary-foreground: oklch(0.985 0 0);
  --sidebar-accent: oklch(0.97 0 0);
  --sidebar-accent-foreground: oklch(0.205 0 0);
  --sidebar-border: oklch(0.922 0 0);
  --sidebar-ring: oklch(0.708 0 0);
}

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

.dark {
  --background: oklch(0.145 0 0);
  --foreground: oklch(0.985 0 0);
  --card: oklch(0.205 0 0);
  --card-foreground: oklch(0.985 0 0);
  --popover: oklch(0.205 0 0);
  --popover-foreground: oklch(0.985 0 0);
  --primary: oklch(0.922 0 0);
  --primary-foreground: oklch(0.205 0 0);
  --secondary: oklch(0.269 0 0);
  --secondary-foreground: oklch(0.985 0 0);
  --muted: oklch(0.269 0 0);
  --muted-foreground: oklch(0.708 0 0);
  --accent: oklch(0.269 0 0);
  --accent-foreground: oklch(0.985 0 0);
  --destructive: oklch(0.704 0.191 22.216);
  --border: oklch(1 0 0 / 10%);
  --input: oklch(1 0 0 / 15%);
  --ring: oklch(0.556 0 0);
  --chart-1: oklch(0.488 0.243 264.376);
  --chart-2: oklch(0.696 0.17 162.48);
  --chart-3: oklch(0.769 0.188 70.08);
  --chart-4: oklch(0.627 0.265 303.9);
  --chart-5: oklch(0.645 0.246 16.439);
  --sidebar: oklch(0.205 0 0);
  --sidebar-foreground: oklch(0.985 0 0);
  --sidebar-primary: oklch(0.488 0.243 264.376);
  --sidebar-primary-foreground: oklch(0.985 0 0);
  --sidebar-accent: oklch(0.269 0 0);
  --sidebar-accent-foreground: oklch(0.985 0 0);
  --sidebar-border: oklch(1 0 0 / 10%);
  --sidebar-ring: oklch(0.556 0 0);
}

@layer base {
  * {
    @apply border-border outline-ring/50;
  }
}

@layer utilities {
  /* Typography Classes based on Style Guide */
  .text-heading-1 {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 700;
    font-size: 112px;
    line-height: 96px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    color: #ffffff;
  }

  .text-heading-2 {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 500;
    font-size: 72px;
    line-height: 100%;
    letter-spacing: -0.03em;
    text-transform: uppercase;
    color: #ffffff;
  }

  .text-heading-2-bold {
    font-family: "Clash Grotesk", system-ui, sans-serif !important;
    font-style: bold;
    font-weight: 800;
    font-size: 80px;
    line-height: 100%;
    letter-spacing: -0.03em;
    text-transform: uppercase;
    color: #ffffff;
  }

  .text-heading-3 {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 500;
    font-size: 40px;
    line-height: 48px;
    letter-spacing: -0.01em;
    text-transform: uppercase;
    color: #ffffff;
  }

  .text-heading-4 {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 32px;
    line-height: 40px;
    letter-spacing: -0.01em;
    text-transform: uppercase;
    color: #ffffff;
  }

  .text-heading-5 {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 24px;
    line-height: 32px;
    text-transform: uppercase;
    color: #ffffff;
  }

  .text-body-1 {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 24px;
    line-height: 32px;
    color: #ffffff;
  }

  .text-body-2 {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 18px;
    line-height: 26px;
    color: #ffffff;
  }

  .text-body-3 {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 16px;
    line-height: 24px;
    color: #ffffff;
  }

  .text-caption {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 16px;
    line-height: 20px;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: #ffffff;
  }

  .text-footer-bottom {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: #ffffff;
  }

  .text-button-big {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 500;
    font-size: 18px;
    line-height: 22px;
    letter-spacing: 0.02em;
    text-transform: uppercase;
  }

  .text-button-medium {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 500;
    font-size: 16px;
    line-height: 20px;
    letter-spacing: 0.02em;
    text-transform: uppercase;
  }

  .text-button-small {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 500;
    font-size: 14px;
    line-height: 17px;
    letter-spacing: 0.02em;
    text-transform: uppercase;
  }

  /* Color System from Style Guide */
  .bg-dark-solid {
    background-color: #121212;
  }
  .bg-dark-90 {
    background-color: rgba(18, 18, 18, 0.9);
  }
  .bg-dark-80 {
    background-color: rgba(18, 18, 18, 0.8);
  }
  .bg-dark-70 {
    background-color: rgba(18, 18, 18, 0.7);
  }
  .bg-dark-60 {
    background-color: rgba(18, 18, 18, 0.6);
  }
  .bg-dark-50 {
    background-color: rgba(18, 18, 18, 0.5);
  }
  .bg-dark-40 {
    background-color: rgba(18, 18, 18, 0.4);
  }
  .bg-dark-30 {
    background-color: rgba(18, 18, 18, 0.3);
  }
  .bg-dark-20 {
    background-color: rgba(18, 18, 18, 0.2);
  }
  .bg-dark-10 {
    background-color: rgba(18, 18, 18, 0.1);
  }

  .bg-light-solid {
    background-color: #ffffff;
  }
  .bg-light-90 {
    background-color: rgba(255, 255, 255, 0.9);
  }
  .bg-light-80 {
    background-color: rgba(255, 255, 255, 0.8);
  }
  .bg-light-70 {
    background-color: rgba(255, 255, 255, 0.7);
  }
  .bg-light-60 {
    background-color: rgba(255, 255, 255, 0.6);
  }
  .bg-light-50 {
    background-color: rgba(255, 255, 255, 0.5);
  }
  .bg-light-40 {
    background-color: rgba(255, 255, 255, 0.4);
  }
  .bg-light-30 {
    background-color: rgba(255, 255, 255, 0.3);
  }
  .bg-light-20 {
    background-color: rgba(255, 255, 255, 0.2);
  }
  .bg-light-10 {
    background-color: rgba(255, 255, 255, 0.1);
  }

  .border-dark-solid {
    border-color: #121212;
  }
  .border-dark-30 {
    border-color: rgba(18, 18, 18, 0.3);
  }
  .border-dark-10 {
    border-color: rgba(18, 18, 18, 0.1);
  }

  .border-light-solid {
    border-color: #ffffff;
  }
  .border-light-30 {
    border-color: rgba(255, 255, 255, 0.3);
  }
  .border-light-10 {
    border-color: rgba(255, 255, 255, 0.1);
  }

  .border-body-80 {
    border-color: rgba(18, 18, 18, 0.8);
  }

  .text-stat-number {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 500;
    font-size: 68px;
    line-height: 100%;
    letter-spacing: -0.03em;
    text-transform: uppercase;
  }

  .text-stat-label {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.02em;
    text-transform: uppercase;
  }

  .text-plan-header {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.02em;
    text-transform: uppercase;
  }

  .fill-dark-solid {
    fill: #121212;
  }
  .fill-dark-90 {
    fill: rgba(18, 18, 18, 0.9);
  }
  .fill-dark-80 {
    fill: rgba(18, 18, 18, 0.8);
  }
  .fill-dark-70 {
    fill: rgba(18, 18, 18, 0.7);
  }
  .fill-dark-60 {
    fill: rgba(18, 18, 18, 0.6);
  }
  .fill-dark-50 {
    fill: rgba(18, 18, 18, 0.5);
  }
  .fill-dark-40 {
    fill: rgba(18, 18, 18, 0.4);
  }
  .fill-dark-30 {
    fill: rgba(18, 18, 18, 0.3);
  }
  .fill-dark-20 {
    fill: rgba(18, 18, 18, 0.2);
  }
  .fill-dark-10 {
    fill: rgba(18, 18, 18, 0.1);
  }

  .fill-light-solid {
    fill: #ffffff;
  }
  .fill-light-90 {
    fill: rgba(255, 255, 255, 0.9);
  }
  .fill-light-80 {
    fill: rgba(255, 255, 255, 0.8);
  }
  .fill-light-70 {
    fill: rgba(255, 255, 255, 0.7);
  }
  .fill-light-60 {
    fill: rgba(255, 255, 255, 0.6);
  }
  .fill-light-50 {
    fill: rgba(255, 255, 255, 0.5);
  }
  .fill-light-40 {
    fill: rgba(255, 255, 255, 0.4);
  }
  .fill-light-30 {
    fill: rgba(255, 255, 255, 0.3);
  }
  .fill-light-20 {
    fill: rgba(255, 255, 255, 0.2);
  }
  .fill-light-10 {
    fill: rgba(255, 255, 255, 0.1);
  }
}
