@charset "UTF-8";

/* -----------------------------------------------------------
   MAIN-VISUAL
------------------------------------------------------------*/

.main-visual::after{
	content: "";
	display: block;
	width: 100%;
	height: 0;
	padding-top: 20.92%;
	background-image: url(../img/main_txt_btm.png);
	background-size: cover;
	position: absolute;
	bottom: 8.3vw;
	left: 0;
	z-index: 0;
}


.main-visual .main-visual-inner{
	width: 100%;
	height: 100%;
	background-image: url(../img/main_cloud.png);
	background-size: cover;
	position: relative;
	opacity: 0;
	z-index: 1;
}
.main-visual .main-visual-inner::after{
	content: "";
	display: block;
	width: 100%;
	height: 0;
	padding-top: 25.234375%;
	background-image: url(../img/main_txt_top.png);
	background-size: cover;
	position: absolute;
	top: 13.9vw;
	left: 0;
}
.main-visual .main-visual-inner .kv-parts{
	position: absolute;
	background-size: cover;
	z-index: 3;
}

.main-visual .main-visual-inner .camp{
	width: 20%;
	height: 0;
	padding-top: calc((552 / 506) * 20%);
	top: 22.4vw;
	left: 0;
	background-image: url(../img/main_camp.png);
	opacity: 0;
}
.main-visual .main-visual-inner .caster{
	width: 27.5%;
	height: 0;
	padding-top: calc((706 / 820) * 27.5%);
	bottom: 0;
	right: 0;
	background-image: url(../img/main_caster.png);
	opacity: 0;
}
.main-visual .main-visual-inner .baseball{
	width: 16%;
	height: 0;
	padding-top: calc((640 / 412) * 16%);
	bottom: 0;
	left: 15vw;
	background-image: url(../img/main_baseball.png);
	opacity: 0;
}

.main-visual .main-visual-inner .interview{
	width: 24.53%;
	height: 0;
	padding-top: calc((538 / 628) * 24.53%);
	top: 22.42vw;
	left: 31.09vw;
	background-image: url(../img/main_interview.png);
	opacity: 0;
}


.main-visual .main-visual-inner .copy{
	width: 60%;
	height: 0;
	padding-top: calc((316 / 1563) * 60%);
	top: 35vw;
	left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
	background-image: url(../img/main_copy.png);
	opacity: 0;
}





@media all and (min-width: 768px) {
	.main-visual{	
		background-color:var(--main-skyblue);
		aspect-ratio: 1280 / 915;
		position: relative;
	}
	.main-visual .main-visual-inner .car{
		width: 22%;
		height: 0;
		padding-top: calc((366 / 562) * 22%);
		top: 52.1vw;
		left: 44.6vw;
		background-image: url(../img/main_car.png);
		opacity: 0;
	}
	.main-visual .main-visual-inner .pet{
		width: 16.56%;
		height: 0;
		padding-top: calc((424 / 382) * 16.56%);
		top: 23.28vw;
		right: 0;
		background-image: url(../img/main_pet.png);
		opacity: 0;
	}

	.main-visual.is-active::after{animation: fadeIn 0.7s cubic-bezier(0.33, 1, 0.68, 1) forwards;}
	.main-visual .main-visual-inner.is-active{animation: fadeIn 0.7s cubic-bezier(0.33, 1, 0.68, 1) forwards;}
	.main-visual .main-visual-inner .camp.is-active{animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) 0s forwards;}
	.main-visual .main-visual-inner .caster.is-active{animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) 0.2s forwards;}
	.main-visual .main-visual-inner .pet.is-active{animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) 0.4s forwards;}
	.main-visual .main-visual-inner .baseball.is-active{animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) 0.6s forwards;}
	.main-visual .main-visual-inner .car.is-active{animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) 0.8s forwards;}
	.main-visual .main-visual-inner .interview.is-active{animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) 1.0s forwards;}
	.main-visual .main-visual-inner .copy.is-active{animation: slideIn 1s cubic-bezier(0.25, 1, 0.5, 1) 1.4s forwards;z-index: 4;}


}
@media all and (max-width: 767px) {
	.main-visual{
		background-color:var(--main-skyblue);
		
	}
	.main-visual::after{
		width: 78%;
		padding-top: calc(92.18% * 0.78);
		background-image: url(../img/main_txt_btm_smp.png);
		bottom: auto;
		top: 101.79vw;
		left: 19vw;
		z-index: 3;
	}
	.main-visual .main-visual-inner{		
		background-image: url(../img/main_cloud_smp.png);
		background-size: cover;
		aspect-ratio: 390 / 708;
	}
	.main-visual .main-visual-inner::after{		
		width: 92%;
		padding-top: calc(77.34% *0.92);
		background-image: url(../img/main_txt_top_smp.png);
		top: 8.7vw;
		left: 0;
		z-index: 1;
	}
	.main-visual .main-visual-inner .copy{
		width: 98%;
		padding-top: calc((316 / 1563) * 98%);
		top: 81.7vw;		
	}
	.main-visual .main-visual-inner .camp{
		width: 43%;
		padding-top: calc((180 / 168) * 43%);
		top: 40.7vw;
		z-index: 1;
	}
	.main-visual .main-visual-inner .baseball{
		width: 36%;
		padding-top: calc((640 / 412) * 36%);
		bottom: auto;
		top:108vw;
		left: 2.5vw;
	}
	.main-visual .main-visual-inner .interview{
		width: 50%;
		padding-top: calc((136 / 153) * 50%);
		top: 14.8vw;
		left: auto;
		right: 0;
	}
	.main-visual .main-visual-inner .caster{
		width: 39%;
		padding-top: calc((136 / 152) * 39%);
		bottom: auto;
		top: 103.8vw;
		background-image: url(../img/main_caster.png);
	}
	.main-visual.is-active::after{animation: fadeIn 0.7s cubic-bezier(0.33, 1, 0.68, 1) forwards;}
	.main-visual .main-visual-inner.is-active{animation: fadeIn 0.7s cubic-bezier(0.33, 1, 0.68, 1) forwards;}
	.main-visual .main-visual-inner .camp.is-active{animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) 0s forwards;}
	.main-visual .main-visual-inner .caster.is-active{animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) 0.2s forwards;}
	.main-visual .main-visual-inner .baseball.is-active{animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) 0.4s forwards;}
	.main-visual .main-visual-inner .interview.is-active{animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) 0.6s forwards;}
	.main-visual .main-visual-inner .copy.is-active{animation: slideIn 1s cubic-bezier(0.25, 1, 0.5, 1) 0.8s forwards;z-index: 4;}
}


/* -----------------------------------------------------------
   UPDATE
------------------------------------------------------------*/
.update-box .update-list:after{
	content: "";
	display: block;
	width: 80px;
	height: 102px;
	background: url(../img/update_waku.png);
	background-size: cover;
	position: absolute;
	bottom: -50px;
	right: 5px;
}
.update-box .update-list li{
	display: flex;
	padding: 8px 0;
	line-height: 1.4;
}
.update-box .update-list li.is-hidden {
  visibility: hidden;
  opacity: 0;
  height: 0;
  margin: 0 10px;
  padding: 0;
}
.update-box .update-list time{
	font-size: 1.6rem;
	color: #98A6B5;
	width: 20%;
}
.update-box .update-list p{
	font-size: 1.6rem;
	color: #000;
	font-weight: 500;
}
.update-box .update-list a{
	transition: .3s;
	color: #000;
	text-decoration: underline;
}
.update-box .update-list a:hover{
	opacity: 0.5;
	text-decoration: none;
}
.update-box .more{
	margin: 10px 0 0 0;
	padding-right: 93px;
	text-align: end;
}
.update-box .more button{
	display: inline-block;
	font-family: "Inter", sans-serif;
	font-size: 1.6rem;
	font-weight: 500;
	color: #000;
	padding: 8px 25px;
	transition:.3s;
	letter-spacing: 0.1em;
	background-color: #FFF;
	position: relative;
	border: none;
	border: 1px solid #000;
}
.update-box .more button::after{
	content: "";
	display: inline-block;
	width: 6px;
	height: 6px;
	border-top: 1px solid #000;
	border-right: 1px solid #000;
	-webkit-transform: translateY(-50%) rotate(135deg);
	transform: translateY(-50%) rotate(135deg);
	-ms-transform:translateY(-50%) rotate(135deg);
	position: absolute;
	top: 50%;
	right: 10px;
}
.update-box .more button:hover{
	color: #FFF;
	background-color: #0050FF;
}
.update-box .more button::after:hover{
	border-top: 1px solid #FFF;
	border-right: 1px solid #FFF;
}



@media all and (min-width: 768px) {
	.update-box{
		
		position: absolute;
		top:65vw;
		right: 0;
		width: 537px;
		padding: 0;
		z-index: 10;
	}
	.update-box .update-list{
		background-color: #FFF;
		padding: 20px;
	}
	.update-box .update-list p{
		width: 80%;
	}
}



@media all and (max-width: 767px) {
	.update-box{
		width: 100%;
		z-index: 100;
		position: relative;
		padding-bottom: 15vw;
	}
	.update-box:after{
		width: 16vw;
		height: 0;
		padding-top: calc(16vw * 1.258);
		background: url(../img/update_waku.png);
		background-size: cover;
		position: absolute;
		bottom: 2.5%;
		right: 2.5%;
	}
	.update-box .update-list{
		width: 100%;
		margin: 0 auto;
		padding: 4%;
		box-sizing: border-box;
		background-color: #FFF;
	}
	.update-box .update-list li{
		padding: 0;
		margin-bottom: 16px;
	}
	.update-box .update-list time{
		font-size: 1.3rem;
		font-weight: 500;
		width: 25%;
		letter-spacing: 0.02em;
	}
	.update-box .update-list p{
		font-size: 1.3rem;
		font-weight: 500;
		width: 75%;
	}
	.update-box .more{
		position: relative;
		margin: 3.3vw auto 0;
		text-align: center;
		padding-right: 0;
	}
	.update-box .more button{
		font-size: 1.2rem;
		padding: 5px 25px 5px 15px;
	}
	.update-box .more button::after{
		right: 10px;
	}
}

/* -----------------------------------------------------------
   CONCEPT
------------------------------------------------------------*/
.top-main{
	overflow: hidden;
}
.wrap{
	background-color:  var(--main-bgblue);
	padding: min(7.5vw,97px) 0;
}
#concept{
	width: 100%;
	margin: 0 auto;
	background-image: url(../img/concept_bg.png);
	background-repeat: no-repeat;
	background-size: contain;
	position: relative;
	padding: 16% 10%;
	box-sizing: border-box;
}
#concept .concept-inner{
	width: 48%;
	margin-left: auto;
}
#concept .concept-inner h2{
	display: block;
	width: 80%;
	height: 0;
	padding-top:calc(9.3% * 0.8);
	background: url(../img/concept_ttl.svg) no-repeat;
	background-size: contain;
	margin-bottom: 30px;
}
#concept .concept-inner .concept-txt{
	margin-bottom: 10px;
}
#concept .concept-inner .concept-txt p{
	font-size: min(1.8rem,1.4vw);
	line-height: 2.0;
	margin-bottom: 1.0em;
}
#concept .concept-inner .concept-txt p:last-child{
	margin-bottom: 0;
}
#concept .concept-inner .concept-end{
	display: block;
	width: 90%;
	height: 0;
	padding-top:calc(12.95% * 0.9);
	background: url(../img/concept_endtxt.png) no-repeat;
	background-size: contain;
}
#concept figure img{
	width: 100%;
}

@media all and (min-width: 1024px) {
	#concept{
		aspect-ratio: 1169 / 817.5;
	}
	#concept figure{
		position: absolute;
	}
	#concept figure.ph1{
		width: 50%;
		top: 0;
		left: -5%;
		opacity: 0;
	}
	#concept figure.ph1.is-active{animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) 0.2s forwards;}
	#concept figure.ph2{
		width: 46%;
		bottom: 3%;
		left: 2%;
		opacity: 0;
	}
	#concept figure.ph2.is-active{animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) 0.4s forwards;}
	#concept figure.ph1 img{
		width: 100%;
		height: 0;
		padding-top: 59.43%;
		background: url(../img/concept_ph1.png) no-repeat;
		background-size: cover;
	}
	#concept figure.ph2 img{
		width: 100%;
		height: 0;
		padding-top: 59.43%;
		background: url(../img/concept_ph2.png) no-repeat;
		background-size: cover;
	}
}
@media all and (max-width: 1023px) {
	.wrap{
		padding: 10vw 0;
	}
	.wrap > .inner{
		width: 100%;
		background-image:url(../img/concept_bgtop_smp.png),url(../img/concept_bgbtm_smp.png) ;
		background-position: top center,bottom center;
		background-size: contain;
		background-repeat: no-repeat;
		padding: 29vw 0 54.35vw;
	}
	#concept{
		width: 100%;
		padding: 0 2%;
		background-color: #FFF;
		background-image: none;
	}
	#concept .concept-inner h2{
		margin: 0 auto 8vw;
	}
	#concept .concept-inner .concept-txt{
		padding: 0 4%;
	}
	#concept figure{
		position: absolute;
	}
	#concept figure.ph1{
		width: 74%;
		left: 4%;
		bottom: -40vw;
	}
	#concept figure.ph2{
		width: 44%;
		right: 4%;
		bottom: -56vw;
	}
	#concept figure.ph1 img{
		width: 100%;
		height: 0;
		padding-top: 79.92%;
		background: url(../img/concept_ph1_smp.png) no-repeat;
		background-size: 100%;
	}
	#concept figure.ph2 img{
		width: 100%;
		height: 0;
		padding-top: 85.63%;
		background: url(../img/concept_ph2_smp.png) no-repeat;
		background-size: 100%;
	}
	#concept .concept-inner{
		width: 100%;
		margin-left: auto;
		margin-right: auto;
		padding-bottom: 34vw;
	}
	#concept .concept-inner .concept-txt p{
		font-size: 1.5rem;
		line-height: 1.8;
		margin-bottom: 1.4em;
	}
	#concept .concept-inner .concept-end{
		width: 100%;
		padding-top:calc(12.95% * 1.0);
	}
}

/* -----------------------------------------------------------
   Banner
------------------------------------------------------------*/
main #bn_jobfes a{
	display: block;
	width: 88%;
	height: 0;
	padding-top: calc(14.58% * 0.88);
	background: url(../img/bn_jobfes_1.png?);
	background-size: cover;
	margin: 0 auto 12vw;
	position: relative;
    z-index: 10;
	text-indent: -9999px;
	transition: .3s;
	top: 0;
}
main #bn_jobfes a:hover{
	top:5px;
	transition: all 200ms ease-out;
}


@media all and (max-width: 767px) {
	main #bn_jobfes{
		width: 90%;
    	margin: 0 auto;
	}
	main #bn_jobfes a{
		width: 100%;
		padding-top: calc(48.4375% * 1.0);
		margin: 0 auto 7.6vw;
		background: url(../img/banner_jobfes.png);
		background-size: cover;
	}
}
/* -----------------------------------------------------------
   PEOPLE
------------------------------------------------------------*/
#people-sec {
	background-color: #FFF;
	padding: 64px;
}
#people-sec .ttl-box{
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin: -130px auto 70px;
}
#people-sec .ttl-box h2{
	width: 40%;
	height: 0;
	padding-top: calc(32.77% * 0.4);
	background: url(../img/top_h_people.png);
	background-size: cover;
}
#people-sec .ttl-box .toptxt-box{
	width: 46%;
	border-top: dashed #000 1px;
	border-bottom: dashed #000 1px;
	background-color: #FFF;
	padding: 1.6rem;
	box-sizing: border-box;
}
#people-sec .ttl-box .toptxt-box p{
	font-size: 1.6rem;
	line-height: 2.0;
}
#people-sec .btn-common{
	width: max(36% , 320px);
	margin:0 auto;
}

@media all and (max-width: 767px) {
	#people-sec {
		padding: 0 2%;
		margin-top: 16vw;
		padding-bottom: 9.4vw;
	}
	#people-sec .ttl-box{
		display: block;
		margin: 0 auto;
		position: relative;
		padding-top: 20vw;
	}
	#people-sec .ttl-box h2{
		width: 70%;
		padding-top: calc(32.77% * 0.7);
		position: absolute;
		top: -10vw;
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
	}
	#people-sec .ttl-box .toptxt-box{
		width: 100%;
	}
	#people-sec .ttl-box .toptxt-box p{
		font-size: 1.5rem;
		line-height: 1.8;
	}
	#people-sec .btn-common{
		width: 100%;
		max-width: 400px;
		margin:0 auto;
	}
}

/* -----------------------------------------------------------
   COMPANY
------------------------------------------------------------*/
#company-sec {
	background-color: #FFF;
	padding: 0 0 min(8.9vw,114px) 0;
}
#company-sec .inner{
	position: relative;
	padding: 0;
}
#company-sec .inner h2{
	width: 50%;
	height: 0;
	padding-top: calc(23.04% * 0.5);
	background: url(../img/top_h_company.png);
	background-size: cover;
	position: absolute;
	top: -45px;
	right: 0;
}
#company-sec .r-box{
	width: 50%;
	margin: 0 0 0 auto;
	position: relative;
	padding-top: 140px;
}

#company-sec .r-box .toptxt-box{
	width: 100%;
	border-top: dashed #000 1px;
	border-bottom: dashed #000 1px;
	background-color: var(--main-skyblue);
	padding: 1.6rem;
	margin-bottom: 50px;
	box-sizing: border-box;
}
#company-sec .r-box .toptxt-box p{
	font-size: 1.6rem;
	line-height: 2.0;
}
#company-sec .sec-image{
	width: min(720px,63%);
	position: absolute;
	top: 50px;
	left: -110px;
	opacity: 0;
}
#company-sec .sec-image.is-active{animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) forwards;}
#company-sec .sec-image img{
	width: 100%;
	height: 0;
	padding-top: 64.85%;
	background: url(../img/top_company_photo.png);
	background-size: cover;
}
#company-sec .card-image{
	width: 463px;
	margin-left: auto;
	margin-bottom: 30px;
}
#company-sec img{
	width: 100%;
}
#company-sec .btn-common{
	width: max(63%, 361px);
	margin:0 0 0 auto;
}
@media all and (max-width: 767px) {
	#company-sec{
		padding: 16vw 0 ;
		background-color: var(--main-skyblue);
	}
	#company-sec .inner{
		padding: 0;
	}
	#company-sec .inner h2{
		width: 90%;
		padding-top: calc(23.04% * 0.9);
		position: relative;
		top: auto;
		left: auto;
		margin:0 auto 6.9vw;
	}
	#company-sec .r-box{
		width: 94%;
		margin: 0 auto;
		padding-top: 6.9vw;
	}
	
	#company-sec .r-box .toptxt-box{
		margin-bottom: 7.15vw;
	}
	#company-sec .r-box .toptxt-box p{
		font-size: 1.5rem;
		line-height: 1.8;
	}
	#company-sec .sec-image{
		position: relative;
		width: 98%;
		margin-right: auto;
		top: auto;
    	left: auto;
	}
	#company-sec .sec-image img{
		padding-top: 49.19%;
		background-image: url(../img/top_company_photo_smp.png);
	}
	#company-sec .card-image{
		width: 94%;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 30px;
	}
	#company-sec .btn-common{
		width: 100%;
		max-width: 400px;
		margin:0 auto;
	}
}

/* -----------------------------------------------------------
   WORK
------------------------------------------------------------*/
#work-sec {
	background-color: var(--main-skyblue);
	padding: 0 0 min(8.9vw,114px) 0;
	position: relative;
}
#work-sec .inner{
	position: relative;
	padding: 0;
}
#work-sec .inner h2{
	width: 36%;
	height: 0;
	padding-top: calc(31.75% * 0.36);
	background: url(../img/top_h_work.png);
	background-size: cover;
	position: absolute;
	top: -45px;
	left: 0;
}
#work-sec .r-box{
	width: 50%;
	margin: 0 auto 0 0;
	position: relative;
	padding-top: 140px;
}

#work-sec .r-box .toptxt-box{
	width: 100%;
	border-top: dashed #000 1px;
	border-bottom: dashed #000 1px;
	background-color: #FFF;
	padding: 1.6rem;
	margin-bottom: 50px;
	box-sizing: border-box;
}
#work-sec .r-box .toptxt-box p{
	font-size: 1.6rem;
	line-height: 2.0;
}
#work-sec .sec-image{
	width: min(720px,63%);
	position: absolute;
	top: 50px;
	right: -110px;
	opacity: 0;
}
#work-sec .sec-image.is-active{animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) forwards;}
#work-sec .sec-image img{
	width: 100%;
	height: 0;
	padding-top: 54.16%;
	background: url(../img/top_work_photo.png);
	background-size: cover;
}
#work-sec .card-image{
	width: 377px;
	margin-right: auto;
	margin-bottom: 30px;
}
#work-sec img{
	width: 100%;
}
#work-sec .btn-common{
	width: max(63%, 361px);
	margin:0 auto 0 0;
}
@media all and (max-width: 767px) {
	#work-sec {
		padding: 0 0 16vw 0;
	}
	#work-sec .inner{
		padding: 0;
	}
	#work-sec .inner h2{
		width: 54%;
		height: 0;
		padding-top: calc(31.75% * 0.54);
		position: relative;
		margin:0 auto 6.9vw;
		top: auto;
		left: auto;
	}
	#work-sec .sec-image{
		position: relative;
		width: 98%;
		margin-left: auto;
		top: auto;
    	right: auto;
	}
	
	#work-sec .sec-image img{
		padding-top: 45.76%;
		background-image: url(../img/top_work_photo_smp.png);
	}
	#work-sec .r-box{
		width: 94%;
		margin: 0 auto;
		padding-top: 6.9vw;
	}
	#work-sec .r-box .toptxt-box{
		margin-bottom: 7.15vw;
		background-color: var(--main-skyblue);
	}
	#work-sec .r-box .toptxt-box p{
		font-size: 1.5rem;
		line-height: 1.8;
	}
	#work-sec .sec-image{
		position: relative;
		width: 98%;
		margin-right: auto;
		top: auto;
    	left: auto;
	}
	#work-sec .card-image{
		width: 94%;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 30px;
	}
	#work-sec .btn-common{
		width: 100%;
		max-width: 400px;
		margin:0 auto;
	}
}

/* -----------------------------------------------------------
   MESSAGE
------------------------------------------------------------*/
#msg-sec {
	background-color: #FFF;
	padding: 64px 0;
}
#msg-sec .inner{
	position: relative;
	padding: 0 0 120px;
}
#msg-sec .inner .msg-container{
	width: 100%;
	position: relative;
}
#msg-sec .inner .msg-container .ttl-box{
	width: min(45%,528px);
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
	z-index: 2;
}
#msg-sec .inner .msg-container .ttl-box h2{
	width: 100%;
	height: 0;
	padding-top: calc(24.05% * 1);
	background: url(../img/top_h_msg.png);
	background-size: cover;
	margin-bottom: 12px;
}
#msg-sec .inner .msg-container .ttl-box .sign-image{
	width: 46.4%;
	height: 0;
	padding-top: calc(34.62% * 0.464);
	background: url(../img/msg_sign.png);
	background-size: cover;
	margin-left: auto;
}
#msg-sec .inner .msg-container .sec-image{
	width: 70%;
	opacity: 0;
}
#msg-sec .inner .msg-container .sec-image.is-active {
	animation: slideIn_left 1s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}
#msg-sec .inner .msg-container .sec-image img{
	width: 100%;
	height: 0;
	padding-top: 48%;
	background: url(../img/top_msg_photo.jpg);
	background-size: cover;
}
#msg-sec .inner .txt-box{
	width: 80%;
	margin-left: auto;
	background-color: var(--main-skyblue);
	padding: 50px;
	opacity: 0;
}
#msg-sec .inner .txt-box.is-active {
	animation: slideIn_right 1s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}
#msg-sec .inner .txt-box p{
	font-size: 1.6rem;
	line-height: 2.0;
	margin-bottom: 1.0em;
}
#msg-sec .inner .txt-box p.en{
	font-weight: 700;
}

@media all and (max-width: 767px) {
	#msg-sec {
		padding: 7vw 0;
	}
	#msg-sec .inner{
		padding: 0 0 19vw;
	}
	#msg-sec .inner .msg-container .ttl-box{
		width: 66%;
		margin: 0 auto;
		position: relative;
		top: auto;
		right: auto;
		transform:none;
		-webkit-transform: none;
		-ms-transform: none;
	}
	#msg-sec .inner .msg-container .ttl-box .sign-image{
		display: none;
	}
	#msg-sec .inner .msg-container .sec-image{
		width: 100%;
		margin-bottom: 6.1vw;
	}
	#msg-sec .inner .msg-container .sec-image img{
		padding-top: 66.92%;
		background: url(../img/top_msg_photo_smp.png);
		background-size: cover;
	}
	#msg-sec .inner .txt-box{
		width: 96%;
		margin-left: auto;
		margin-right: auto;
		padding: 8% 5%;
		box-sizing: border-box;
	}
	#msg-sec .inner .txt-box p{
		font-size: 1.5rem;
		line-height: 1.8;
	}
}