:root {
  --font-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-serif: Georgia, 'Times New Roman', serif;
  --background: 42 24% 94%;
  --foreground: 32 18% 14%;
  --card: 40 28% 98%;
  --card-foreground: 32 18% 14%;
  --popover: 40 28% 98%;
  --popover-foreground: 32 18% 14%;
  --primary: 28 36% 27%;
  --primary-foreground: 42 24% 94%;
  --secondary: 38 19% 86%;
  --secondary-foreground: 32 18% 18%;
  --muted: 38 18% 88%;
  --muted-foreground: 30 10% 41%;
  --accent: 80 13% 41%;
  --accent-foreground: 42 24% 96%;
  --destructive: 0 67% 42%;
  --destructive-foreground: 42 24% 96%;
  --success: 142 36% 34%;
  --success-foreground: 42 24% 96%;
  --warning: 38 82% 38%;
  --warning-foreground: 42 24% 96%;
  --info: 205 45% 35%;
  --info-foreground: 42 24% 96%;
  --border: 35 16% 78%;
  --input: 35 16% 78%;
  --ring: 28 36% 27%;
  --radius: 0.625rem;
  --shadow-sm: 0 1px 2px hsl(var(--foreground) / 0.05);
  --shadow-md: 0 4px 12px hsl(var(--foreground) / 0.08);
  --shadow-lg: 0 12px 32px hsl(var(--foreground) / 0.12);
  --shadow-elegant: 0 24px 80px hsl(var(--foreground) / 0.16);
  --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition: 200ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-smooth: 300ms cubic-bezier(0.4, 0, 0.2, 1);
}
.dark {
  --background: 30 14% 9%;
  --foreground: 42 24% 91%;
  --card: 30 13% 13%;
  --card-foreground: 42 24% 91%;
  --popover: 30 13% 13%;
  --popover-foreground: 42 24% 91%;
  --primary: 42 24% 84%;
  --primary-foreground: 30 14% 10%;
  --secondary: 30 11% 19%;
  --secondary-foreground: 42 24% 90%;
  --muted: 30 11% 18%;
  --muted-foreground: 40 10% 66%;
  --accent: 78 17% 56%;
  --accent-foreground: 30 14% 9%;
  --destructive: 0 60% 48%;
  --destructive-foreground: 42 24% 96%;
  --success: 142 31% 45%;
  --success-foreground: 30 14% 9%;
  --warning: 38 74% 52%;
  --warning-foreground: 30 14% 9%;
  --info: 205 42% 58%;
  --info-foreground: 30 14% 9%;
  --border: 30 10% 25%;
  --input: 30 10% 25%;
  --ring: 42 24% 84%;
}
* { box-sizing: border-box; }
html { font-family: var(--font-sans); background: hsl(var(--background)); color: hsl(var(--foreground)); }
body { margin: 0; min-height: 100vh; background: hsl(var(--background)); color: hsl(var(--foreground)); }
.font-serif { font-family: var(--font-serif); }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
input, textarea, select { font-size: max(16px, 1rem); }
::selection { background: hsl(var(--primary) / 0.18); }
.safe-bottom { padding-bottom: calc(0.75rem + env(safe-area-inset-bottom)); }
.hero-vignette { background: linear-gradient(180deg, hsl(var(--foreground) / 0.05), hsl(var(--foreground) / 0.48)); }
.plan-paper { background-image: linear-gradient(hsl(var(--border) / 0.55) 1px, transparent 1px), linear-gradient(90deg, hsl(var(--border) / 0.55) 1px, transparent 1px); background-size: 32px 32px; }
.lightbox-backdrop { background: hsl(var(--background) / 0.96); backdrop-filter: blur(12px); }
