@charset "utf-8";
.huwa{
	animation-name: huwa;
}
.animation{
	animation-timing-function: ease-in-out;
	animation-iteration-count: infinite;
	animation-direction: alternate;
	animation-duration: 1.5s;
}
@keyframes huwa{
	0% {
    transform: translate(0, 0px);
	}
	100% {
    transform: translate(0, 30px);
	}
}

.sub_btn{
	position: fixed;
	top: 20px;
	right: 20px;
	filter: drop-shadow(0px 10px 20px rgba(0,0,0,0.2));
	z-index: 100;
	transition: all 0.3s;
}

.sub_btn.off{
	opacity:0;
	z-index:-1;
}

.mv{
	height: 653px;
	padding: 0 20px;
	position:relative;
}

.mv .bg{
	position:absolute;
	left:0;
	right:0;
	top:0;
}

.mv .bg img{
	object-fit: cover;
	height: 653px;
}

.home h1{
	max-width: 1300px;
	margin: 0 auto;
	padding:20px 0 0 0;
	position:relative;
	z-index:2;
}

.main_btn{
	margin: -70px auto 0;
	text-align:center;
}

.home h2.tit{
	text-align:center;
	font-size:26px;
	font-weight:bold;
	color:#0FAFAA;
	position:relative;
	padding:40px 0 0 0;
}

.home h2.tit:after{
	position:absolute;
	top:0;
	left:0;
	right:0;
	margin:0 auto;
	content:"";
	width:71px;
	height:17px;
	background: url(../img/sankaku.png) no-repeat center center;
}

.home .tit02{
	font-size: 40px;
	line-height: 1.6em;
	font-weight: bold;
	text-align:center;
	margin-bottom: 40px;
}

.home .line {
    background: linear-gradient(transparent 70%, #fff84e 20%);
}

.home .line02 {
    color: #F06464;
    background: linear-gradient(transparent 70%, #fff84e 20%);
}

#area01{
	text-align: center;
	padding:90px 20px 120px 20px;
}

#area01 .tit02{
	padding:60px 0 0 0;
}

#area01 .box{
	max-width:1316px;
	margin: 0 auto;
	display: flex;
	justify-content:space-around;
}


#area01 .box li{
	padding:0 5px 20px 5px;
}

#area02{
	background: #E4F7F5;
	text-align: center;
	padding:120px 20px 150px 20px;
	position: relative;
}

#area02 .haikei{
	position: absolute;
	top: 0%;
	left: 50%;
	margin-left: -80px;
}

#area02 ul{
	display: flex;
	justify-content: center;
	align-items: center;
	padding:20px 0 50px 0;
}

#area02 ul li:nth-child(1){
	padding:0 40px 0 0;
}

#area02 .txtbox{
	width: 872px;
	text-align: left;
	font-size: 24px;
	margin: 0 auto;
}

#area02 .txtbox .txt{
	letter-spacing:0.05em;
	line-height:1.6em;
	text-align:justify;
	padding:0 0 50px 0;
}

#area03{
	text-align: center;
	padding: 110px 20px 100px 20px;
}

#area03 .tit{
	background: url(../img/area03_titbg.png) no-repeat bottom center;
}

#area03 .box{
	max-width:1172px;
	margin: 0 auto 70px;
	display: flex;
	justify-content:space-around;
}

#area03 .box li:nth-child(2){
	padding:70px 0 0 0;
}

#area03 .box02{
	display: flex;
	align-items: center;
	justify-content: center;
}

#area03 .box02 .tit02{
	margin:0 40px;
}

#area04{
	background: #E6F9FF;
	text-align: center;
	padding:120px 20px 150px 20px;
	position: relative;
}


#area04 .haikei{
	position: absolute;
	top: 0%;
	left: 50%;
	margin-left: -80px;
}

#area04 .box{
	max-width: 900px;
	margin: 20px auto 0;
	display: flex;
	justify-content: space-around;
	flex-wrap: wrap;
}

#area04 .box li{
	margin-bottom: 20px;
}

#area05{
	background: #46908D;
	text-align: center;
	padding:120px 20px 380px 20px;
	position: relative;
}

.home #area05 .tit span{
	padding:0 10px;
	border-radius:80px;
	background:#FFF84E;
}

#area05 .txt01{
	font-size: 30px;
	font-weight: bold;
	color: white;
	padding:60px 0 50px 0;
	line-height:1.6em;
}

@media screen and (max-width: 1200px) {
#area05 .txt01{
	font-size: 26px;
	font-weight: bold;
	color: white;
	padding:60px 0 50px 0;
	line-height:1.6em;
}
}

#area05 .txt01 span{
	padding:0 5px;
}

.line03 {
    color: #fff84e;
    border-bottom: dotted 5px #fff84e;
}

#area05 .img{
	position: absolute;
	right: 55%;
	z-index:4;
}

#area05 .box h3{
	color: white;
	margin-bottom: 15px;
	line-height:1.4em;
}

#area05 .txtarea{
	max-width:540px;
	margin-left: 50%;
}


#area05 .box{
	max-width: 1205px;
	margin: 0 auto;
	display: flex;
	text-align: left;
	color: white;
	font-size: 24px;
	line-height: 1.6em;
}

.base_cont .box{
	width:910px;
	margin:0 auto;
	position:relative;
}

.base_cont dl{
	width:910px;
	margin:-250px auto 0;
	background:#F77C5B;
	padding:20px 20px 60px 20px;
	text-align:center;
	border-radius:40px;
	color:#fff;
	position:relative;
	z-index:2;
	box-sizing:border-box;
}

.base_cont .bg{
	position:absolute;
	width:910px;
	background:#D17157;
	height:510px;
	right:-20px;
	bottom:-20px;
	border-radius:40px;
}

.base_cont dl dd{
	font-size:34px;
	line-height:1.6em;
	font-weight:bold;
}

.base_cont dl dd span{
	color:#FFF84E;
}


#area06 .box01{
	text-align: center;
	padding:120px 20px 330px 20px;
	position: relative;
}

#area06 .box01 .tit02{
	padding:70px 0 0 0;
}

#area06 .txt{
	font-size: 24px;
	line-height: 1.8em;
	padding:20px 0 0 0;
}

#area06 .box02{
	padding:300px 20px 100px 20px;
	background: #E6F9FF;
	position:relative;
}

#area06 .box02 .img{
	position:absolute;
	top:-230px;
	margin:0 auto;
	left:0;
	right:0;
	text-align:center;
}


#area06 .box02 .box{
	max-width: 1255px;
	margin: 0 auto;
	position:relative;
}

#area06 .box02 .box_in{
	width:875px;
	background:#fff;
	text-align: left;
	padding:50px 60px;
	box-sizing:border-box;
	border-radius:30px;
	font-size: 24px;
	line-height: 1.6em;
	font-weight: 500;
}

#area06 .box02 .box_in h3.tit02{
	margin-bottom: 20px;
	text-align:left;
}

#area06 .box02 .img02{
	position:absolute;
	left:650px;
	top:-60px;
}

#area06 .box02 .img02 img{
	max-width:inherit;
}

#area06 .box02 .btn{
	text-align:center;
	padding:110px 0 0 0;
}

#area07{
	text-align: center;
	padding:110px 20px 80px 20px;
}

#area07 h3{
	padding:70px 0 0 0;
}

#area07 ul{
	max-width: 1356px;
	margin: 50px auto 120px;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}

#area07 ul li{
	padding:0 10px 20px 10px;
}

#area08{
	text-align:center;
	padding:0 20px 140px 20px;
}

#area08 h2{
	padding:0 0 100px 0;
}

.contact{
	padding:70px 0 90px 0;
	background:#E4F7F5;
}

.contact h2.tit{
	padding:25px 0 50px 0;
}

.contact .box{
	width:870px;
	background:#fff;
	box-shadow: 0 10px 20px rgb(0 0 0 / 20%);
	padding:60px 0 60px 0;
	border-radius:30px;
	margin:0 auto;
	position:relative;
}

.contact h2{
	font-size:26px;
	text-align:center;
	line-height:1.6em;
	padding:0 0 10px 0;
	font-weight:normal;
}

.contact .sub{
	font-size:14px;
	padding:0 0 30px 0;
	text-align:center;
}

.formbox{
	width:650px;
	margin:0 auto;
}

.contact .box dl{
	padding:0 0 30px 0;
}

.contact .box dl dt{
	display:table-cell;
	vertical-align:middle;
	width:195px;
	text-align:right;
	font-size:17px;
	box-sizing:border-box;
	padding:0 20px 0 0;
}

.contact .box dl.free dt{
	vertical-align:top;
	padding:5px 20px 0 0;
}

.contact .box dl dt.hissu:before{
	content:"必須";
	color:#fff;
	font-size:10px;
	background:#e7155f;
	padding:0 5px;
	line-height:20px;
	height:20px;
	position:relative;
	top:-2px;
	margin:0 8px 0 0;
	display:inline-block;
	border-radius:5px;
}

.contact .box dl dd{
	display:table-cell;
	vertical-align:middle;
	width:430px;
}

.contact .kome{
	padding:25px 0 0 0;
}

input[type=text],
input[type=email],
textarea{
    font-size : 16px;
    border : none;
	background:#F5F5F5;
    -webkit-appearance : none;
    -webkit-tap-highlight-color : rgba(0,0,0,0);
	padding:10px;
	border-radius:5px;
	width:100%;
	box-sizing:border-box;
    font-family: source-han-sans-japanese, sans-serif;
}

textarea{
    height: 200px !important;
    width: 100% !important;
}



input[type="submit"]{
	width:300px;
	text-align:center;
	padding:15px 0;
	border-radius:10px;
	background:#25BEAE;
	margin:40px auto 0;
	transition: all 0.3s;
	border:none;
	display:block;
	font-size:20px;
	cursor:pointer;
	color:#333333;
	transition: all 0.3s;
    font-family: source-han-sans-japanese, sans-serif;
	color:#fff;
	border:2px solid #25BEAE;
}

input[type="submit"]:hover{
	background:#fff;
	color:#1b1b1b;
}


.thanks .content{
	padding:100px 0 100px 0;
	background: url(../img/contact_bg.jpg);
	color: #333333;
}

.thanks .txt{
	font-size:18px;
	padding:40px 0 0 0;
	font-weight:bold;
	text-align:center;
}

.thanks h1{
	font-size: 30px;
	font-weight:bold;
	text-align:center;
}

.mfp_thanks{
	text-align:center;
	padding:0 0 50px 0;
}

.thanks .btn a{
	width:200px;
	text-align:center;
	padding:10px 0;
	border-radius:100px;
	background:#e1f3fe;
	margin:0 auto 100px;
	display:block;
	font-weight:bold;
	transition: all 0.3s;
}

.thanks .btn a:hover{
    transform: translateY(-5px);
}

.g-recaptcha {
    margin-right: auto;
    margin-left: auto;
    text-align: center;
    width: 300px;
    padding: 30px 0 0 0;
}

input:disabled {
    opacity: 0.5;
    pointer-events: none;
}

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

.sub_btn{
	display:none;
}

.mv{
	height: auto;
	padding: 0;
	margin:0 -10px;
}

.home h1{
	display:none;
}

.main_btn{
	margin: -60px auto 0;
	max-width:300px;
}

.home h2.tit{
	font-size:18px;
	padding:20px 0 0 0;
}

.home h2.tit:after{
	width:50px;
	height:10px;
	background: url(../img/sankaku.png) no-repeat center center;
	background-size:50px;
}

.home .tit02{
	font-size: 20px;
	margin-bottom: 30px;
}

#area01{
	text-align: center;
	padding:60px 20px 60px 20px;
}

#area01 .tit02{
	padding:30px 0 0 0;
}

#area01 .box{
	max-width:inherit;
	justify-content:center;
	flex-wrap:wrap;
}


#area01 .box li{
	padding:0 5px 10px 5px;
	width:50%;
	box-sizing:border-box;
}

#area02{
	padding:60px 20px 60px 20px;
}

#area02 .haikei{
	width:80px;
	margin-left: -40px;
}

#area02 ul{
	display: flex;
	padding:20px 0 40px 0;
}

#area02 ul li:nth-child(1){
	padding:0 20px 0 0;
}

#area02 .txtbox{
	width: 100%;
	font-size: 16px;
}

#area02 .txtbox .txt{
	padding:0 0 30px 0;
}

#area02 .btn{
	max-width:300px;
	margin:0 auto;
}

#area03{
	text-align: center;
	padding: 60px 20px;
}

#area03 .tit{
	background: url(../img/area03_titbg.png) no-repeat bottom center;
	background-size:280px;
}

#area03 .box{
	max-width:inherit;
	margin: 0 auto 30px;
}

#area03 .box li:nth-child(1){
	padding:20px 0 0 0;
}

#area03 .box li:nth-child(2){
	padding:60px 0 0 0;
}

#area03 .box02{
	display:block;
}

#area03 .box02 .tit02{
	margin:15px 0;
}

#area04{
	padding:60px 20px;
}


#area04 .haikei{
	width:80px;
	margin-left: -40px;
}

#area04 .box{
	max-width: inherit;
	margin: 20px auto 0;
	flex-wrap: wrap;
	justify-content:space-between;
}

#area04 .box li{
	margin-bottom: 2%;
	width:49%;
}

#area05{
	padding:60px 20px 100px 20px;
}

#area05 .txt01{
	font-size: 18px;
	padding:30px 0 20px 0;
}

#area05 .img{
	position:static;
    width: 100%;
}

#area05 .box h3{
	text-align:center;
	padding:0 0 10px 0;
}

#area05 .txtarea{
	max-width:inherit;
	margin-left:auto;
}


#area05 .box{
	max-width:inherit;
	margin: 0 auto;
	display:block;
	font-size: 16px;
}

.base_cont .box{
	width:95%;
	margin:0 auto;
}

.base_cont dl{
	width:93%;
	margin:-50px auto 0;
	padding:20px 20px 40px 20px;
	border-radius:30px;
}

.base_cont .bg{
	position:absolute;
	width:93%;
	height:100%;
	right:5px;
	bottom:-10px;
	border-radius:30px;
}

.base_cont dl dt{
	width:200px;
	margin:0 auto;
}


.base_cont dl dd{
	font-size:18px;
	line-height:1.6em;
}

.base_cont dl dd span{
	color:#FFF84E;
}


#area06 .box01{
	padding:60px 20px 130px 20px;
}

#area06 .box01 .tit02{
	padding:30px 0 0 0;
}

#area06 .txt{
	font-size: 18px;
	text-align:left;
	text-align:justify;
	line-height: 1.8em;
	padding:0;
}

#area06 .box02{
	padding:0 20px 60px 20px;
}

#area06 .box02 .img{
	position:relative;
	top:-80px;
	padding:0 20px;
	max-width:400px;
	margin:0 auto;
}


#area06 .box02 .box{
	max-width: inherit;
}

#area06 .box02 .box_in{
	width:100%;
	padding:30px 20px;
	border-radius:20px;
	font-size: 16px;
}

#area06 .box02 .box_in h3.tit02{
	margin-bottom: 20px;
}

#area06 .box02 .img02{
	position:static;
	width:80%;
	margin:-10px auto;
}

#area06 .box02 .img02 img{
	max-width:100%;
}

#area06 .box02 .btn{
	padding:40px 0 0 0;
	max-width:300px;
	margin:0 auto;
}

#area07{
	padding:60px 20px 0 20px;
}

#area07 h3{
	padding:30px 0 0 0;
}

#area07 ul{
	max-width: inherit;
	margin: 30px auto 60px;
	justify-content: space-between;
}

#area07 ul li{
	padding:0 0 1% 0;
	width:49%;
}

#area08{
	padding:0 20px 60px 20px;
}

#area08 h2{
	padding:20px 0 30px 0;
	color:#000;
}

#area08 .txt{
	padding:0 0 30px 0;
}

.contact{
	padding:60px 20px;
}

.home .contact .tit02{
	padding:30px 0 0 0;
}

.contact .box{
	width:100%;
	padding:60px 0 60px 0;
	border-radius:20px;
}

.contact h2{
	font-size:22px;
	text-align:center;
	line-height:1.6em;
	padding:0 0 10px 0;
	font-weight:normal;
}

.contact .sub{
	font-size:14px;
	padding:0 0 50px 0;
	text-align:center;
}

.formbox{
	width:100%;
	padding:0 20px;
	box-sizing:border-box;
}

.contact .box dl{
	padding:0 0 20px 0;
}

.contact .box dl dt{
	display:block;
	width:auto;
	text-align:left;
	font-size:16px;
	padding:0 0 10px 0;
}

.contact .box dl dt.hissu:before{
	top:-1px;
}

.contact .box dl dd{
	display:block;
	width:100%;
}

.contact .box dl.free dt {
    vertical-align: top;
    padding: 0 0 10px 0;
}



input[type="submit"]{
	width:200px;
	padding:10px 0;
	font-size:16px;
}

.thanks .content{
	padding:0 20px 80px 20px;
	text-align:center;
}

.thanks .txt{
	display:inline-block;
	font-size:16px;
	padding:30px 0 0 0;
	font-weight:bold;
	text-align:left;
}

.thanks h1{
	font-size: 24px;
	font-weight:700;
	line-height:1.6em;
	text-align:center;
}

.mfp_thanks{
	text-align:center;
	padding:100px 0 0 0;
}

.thanks .btn a{
	width:200px;
	text-align:center;
	padding:10px 0;
	border-radius:100px;
	background:#e1f3fe;
	margin:0 auto;
	display:block;
	font-weight:bold;
	transition: all 0.3s;
}

.thanks .btn a:hover{
    transform: translateY(-5px);
}
}


.Calendar_txt dt{ 
	padding:40px 0 0 0;
	text-align:center;
	font-size:24px;
	line-height:1.8em;
}

.Calendar_txt dd{ 
	padding:30px 0 40px 0;
	text-align:center;
	font-size:16px;
}

.Calendar_btn{ 
	width:600px;
	margin:0 auto 120px;
}

.Calendar_btn a{ 
	display:block;
	text-align:center;
	font-size:24px;
	color:#fff;
	padding:20px 0;
	border-bottom:5px solid #05a21a;
	background:#31b242;
	border-radius:5px;
	transition: all 0.3s;
}

.Calendar_btn a:hover{ 
	border-bottom:5px solid #31b242;
	background:#05a21a;
}

@media screen and (max-width: 800px) {
.Calendar_txt dt{ 
	padding:30px 0 0 0;
	text-align:left;
	font-size:18px;
}

.Calendar_txt dd{ 
	padding:20px 0 40px 0;
	text-align:left;
	font-size:16px;
}

.Calendar_btn{ 
	width:300px;
	margin:0 auto 60px;
}

.Calendar_btn a{ 
	display:block;
	text-align:center;
	font-size:18px;
	color:#fff;
	padding:15px 0;
	border-bottom:3px solid #05a21a;
	background:#31b242;
	border-radius:5px;
	transition: all 0.3s;
}

.Calendar_btn a:hover{ 
	border-bottom:3px solid #05a21a;
	background:#31b242;
}

}

.check{
	text-align:center;
}

.check input[type="checkbox"] {
  height: 20px;
  width: 20px;
  position: relative;
  top:-2px;
  margin:0 10px 0 0;
}




@media screen and (max-width: 800px) {
.simetxt{
	text-align:center;
	color:#F00;
	font-weight:bold;
	font-size:24px;
	padding:30px 20px 0 20px;
}
}



#privacy{
    background: #eaeaea;
	color:#000;
    margin: 20px auto 0;
    padding: 10px;
	width:600px;
	height:65px;
    border: .82px solid #eee;
    border-radius: 6px;
    overflow: auto;
	font-size:10px;
}

#privacy h3{
	font-size:14px;
}

#privacy h4{
	font-size:12px;
}

#privacy p{
	padding:0 0 20px 0;
}

.contact .kome{
	padding:20px 0 0 0;
	text-align:center;
}


@media screen and (max-width: 800px) {
.contact .kome{
	padding:20px 0 0 0;
	font-size:13px;
}

.check input[type="checkbox"] {
    height: 15px;
    width: 15px;
    position: relative;
    top: -2px;
    margin: 0 10px 0 0;
}

#privacy{
	width:100%;
	height:100px;
	box-sizing:border-box;
}

}
