:root {
  --background: 0 0% 100%;
  --foreground: 220 28% 12%;
  --primary: 29 100% 50%;
  --primary-foreground: 0 0% 100%;
  --secondary: 142 71% 45%;
  --secondary-foreground: 0 0% 100%;
  --muted: 32 100% 96%;
  --muted-foreground: 220 10% 42%;
  --destructive: 0 84% 60%;
  --destructive-foreground: 0 0% 100%;
  --border: 28 32% 88%;
  --card: 0 0% 100%;
  --card-foreground: 220 28% 12%;
  --shadow-sm: 0 6px 18px rgba(25, 31, 42, 0.07);
  --shadow-md: 0 16px 40px rgba(25, 31, 42, 0.10);
  --shadow-lg: 0 26px 70px rgba(25, 31, 42, 0.14);
  --transition-fast: 160ms ease;
  --transition-smooth: 320ms cubic-bezier(0.2, 0.8, 0.2, 1);
  --radius-sm: 12px;
  --radius-md: 18px;
  --radius-lg: 28px;
}

.dark {
  --background: 220 30% 7%;
  --foreground: 35 45% 96%;
  --primary: 29 100% 56%;
  --primary-foreground: 0 0% 100%;
  --secondary: 142 68% 48%;
  --secondary-foreground: 0 0% 100%;
  --muted: 220 24% 13%;
  --muted-foreground: 32 18% 74%;
  --destructive: 0 75% 58%;
  --destructive-foreground: 0 0% 100%;
  --border: 220 20% 22%;
  --card: 220 25% 10%;
  --card-foreground: 35 45% 96%;
  --shadow-sm: 0 6px 18px rgba(0, 0, 0, 0.22);
  --shadow-md: 0 16px 40px rgba(0, 0, 0, 0.32);
  --shadow-lg: 0 26px 70px rgba(0, 0, 0, 0.42);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  background: hsl(var(--background));
  color: hsl(var(--foreground));
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  overflow-x: hidden;
}

::selection {
  background: hsl(var(--primary) / 0.22);
  color: hsl(var(--foreground));
}

.glass {
  background: hsl(var(--card) / 0.72);
  border: 1px solid hsl(var(--border) / 0.78);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.gradient-text {
  background: linear-gradient(120deg, hsl(var(--primary)), hsl(var(--secondary)));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.hero-grid {
  background-image: radial-gradient(circle at 20% 20%, hsl(var(--primary) / 0.16), transparent 28%), radial-gradient(circle at 80% 12%, hsl(var(--secondary) / 0.16), transparent 30%), linear-gradient(hsl(var(--border) / 0.25) 1px, transparent 1px), linear-gradient(90deg, hsl(var(--border) / 0.25) 1px, transparent 1px);
  background-size: auto, auto, 42px 42px, 42px 42px;
}

.no-scrollbar::-webkit-scrollbar { display: none; }
.no-scrollbar { -ms-overflow-style: none; scrollbar-width: none; }

.map-frame {
  border: 0;
  width: 100%;
  min-height: 290px;
  border-radius: var(--radius-lg);
  filter: saturate(1.08) contrast(1.02);
}

button, a, input, textarea { transition: var(--transition-smooth); }

@keyframes floaty {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-14px); }
}
.floaty { animation: floaty 5s ease-in-out infinite; }

@keyframes pulseSoft {
  0%, 100% { box-shadow: 0 0 0 0 hsl(var(--secondary) / 0.42); }
  50% { box-shadow: 0 0 0 14px hsl(var(--secondary) / 0); }
}
.whatsapp-pulse { animation: pulseSoft 2.2s infinite; }

.focus-ring:focus {
  outline: none;
  box-shadow: 0 0 0 4px hsl(var(--primary) / 0.18);
  border-color: hsl(var(--primary));
}