:root {
  /* ── Colors (HSL values) ── */
  --background: 222 47% 8%;
  --foreground: 210 40% 98%;
  --primary: 199 89% 55%;
  --primary-foreground: 222 47% 10%;
  --secondary: 222 35% 14%;
  --secondary-foreground: 210 40% 98%;
  --accent: 262 83% 66%;
  --accent-foreground: 210 40% 98%;
  --muted: 222 35% 14%;
  --muted-foreground: 215 20% 70%;
  --destructive: 0 84% 60%;
  --border: 222 28% 20%;
  --ring: 199 89% 55%;
  --card: 222 40% 11%;
  --card-foreground: 210 40% 98%;

  /* ── Shadows ── */
  --shadow-sm: 0 1px 2px 0 hsl(var(--foreground) / 0.06);
  --shadow-md: 0 6px 14px -6px hsl(var(--foreground) / 0.10), 0 2px 6px -2px hsl(var(--foreground) / 0.06);
  --shadow-lg: 0 18px 30px -18px hsl(var(--foreground) / 0.14), 0 8px 18px -10px hsl(var(--foreground) / 0.08);
  --shadow-elegant: 0 18px 50px -18px hsl(var(--primary) / 0.35);

  /* ── Gradients ── */
  --gradient-primary: linear-gradient(135deg, hsl(var(--primary)), hsl(var(--accent)));
  --gradient-subtle: linear-gradient(135deg, hsl(var(--background)), hsl(var(--secondary)));

  /* ── Transitions ── */
  --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-smooth: 300ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 500ms cubic-bezier(0.4, 0, 0.2, 1);

  /* ── Border Radius ── */
  --radius-sm: 0.375rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-xl: 1rem;
  --radius-full: 9999px;
}

.dark, [data-theme="dark"] {
  --background: 222 47% 8%;
  --foreground: 210 40% 98%;
}

* { box-sizing: border-box; }

:focus-visible {
  outline: 2px solid hsl(var(--ring));
  outline-offset: 2px;
}

::selection {
  background: hsl(var(--primary) / 0.25);
}

.app-shell {
  min-height: 100vh;
  background: var(--gradient-subtle);
}

.card {
  background: hsl(var(--card));
  border: 1px solid hsl(var(--border));
  box-shadow: var(--shadow-md);
  border-radius: var(--radius-xl);
}

.btn {
  border-radius: var(--radius-lg);
  transition: transform var(--transition-fast), filter var(--transition-fast), background var(--transition-fast);
}

.btn:active { transform: translateY(1px); }

.kbd {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  border: 1px solid hsl(var(--border));
  background: hsl(var(--secondary));
  border-radius: var(--radius-sm);
  padding: 0.1rem 0.35rem;
  color: hsl(var(--muted-foreground));
}
