@import "tailwindcss" source(none);
@source "../src";
@import "tw-animate-css";

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

/* Fonts */
@import url("https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Inter+Tight:wght@300;400;500;600;700&display=swap");

@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-brand-navy: var(--brand-navy);
  --color-brand-blue: var(--brand-blue);
  --color-brand-green: var(--brand-green);
  --color-brand-green-soft: var(--brand-green-soft);
  --color-ink: var(--ink);
  --color-paper: var(--paper);
  --color-mist: var(--mist);

  --font-display: "Instrument Serif", ui-serif, Georgia, serif;
  --font-sans: "Inter Tight", ui-sans-serif, system-ui, sans-serif;

  --shadow-elegant: 0 30px 80px -40px color-mix(in oklab, var(--brand-navy) 35%, transparent);
  --shadow-soft: 0 10px 40px -20px color-mix(in oklab, var(--brand-navy) 18%, transparent);

  --gradient-brand: linear-gradient(135deg, var(--brand-blue), var(--brand-green));
  --gradient-hero: linear-gradient(180deg, color-mix(in oklab, var(--brand-navy) 92%, black) 0%, var(--brand-navy) 100%);
}

:root {
  --radius: 0.5rem;

  /* Brand */
  --brand-navy: oklch(0.22 0.09 260);
  --brand-blue: oklch(0.48 0.18 255);
  --brand-green: oklch(0.66 0.18 150);
  --brand-green-soft: oklch(0.82 0.10 150);
  --ink: oklch(0.18 0.02 260);
  --paper: oklch(0.985 0.005 240);
  --mist: oklch(0.96 0.008 240);

  --background: oklch(0.99 0.003 240);
  --foreground: oklch(0.18 0.02 260);
  --card: oklch(1 0 0);
  --card-foreground: var(--ink);
  --popover: oklch(1 0 0);
  --popover-foreground: var(--ink);
  --primary: var(--brand-navy);
  --primary-foreground: oklch(0.99 0.003 240);
  --secondary: var(--mist);
  --secondary-foreground: var(--ink);
  --muted: var(--mist);
  --muted-foreground: oklch(0.50 0.02 260);
  --accent: var(--brand-green);
  --accent-foreground: oklch(0.15 0.04 160);
  --destructive: oklch(0.58 0.22 27);
  --destructive-foreground: oklch(0.99 0 0);
  --border: oklch(0.91 0.008 250);
  --input: oklch(0.91 0.008 250);
  --ring: var(--brand-blue);
}

.dark {
  --background: var(--brand-navy);
  --foreground: oklch(0.98 0.003 240);
  --card: oklch(0.26 0.06 260);
  --card-foreground: oklch(0.98 0.003 240);
  --muted: oklch(0.28 0.05 260);
  --muted-foreground: oklch(0.72 0.02 250);
  --border: oklch(1 0 0 / 0.1);
  --input: oklch(1 0 0 / 0.15);
}

@layer base {
  * { border-color: var(--color-border); }
  html { scroll-behavior: smooth; }
  body {
    background-color: var(--color-background);
    color: var(--color-foreground);
    font-family: var(--font-sans);
    -webkit-font-smoothing: antialiased;
    font-feature-settings: "ss01", "cv11";
  }
  ::selection {
    background: color-mix(in oklab, var(--brand-green) 35%, transparent);
    color: var(--brand-navy);
  }
}

@utility font-display { font-family: var(--font-display); font-weight: 400; letter-spacing: -0.01em; }
@utility text-balance { text-wrap: balance; }
@utility container-x { padding-inline: 1.5rem; max-width: 80rem; margin-inline: auto; }
@utility hairline { border-top: 1px solid var(--color-border); }
@utility gradient-text {
  background: var(--gradient-brand);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
@utility eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.72rem;
  font-weight: 500;
  color: color-mix(in oklab, var(--brand-blue) 80%, var(--ink));
}

@keyframes rise {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}
@utility animate-rise { animation: rise 0.9s cubic-bezier(0.2, 0.7, 0.2, 1) both; }

@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
