@charset "utf-8";
#header {
  transition-delay: 2.5s;
}
/* ---------------------------------------------------------------------------------------------

　   MV

--------------------------------------------------------------------------------------------- */
#mv {
	height: 100vh;
	width: 100%;
	background: rgb(254,255,255);
	background: -moz-linear-gradient(left,  rgba(254,255,255,1) 0%, rgba(255,252,252,1) 100%);
	background: -webkit-linear-gradient(left,  rgba(254,255,255,1) 0%,rgba(255,252,252,1) 100%);
	background: linear-gradient(to right,  rgba(254,255,255,1) 0%,rgba(255,252,252,1) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#feffff', endColorstr='#fffcfc',GradientType=1 );
	position: relative;
}
#mv_logo_wrap {
	position: absolute;
   top: 50%;
   left: 50%;
   -webkit-transform: translate(-50%, -50%);
   transform: translate(-50%, -50%);
	mix-blend-mode: multiply;
}
#mv_logo_wrap:after {
	content: "";
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: -moz-linear-gradient(left,  rgba(255,255,255,.8) 0%, rgba(255,255,255,0) 100%);
	background: -webkit-linear-gradient(left,  rgba(255,255,255,.8) 0%,rgba(255,255,255,0) 100%);
	background: linear-gradient(to right,  rgba(255,255,255,.8) 0%,rgba(255,255,255,0) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#00ffffff',GradientType=0.8 );
	transform:rotate(180deg);
}
#mv_logo path {
	fill: #ffb2ab;
	stroke: #ffb2ab;
	stroke-width: 0.25px;
	animation: svg 5s ease-in both;
}
@keyframes svg {
	0% {
	  fill: transparent;
	  stroke-dasharray: 100px;
	  stroke-dashoffset: 100px;
	}
	20%{
	  stroke-dashoffset: 0;
	}
	30%{
	  fill: transparent;
	}
	50%{
	  fill: #ffb2ab;
	}
}
#mv h1 {
	text-align: center;
	position: relative;
	z-index: 5;
}
#mv h1 span {
	display: block;
	text-align: center;
}
#mv h1 span.en {
  transition-delay: 1s;
}
#mv h1 span.jp {
  transition-delay: 1.5s;
}
#mv_scroll {
	position: absolute;
   left: 50%;
   -webkit-transform: translate(-50%, 0%);
   transform: translate(-50%, 0%);
}
#mv_scroll a {
	display: block;
  	transition-delay: 2s;
}
#mv_scroll a,
#mv_scroll p {
	text-align: center;
}
#mv_scroll p {
	margin-top: 10px;
	font-size: 15px;
}
#mv_scroll img {
	width: 28px;
	display: block;
	margin: 0 auto;
	-webkit-animation: sdb 2s infinite;
	animation: sdb 2s infinite;
}
@-webkit-keyframes sdb {
  0% {
    -webkit-transform: translate(0, 0);
  }
  20% {
    -webkit-transform: translate(0, 10px);
  }
  40% {
    -webkit-transform: translate(0, 0);
  }
}
@keyframes sdb {
  0% {
    transform: translate(0, 0);
  }
  20% {
    transform: translate(0, 10px);
  }
  40% {
    transform: translate(0, 0);
  }
}

@media only screen and ( max-width : 991px ) {

}

@media only screen and ( max-width : 767px ) {
	#mv {
		min-height: 500px;
	}
	#mv h1 {
		font-size: 46px;
		padding: 0 15px;
	}
	#mv h1 span.en {
		line-height: 1.2em;
	}
	#mv h1 span.jp {
		font-size: 13px;
		margin-top: 20px;
		line-height: 1.8em;
	}
	#mv_scroll {
		bottom: 20px;
	}
	#mv_logo_wrap {
		width: 300px;
	}

}

@media print, screen and ( min-width : 768px ) {
	#mv {
		min-height: 800px;
	}
	#mv h1 {
		font-size: 75px;
	}
	#mv h1 span.jp {
		font-size: 17px;
	}
	#mv_scroll {
		bottom: 50px;
	}
	#mv_logo_wrap {
		width: 470px;
	}
}

/* ---------------------------------------------------------------------------------------------

　   MISSION

--------------------------------------------------------------------------------------------- */
.mission_pic {
	text-align: center;
}
.top_mission{
        margin-top: 50px;
}

@media only screen and ( max-width : 1199px ) {
	.mission_txt {
		margin-bottom: 40px;
	}
	.mission_pic img {
		max-width: 400px;
	}
}
@media only screen and ( max-width : 991px ) {

}

@media only screen and ( max-width : 767px ) {
	.mission_pic img {
		max-width: 100%;
	}

}

@media print, screen and ( min-width : 1200px ) {

}

/* ---------------------------------------------------------------------------------------------

　   BUSINESS

--------------------------------------------------------------------------------------------- */
.business_pic {
	text-align: center;
}
@media only screen and ( max-width : 1199px ) {
	.business_pic {
		margin-bottom: 40px;
	}
	.business_pic img {
		max-width: 400px;
	}
}

@media only screen and ( max-width : 767px ) {
	.business_pic img {
		max-width: 100%;
	}
	#medical_examination .business_pic img {
		max-width: 80%;
	}
}

@media print, screen and ( min-width : 1200px ) {
	#medical_examination .business_pic img {
		max-width: 80%;
	}

}

/* ---------------------------------------------------------------------------------------------

　   company

--------------------------------------------------------------------------------------------- */
#company {
	background: #fcfcfc;
}
#company .container {
	position: relative;
}
#company .container:before {
	content: "";
	position: absolute;
	background: url(../img/top/leaf.png) no-repeat center / 100%;
}
.dl_list dt {
	font-weight: bold;
}
#company iframe {
	width: 100%;
	display: block;
	height: 300px;
}
@media only screen and ( max-width : 991px ) {

}

@media only screen and ( max-width : 767px ) {
	.dl_list dt:first-of-type {
		border-top: 1px solid #ddd;
	}
	.dl_list dt {
		padding-top: 20px;
		margin-bottom: 5px;
	}
	.dl_list dd {
		border-bottom: 1px solid #ddd;
		padding-bottom: 20px;
	}
}

@media print, screen and ( min-width : 768px ) {
	#company .container:before {
		width: 100px;
		height: 100px;
		top: -140px;
		right: 0;
	}
	.dl_list {
		width: 550px;
		margin: 0 auto;
	}
	.dl_list dt,.dl_list dd {
		padding: 25px 0;
		border-bottom: 1px solid #ddd;
	}
	.dl_list dt {
		width: 10em;
		padding-right: 1em;
	}
	.dl_list dd {
		width: calc(100% - 10em);
	}
}

/* ---------------------------------------------------------------------------------------------

　   XXX

--------------------------------------------------------------------------------------------- */


@media only screen and ( max-width : 1199px ) {
	#news .side_tit .btn,#topics .side_tit .btn {
		display: none;
	}
	#news .sp_btn,#topics .sp_btn {
		width: 100%;
	}
}

@media only screen and ( max-width : 767px ) {

}

@media print, screen and ( min-width : 992px ) {
	#news .sp_btn,#topics .sp_btn {
		display: none;
	}
}
