/* 左右共通 */
.balloon_left,
.balloon_right {
  width: 100%;
  margin: 1.5rem 0;
  overflow: hidden;
}

/* 左右共通:アイコン画像領域 */
.balloon_left .faceicon img,
.balloon_right .faceicon img {
  width: 100%;
  height: auto;
  border: solid 3px #d7ebfe;
  border-radius: 50%;
}

/* 左右共通:セリフの幅 */
.balloon_left .chatting,
.balloon_right .chatting {
  width: 100%;
}

/* 左側:アイコン */
.balloon_left .faceicon {
  float: left;
  margin-right: -90px;
  width: 80px;
}

/* 左側:セリフ */
.balloon_left .says {
  display: inline-block;
  position: relative;
  margin: 5px 0 0 105px;
  padding: 17px 13px;
  border-radius: 12px;
  background: #d7ebfe;
}

/* 左側:セリフ三角形 */
.balloon_left .says:after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 18px;
  left: -24px;
  border: 12px solid transparent;
  border-right: 12px solid #d7ebfe;
}

/* 右側:アイコン */
.balloon_right .faceicon {
  float: right;
  width: 80px;
  margin-left: -90px;
  margin-right: 6px;
}

.balloon_right .chatting {
  width: 100%;
  text-align: right;
}

/* 右側:セリフ */
.balloon_right .says {
  text-align: left;
  display: inline-block;
  position: relative;
  margin: 5px 105px 0 0;
  padding: 17px 13px;
  border-radius: 12px;
  background: #d7ebfe;
}

/* 右側:セリフ三角形 */
.balloon_right .says:after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 18px;
  right: -24px;
  border: 12px solid transparent;
  border-left: 12px solid #d7ebfe;
}

.says p {
  margin: 0;
  padding: 0;
}
