:root {
  /* ── Colors (HSL values — customize per app) ── */
  --background: 222 47% 7%;
  --foreground: 210 40% 98%;
  --primary: 191 95% 45%;
  --primary-foreground: 222 47% 11%;
  --secondary: 222 35% 14%;
  --secondary-foreground: 210 40% 98%;
  --accent: 260 90% 66%;
  --accent-foreground: 222 47% 11%;
  --muted: 222 28% 16%;
  --muted-foreground: 215 20% 70%;
  --destructive: 0 84% 60%;
  --border: 222 22% 22%;
  --ring: 191 95% 45%;
  --card: 222 35% 12%;
  --card-foreground: 210 40% 98%;

  /* ── Shadows (use primary tint for elegance) ── */
  --shadow-sm: 0 1px 2px 0 hsl(var(--foreground) / 0.06);
  --shadow-md: 0 10px 18px -12px hsl(var(--foreground) / 0.18), 0 2px 6px -2px hsl(var(--foreground) / 0.08);
  --shadow-lg: 0 18px 40px -18px hsl(var(--foreground) / 0.22), 0 10px 18px -14px hsl(var(--foreground) / 0.12);
  --shadow-elegant: 0 18px 60px -22px hsl(var(--primary) / 0.45);

  /* ── Gradients ── */
  --gradient-primary: linear-gradient(135deg, hsl(var(--primary)), hsl(var(--accent) / 0.95));
  --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% 7%;
  --foreground: 210 40% 98%;
  --card: 222 35% 12%;
  --card-foreground: 210 40% 98%;
  --border: 222 22% 22%;
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  background: hsl(var(--background));
  color: hsl(var(--foreground));
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}

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

a { color: inherit; }

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

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

.btn {
  border-radius: var(--radius-lg);
  transition: transform var(--transition-fast), background var(--transition-fast), border-color var(--transition-fast), opacity var(--transition-fast);
}
.btn:active { transform: translateY(1px); }

.kbd {
  font-variant-numeric: tabular-nums;
  border: 1px solid hsl(var(--border));
  background: hsl(var(--muted));
  color: hsl(var(--muted-foreground));
  border-radius: var(--radius-md);
  padding: 0.15rem 0.4rem;
  box-shadow: var(--shadow-sm);
}

.grid-bg {
  background-image:
    radial-gradient(circle at 1px 1px, hsl(var(--foreground) / 0.08) 1px, transparent 0);
  background-size: 18px 18px;
}

.overlay-panel {
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  background: hsl(var(--card) / 0.72);
  border: 1px solid hsl(var(--border) / 0.9);
  box-shadow: var(--shadow-elegant);
}

.skeleton {
  border-radius: var(--radius-md);
  background: linear-gradient(90deg, hsl(var(--muted)) 0%, hsl(var(--muted) / 0.65) 50%, hsl(var(--muted)) 100%);
  background-size: 200% 100%;
  animation: shimmer 1.2s infinite;
}
@keyframes shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
