body {
  font-family: 'Nunito', 'Prompt', sans-serif;
  background: linear-gradient(160deg, #fef7ed 0%, #ffedd5 35%, #fef3c7 100%);
  min-height: 100vh;
}

.card-cartoon {
  background: linear-gradient(180deg, #fff 0%, #fffbeb 100%);
  border: 3px solid #fed7aa;
  border-radius: 1.25rem;
  box-shadow: 0 4px 0 0 #fdba74, 0 8px 20px rgba(249, 115, 22, 0.15);
}

.btn-cartoon {
  border-radius: 1rem;
  font-weight: 700;
  box-shadow: 0 4px 0 0 rgba(0, 0, 0, 0.15);
  transition: transform 0.1s, box-shadow 0.1s;
}

.btn-cartoon:active {
  transform: translateY(2px);
  box-shadow: 0 2px 0 0 rgba(0, 0, 0, 0.15);
}

.input-cartoon {
  border: 2px solid #fed7aa;
  border-radius: 0.875rem;
}

.input-cartoon:focus {
  border-color: #f97316;
  outline: none;
  box-shadow: 0 0 0 3px rgba(251, 191, 36, 0.4);
}

@keyframes float {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50% { transform: translateY(-12px) rotate(5deg); }
}

@keyframes floatSlow {
  0%, 100% { transform: translateY(0) translateX(0); }
  50% { transform: translateY(-8px) translateX(6px); }
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.food-float {
  position: fixed;
  font-size: 1.5rem;
  opacity: 0.35;
  pointer-events: none;
  z-index: 0;
}

.food-float.f1 { top: 12%; left: 4%; animation: float 4s ease-in-out infinite; }
.food-float.f2 { top: 25%; right: 6%; animation: floatSlow 5s ease-in-out infinite; }
.food-float.f3 { bottom: 30%; left: 5%; animation: float 3.5s ease-in-out infinite 0.5s; }
.food-float.f4 { bottom: 15%; right: 8%; animation: floatSlow 4.5s ease-in-out infinite 1s; }
.food-float.f5 { top: 50%; right: 3%; animation: float 5.5s ease-in-out infinite 0.3s; }
.food-float.f6 { top: 70%; left: 3%; animation: floatSlow 4s ease-in-out infinite; }
.food-float.f7 { top: 18%; left: 50%; animation: spin 20s linear infinite; opacity: 0.25; }
.food-float.f8 { bottom: 45%; right: 12%; animation: float 3s ease-in-out infinite 0.8s; }

.fade-enter-active, .fade-leave-active { transition: opacity 0.3s ease; }
.fade-enter-from, .fade-leave-to { opacity: 0; }

@font-face {
  font-family: 'TH Sarabun New';
  src: url('https://cdn.jsdelivr.net/npm/thsarabunnew-webfont@1.0.1/THSarabunNew.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}
