@import "tailwindcss" source(none);
@source "../src";
@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);
  --radius-2xl: calc(var(--radius) + 8px);
  --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-ink: var(--ink);
  --color-cream: var(--cream);
  --color-signal: var(--signal);
  --color-signal-foreground: var(--signal-foreground);
  --color-grid-line: var(--grid-line);
  --font-display: "Unbounded", "Inter", sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;
  --font-sans: "Inter", system-ui, sans-serif;
}

:root {
  --radius: 0.5rem;

  /* Editorial data-terminal palette: deep ink + cream + electric signal yellow */
  --ink: oklch(0.18 0.015 250);
  --cream: oklch(0.97 0.012 85);
  --signal: oklch(0.88 0.19 100); /* electric yellow-lime */
  --signal-foreground: oklch(0.18 0.015 250);

  --background: var(--cream);
  --foreground: var(--ink);
  --card: oklch(1 0 0);
  --card-foreground: var(--ink);
  --popover: oklch(1 0 0);
  --popover-foreground: var(--ink);
  --primary: var(--ink);
  --primary-foreground: var(--cream);
  --secondary: oklch(0.93 0.012 85);
  --secondary-foreground: var(--ink);
  --muted: oklch(0.93 0.012 85);
  --muted-foreground: oklch(0.45 0.02 250);
  --accent: var(--signal);
  --accent-foreground: var(--ink);
  --destructive: oklch(0.6 0.22 25);
  --destructive-foreground: oklch(1 0 0);
  --border: oklch(0.88 0.014 85);
  --input: oklch(0.88 0.014 85);
  --ring: var(--ink);
  --grid-line: oklch(0.85 0.014 85);
}

.dark {
  --background: var(--ink);
  --foreground: var(--cream);
  --card: oklch(0.22 0.018 250);
  --card-foreground: var(--cream);
  --border: oklch(0.3 0.018 250);
  --muted: oklch(0.25 0.018 250);
  --muted-foreground: oklch(0.7 0.02 250);
  --primary: var(--cream);
  --primary-foreground: var(--ink);
  --grid-line: oklch(0.28 0.018 250);
}

@layer base {
  * {
    border-color: var(--color-border);
  }

  html {
    font-family: var(--font-sans);
  }

  body {
    background-color: var(--color-background);
    color: var(--color-foreground);
    font-feature-settings: "ss01", "cv11";
    -webkit-font-smoothing: antialiased;
  }

  h1, h2, h3, h4 {
    font-family: var(--font-display);
    letter-spacing: -0.03em;
  }
}

@layer utilities {
  .grid-bg {
    background-image:
      linear-gradient(to right, var(--grid-line) 1px, transparent 1px),
      linear-gradient(to bottom, var(--grid-line) 1px, transparent 1px);
    background-size: 56px 56px;
  }

  .grid-bg-fade {
    mask-image: radial-gradient(ellipse at center, black 40%, transparent 80%);
  }

  .text-balance {
    text-wrap: balance;
  }

  .underline-signal {
    background-image: linear-gradient(transparent 65%, var(--signal) 65%);
    background-size: 100% 100%;
    background-repeat: no-repeat;
    padding: 0 0.1em;
  }

  .marquee {
    animation: marquee 40s linear infinite;
  }

  @keyframes marquee {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
  }

  .pulse-dot::before {
    content: "";
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 9999px;
    background: var(--signal);
    margin-right: 0.5rem;
    box-shadow: 0 0 0 0 var(--signal);
    animation: pulseDot 2s infinite;
    vertical-align: middle;
  }

  @keyframes pulseDot {
    0% { box-shadow: 0 0 0 0 oklch(0.88 0.19 100 / 0.6); }
    70% { box-shadow: 0 0 0 10px oklch(0.88 0.19 100 / 0); }
    100% { box-shadow: 0 0 0 0 oklch(0.88 0.19 100 / 0); }
  }
}
