:root {
  --background: 215 36% 97%;
  --foreground: 220 38% 12%;
  --primary: 172 82% 31%;
  --primary-foreground: 0 0% 100%;
  --secondary: 225 49% 18%;
  --secondary-foreground: 0 0% 100%;
  --muted: 214 24% 90%;
  --muted-foreground: 218 14% 42%;
  --destructive: 0 74% 48%;
  --destructive-foreground: 0 0% 100%;
  --border: 214 24% 83%;
  --card: 0 0% 100%;
  --accent: 38 92% 52%;
  --success: 151 72% 35%;
  --warning: 42 92% 50%;
  --radius-sm: 0.55rem;
  --radius-md: 0.85rem;
  --radius-lg: 1.25rem;
  --shadow-sm: 0 1px 3px hsl(220 38% 12% / 0.08);
  --shadow-md: 0 12px 30px hsl(220 38% 12% / 0.12);
  --shadow-lg: 0 22px 60px hsl(220 38% 12% / 0.18);
  --transition-fast: 140ms ease;
  --transition-smooth: 260ms cubic-bezier(.2,.8,.2,1);
}
.dark {
  --background: 220 40% 8%;
  --foreground: 210 30% 96%;
  --primary: 172 75% 42%;
  --primary-foreground: 220 40% 8%;
  --secondary: 217 32% 17%;
  --secondary-foreground: 210 30% 96%;
  --muted: 218 28% 16%;
  --muted-foreground: 216 18% 70%;
  --destructive: 0 70% 55%;
  --destructive-foreground: 0 0% 100%;
  --border: 218 24% 24%;
  --card: 221 35% 11%;
  --accent: 38 92% 56%;
  --success: 151 70% 42%;
  --warning: 42 92% 55%;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, hsl(var(--primary) / 0.14), transparent 34rem),
    radial-gradient(circle at top right, hsl(var(--accent) / 0.14), transparent 28rem),
    hsl(var(--background));
  color: hsl(var(--foreground));
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
button, a { transition: all var(--transition-fast); }
.card-hover { transition: transform var(--transition-smooth), box-shadow var(--transition-smooth), border-color var(--transition-smooth); }
.card-hover:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.status-now { background: hsl(var(--success) / 0.14); color: hsl(var(--success)); border-color: hsl(var(--success) / 0.28); }
.status-later { background: hsl(var(--warning) / 0.16); color: hsl(34 88% 32%); border-color: hsl(var(--warning) / 0.34); }
.status-low { background: hsl(var(--destructive) / 0.12); color: hsl(var(--destructive)); border-color: hsl(var(--destructive) / 0.28); }
.dark .status-later { color: hsl(var(--warning)); }
.table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.table-scroll table { min-width: 1180px; }
.focus-ring:focus-visible { outline: 3px solid hsl(var(--primary) / 0.35); outline-offset: 2px; }
