.centered {
  position: fixed;
  top: 50%;
  left: 50%;
  /* bring your own prefixes */
  transform: translate(-50%, -50%);
}

#agy_00 {
    position: relative;
left:25px;
    -webkit-animation-name: agy_felso; /* Chrome, Safari, Opera */
    -webkit-animation-duration: 2s; /* Chrome, Safari, Opera */
    -webkit-animation-iteration-count: infinite; /* Chrome, Safari, Opera */
    animation-name: agy_felso;
    animation-duration: 2s;
    animation-iteration-count: infinite;
animation-timing-function: ease-in-out;
}

/* agyfelso for Chrome, Safari, Opera */
@-webkit-keyframes agy_felso {
    0%  {top:+0px;}
    50%  {top:+20px;}
    100%  {top:+0px;}
}



/* agyfelso for Standard syntax */
@keyframes agy_felso {
    0%  {top:+0px;}
    50%  {top:+20px;}
    100%  {top:+0px;}
}

#agy_01 {
    position: relative;
    -webkit-animation-name: agy_also; /* Chrome, Safari, Opera */
    -webkit-animation-duration: 2s; /* Chrome, Safari, Opera */
    -webkit-animation-iteration-count: infinite; /* Chrome, Safari, Opera */
    animation-name: agy_also;
    animation-duration: 2s;
    animation-iteration-count: infinite;
animation-timing-function: ease-in-out;
}

/* Agyalso for Chrome, Safari, Opera */
@-webkit-keyframes agy_also {
    0%  {width:400px;left:+0px;}
    50%  {width:350px;left:+25px;}
    100%  {width:400px;left:+0px;}
}

/* Agyalso for Standard syntax */
@keyframes agy_also {
    0%  {width:400px;left:+0px;}
    50%  {width:350px;left:+25px;}
    100%  {width:400px;left:+0px;}
}


/*for the speech box*/

p.speech {
  position: relative;

  width: 400px;
/*  height: 100px;*/
  text-align: center;
  vertical-align: bottom;
/* line-height: 100px; */
  padding : 5px;
  background-color: #fff;
  border: 4px solid #000;
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
  border-radius: 20px;
  -webkit-box-shadow: 2px 2px 4px #7c7c7c;
  -moz-box-shadow: 2px 2px 4px #7c7c7c;
  box-shadow: 2px 2px 4px #7c7c7c;
}
