:root {
  --indigo: #1a1a2e;
  --indigo-light: #22223a;
  --warm-white: #faf9f6;
  --sakura: #f7a8b8;
  --sakura-dark: #e8899c;
  --matcha: #7db46c;
  --wasabi: #c5e17a;
  --nori: #2d2d2d;
  --tamago: #f5d76e;
  --soy: #3e2723;
  --caramel: #c49a3c;
  --ocean: #1a3a4a;
  --cream: #f5f0e8;
  --salmon: #e8a090;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}

body {
  background: var(--indigo);
  color: var(--warm-white);
  font-family: 'DM Sans', sans-serif;
  overflow-x: hidden;
}

.font-serif-jp {
  font-family: 'Noto Serif JP', serif;
}

.font-crimson {
  font-family: 'Crimson Pro', serif;
}

/* Floating animation */
@keyframes float {
  0%, 100% { transform: translateY(0px) rotate(0deg); }
  33% { transform: translateY(-6px) rotate(0.5deg); }
  66% { transform: translateY(-3px) rotate(-0.3deg); }
}

@keyframes floatSlow {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-10px); }
}

@keyframes bobble {
  0%, 100% { transform: translateY(0) rotate(-1deg); }
  50% { transform: translateY(-8px) rotate(1deg); }
}

@keyframes shimmer {
  0% { background-position: -200% center; }
  100% { background-position: 200% center; }
}

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes dissolve {
  0% { opacity: 1; filter: blur(0); transform: scale(1); }
  50% { opacity: 0.6; filter: blur(2px); transform: scale(1.05); }
  100% { opacity: 0; filter: blur(8px); transform: scale(1.15); }
}

@keyframes waveMove {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes grainDrift {
  0%, 100% { transform: translateY(0) translateX(0); }
  25% { transform: translateY(20px) translateX(5px); }
  50% { transform: translateY(40px) translateX(-3px); }
  75% { transform: translateY(60px) translateX(7px); }
}

@keyframes melt {
  0% { border-radius: 8px; transform: scaleY(1); }
  100% { border-radius: 50%; transform: scaleY(0.6) scaleX(1.3); }
}

@keyframes pulseGreen {
  0%, 100% { background: #c5e17a; box-shadow: 0 0 20px #c5e17a44; }
  50% { background: #a8d44e; box-shadow: 0 0 40px #c5e17a88; }
}

@keyframes sparkle {
  0%, 100% { opacity: 0; transform: scale(0) rotate(0deg); }
  50% { opacity: 1; transform: scale(1) rotate(180deg); }
}

@keyframes scrollBounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(8px); }
}

@keyframes conveyorMove {
  0% { background-position: 0 0; }
  100% { background-position: 40px 0; }
}

@keyframes countUp {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes shakeWasabi {
  0%, 100% { transform: translateX(0); }
  10% { transform: translateX(-2px) rotate(-1deg); }
  20% { transform: translateX(2px) rotate(1deg); }
  30% { transform: translateX(-2px) rotate(-1deg); }
  40% { transform: translateX(2px) rotate(1deg); }
  50% { transform: translateX(0); }
}

@keyframes unfurl {
  from { clip-path: inset(100% 0 0 0); opacity: 0; }
  to { clip-path: inset(0 0 0 0); opacity: 1; }
}

.animate-float { animation: float 4s ease-in-out infinite; }
.animate-float-slow { animation: floatSlow 6s ease-in-out infinite; }
.animate-bobble { animation: bobble 5s ease-in-out infinite; }
.animate-fade-in-up { animation: fadeInUp 0.8s ease-out forwards; }
.animate-fade-in { animation: fadeIn 0.6s ease-out forwards; }
.animate-scroll-bounce { animation: scrollBounce 2s ease-in-out infinite; }
.animate-unfurl { animation: unfurl 0.8s ease-out forwards; }

.candy-shadow-pink { filter: drop-shadow(0 8px 16px rgba(247, 168, 184, 0.3)); }
.candy-shadow-green { filter: drop-shadow(0 8px 16px rgba(125, 180, 108, 0.3)); }
.candy-shadow-yellow { filter: drop-shadow(0 8px 16px rgba(245, 215, 110, 0.3)); }
.candy-shadow-salmon { filter: drop-shadow(0 8px 16px rgba(232, 160, 144, 0.25)); }

/* Conveyor belt style */
.conveyor-belt {
  background: repeating-linear-gradient(
    90deg,
    #2d2d2d 0px,
    #2d2d2d 18px,
    #3a3a3a 18px,
    #3a3a3a 20px
  );
  animation: conveyorMove 2s linear infinite;
}

/* Nutrition facts styling */
.nutrition-label {
  font-family: 'DM Sans', Helvetica, Arial, sans-serif;
  border: 2px solid #000;
  padding: 4px;
  background: #fff;
  color: #000;
  width: 280px;
}

.nutrition-label .thick-bar {
  height: 10px;
  background: #000;
  margin: 2px 0;
}

.nutrition-label .medium-bar {
  height: 5px;
  background: #000;
  margin: 2px 0;
}

.nutrition-label .thin-line {
  height: 1px;
  background: #000;
  margin: 1px 0;
}

/* Tasting experience backgrounds */
.act-ocean {
  background: linear-gradient(180deg, #0a1628 0%, #1a3a4a 40%, #1a4a3a 100%);
}

.act-cream {
  background: linear-gradient(180deg, #f5f0e8 0%, #fff8f0 50%, #f0e8d8 100%);
}

.act-salmon {
  background: linear-gradient(180deg, #e8a09066 0%, #f7a8b866 50%, #f5d76e33 100%);
}

/* Radar chart */
.radar-svg text {
  font-family: 'DM Sans', sans-serif;
  font-size: 11px;
  fill: var(--warm-white);
}

/* Custom scrollbar */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--indigo); }
::-webkit-scrollbar-thumb { background: var(--caramel); border-radius: 3px; }

/* Section transitions */
.section-enter {
  opacity: 0;
  transform: translateY(40px);
  transition: all 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.section-enter.visible {
  opacity: 1;
  transform: translateY(0);
}

/* Pill badges */
.badge-pill {
  display: inline-flex;
  align-items: center;
  padding: 4px 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.5px;
  border: 1px solid rgba(255,255,255,0.15);
}

/* Soy sauce drip */
@keyframes drip {
  0% { transform: scaleY(0); transform-origin: top; }
  60% { transform: scaleY(1.2); transform-origin: top; }
  100% { transform: scaleY(1); transform-origin: top; }
}

.drip-anim { animation: drip 0.6s ease-out forwards; }

/* Thermometer */
.thermo-fill {
  transition: height 1s ease-out;
}

/* Mobile adjustments */
@media (max-width: 768px) {
  .nutrition-label {
    width: 260px;
  }
}