:root {
  --bg1: #fff7ed;
  --bg2: #dbeafe;
  --ink: #1f2937;
  --skin: #ffd7b5;
  --shirt: #2563eb;
  --pants: #0f172a;
  --bubble: #ffffff;
  --shadow: 0 20px 50px rgba(0,0,0,.12);
}
* { box-sizing: border-box; }
body {
  margin: 0;
  min-height: 100vh;
  display: grid;
  place-items: center;
  font-family: Inter, system-ui, sans-serif;
  background: linear-gradient(180deg, var(--bg1), var(--bg2));
  color: var(--ink);
}
.scene {
  display: grid;
  place-items: center;
  gap: 18px;
  padding: 24px;
}
.bubble {
  background: var(--bubble);
  border-radius: 24px;
  padding: 16px 22px;
  font-size: clamp(1.2rem, 3vw, 2rem);
  font-weight: 800;
  box-shadow: var(--shadow);
  position: relative;
}
.bubble::after {
  content: '';
  position: absolute;
  left: 48px;
  bottom: -12px;
  width: 22px;
  height: 22px;
  background: white;
  transform: rotate(45deg);
}
.character {
  position: relative;
  width: 220px;
  height: 320px;
}
.head {
  position: absolute;
  left: 60px;
  top: 0;
  width: 100px;
  height: 100px;
  background: var(--skin);
  border-radius: 50%;
  box-shadow: var(--shadow);
}
.eye {
  position: absolute;
  top: 38px;
  width: 10px;
  height: 10px;
  background: var(--ink);
  border-radius: 50%;
}
.eye.left { left: 28px; }
.eye.right { right: 28px; }
.mouth {
  position: absolute;
  left: 38px;
  bottom: 22px;
  width: 24px;
  height: 10px;
  border-bottom: 4px solid var(--ink);
  border-radius: 0 0 20px 20px;
}
.body {
  position: absolute;
  left: 70px;
  top: 92px;
  width: 80px;
  height: 110px;
  background: var(--shirt);
  border-radius: 26px;
}
.arm {
  position: absolute;
  top: 104px;
  width: 20px;
  height: 94px;
  background: var(--skin);
  border-radius: 20px;
  transform-origin: top center;
}
.left-arm {
  left: 56px;
  transform: rotate(18deg);
}
.right-arm {
  right: 46px;
  animation: wave 1s steps(4) infinite;
}
.leg {
  position: absolute;
  top: 192px;
  width: 22px;
  height: 100px;
  border-radius: 20px;
  background: var(--pants);
}
.left-leg { left: 82px; }
.right-leg { right: 82px; }
.caption {
  margin: 0;
  color: #475569;
  font-weight: 600;
}
@keyframes wave {
  0% { transform: rotate(-10deg); }
  25% { transform: rotate(-35deg); }
  50% { transform: rotate(-5deg); }
  75% { transform: rotate(-30deg); }
  100% { transform: rotate(-10deg); }
}
