@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 {
  /* Hide scrollbar for Chrome, Safari and Opera */
  .scrollbar-hide::-webkit-scrollbar {
    display: none;
  }

  /* Hide scrollbar for IE, Edge and Firefox */
  .scrollbar-hide {
    -ms-overflow-style: none; /* IE and Edge */
    scrollbar-width: none; /* Firefox */
  }

  /* 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: clamp(48px, 6.5vw, 112px);
    line-height: 0.85;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    white-space: pre-line;
  }

  .text-heading-2 {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 500;
    font-size: clamp(32px, 5.2vw, 72px);
    line-height: 1;
    letter-spacing: -0.03em;
    text-transform: uppercase;
    white-space: pre-line;
  }

  .text-heading-2-bold {
    font-family: "Clash Grotesk", system-ui, sans-serif !important;
    font-style: bold;
    font-weight: 800;
    font-size: clamp(36px, 5.5vw, 80px);
    line-height: 1;
    letter-spacing: -0.03em;
    text-transform: uppercase;
    white-space: pre-line;
  }

  .text-heading-3 {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 500;
    font-size: clamp(20px, 3.2vw, 40px);
    line-height: 1.2;
    letter-spacing: -0.01em;
    text-transform: uppercase;
    white-space: pre-line;
  }

  .text-heading-4 {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: clamp(18px, 2.8vw, 32px);
    line-height: 1.25;
    letter-spacing: -0.01em;
    text-transform: uppercase;
    white-space: pre-line;
  }

  .text-heading-5 {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: clamp(14px, 2.2vw, 24px);
    line-height: 1.3;
    text-transform: uppercase;
    white-space: pre-line;
  }

  .text-body-1 {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 24px;
    line-height: 32px;
    white-space: pre-line;
  }

  .text-body-2 {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 18px;
    line-height: 26px;
    white-space: pre-line;
  }

  .text-body-3 {
    font-family: "Clash Grotesk", system-ui, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 16px;
    line-height: 24px;
    white-space: pre-line;
  }

  .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;
  }

  .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;
  }

  .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);
  }
}

/* ── Image Hover Zoom ─────────────────────────────────────────── */
/* Any image inside a rounded/clipped container zooms on hover */
.img-zoom {
  overflow: hidden;
}
.img-zoom img,
.img-zoom video {
  transition: transform 500ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.img-zoom:hover img,
.img-zoom:hover video {
  transform: scale(1.06);
}

/* Auto-zoom for images inside overflow-hidden containers with aspect ratios */
[class*="aspect-"][class*="overflow-hidden"] img,
[class*="rounded"][class*="overflow-hidden"] img,
[class*="shadow"][class*="overflow-hidden"] img {
  transition: transform 500ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
[class*="aspect-"][class*="overflow-hidden"]:hover img,
[class*="rounded"][class*="overflow-hidden"]:hover img,
[class*="shadow"][class*="overflow-hidden"]:hover img {
  transform: scale(1.06);
}

/* ── Button & Link Hover Lift ─────────────────────────────────── */
/* Subtle upward lift on interactive elements */
button:not([disabled]):not(.marquee-track button),
a[class*="border"]:not(nav a):not(header a),
[data-slot="button"] {
  transition: transform 200ms ease, box-shadow 200ms ease, background 200ms ease, color 200ms ease, border-color 200ms ease, opacity 200ms ease;
}
button:not([disabled]):not(.marquee-track button):hover,
a[class*="border"]:not(nav a):not(header a):hover,
[data-slot="button"]:hover {
  transform: translateY(-2px);
}
button:not([disabled]):not(.marquee-track button):active,
a[class*="border"]:not(nav a):not(header a):active,
[data-slot="button"]:active {
  transform: translateY(0);
}

/* ── Animation Styles ─────────────────────────────────────────── */
/* GSAP handles scroll animations — no CSS hiding so content
   is always visible on initial page load. */

/* ── Mouseover: Feature cards & tiles ────────────────────────── */
/* Bordered boxes with padding (cards/tiles) lift on hover */
section div[class*="border"][class*="p-6"],
section div[class*="border"][class*="p-8"],
section div[class*="border"][class*="p-10"],
section div[class*="border"][class*="p-12"],
section a[class*="border"][class*="p-6"],
section a[class*="border"][class*="p-8"] {
  transition: transform 300ms cubic-bezier(0.25, 0.46, 0.45, 0.94),
              box-shadow 300ms cubic-bezier(0.25, 0.46, 0.45, 0.94),
              border-color 300ms ease,
              background-color 300ms ease;
}
section div[class*="border"][class*="p-6"]:hover,
section div[class*="border"][class*="p-8"]:hover,
section div[class*="border"][class*="p-10"]:hover,
section div[class*="border"][class*="p-12"]:hover,
section a[class*="border"][class*="p-6"]:hover,
section a[class*="border"][class*="p-8"]:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12);
}
section div[class*="border"][class*="p-6"]:active,
section div[class*="border"][class*="p-8"]:active,
section div[class*="border"][class*="p-10"]:active,
section div[class*="border"][class*="p-12"]:active {
  transform: translateY(-1px);
}

/* Dark background cards get a glow shadow instead */
section.bg-black div[class*="border"]:hover,
section.bg-neutral-900 div[class*="border"]:hover,
section[class*="bg-black"] div[class*="border"]:hover,
section[class*="bg-neutral-900"] div[class*="border"]:hover {
  box-shadow: 0 12px 32px rgba(255, 255, 255, 0.06);
}

/* ── Mouseover: Rounded pill / large CTA links ──────────────── */
a[class*="rounded-full"][class*="border"] {
  transition: transform 300ms ease, box-shadow 300ms ease, background-color 300ms ease, color 300ms ease;
}
a[class*="rounded-full"][class*="border"]:hover {
  transform: translateY(-3px) scale(1.02);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.15);
}

/* ── Mouseover: Icon circles (about page timeline, etc.) ────── */
section div[class*="rounded-full"][class*="border"][class*="flex"][class*="items-center"] {
  transition: transform 300ms ease, box-shadow 300ms ease;
}
section div[class*="rounded-full"][class*="border"][class*="flex"][class*="items-center"]:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1);
}

/* ── Mouseover: Accordion-style triggers ─────────────────────── */
section [class*="border-b"] > button,
section [class*="border-t"] > button,
[data-state] button {
  transition: background-color 200ms ease, padding-left 200ms ease;
}
section [class*="border-b"] > button:hover,
section [class*="border-t"] > button:hover,
[data-state] button:hover {
  background-color: rgba(128, 128, 128, 0.05);
  padding-left: 8px;
}

/* ── Mouseover: Text links inside sections ───────────────────── */
section a:not([class*="border"]):not([class*="absolute"]):not(nav a):not(header a) {
  transition: opacity 200ms ease;
}
section a:not([class*="border"]):not([class*="absolute"]):not(nav a):not(header a):hover {
  opacity: 0.75;
}

/* ── Mouseover: SVG icons ────────────────────────────────────── */
section svg {
  transition: transform 300ms ease;
}
section div:hover > svg,
section button:hover > svg,
section a:hover > svg {
  transform: scale(1.12);
}


/* Button sheen sweep */
.btn-sheen {
  position: relative;
  overflow: hidden;
}
.btn-sheen::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.1);
  transform: translateX(-110%) skewX(-20deg);
  transition: transform 400ms ease;
}
.btn-sheen:hover::before {
  transform: translateX(110%) skewX(-20deg);
}

/* Marquee / scrolling ticker */
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.marquee-track {
  display: flex;
  width: max-content;
  animation: marquee 20s linear infinite;
}
.marquee-track:hover {
  animation-play-state: paused;
}

/* Pricing card selected state */
.pricing-card-selected {
  transform: translateY(-4px);
  box-shadow: 0 8px 32px rgba(214, 73, 51, 0.2);
  transition: transform 200ms ease, box-shadow 200ms ease;
}

/* Reduced motion: disable all custom animations & hover effects */
@media (prefers-reduced-motion: reduce) {
  .marquee-track {
    animation: none;
  }
  .btn-sheen::before {
    display: none;
  }
  * {
    transition-duration: 0ms !important;
    animation-duration: 0ms !important;
  }
  *:hover {
    transform: none !important;
    box-shadow: none !important;
  }
}
