@charset "UTF-8";

/* ++++++++++++++++++++++++++++++++++++++++
TOP page
++++++++++++++++++++++++++++++++++++++++ */

/* main visual */
#mainVis { position: relative; }
#mainVis::after {
	content: "";
	display: block;
	position: absolute;
	background: no-repeat center center;
	background-size: cover;
	pointer-events: none;
	margin: 0 auto;
}
#mainVisText {
	top: 0;
	left: 0;
	height: 100%;
	position: absolute;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	z-index: 10;
}
#mainVisText .text { font-weight: bold; }
#mainVisBg > li {
	top: 0;
	left: 0;
	width: 100%;
	height: 0;
	overflow: hidden;
	position: absolute;
	z-index: 0;
	background-size: cover;
	background-repeat: no-repeat;
	transition-duration: 0.3s;
	transition-property: opacity;
}
@keyframes mainVisBg  {
	0% { opacity: 1; }
	31% { opacity: 1; }
	36% { opacity: 0; }
	97% { opacity: 0; }
	100% { opacity: 1; }
}
/*#mainVisBg #mainVisBg01 { z-index: 3; animation: mainVisBg 9s linear 0s infinite normal forwards; }*/
/*#mainVisBg #mainVisBg02 { z-index: 2; animation: mainVisBg 9s linear -3s infinite normal forwards; }*/
/*#mainVisBg #mainVisBg03 { z-index: 1; animation: mainVisBg 9s linear -6s infinite normal forwards; }*/
#enrollBox {
	z-index: 10;
	background: #ff79a8;
}
#enrollBox::before {
	content: "";
	border-radius: 50%;
	position: absolute;
	background: url(../images/top/enroll_box_img.jpg) no-repeat center center;
	background-size: cover;
}
#enrollBox .title,
#enrollBox .cLinks { position: relative; }
#enrollBox .tag {
	font-weight: bold;
	position: absolute;
	border-radius: 999px;
	background: #ffde00;
}
#enrollBox .cLinks a {
	display: block;
	font-weight: bold;
	border-radius: 999px;
}
#enrollBox .cLinks a::before {
	content: "";
	display: inline-block;
	background: no-repeat center center;
	background-size: cover;
}
#enrollBox .cLinks .line a::before { background-image: url(../images/top/enroll_box_line.png); }
@media screen and (min-width:769px), print{
	#mainVis::after {
		content: "";
		top: 207px;
		right: 0;
		left: -298px;
		width: 787px;
		height: 709px;
		z-index: 20;
		background-image: url(../images/top/deco_mainvis_pc.png);
	}
	#mainVisText { left: 115px; }
	#mainVisText .title {
		width: 438px;
	}
	#mainVisText .text {
		font-size: 20px;
		margin-top: 24px;
	}
	#mainVisBg {
		height: 870px;
	}
	#mainVisBg li {
		padding-top: 870px;
		background-position: right center;
	}
	#mainVisBg #mainVisBg01 { background-image: url(../images/top/mainvis01_pc.jpg); }
	#mainVisBg #mainVisBg02 { background-image: url(../images/top/mainvis02_pc.jpg); }
	#mainVisBg #mainVisBg03 { background-image: url(../images/top/mainvis03_pc.jpg); }
	#enrollBox {
		right: 30px;
		bottom: 25px;
		position: absolute;
		border-radius: 20px;
		padding: 36px 20px 20px;
	}
	#enrollBox::before {
		top: -15px;
		right: -15px;
		width: 127px;
		height: 127px;
	}
	#enrollBox .title { width: 177px; }
	#enrollBox .tag {
		left: 0;
		top: -16px;
		font-size: 15px;
		padding: 6px 13px;
		letter-spacing: 0.01em;
	}
	#enrollBox .cLinks {
		display: flex;
		margin-top: 16px;
	}
	#enrollBox .cLinks li { width: 144px; }
	#enrollBox .cLinks li + li { margin-left: 10px; }
	#enrollBox .cLinks a {
		color: #fff;
		height: 41px;
		display: flex;
		overflow: hidden;
		align-items: center;
	}
	#enrollBox .cLinks .tel a {
		font-size: 14px;
		padding-left: 4px;
		background: #e63070;
	}
	#enrollBox .cLinks .line a {
		font-size: 13px;
		line-height: 16px;
		padding-left: 8px;
		background: #4cc764;
		transition-duration: .3s;
		transition-property: color, background-color;
	}
	#enrollBox .cLinks .line a:hover {
		color: #4cc764;
		background: #fff;
	}
	#enrollBox .cLinks a::before {
		width: 30px;
		height: 30px;
		margin-right: 3px;
	}
	#enrollBox .cLinks .tel a::before { background-image: url(../images/top/enroll_box_tel_pc.png); }
}
@media screen and (max-width:768px){
	#mainVisBg,
	#mainVisBg > li {
		padding-top: 152vw;
	}
	#mainVisBg #mainVisBg01 { background-image: url(../images/top/mainvis01_sp.jpg); }
	#mainVisBg #mainVisBg02 { background-image: url(../images/top/mainvis02_sp.jpg); }
	#mainVisBg #mainVisBg03 { background-image: url(../images/top/mainvis03_sp.jpg); }
	#enrollBox {
		display: flex;
		position: relative;
		padding: 15px 0 15px 25px;
	}
	#enrollBox::before {
		top: -8px;
		right: -8px;
		width: 82px;
		height: 82px;
	}
	#enrollBox .title {
		width: 131px;
		margin-top: 4px;
		margin-right: 11px;
	}
	#enrollBox .tag {
		left: 25px;
		top: -12.5px;
		font-size: 11.5px;
		line-height: 25px;
		padding: 0 10px;
		letter-spacing: 0.15em;
	}
	#enrollBox .cLinks li + li { margin-top: 4px; }
	#enrollBox .cLinks a {
		width: 121px;
		background: #fff;
		line-height: 25px;
		text-align: center;
		padding-left: 16px;
		position: relative;
		box-sizing: border-box;
	}
	#enrollBox .cLinks .tel a {
		color: #ff79a8;
		font-size: 12px;
	}
	#enrollBox .cLinks .line a {
		color: #4cc764;
		font-size: 10px;
	}
	#enrollBox .cLinks a::before {
		top: 0;
		left: 6px;
		bottom: 0;
		width: 15px;
		height: 15px;
		margin: auto 0;
		position: absolute;
	}
	#enrollBox .cLinks .tel a::before {
		transform: scale(1.2);
		background-image: url(../images/top/enroll_box_tel_sp.png);
	}
}

/* news */
#news {
	color: #fff;
	background: #50aacd;
}
#news .title {
	font-weight: bold;
}
#news .title::before {
	content: "";
	display: inline-block;
	background: url(../images/icon_news.svg) no-repeat center center;
	background-size: cover;
}
#news .postList {
	border-bottom: 1px solid #fff;
}
#news .postList li {
	border-top: 1px solid #fff;
}
#news .postList li a { display: block; }
#news .postList li a time::before {
	content: "";
	width: 1em;
	height: 1em;
	border-radius: 50%;
	background: #e1ef2a;
	display: inline-block;
	vertical-align: middle;
}
#news .link a {
	display: block;
	color: #50aacd;
	background: #fff;
	font-weight: bold;
	border-radius: 999px;
}
#news .link a::after {
	content: "";
	display: inline-block;
	vertical-align: middle;
	background: url(../images/top/news_arrow.svg) no-repeat center center;
	background-size: cover;
}
@media screen and (min-width:769px), print{
	#news { padding: 78px 0 90px; }
	#news::before { content: none; }
	#news .inner {
		display: flex;
		margin: 0 auto;
		max-width: 1100px;
		justify-content: space-between;
	}
	#news .title {
		font-size: 26px;
		align-self: flex-start;
		writing-mode: vertical-rl;
		text-orientation: upright;
	}
	#news .title::before {
		width: 43px;
		height: 37px;
		margin-bottom: 22px;
	}
	#news .postList {
		width: 780px;
		align-self: flex-start;
	}
	#news .postList li {
		position: relative;
	}
	#news .postList li a {
		font-size: 16px;
		overflow: hidden;
		white-space: nowrap;
		text-overflow: ellipsis;
		padding: 25px 12px;
		position: relative;
		transition-duration: .3s;
		transition-property: color;
	}
	#news .postList li::before {
		content: "";
		top: 0;
		left: 0;
		width: 0;
		height: 100%;
		display: block;
		position: absolute;
		background: #fff;
		transition-duration: .3s;
		transition-property: width;
	}
	#news .postList li:hover::before { width: 100%; }
	#news .postList li:hover a { color: #000; }
	#news .postList li a time {
		width: 140px;
		font-size: 14px;
		display: inline-block;
	}
	#news .postList li a time::before {
		margin-top: -0.1em;
		margin-right: 0.5em;
	}
	#news .link { align-self: flex-end; }
	#news .link a {
		padding: 20px 39px;
		transition-duration: .3s;
		transition-property: color, background-color;
	}
	#news .link a:hover {
		color: #000;
		background-color: #e1ef2a;
	}
	#news .link a::after {
		width: 20px;
		height: 14px;
		font-size: 16px;
		margin-top: -3px;
		margin-left: 12px;
		transition-duration: .3s;
		transition-property: background-image;
	}
	#news .link a:hover::after { background-image: url(../images/top/news_arrow_b.svg); }
}
@media screen and (max-width:768px){
	#news { padding: 48px 25px 51px; }
	#news::before {
		top: 40px;
		right: 24px;
		width: 51px;
		height: 53.5px;
		background-image: url(../images/top/deco_news_sp.svg);
	}
	#news .title {
		font-size: 23px;
	}
	#news .title::before {
		width: 30px;
		height: 26px;
		margin-top: -5px;
		margin-right: 13px;
		vertical-align: middle;
	}
	#news .postList { margin: 37px 0 30px; }
	#news .postList li a {
		padding: 18px 13px 22px;
		line-height: 25px;
	}
	#news .postList li a > * { display: block; }
	#news .postList li a time {
		font-size: 12px;
		margin-bottom: 5px;
	}
	#news .postList li a time::before {
		margin-top: -0.2em;
		margin-right: 0.5em;
	}
	#news .postList li a span { font-size: 13px; }
	#news .link::after {
		content: "";
		display: block;
		clear: both;
	}
	#news .link a {
		float: right;
		font-size: 13px;
		line-height: 45px;
		padding-left: 22px;
		padding-right: 19px;
	}
	#news .link a::after {
		width: 15px;
		height: 10px;
		margin-left: 15px;
	}
}

/* about */
#about .inner > .title {
	color: #f381a9;
	font-weight: bold;
	text-align: center;
}
#about .inner > .title::before {
	content: "";
	display: block;
	margin-left: auto;
	margin-right: auto;
	background: url(../images/top/icon_about.svg) no-repeat;
}
#about .inner > .subTitle {
	font-weight: bold;
}
#about .attention { text-align: center; }
#about .attention span {
	color: #f69842;
	font-weight: bold;
	border: 2px solid #f69842;
}

#thoughts { background: #ffeceb; }
#thoughts .title {
	color: #f381a9;
	font-weight: bold;
	letter-spacing: 0.15em;
}
#thoughts .name span { font-weight: bold; }

#staff .title {
	color: #f381a9;
	font-weight: bold;
	text-align: center;
}
#staff .list .image {
	font-weight: bold;
	text-align: center;
}
#staff dt {
	color: #f381a9;
	font-weight: bold;
}
#staff .image img { border-radius: 50%; }
@media screen and (min-width:769px), print{
	#about::before {
		max-width: 1260px;
		height: 385px;
		margin: 0 auto;
		top: -18px;
		left: 0;
		right: -58px;
		background-image: url(../images/top/deco_about_pc.png);
	}
	#about .inner {
		margin: 0 auto;
		padding: 50px 0 145px;
		max-width: 1200px;
	}
	#about .inner > .title {
		font-size: 40px;
		margin-bottom: 58px;
	}
	#about .inner > .title::before {
		width: 52px;
		height: 45px;
		margin-bottom: 25px;
	}
	#about .inner > .subTitle,
	#about .inner > .text {
		width: 50%;
		float: left;
		padding-left: 50px;
		box-sizing: border-box;
		letter-spacing: 0.15em;
	}
	#about .inner > .subTitle {
		font-size: 30px;
		line-height: 50px;
	}
	#about .inner > .text {
		font-size: 18px;
		line-height: 32px;
		margin-top: 13px;
		padding-right: 40px;
	}
	#about .inner > .image {
		width: 50%;
		float: right;
		padding-top: 16px;
		padding-left: 24px;
		box-sizing: border-box;
	}
	#about .inner > .image p {
		float: right;
		font-size: 14px;
		line-height: 20px;
		margin-top: 20px;
	}
	#about .inner > .attention {
		clear: both;
		padding-top: 15px;
	}
	#about .inner > .attention span {
		font-size: 26px;
		padding: 15px 55px;
		letter-spacing: 0.15em;
		display: inline-block;
	}

	#thoughts {
		display: flex;
		margin-top: 60px;
		border-radius: 20px;
		padding: 45px 72px 50px;
		justify-content: space-between;
	}
	#thoughts::before { content: none; }
	#thoughts .image {
		width: 246px;
	}
	#thoughts > div {
		width: calc(100% - 330px);
	}
	#thoughts .title {
		font-size: 24px;
		line-height: 42px;
		margin:  -10px 0 15px;
	}
	#thoughts .text {
		font-size: 18px;
		line-height: 32px;
	}
	#thoughts .name {
		font-size: 16px;
		margin-top: 50px;
		text-align: right;
	}
	#thoughts .name span {
		font-size: 28px;
	}

	#staff { margin-top: 33px; }
	#staff .title {
		font-size: 28px;
		margin-bottom: 35px;
	}
	#staff .list {
		display: flex;
		padding: 0 50px;
		justify-content: center;
	}
	#staff .list li {
		width: 50%;
		display: flex;
	}
	#staff .list .image {
		min-width: 170px;
		padding-left: 25px;
		padding-right: 38px;
	}
	#staff .list .image figcaption {
		font-size: 18px;
		margin-top: 15px;
	}
	#staff .list dl {
		padding-right: 70px;
	}
	#staff .list dt {
		font-size: 18px;
		margin-top: 24px;
	}
	#staff .list dd {
		font-size: 16px;
		line-height: 30px;
		margin-top: 16px;
	}
}
@media screen and (max-width:768px){
	#about { padding: 38px 25px 47px; }
	#about::before {
		top: -25px;
		left: 26px;
		width: 49px;
		height: 60px;
		background-image: url(../images/top/deco_about_sp.png);
	}
	#about .inner > .title {
		font-size: 25px;
		line-height: 35px;
	}
	#about .inner > .title::before {
		width: 45px;
		height: 39px;
		margin-bottom: 23px;
	}
	#about .inner > .subTitle {
		font-size: 20px;
		line-height: 28px;
		text-align: center;
		margin-top: 30px;
	}
	#about .inner > .image { margin-top: 22px; }
	#about .inner > .image p {
		font-size: 10px;
		line-height: 15px;
		margin-top: 39px;
	}
	#about .inner > .text {
		font-size: 13px;
		line-height: 24px;
		margin-top: 37px;
	}
	#about .inner > .attention { margin: 0 -25px; }
	#about .inner > .attention span {
		font-size: 16px;
		line-height: 24px;
		margin-top: 39px;
		border-width: 1px;
		display: inline-block;
		letter-spacing: 0.15em;
		padding: 17px 20px 16px;
	}

	#thoughts {
		margin-top: 65px;
		border-radius: 20px;
		padding: 30px 40px 45px;
	}
	#thoughts::before {
		top: -27px;
		right: 15px;
		width: 56.5px;
		height: 88px;
		background-image: url(../images/top/deco_cc_sp.png);
	}
	#thoughts .title {
		font-size: 20px;
		line-height: 30px;
		margin-top: 19px;
	}
	#thoughts .text {
		font-size: 13px;
		line-height: 24px;
		margin-top: 17px;
	}
	#thoughts .name {
		font-size: 12px;
		margin-top: 17px;
	}
	#thoughts .name span { font-size: 21px; }

	#staff .title {
		font-size: 20px;
		margin-top: 40px;
		margin-bottom: 43px;
	}
	#staff li {
		display: flex;
		align-items: flex-start;
		justify-content: space-between;
	}
	#staff li + li { margin-top: 37px; }
	#staff .image { width: 128px; }
	#staff .image figcaption {
		font-size: 10px;
		margin-top: 8px;
	}
	#staff dl {
		letter-spacing: 0.15em;
		width: calc(100% - 157px);
	}
	#staff dt {
		font-size: 15px;
		line-height: 27px;
	}
	#staff dd {
		font-size: 13px;
		line-height: 24px;
	}
}

/* goal */
#goal { background: #f9f0d3; }
#goal .inner > .title {
	color: #f381a9;
	font-weight: bold;
	text-align: center;
}
#goalList {
	background: #fff;
	font-weight: bold;
	text-align: center;
	position: relative;
}
#goalList::after {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	right: 0;
	margin: 0 auto;
	background: #fff;
	transform: rotate(45deg);
}
#goalList .title,
#goalList .subTitle {
	font-weight: bold;
}
#goalList .list {
	text-align: left;
}
#goalList .list .num {
	display: inline-block;
	vertical-align: middle;
}
#goalList .list .num img { border-radius: 50%; }

#effort > .title {
	color: #50aacd;
	font-weight: bold;
	text-align: center;
}
#effort .block {
	position: relative;
	box-sizing: border-box;
}
#effort .block::before {
	content: "";
	display: block;
	background: no-repeat center center;
	background-size: cover;
}
#effort #ef_prepare::before { background-image: url(../images/top/goal_img_prepare.jpg); }
#effort #ef_food::before { background-image: url(../images/top/goal_img_food.jpg); }
#effort #ef_disaster::before { background-image: url(../images/top/goal_img_disaster.jpg); }
#effort #ef_food .inner::after {
	content: "";
	display: block;
	background: url(../images/top/goal_img_food_s.jpg) no-repeat center center;
	background-size: 100% 100%;
}
#effort .block .title {
	color: #fff;
	font-weight: bold;
	border-radius: 999px;
	display: inline-block;
	letter-spacing: 0.15em;
}
#effort #ef_prepare .title { background-color: #7db161; }
#effort #ef_food .title { background-color: #f69842; }
#effort #ef_disaster .title { background-color: #f381a9; }
#effort .program { background: #fff; }
#effort .program dt { font-weight: bold; }
#effort #ef_prepare dt { color: #7db161; }
#effort #ef_food dt { color: #f69842; }
#effort #ef_disaster dt { color: #f381a9; }
@media screen and (min-width:769px), print{
	#goal { padding: 95px 0 123px; }
	#goal::before {
		top: 85px;
		left: 0;
		right: -90px;
		max-width: 1174px;
		height: 828px;
		background-image: url(../images/top/deco_goal_pc.png);
	}
	#goalList::after {
		width: 58px;
		height: 58px;
		border-radius: 10px;
		bottom: -20px;
	}
	#goal .inner > .title {
		font-size: 40px;
		margin-bottom: 32px;
	}
	#goalList {
		margin: 0 auto;
		padding: 68px 0;
		max-width: 990px;
		border-radius: 20px;
	}
	#goalList .title img { width: 734px; }
	#goalList .subTitle {
		font-size: 20px;
		margin-top: 20px;
	}
	#goalList .list {
		font-size: 20px;
		margin-top: 36px;
		display: inline-block;
	}
	#goalList .list li + li { margin-top: 14px; }
	#goalList .list .num {
		width: 45px;
		margin-right: 12px;
	}

	#effort > .title {
		font-size: 30px;
		line-height: 50px;
		margin-top: 104px;
		margin-bottom: 44px;
	}
	#effort .block {
		display: flex;
		min-height: 432px;
		max-width: 1200px;
		margin-left: auto;
		margin-right: auto;
	}
	#effort .block + .block { margin-top: 80px; }
	#effort .block:nth-of-type(odd) { justify-content: flex-start; }
	#effort .block:nth-of-type(even) { justify-content: flex-end; }
	#effort .block::before {
		bottom: 0;
		width: calc(50vw + 68px);
		height: 432px;
		position: absolute;
	}
	#effort .block:nth-of-type(odd)::before {
		left: calc(50% - 68px);
		border-radius: 20px 0 0 20px;
	}
	#effort .block:nth-of-type(even)::before {
		right: calc(50% - 68px);
		border-radius: 0 20px 20px 0;
	}
	#effort .block .inner { width: 412px; }
	#effort .block:nth-of-type(odd) .inner { padding-left: 50px; }
	#effort .block:nth-of-type(even) .inner { padding-right: 50px; }
	#ef_food::after { content: none; }
	#effort #ef_food .inner::after {
		width: 320px;
		height: 272px;
		position: absolute;
		top: 195px;
		right: 0;
	}
	#effort .block .title {
		font-size: 36px;
		padding: 6px 35px;
		margin-left: -50px;
	}
	#effort .block .text {
		font-size: 18px;
		line-height: 32px;
	}
	#effort .program {
		margin-top: 22px;
		border-radius: 20px;
		padding: 28px 32px 34px;
	}
	#effort .program dt { font-size: 20px; }
	#effort .program dd {
		font-size: 16px;
		line-height: 30px;
		margin-top: 5px;
	}
	#effort::after {
		width: 121px;
		height: 130px;
		left: calc(50% + 518px);
		bottom: -108px;
		background-image: url(../images/top/deco_goal_bottom_pc.png);
	}
	#ef_prepare::after {
		width: 69px;
		height: 87px;
		left: calc(50% + 502px);
		bottom: -73px;
		background-image: url(../images/top/deco_goal_prepare.svg);
	}
	#ef_disaster::after {
		width: 93px;
		height: 86px;
		right: calc(50% + 456px);
		bottom: 54px;
		background-image: url(../images/top/deco_goal_disaster.svg);
	}
}
@media screen and (max-width:768px){
	#goal { padding: 35px 25px 74px; }
	#goal::before {
		top: 52px;
		left: -18px;
		right: -12px;
		width: 345px;
		height: 633px;
		margin: 0 auto;
		background-image: url(../images/top/deco_goal_sp.png);
	}
	#goal > .inner > .title {
		font-size: 25px;
	}
	#goalList {
		margin-top: 30px;
		border-radius: 15px;
		padding: 42px 25px 30px;
	}
	#goalList::after {
		width: 29px;
		height: 29px;
		bottom: -12px;
		border-radius: 5px;
	}
	#goalList .title img { width: 280px; }
	#goalList .subTitle {
		font-size: 13px;
		margin-top: 15px;
	}
	#goalList .list {
		font-size: 14px;
		line-height: 23px;
		margin-top: 35px;
	}
	#goalList .list li {
		position: relative;
		padding-left: 38px;
	}
	#goalList .list li + li { margin-top: 30px; }
	#goalList .list li .num {
		top: -3px;
		left: 0;
		width: 26px;
		position: absolute;
	}

	#effort { margin-top: 60px; }
	#effort::after {
		right: 14px;
		bottom: -44px;
		width: 49.5px;
		height: 49px;
		background-image: url(../images/top/deco_goal_bottom_sp.png);
	}
	#effort > .title {
		font-size: 20px;
		line-height: 30px;
	}
	#ef_prepare { padding-bottom: 50px; }
	#ef_prepare::after {
		right: -2px;
		bottom: 65px;
		width: 41.5px;
		height: 52px;
		background-image: url(../images/top/deco_goal_prepare.svg);
	}
	#ef_food { padding-bottom: 242px; }
	#ef_food::after {
		left: 0;
		right: 0;
		bottom: 42px;
		width: 318.5px;
		height: 180px;
		margin: 0 auto;
		background-image: url(../images/top/goal_img_food_sp.jpg);
	}
	#effort .block::before {
		height: 216px;
		margin-bottom: -25px;
	}
	#effort .block:nth-of-type(odd)::before {
		margin-right: -25px;
		border-radius: 10px 0 0 0;
	}
	#effort .block:nth-of-type(even)::before {
		margin-left: -25px;
		border-radius: 0 10px 10px 0;
	}
	#effort .block .title {
		font-size: 23px;
		line-height: 50px;
		padding: 0 30px;
		margin-bottom: 20px;
	}
	#effort .inner {
		font-size: 13px;
		line-height: 24px;
		padding: 0 15px;
	}
	#effort .program {
		margin-top: 25px;
		border-radius: 10px;
		padding: 16px 25px 19px;
	}
	#effort .program dt {
		font-size: 14px;
		margin-bottom: 3px;
	}
}

/* flow */
#flow {
	text-align: center;
}
#flow > .title {
	font-weight: bold;
	letter-spacing: 0.15em;
}
#flow > .title::before {
	content: "";
	display: block;
	margin-left: auto;
	margin-right: auto;
	background: url(../images/top/icon_time.png) no-repeat center center;
	background-size: 100% 100%;
}
@media screen and (min-width:769px), print{
	#flow { padding: 88px 0 60px; }
	#flow::before {
		width: 120px;
		height: 80px;
		top: 158px;
		left: calc(50% + 451px);
		background-image: url(../images/top/deco_time01.svg);
	}
	#flow > .title {
		font-size: 40px;
		margin-bottom: 38px;
	}
	#flow > .title::before {
		width: 77px;
		height: 77px;
		margin-bottom: 24px;
	}
	#flow .image,
	#flow .image img { height: 1095px; }
}
@media screen and (max-width:768px){
	#flow { padding: 54px 25px 64px; }
	#flow::before {
		top: 27px;
		right: 27px;
		width: 71.5px;
		height: 48px;
		background-image: url(../images/top/deco_time01.svg);
	}
	#flow > .title {
		font-size: 25px;
		margin-bottom: 43px;
	}
	#flow > .title::before {
		width: 64px;
		height: 64px;
		margin-bottom: 25px;
	}
	#flow .image,
	#flow .image .jspContainer {
		overflow: visible !important;
	}
	#flow .image {
		height: calc(820px + 47px);
	}
	#flow .image img {
		height: 820px;
		max-width: none;
		padding-bottom: 47px;
	}
}

/* season */
#season .title {
	font-weight: bold;
	text-align: center;
}
#season dl {
	display: flex;
}
#season dl > * { box-sizing: border-box; }
#season dt { text-align: center; }
#season dt, #season dd .month { font-weight: bold; }
#s_spring dt { background: #bbe7a3; }
#s_spring dd { background: #ecfae4; }
#s_spring dt, #s_spring dd .month { color: #03b343; }
#s_summer dt { background: #ffcac7; }
#s_summer dd { background: #ffeceb; }
#s_summer dt, #s_summer dd .month { color: #f03792; }
#s_autumn dt { background: #fedca1; }
#s_autumn dd { background: #fef1d8; }
#s_autumn dt, #s_autumn dd .month { color: #f2860e; }
#s_winter dt { background: #a5cee0; }
#s_winter dd { background: #d5eaf2; }
#s_winter dt, #s_winter dd .month { color: #156ac8; }
#season dt::after {
	content: "";
	display: block;
	margin-left: auto;
	margin-right: auto;
	background: no-repeat center center;
	background-size: cover;
}
#s_spring dt::after { background-image: url(../images/top/icon_season_01spring.svg); }
#s_summer dt::after { background-image: url(../images/top/icon_season_02summer.svg); }
#s_autumn dt::after { background-image: url(../images/top/icon_season_03autumn.svg); }
#s_winter dt::after { background-image: url(../images/top/icon_season_04winter.svg); }
#season dd::after {
	content: "";
	display: block;
	background: no-repeat center center;
	background-size: cover;
}
#s_spring dd::after { background-image: url(../images/top/event_img_01spring.jpg); }
#s_summer dd::after { background-image: url(../images/top/event_img_02summer.jpg); }
#s_autumn dd::after { background-image: url(../images/top/event_img_03autumn.jpg); }
#s_winter dd::after { background-image: url(../images/top/event_img_04winter.jpg); }
#season dd .month { display: inline-block; }

#event { position: relative; }
#event::after {
	content: "";
	display: block;
	background: no-repeat center center;
	background-size: cover;
}
#event .title {
	font-weight: bold;
	text-align: center;
}
#event ul {
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
}
#event li {
	font-weight: bold;
	border-radius: 999px;
	border: 2px solid #50aacd;
}
#event .attention { text-align: center; }
@media screen and (min-width:769px), print{
	#season { padding: 0 0 52px; }
	#season::before {
		width: 104px;
		height: 75px;
		top: -24px;
		right: calc(50% + 492px);
		background-image: url(../images/top/deco_time02.svg);
	}
	#season .title {
		font-size: 40px;
		padding: 40px 0;
	}
	#season dl {
		height: 238px;
		max-width: 1000px;
		margin-left: auto;
		margin-right: auto;
	}
	#season dl + dl { margin-top: 24px; }
	#season dt {
		width: 112px;
		font-size: 40px;
		padding-top: 38px;
		border-radius: 20px 0 0 20px;
	}
	#season dt::after {
		width: 41px;
		height: 41px;
		margin-top: 64px;
	}
	#season dd {
		display: flex;
		width: calc(100% - 112px);
		border-radius: 0 20px 20px 0;
	}
	#season dd::after {
		width: 341px;
		border-radius: 0 20px 20px 0;
	}
	#season dd ul {
		font-size: 20px;
		line-height: 51px;
		width: calc(100% - 341px);
		padding: 48px 44px 0;
	}
	#season dd .month { width: 60px; }

	#event::before {
		width: 99px;
		height: 68px;
		top: 120px;
		left: calc(50% + 508px);
		background-image: url(../images/top/deco_event.svg);
	}
	#event::after {
		height: 566px;
		margin-top: 102px;
		background-image: url(../images/top/event_img_pc.jpg);
	}
	#event .title {
		font-size: 40px;
		padding: 36px 0;
	}
	#event li {
		font-size: 18.5px;
		margin: 0 7px;
		padding: 15px 46px 13px;
	}
	#event .attention { margin-top: 32px; }
}
@media screen and (max-width:768px){
	#season { padding: 30px 25px 10px; }
	#season::before {
		top: -45px;
		left: 18px;
		width: 62.5px;
		height: 45px;
		background-image: url(../images/top/deco_time02.svg);
	}
	#season .title {
		font-size: 25px;
		margin-bottom: 35px;
	}
	#season dl + dl { margin-top: 18px; }
	#season dt {
		width: 63px;
		font-size: 25px;
		padding: 18px 0;
		border-radius: 15px 0 0 15px;
	}
	#season dt::after {
		width: 30px;
		height: 30px;
		margin-top: 16px;
	}
	#season dd {
		font-size: 14px;
		line-height: 30px;
		width: calc(100% - 63px);
		padding: 18px 22px 29px 28px;
		border-radius: 0 15px 15px 0;
	}
	#season dd::after {
		margin-top: 19px;
		padding-top: 70%;
	}
	#season dd .month { width: 38px; }

	#event { padding: 25px 5px 0; }
	#event .title { font-size: 25px; }
	#event .list {
		flex-wrap: wrap;
		margin-top: 14px;
	}
	#event .list li {
		font-size: 14px;
		line-height: 43px;
		border-width: 1px;
		padding: 0 40px;
		margin: 10px 5px 0;
	}
	#event .attention {
		font-size: 10px;
		line-height: 20px;
		margin-top: 22px;
	}
	#event::after {
		height: 84.4vw;
		margin: 44px -5px 0;
		background-image: url(../images/top/event_img_sp.jpg);
	}
}

/* facility */
#facility .title {
	font-weight: bold;
	text-align: center;
}
#facility .title::before {
	content: "";
	display: block;
	margin-left: auto;
	margin-right: auto;
	background: url(../images/logo.png) no-repeat center center;
	background-size: cover;
}
#facility .table table {
	width: 100%;
	table-layout: fixed;
}
#facility .table tr {
	border-top: 1px solid #cccccc;
}
#facility .table .notable tr {
	border-bottom: 1px solid #cccccc;
}
#facility .table tr > * {
	vertical-align: top;
}
#facility .table th {
	color: #50aacd;
	font-weight: bold;
}
@media screen and (min-width:769px), print{
	#facility { padding: 42px 0 44px; }
	#facility::before {
		width: 69px;
		height: 87px;
		top: -22px;
		right: calc(50% + 476px);
		background-image: url(../images/top/deco_goal_prepare.svg);
	}
	#facility::after {
		max-width: 1296px;
		height: 493px;
		left: -80px;
		right: -115px;
		bottom: 93px;
		margin-left: auto;
		margin-right: auto;
		background-image: url(../images/top/deco_facility_pc.png);
	}
	#facility .title {
		font-size: 40px;
	}
	#facility .title::before {
		width: 120px;
		height: 126px;
		margin-bottom: 38px;
	}
	#facility .table {
		max-width: 1000px;
		margin: 48px auto 0;
	}
	#facility .table tr > * {
		font-size: 16px;
		line-height: 40px;
		padding: 15px 0;
	}
	#facility .table th { padding-left: 30px; }
	#facility .table table:not(.notable) th { width: 260px; }
	#facility .table td {}
	#facility .table .notable,
	#facility .table .notable tbody,
	#facility .table .notable tr,
	#facility .table .notable tr > * {
		width: 100%;
		display: block;
	}
	#facility .table .notable td {
		padding: 0 0 40px;
		text-align: center;
	}
}
@media screen and (max-width:768px){
	#facility { padding: 40px 25px 40px; }
	#facility .title {
		font-size: 25px;
		margin-bottom: 40px;
	}
	#facility .title::before {
		width: 78px;
		height: 82px;
		margin-bottom: 40px;
	}
	#facility .table table,
	#facility .table tbody,
	#facility .table tr,
	#facility .table tr > * {
		width: 100%;
		display: block;
	}
	#facility .table tr {
		font-size: 13px;
		line-height: 30px;
		box-sizing: border-box;
		padding: 18px 14px 22px;
	}
	#facility .notable img {
		margin: 0 -14px 16px;
		max-width: calc(100% + 28px);
	}
}

/* price */
#price .title {
	font-weight: bold;
	text-align: center;
}
#price .priceList {
	background: #f9f0d3;
	box-sizing: border-box;
}
#price .priceList dt {
	color: #50aacd;
	font-weight: bold;
}
#price .name { font-weight: bold; }
#price .name::before {
	content: "";
	width: 1em;
	height: 1em;
	border-radius: 50%;
	display: inline-block;
	vertical-align: middle;
	background: #f381a9;
	margin-top: -0.1em;
	margin-right: 0.1em;
}
#price .table table {
	width: 100%;
	table-layout: fixed;
}
#price .table tr {
	border-top: 1px solid #e2dbad;
	border-bottom: 1px solid #e2dbad;
}
#price .table tr > * { vertical-align: top; }
#price .table th,
#price .other dt { font-weight: bold; }
@media screen and (min-width:769px), print{
	#price {
		margin-top: 60px;
		padding-bottom: 80px;
	}
	#price::after {
		width: 114px;
		height: 107px;
		bottom: 407px;
		left: calc(50% + 547px);
		background-image: url(../images/top/deco_price.png);
	}
	#price .title {
		font-size: 40px;
		margin-bottom: 40px;
	}
	#price .priceList {
		display: flex;
		margin-left: auto;
		margin-right: auto;
		max-width: 1000px;
		border-radius: 20px;
		padding: 40px 25px 40px 60px;
		align-items: flex-start;
		justify-content: space-between;
	}
	#price .priceList + .priceList { margin-top: 25px; }
	#price .priceList dt {
		font-size: 28px;
		letter-spacing: 0.15em;
		writing-mode: vertical-rl;
		text-orientation: upright;
	}
	#price .priceList dd {
		width: calc(100% - 135px);
	}
	#price .name,
	#price .priceList tr > * {
		font-size: 16px;
		line-height: 30px;
		padding: 5px 0 3px 20px;
	}
	#price .priceList th + td { width: 350px; }
	#price .priceList .attention { border-bottom: none; }
	#price .priceList .attention td {
		font-size: 14px;
		line-height: 29px;
		padding-bottom: 20px;
	}
	#price .priceList tr.noborder,
	#price .priceList .attention + tr { border-top: none; }
	#price .priceList dd > section + section {
		margin-top: 30px;
	}
	#price .priceList .name + .table tr > th {
		padding-left: 38px;
	}
	#price .other {
		margin-left: auto;
		margin-right: auto;
		max-width: 1000px;
	}
	#price .other {
		display: flex;
		line-height: 35px;
		margin-top: 33px;
	}
	#price .other dt {
		font-size: 20px;
		padding-left: 50px;
		padding-right: 63px;
	}
	#price .other dd { font-size: 16px; }
}
@media screen and (max-width:768px){
	#price {
		margin-top: 65px;
		padding: 0 25px 67px;
	}
	#price::after {
		top: -120px;
		left: 0;
		right: -3px;
		width: 332px;
		height: 172.5px;
		margin: 0 auto;
		background-image: url(../images/top/deco_facility_sp.png);
	}
	#price .title {
		font-size: 25px;
		margin-bottom: 40px;
	}
	#price .priceList {
		padding: 30px 17px;
		border-radius: 10px;
	}
	#price .priceList + .priceList {
		margin-top: 20px;
	}
	#price .priceList dt {
		font-size: 18px;
		padding-left: 10px;
		margin-bottom: 30px;
	}
	#price .priceList dd {
		line-height: 22px;
	}
	#price .priceList dd > section + section {
		margin-top: 40px;
	}
	#price .priceList tr > * {
		padding: 12px 10px 13px;
	}
	#price .priceList th {
		font-size: 13px;	
	}
	#price .priceList td {
		font-size: 12px;
	}
	#price .priceList + .priceList td {
		width: 100px;
	}
	#price .priceList .attention td {
		font-size: 10px;
		line-height: 18px;
		padding-top: 7px;
	}
	#price .name {
		font-size: 13px;
		padding-bottom: 7px;
	}
	#price .other { margin-top: 25px; }
	#price dt { font-size: 14px; }
	#price dd {
		font-size: 13px;
		line-height: 22px;
		margin-top: 10px;
	}
}

/* instagram */
#instagram { background: #d8ecf8; }
#instagram .title::before {
	content: "";
	display: block;
	background: url(../images/icon_instagram.png) no-repeat center center;
	background-size: cover;
}
#instagram .text { font-weight: bold; }
#instagram .link a {
	color: #fff;
	font-weight: bold;
	background: #f69842;
	display: inline-block;
}
#instagram .link a::after {
	content: "";
	display: inline-block;
	vertical-align: middle;
	background: url(../images/top/inst_arrow.svg) no-repeat center center;
	background-size: cover;
}
@media screen and (min-width:769px), print{
	#instagram {
		display: flex;
		align-items: flex-end;
		padding: 108px 0 105px 25px;
	}
	#instagram::before,
	#instagram::after { content: none; }
	#instagram .inner {
		width: 434px;
		min-width: 434px;
		padding-left: calc(50vw - 625px);
	}
	#instagram .title::before {
		width: 49px;
		height: 49px;
		margin-bottom: 30px;
	}
	#instagram .text {
		font-size: 16px;
		line-height: 30px;
		margin: 34px 0 40px;
	}
	#instagram .link a {
		font-size: 16px;
		padding: 18px 27px;
		border-radius: 999px;
		transition-duration: .3s;
		transition-property: background-color;
	}
	#instagram .link a:hover { background-color: #50aacd; }
	#instagram .link a::after {
		width: 20px;
		height: 14px;
		margin-top: -3px;
		margin-left: 16px;
	}
	#instagram .imgList {
		display: flex;
	}
	#instagram .imgList li {
		min-width: 300px;
		margin-right: 30px;
	}
}
@media screen and (max-width:768px){
	#instagram { padding: 45px 25px 50px; }
	#instagram::before {
		top: -45px;
		right: 26px;
		width: 68.5px;
		height: 64px;
		background-image: url(../images/top/deco_price.png);
	}
	#instagram .title::before {
		width: 31px;
		height: 31px;
		margin-bottom: 30px;
	}
	#instagram .title img { height: 25px; }
	#instagram .text {
		font-size: 13px;
		margin-top: 15px;
	}
	#instagram .imgList {
		display: flex;
		margin-top: 37px;
	}
	#instagram .imgList li {
		min-width: 152px;
		margin-right: 15px;
	}
	#instagram .link {
		margin-top: 32px;
		text-align: center;
	}
	#instagram .link a {
		font-size: 13px;
		line-height: 45px;
		padding-left: 22px;
		padding-right: 18px;
	}
	#instagram .link a::after {
		width: 15px;
		height: 10px;
		margin-left: 15px;
	}
}

/* enroll */
#enroll { text-align: center; }
#enroll .text,
#enroll .cLinks { font-weight: bold; }
#enroll .cLinks a {
	display: block;
	border-radius: 999px;
	border: 2px solid #ff79a8;
}
#enroll .cLinks .tel a {
	color: #fff;
	background: #ff79a8;
}
#enroll .cLinks .line a {
	color: #4cc764;
}
#enroll .cLinks a::before {
	content: "";
	display: inline-block;
	vertical-align: middle;
	background: no-repeat center center;
	background-size: cover;
}
#enroll .cLinks .tel a::before { background-image: url(../images/top/enroll_box_tel_pc.png); }
#enroll .cLinks .line a::before { background-image: url(../images/top/enroll_box_line.png); }
@media screen and (min-width:769px), print{
	#enroll { padding: 88px 0 100px; }
	#enroll::before {
		width: 460px;
		height: 169px;
		top: -140px;
		right: calc(50% + 208px);
		background-image: url(../images/top/deco_enroll_pc.png);
	}
	#enroll .title img { width: 247px; }
	#enroll .text {
		font-size: 20px;
		line-height: 42px;
		margin: 26px 0 22px;
	}
	#enroll .cLinks {
		display: flex;
		justify-content: center;
		margin-bottom: 44px;
	}
	#enroll .cLinks li {
		width: 466px;
		margin: 0 11px;
	}
	#enroll .cLinks a {
		font-size: 30px;
		padding: 20px 24px 20px;
		text-align: left;
	}
	#enroll .cLinks .line a {
		transition-duration: .3s;
		transition-property: color, background-color, border-color;
	}
	#enroll .cLinks .line a:hover {
		color: #fff;
		background: #4cc764;
		border-color: #4cc764;
	}
	#enroll .cLinks a::before {
		width: 56px;
		height: 56px;
		margin-top: -3px;
		margin-right: 45px;
	}
	#enroll .cLinks a small { font-size: 16px; }
	#enroll .time { font-size: 16px; }
}
@media screen and (max-width:768px){
	#enroll { padding: 45px 0 78px; }
	#enroll::before {
		top: -50px;
		left: 18px;
		width: 71px;
		height: 118px;
		background-image: url(../images/top/deco_enroll_sp.png);
	}
	#enroll .title img { width: 200px; }
	#enroll .text {
		font-size: 13px;
		line-height: 28px;
		margin-top: 20px;
	}
	#enroll .cLinks {
		padding: 0 37px;
		margin-top: 25px;
	}
	#enroll .cLinks li + li { margin-top: 10px; }
	#enroll .cLinks li a {
		height: 62px;
		font-size: 19px;
		line-height: 62px;
		position: relative;
		padding-left: 28px;
	}
	#enroll .cLinks li a::before {
		top: 0;
		bottom: 0;
		margin: auto 0;
		width: 35px;
		height: 35px;
		position: absolute;
	}
	#enroll .cLinks .tel a::before { left: 27px; }
	#enroll .cLinks .line a::before { left: 16px; }
	#enroll .cLinks li a small {
		font-size: 10px;
		margin-left: 0.5em;
	}
}