@charset "UTF-8";

html {
  font-size: 100%;
}
body {
  color: #333;
  font-family: 'Source Sans Pro', sans-serif;
  font-weight: 300;
}
a {
  color: #003067;
  text-decoration: none;
}
img {
  max-width: 100%;
  vertical-align: bottom;
}
li {
  list-style: none;
}

/* h1タグ用 */
.site-title {
  font-size: 3.25rem;
  font-weight: 300;
  letter-spacing: 0.03em;
  margin: 100px 0;
}
/* h2タグ用 */
.section-title {
  border-bottom: solid 1px #fff;
  /* 下線をテキストと同じ幅にあわせるために設定 */
  display: inline-block;
  font-size: 3.75rem;
  font-weight: 300;
  letter-spacing: 0.03em;
  margin-bottom: 30px;
  margin-top: 45px;
}

/* MainとFooter全体を囲むクラス */
.container {
  color: #003067;
  text-align: center;
}
.container {
  font-family: "M PLUS 1", sans-serif;
  font-optical-sizing: auto;
  font-weight: 800;
  font-style: normal;
}


.fadein {
  opacity: 0;
  transform: translate(0, 50%);
  transition: 2s;
}

.fadein.show {
  transform: translate(0, 0);
  opacity: 1;
}
h2{
	color: #ff8080;
}

/*-------------------------------------------
ヘッダー
-------------------------------------------*/

#header h1 {
	width: 182px;
	margin-right: auto;
	z-index: 10000;
  margin-left: 30px;
}

.hamburger {
  width: 42px;
  height: 42px;
  cursor: pointer;
  position: fixed;
  top: 20px;
  right: 25px;
  z-index: 40;
}
.hamburger span {
  width: 30px;
  height: 1px;
  background-color: #333;
  position: absolute;
  left: 6px;
  transition: 0.5s ease-in-out;
}
.hamburger span:nth-child(1) {
  top: 11px;
}
.hamburger span:nth-child(2) {
  top: 21px;
}
.hamburger span:nth-child(3) {
  top: 31px;
}
.hamburger.active span:nth-child(1) {
  top: 21px;
  left: 6px;
  transform: rotate(-45deg);
}
.hamburger.active span:nth-child(2),
.hamburger.active span:nth-child(3) {
  top: 21px;
  transform: rotate(45deg);
}
#navi {
  width: 100%;

  position: fixed;
  top: 0;
  left: 0;
  text-align: center;
  transform: translateY(-100%);
  transition: 0.6s;
  z-index: 30;
}
#navi ul {
  width: 100%;
  background: url(../img/bg3.jpg);
  background-size: cover;
  padding: 80px 0 30px 0;
}
#navi ul li {
  padding: 10px 0;
}
#navi ul li a {
  display: block;
}
#navi.active {
  transform: translateY(0%);
}

/*-------------------------------------------
Mainvisual
-------------------------------------------*/
#mainvisual {
  display: flex;
  justify-content: center;
  /* スクロールで画像を拡大させた際に、横スクロールが出ないよう設定 */
  overflow-x: hidden;
  position: relative;
  z-index: 20;

}
/*
スクロールしたタイミングでjQueryにて画像を拡大するが、
その際に画像が縮まないよう「flex-shrink: 0;」を設定する
*/
#mainvisual img {
  width: calc(100%/3);
  height: 100vh;
  flex-shrink: 0;
  object-fit: cover;
}

/*-------------------------------------------
Contact
-------------------------------------------*/
/*
「z-index: 20;」でコンテンツが背景画像の上にくるようにする
*/
#contact {
  margin-bottom: 100px;
  position: relative;
  z-index: 20;
}

.address{
	padding-bottom: 30px;
}
/*-------------------------------------------
SP
-------------------------------------------*/
@media screen and (max-width: 900px) {
  .site-title {
    font-size: 2rem;
    margin: 50px 0;
  }
  .section-title {
    font-size: 2rem;
  }



  /*-------------------------------------------
  Footer
  -------------------------------------------*/
  #footer {
    flex-direction: column;
    align-items: flex-start;
    padding: 60px 30px;
  }
  #footer .sns {
    margin-bottom: 30px;
  }
}


/* ==========================================================================
  footer
========================================================================== */
#footer {
  position: relative;
  padding: 100px 0 0 0px;
  background: #fff;
}

#footer::before {
  content: "";
  display: block;
  width: 100%;
  height: 115px;
  position: absolute;
  left: 0;
  top: -115px;
  z-index: 1;
  background: -moz-linear-gradient(bottom, #FFf, transparent);
  background: -webkit-linear-gradient(bottom, #FFf, transparent);
  background: linear-gradient(to top, #Fff, transparent);
}

.footer_inr {
  position: relative;
  width: 90%;
  max-width: 1075px;
  margin: 0 auto 30px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: flex-start;
}

#footer .logo_area {
  position: absolute;
  width: 350px;
  top: -15px;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 10;
  text-align: center;
}

#footer h2 a {
  display: block;
  width: 220px;
  margin: 20px auto 40px;
}

#footer .logo_area p {
  font-size: 14px;
  line-height: 27px;
  font-weight: 700;
  letter-spacing: 0.06em;
}

#footer .kumo {
  display: block;
  width: 103px;
  position: absolute;
  left: -28px;
  top: -5px;
  z-index: 10;

  animation: kumo 4s infinite ease-in-out;
}

@keyframes kumo {
  50% {
    transform: translate(5px, -5px);
  }
}

#footer .kumo02 {
  display: block;
  width: 96px;
  position: absolute;
  right: -33px;
  top: 220px;
  z-index: 10;
  animation: kumo02 5s infinite ease-in-out;
}

@keyframes kumo02 {
  50% {
    transform: translate(-5px, -5px);
  }
}

#footer .sns_area {
  position: relative;
  width: 280px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  padding-top: 75px;
}

.ie #footer .sns_area {
  position: absolute;
  left: 0;
}

#footer .sns_area::before {
  content: "";
  display: block;
  width: 164px;
  height: 108px;
  position: absolute;
  top: -19px;
  right: 63px;
  z-index: 20;
  background: url(../img/tori.png);
  background-size: cover;
}

#footer .sns_area a {
  display: block;
  width: calc(50% - 5px);
  padding: 40px 0 39px;
  text-align: center;
  color: #333;
  background: #f5f1ee;
  border-radius: 40px;
  box-shadow: 3px 3px 0px 0px rgba(0, 0, 0, 0.2);
  margin-bottom: 10px;
}

#footer .sns_area a:hover {
  background: #E3DEC5;
  transform: translate(3px, 3px);
  box-shadow: none;
}

#footer .sns_area img {
  width: 34px;
  margin-bottom: 14px;
}

#footer .sns_area a.line img {
  width: 39px;
  margin-bottom: 10px;
}

#footer .sns_area p {
  font-size: 11px;
  font-weight: 700;
  color: #333;
}

#footer .link_area {
  width: 275px;
  text-align: left;
}

#footer li a {
  position: relative;
  display: block;
  padding: 15px 15px 15px 40px;
  box-sizing: border-box;
  border-bottom: 1px solid #d4d4d4;
  font-size: 16px;
  color: #333;
}

#footer li a:before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 3.5px 0 3.5px 5px;
  border-color: transparent transparent transparent #ff8080;
  position: absolute;
  left: 20px;
  top: 0;
  bottom: 0;
  margin: auto;
  transition: all 0.4s ease;
}

#footer li:last-child a:last-child {
  font-size: 14px;
  color: #686868;
  padding-top: 25px;
  border-bottom: none;
}

#footer li a:hover {
  color: #FF8080;
}

#footer li:last-child a:last-child:before {
  bottom: auto;
  top: 28px;
  border-color: transparent transparent transparent #B1A076;
}

#footer li:last-child a:hover:last-child:hover {
  color: #FF8080;
}

#footer li:last-child a:hover:last-child:before {
  border-color: transparent transparent transparent #B1A076;
}


@media screen and (max-width: 1350px) {
  #footer {
    position: relative;
    padding: 100px 0 0px;
    background: #fff;
  }

  #footer::before {
    content: "";
    display: block;
    width: 100%;
    height: 115px;
    position: absolute;
    left: 0;
    top: -115px;
    z-index: 1;
    background: -moz-linear-gradient(bottom, #FFf, transparent);
    background: -webkit-linear-gradient(bottom, #FFf, transparent);
    background: linear-gradient(to top, #Fff, transparent);
  }

  .footer_inr {
    position: relative;
    width: 90%;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }

  #footer h2 a {
    width: 203px;
    margin: 0 auto 34px;
  }

  #footer .kumo02 {
    top: 200px;
  }
}

@media screen and (max-width: 1100px) {
  #footer .sns_area {
    width: 27vw;
  }

  #footer .link_area {
    width: 23vw;
  }
}

@media screen and (max-width: 890px) {
  #footer .logo_area {
    position: relative;
    width: 350px;
    top: -15px;
    margin: 0 auto;
    margin-left: calc(50% - 175px);
  }

  #footer .sns_area {
    width: 48%;
    margin-top: 30px;
  }

  #footer .link_area {
    width: 48%;
    margin-top: 100px;
  }
}

@media screen and (max-width: 800px) {
  #header h1 {
		width: 148px;
		left: 20px;
		/* top: 12px; */
	}

  #footer {
    padding: 80px 0 0px;
  }

 

  #footer::before {
    height: 70px;
    top: -70px;
  }

  .footer_inr {
    width: 100%;
    margin-bottom: 40px;
  }

  #footer h2 a {
    display: block;
    width: 160px;
    margin: 0 auto 27px;
  }

  #footer .logo_area {
    width: 100%;
    max-width: 350px;
    margin: 0 auto;
  }

  #footer .logo_area p {
    font-size: 12px;
    line-height: 24px;
  }

  #footer .kumo {
    display: block;
    width: 76px;
    left: 0;
    top: 26px;
  }

  #footer .kumo02 {
    width: 81px;
    right: 0;
   
  }

  #footer .sns_area {
    width: 87%;
    padding-top: 80px;
    margin: 30px auto 38px;
  }

  ie #footer .sns_area {
    position: relative;
    left: auto;
  }

  #footer .sns_area::before {
    width: 151px;
    height: 100px;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
  }

  #footer .sns_area a {
    width: calc(50% - 3px);
    padding: 25px 0 22px;
    border-radius: 20px;
    box-shadow: 2px 2px 0px 0px rgba(0, 0, 0, 0.2);
    margin-bottom: 7px;
  }

  #footer .sns_area a:hover {
    transform: translate(2px, 2px);
  }

  #footer .sns_area img {
    width: 31px;
    margin-bottom: 12px;
  }



  #footer .link_area {
    width: 87%;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 0 auto;
  }

  #footer li {
    width: 48%;
  }

  #footer li a {
    padding: 15px 0 15px 26px;
    font-size: 12px;
  }

  #footer li a:before {
    border-width: 3px 0 3px 5px;
    left: 8px;
  }

  #footer li:last-child a:last-child {
    font-size: 12px;
    color: #333;
    padding-top: 15px;
    border-bottom: 1px solid #d4d4d4;
  }

  #footer li:last-child a:last-child:before {
    top: 0;
    bottom: 0;
    border-color: transparent transparent transparent #ff8080;
  }

}
.siba {
    margin-right: calc(50% - 50vw);
    margin-left: calc(50% - 50vw);
  }
  
  .siba img {
    display: block;
    width: 100%;
    height: auto;
  }
  
/* ==========================================================================
	step_area
========================================================================== */
.step_area {
	position: relative;
	width: 100%;
	box-sizing: border-box;
	margin: 6.4vw 0 30px;
  background-color: #78ccf0;
  padding: 8.1vw;
}
.step {
	position: relative;
	background: #fff;
	padding: 60px 0 0px;
	border-radius: 30px;
	min-height: 800px;
	box-sizing: border-box;
}
.step h4 {
	font-size: 28px;
	line-height: 35px;
	font-weight: 700;
	width: 85%;
	max-width: 320px;
	margin: 0 auto;
}
.step p {
	width: 85%;
	max-width: 320px;
	margin: 0 auto;
	font-size: 14px;
	line-height: 28px;
	font-weight: 700;
  display: flex;
  padding: 5px 12px 5px 20px;
}
.step h5 {
	display: flex;
	align-items: center;
	width: 87%;
	max-width: 340px;
	height: 38px;
	font-size: 14px;
	font-weight: 700;
	border-radius: 19px;
	background: #ded8c0;
	margin: 25px auto 0;
	padding-left: 30px;
	box-sizing: border-box;
}
.step .list_txt {
	position: relative;
	width: 85%;
	max-width: 320px;
	margin: 2px auto 0;
	padding: 5px 12px 5px 20px;
	box-sizing: border-box;
	border-bottom: 1px solid #b9b9b9;
	font-size: 14px;
	font-weight: 700;
  display: flex;
}
.step .list_txt::before {
	content: "";
	display: block;
	width: 7px;
	height: 7px;
	background: #fd7e85;
	border-radius: 7px;
	position: absolute;
	left: 6px;
	top: 15px;
}
.step .list_txt span {
	font-size: 12px;
	font-weight: 700;
}
/* ==========================================================================
	map_area
========================================================================== */
.outline .map_area {
	position: relative;
	height: 430px;
	overflow: hidden;
	width: 100%;
	border-radius: 45px 45px 45px 45px;
	box-shadow: 0px 3px 0px 0px rgba(0, 0, 0, 0.2);
  margin: 6.4vw 0 30px;
  position: relative;
	width: 80%;
	margin: 2px auto 0;  
}

.outline .map_area iframe,
.outline .map_area object,
.outline .map_area embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border-radius: 0 0 45px 45px;
	top: -150px;
	height: calc(100% + 150px + 150px);
}
.map_area h2{
	font-size: 28px;
	line-height: 35px;
	font-weight: 700;
	width: 85%;
	max-width: 320px;
	margin: 0 auto;
}

@media screen and (max-width: 800px) {

	.step_area {
		padding: 8.1vw;
		box-sizing: border-box;
		margin: 40px 0 20px;
	}


	.step {
		position: relative;
		background: #fff;
		padding: 73px 0 0px;
		border-radius: 15px;
		
	}


	.step h4,
  .map_area h2 {
		font-size: 20px;
		line-height: 25px;
		width: 85%;
		max-width: 600px;
	}


	.step p {
		width: 85%;
		max-width: 600px;
		font-size: 13px;
		line-height: 26px;
	}

	.step h5 {
		width: 87%;
		max-width: 600px;
		height: 28px;
		font-size: 12px;
		margin: 25px auto 0;
		padding-left: 30px;
	}

	.step .list_txt {
		max-width: 600px;
		font-size: 13px;
    
	}

	.step .list_txt span {
		font-size: 11px;
	}

	.step .bottom_txt {
		max-width: 600px;
		color: #ff8080;
		font-size: 11px;
		line-height: 20px;
		margin: 15px auto 0;
	}

  .outline {
		margin: 0 auto 125px;
	}


	.outline .map_area {
		border-radius: 30px 30px 30px 30px;
		box-shadow: 0px 2px 0px 0px rgba(0, 0, 0, 0.2);
	}

	.outline .map_area iframe,
	.outline .map_area object,
	.outline .map_area embed {
		border-radius: 0 0 30px 30px;
	}

	.outline a {
		width: 130px;
		height: 25px;
		font-size: 11px;
		padding-right: 13px;
		border-radius: 25px;
	}

	.outline a:before {
		right: 20px;
		top: 8px;
	}

}
/* ==========================================================================
	yoshimoto
========================================================================== */
.yoshimoto {
	position: relative;
	width: 90%;
	max-width: 1215px;
	margin: 0 auto 230px;
	padding-top: 153px;
}

.yoshimoto ul {
	-js-display: flex;
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin: 30px auto 0;
}

.yoshimoto li {
	position: relative;
	width: 32.5%;
	background: rgb(245, 252, 254);
	padding: 65px 15px 104px;
	box-sizing: border-box;
	border-radius: 45px;
	box-shadow: 0px 3px 0px 0px rgba(0, 0, 0, 0.2);
}


.yoshimoto .img_area {
	position: relative;
	width: 100%;
	max-width: 222px;
	margin: 0 auto;
	text-align: center;
	padding-bottom: 70px;
}
.yoshimoto .img_area .img01,
.yoshimoto .img_area .img02,
.yoshimoto .img_area .img03,
.yoshimoto .img_area .img04 {
	width: 100%;
	max-width: 222px;
	transform: translateY(50px);
	border-radius: 50%;
	box-shadow: 0px 3px 0px 0px rgba(0, 0, 0, 0.2);
}

.yoshimoto .move .img_area .img01,
.yoshimoto .move .img_area .img02,
.yoshimoto .move .img_area .img03,
.yoshimoto .move .img_area .img04 {
	-webkit-animation: sakana03 3s ease-in-out;
	-ms-animation: sakana03 3s ease-in-out;
	-o-animation: sakana03 3s ease-in-out;
	animation: sakana03 3s ease-in-out;
	animation-fill-mode: forwards;
}

.yoshimoto .post {
	display: block;
	text-align: center;
	font-size: 14px;
	font-weight: 700;
	color: #ff8580;
	margin: 34px auto 19px;
}

.yoshimoto li:nth-child(2) .post {
	color: #69a85e;
}

.yoshimoto li:nth-child(3) .post {
	color: #c1b000;
}

.yoshimoto h3 {
	font-size: 36px;
	font-weight: 700;
	text-align: center;
}

.yoshimoto .en {
	display: block;
	font-size: 12px;
	font-weight: 700;
	text-align: center;
	color: #ab9e8b;
	margin: 25px auto 35px;
}

.yoshimoto p {
	font-size: 16px;
	line-height: 34px;
	font-weight: 700;
	margin: 0 auto;
	max-width: 265px;
}
#contact .btn a,
.outline .btn a,
.yoshimoto .btn a{
	color: #000;
	font-size: 16px;
	line-height: 34px;
	font-weight: 700;
	text-align: center;
	width: 100%;
	height: 40px;
	margin:20px auto 0;
	max-width:265px;
	background-color: #e4dec6;
	box-shadow: 3px 3px 0px 0px rgba(0, 0, 0, 0.2);
	border-radius: 20px;
	display: flex;
	justify-content: center;
	align-items: center;
}
#contact .btn a:hover,
.outline .btn a:hover,
.yoshimoto .btn a:hover{
	color: #fff;
	background: #ff8080;
	transform: translate(3px, 3px);
	box-shadow: none;
}

@media screen and (max-width: 800px) {

	.yoshimoto {
		width: 88%;
		margin: 0 auto 78px;
		padding-top: 150px
	}

	.yoshimoto .s_tit {
		padding-left: 0;
		text-align: center;
	}

	.yoshimoto ul {
		margin: 38px auto 0;
	}

	.yoshimoto li {
		width: 100%;
		padding: 58px 0 80px;
		border-radius: 30px;
		box-shadow: 0px 2px 0px 0px rgba(0, 0, 0, 0.2);
	}

	.yoshimoto li:nth-child(2) {
		margin: 65px auto;
	}

	.yoshimoto li:first-child,
	.yoshimoto li:last-child {
		transform: translateY(0px)
	}

	.yoshimoto li .fukidashi {
		top: -20px;
		width: 72%;
	}

	.yoshimoto .img_area {
		position: relative;
		width: 100%;
		max-width: 222px;
		margin: 0 auto;
		text-align: center;
		padding-bottom: 65px;
	}

	.yoshimoto .post {
		font-size: 13px;
		margin: 25px auto 12px;
	}

	.yoshimoto h3 {
		font-size: 27px;
	}

	.yoshimoto .en {
		font-size: 10px;
		margin: 15px auto 27px;
	}

	.yoshimoto p {
		width: 80%;
		margin: 0 auto;
		font-size: 13px;
		line-height: 25px;
		max-width: 800px;
	}

  #contact .btn a,
  .outline .btn a,
	.yoshimoto .btn a {
		font-size: 13px;
		max-width: 800px;
	}

  #contact .btn a,
  .outline .btn a{
		width: 87%;
		max-width: 600px;
		height: 28px;
		font-size: 12px;
		margin: 25px auto 0;
		padding-left: 30px;
	}
}
/* ==========================================================================
	intro
========================================================================== */
.intro {
	position: relative;
	width: 93%;
	max-width: 1300px;
	margin: 40px auto 110px;
	background: #fff;
	border-radius: 45px;
	padding: 125px 0 120px;
	box-shadow: 0px 3px 0px 0px rgba(0, 0, 0, 0.2);
}

.intro h2 {
	position: relative;
	width: 489px;
	margin: 0 0 0 132px;
}

.intro .img_area {
	position: absolute;
	width: 528px;
	right: 78px;
	top: 85px;
}

.intro .img_area03 {
	position: absolute;
	width: 528px;
	right: 78px;
  top: 700px;
}

.intro .boy01 {
	position: absolute;
	width: 7vw;
	right: 20px;
	bottom: 0;
	-webkit-animation: build03 4s infinite ease-in-out;
	-ms-animation: build03 4s infinite ease-in-out;
	-o-animation: build03 4s infinite ease-in-out;
	animation: build03 4s infinite ease-in-out;
}

@keyframes build03 {
	50% {
		transform: translate(10px, 0);
	}
}

@-ms-keyframes build03 {
	50% {
		transform: translate(10px, 0);
	}
}

.intro p {
	font-size: 16px;
	line-height: 37px;
	font-weight: 700;
}


.intro p.text01 {
	margin: 150px 0 15px 56%;
}

.intro p.text02 {
  margin: 250px 50% 20px 0;
}

.intro .img_area02 {
	position: absolute;
	top: 320px;
	left: 117px;
	width: 518px;
}
.intro .img_area04 {
	position: absolute;
	left: 117px;
	width: 518px;
  top: 950px;
}
.intro .girl {
	width: 5vw;
	position: absolute;
	bottom: 22px;
	left: 0;
	-webkit-animation: build01 4s infinite ease-in-out;
	-ms-animation: build01 4s infinite ease-in-out;
	-o-animation: build01 4s infinite ease-in-out;
	animation: build01 4s infinite ease-in-out;
}

@keyframes build01 {
	50% {
		transform: translate(10px, 10px);
	}
}

@-ms-keyframes build01 {
	50% {
		transform: translate(10px, 10px);
	}
}

.intro .sakana {
	width: 63px;
	position: absolute;
	top: 139px;
	right: 198px;
	-moz-animation: swing3 linear 6s infinite;
	-moz-transform-origin: center 25px 0;
	-webkit-animation: swing3 linear 6s infinite;
	-webkit-transform-origin: 50% 100%;
	-ms-animation: swing3 linear 6s infinite;
	-ms-transform-origin: 50% 100%;
	-o-animation: swing3 linear 6s infinite;
	-o-transform-origin: 50% 100%;
	animation: swing3 linear 6s infinite;
	transform-origin: 50% 100%;
}

@-moz-keyframes swing3 {
	50% {
		-moz-transform: rotate(-15deg);
	}

	100% {
		-moz-transform: rotate(0deg);
	}
}

@-webkit-keyframes swing3 {
	50% {
		-webkit-transform: rotate(-15deg);
	}

	100% {
		-webkit-transform: rotate(0deg);
	}
}

@-o-keyframes swing3 {
	50% {
		-o-transform: rotate(-15deg);
	}

	100% {
		-o-transform: rotate(0deg);
	}
}

@-ms-keyframes swing3 {
	50% {
		-ms-transform: rotate(-15deg);
	}

	100% {
		-ms-transform: rotate(0deg);
	}
}

@keyframes swing3 {
	50% {
		transform: rotate(-15deg);
	}

	100% {
		transform: rotate(0deg);
	}
}

@media screen and (max-width: 1350px) {
	.intro h2 {
		width: 45%;
		margin: 0 0 0 5vw;
	}

	.intro .img_area {
		position: absolute;
		width: 38vw;
		right: 5.5vw;
		top: 85px;
	}

  .intro .img_area03 {
		position: absolute;
		width: 30vh;
	
		right: 5.5vw;
    top: 700px;
	}
	.intro .boy01 {
		width: 10vw;
		right: 1.4vw;
	}

	.intro p {
		font-size: 16px;
		line-height: 37px;
		font-weight: 700;
	}

	.intro p.text01 {
		margin: 10.7vw 0 15px 56%;
	}
	


	.intro .img_area02 {
		position: absolute;
		top: 320px;
		left: 5vw;
		width: 39vw;
	}

  .intro .img_area04 {
		position: absolute;
		left: 5vw;
		
    top: 950px;
	}

	.intro .girl {
		width: 8vw;
		bottom: 1.5vw;
	}

	.intro .sakana {
		width: 4.5vw;
		top: 9.9vw;
		right: 14.14vw;
	}

}


@media screen and (max-width: 800px) {
	.intro {
		margin: 35px auto 55px;
		border-radius: 30px;
		padding: 65px 0 95px;
		box-shadow: 0px 2px 0px 0px rgba(0, 0, 0, 0.2);
	}

	.intro h2 {
		width: 74%;
		margin: 0 auto;
	}

	.intro .img_area {
		position: relative;
		width: 74%;
		right: auto;
		top: auto;
		margin: 50px auto 57px;
	}

	.intro .boy01 {
		width: 20vw;
		right: 9px;
		bottom: 0;
		-webkit-animation: build03 4s infinite ease-in-out;
		-ms-animation: build03 4s infinite ease-in-out;
		-o-animation: build03 4s infinite ease-in-out;
		animation: build03 4s infinite ease-in-out;
	}

	@keyframes build03 {
		50% {
			transform: translate(5px, 0);
		}
	}

	@-ms-keyframes build03 {
		50% {
			transform: translate(5px, 0);
		}
	}

	.intro p {
		font-size: 14px;
		line-height: 30px;
	}

	.intro p.text01,
	.intro p.text02 {
		margin: 0 auto;
		width: 80%;
	}

	.intro .img_area02,
  .intro .img_area03,
  .intro .img_area04 {
		position: relative;
		top: auto;
		left: auto;
		width: 74%;
		margin: 60px auto;
	}

	.intro .girl {
		width: 15vw;
		bottom: 10px;
	}

	@keyframes build01 {
		50% {
			transform: translate(5px, 5px);
		}
	}

	@-ms-keyframes build01 {
		50% {
			transform: translate(5px, 5px);
		}
	}

	.intro .sakana {
		width: 8vw;
		top: 18vw;
		right: 27.25vw;
	}
	@keyframes build02 {
		50% {
			transform: translate(5px, -5px);
		}
	}

	@-ms-keyframes build02 {
		50% {
			transform: translate(5px, -5px);
		}
	}
}

.identity{
    font-size: 4rem;
}
    
.identity a{
    display: inline-block;
}

@media screen and (max-width: 920px){
.top .identity{
    display: none;
}
}
@media screen and (max-width: 920px){
 .identity{
     top:15px;
     left:20px;
    font-size: 1.1rem;
}
}
.none{
	visibility:hidden;

}