:root {
  --background: 32 100% 96%;
  --foreground: 22 42% 14%;
  --primary: 17 88% 52%;
  --primary-foreground: 0 0% 100%;
  --secondary: 151 45% 35%;
  --secondary-foreground: 0 0% 100%;
  --muted: 30 28% 88%;
  --muted-foreground: 25 18% 38%;
  --destructive: 358 72% 50%;
  --destructive-foreground: 0 0% 100%;
  --border: 26 32% 82%;
  --card: 0 0% 100%;
  --card-foreground: 22 42% 14%;
  --shadow-sm: 0 2px 10px hsl(22 42% 14% / 0.08);
  --shadow-md: 0 12px 30px hsl(22 42% 14% / 0.12);
  --shadow-lg: 0 24px 70px hsl(22 42% 14% / 0.18);
  --transition-fast: 150ms ease;
  --transition-smooth: 280ms cubic-bezier(.2,.8,.2,1);
  --radius-sm: 12px;
  --radius-md: 18px;
  --radius-lg: 28px;
}

.dark {
  --background: 24 30% 8%;
  --foreground: 32 100% 94%;
  --primary: 17 90% 58%;
  --primary-foreground: 0 0% 100%;
  --secondary: 151 50% 48%;
  --secondary-foreground: 24 30% 8%;
  --muted: 24 20% 16%;
  --muted-foreground: 31 20% 72%;
  --destructive: 358 78% 62%;
  --destructive-foreground: 0 0% 100%;
  --border: 24 20% 22%;
  --card: 24 25% 12%;
  --card-foreground: 32 100% 94%;
}

* { box-sizing: border-box; }

html { min-height: 100%; }

body {
  margin: 0;
  min-height: 100%;
  background:
    radial-gradient(circle at 15% 5%, hsl(var(--primary) / 0.18), transparent 28rem),
    radial-gradient(circle at 90% 0%, hsl(var(--secondary) / 0.15), transparent 24rem),
    hsl(var(--background));
  color: hsl(var(--foreground));
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

button, input, textarea, select { font: inherit; }

input, textarea, select { font-size: max(16px, 1rem); }

button, a, input, textarea, select { -webkit-tap-highlight-color: transparent; }

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

.recipe-card {
  transition: transform var(--transition-smooth), box-shadow var(--transition-smooth), border-color var(--transition-fast);
}

.recipe-card:active { transform: scale(0.985); }

@media (min-width: 640px) {
  .recipe-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
  }
}

.safe-bottom { padding-bottom: calc(6rem + env(safe-area-inset-bottom)); }

.bottom-nav-safe { padding-bottom: calc(0.7rem + env(safe-area-inset-bottom)); }

.line-clamp-2 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.line-clamp-3 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}