@charset "utf-8";

/* COMMON
--------------------------*/

.topmessage {
	overflow: hidden;
	max-width: 100%;
	margin: 0;
}

.topmessage__mainvisual {
	position: relative;
	height: 310px;
}

.topmessage__mainvisual > img {
	position: absolute;
	right: 0;
	max-width: none;
	height: 310px;
}

.topmessage .fluid-image {
	width: 100%;
	height: auto;
}

.topmessage__wrapper {
  display: flex;
	max-width: 1500px;
	margin: auto;
}

.topmessage__inner {
	display: flex;
  flex-direction: column;
	width: 50%;
	margin: 50px auto 100px;
}

.topmessage__container {
	max-width: calc(100% - 380px);
	margin-left: auto;
	margin-right: 0;
	padding: 0 0 0 40px;
}

.topmessage__thumbnail {
	position: relative;
	width: 50%;
  height: fit-content;
}

.topmessage__lead {
	padding: 0 3vw;
	font-size: 1.9rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  width: 50%;
}

.lead_text{
  font-size: 20px;
}

.topmessage__logo {
	max-width: 320px;
	margin: 40px 0;
}

.topmessage__comment {
	font-size: 1.58rem;
}

.topmessage__comment-head {
	display: inline-block;
	padding: 10px 0;
	font-size: 2rem;
}

.topmessage_head{
  display: flex;
}

.topmessage__name {
  margin-top: 80px;
}

.comment_text{
  margin: 50px 30px;
}
.topmessage__line{
  position: absolute;
  bottom: 0;
  left: 0;
  width: calc(100% - 30px);
  height: auto;
}

@media screen and (min-width: 1920px) {
	.topmessage__mainvisual > img {
		left: 0;
		margin: auto;
	}
}

@media screen and (max-width: 1200px) {
	.topmessage__name{
    margin-top: 2vw;
  }
}

@media screen and (max-width: 960px) {
  .topmessage__wrapper{
    flex-direction: column;
  }
  .topmessage__inner{
    width: 100%;
  }

  .topmessage__name{
    margin-top: 100px;
  }

  .topmessage__lead{
    justify-content: center;
  }
}
@media screen and (max-width: 768px) {

}

@media screen and (max-width: 480px) {
  .topmessage_head{
    flex-direction: column;
  }
  .lead_text{
    margin-top: 20px;
  }
  .topmessage__thumbnail,
  .topmessage__lead{
    width: 100%;
  }
  .topmessage__name{
    margin-top: 50px;
    margin-bottom: 20px;
  }
}
