@charset "UTF-8";

body{
	background-color:#fff;
}

h1, h2, h3, p, a, ul li, dt, dd, label, input, textarea{
	letter-spacing:3px;
	line-height:2.5;
	color:#000;
}

.pc{
	display:block;
}

.sp, .sp-phone{
	display: none;
}

ul li{
	list-style-type: none;
}

.big_serif{
	font-family: 'Zen Antique Soft', serif;
	font-size:4.7rem;
}

.middle_sansserif{
	font-family: 'Noto Sans JP', sans-serif;
	font-weight:900;
	font-size:2.5rem;
}

p, a, ul li, textarea, input{
	font-family: 'Noto Sans JP', sans-serif;
}

.address p, .credit p, .map p, .m-flex-container p, .company_info, h3, .form_area h2 , label, .submit{
	font-family: 'Lora', serif;
}

.address p, .credit p, .center{
	text-align: center;
}

.address p, .map p, .m-flex-container p, dt, dd, label, textarea{
	font-size:1.3rem;
}

h3{
	font-size:1.5rem;
	font-weight:bold;
	margin-bottom:15px;
}

.map p, .company_info{
	line-height:3;
}

.pc-margin-sp-block{
	margin-left:20px;
}

.credit p{
	font-size:1rem;
}

a{
	text-decoration: none;
}

a:hover{
	opacity:0.7;
	-webkit-transition: all .3s;
	transition: all .3s;	
}

.bold{
	font-weight:bold;
}

.bold-link a{
	font-size:1.6rem;
}

.bold-sansserif{
	font-size:2.5rem;
	font-weight:900;
}

/* loading */

#loading {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  z-index: 99999;
  background: #fff;
  text-align: center;
}
#loading_logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
#loading .kvArea {
  width: 100%;
}
#loading .kvArea .img_box {
  text-align: center;
  width:400px;
  margin:30px auto;
}
#loading .kvArea .img_box img {
  max-width: 100%;
  height: auto;
}
.fadeUp {
  animation-name: fadeUpAnime;
  animation-duration: 1.2s;
  animation-delay: 1.2s;
  animation-fill-mode: forwards;
  opacity: 1;
}
@keyframes fadeUpAnime {
  from {
    opacity: 1;
    transform: translateY(0);
  }
  to {
    opacity: 0;
    transform: translateY(-100px);
  }
}

/*inview*/

.fadeIn {
  opacity: 0;
  transition: 2s;
}
.fadeIn.is-show {
  opacity: 1;
}

.fadeIn_up {
  opacity: 0;
  transform: translate(0, 20%);
  transition: 1.5s;
}
.fadeIn_up.is-show {
  transform: translate(0, 0);
  opacity: 1;
}

/*戻るボタン*/
#p-top{
	display:block;
    position: fixed;
    bottom: 5%;
    right: 3%;
	z-index:1000;
	padding:0.7% 1%;
	filter:alpha(opacity=70);
    -moz-opacity: 0.7;
    opacity: 0.7;
}
#p-top::after{
	content:'\f077';
	font-family:'FontAwesome';
	color:#666;
	font-size:2.5rem;
}
#p-top:hover {
	filter:alpha(opacity=50);
    -moz-opacity: 0.5;
    opacity: 0.5;
	-webkit-transition: opacity 0.3s ease-out;
	-moz-transition: opacity 0.3s ease-out;
	-ms-transition: opacity 0.3s ease-out;
	transition: opacity 0.3s ease-out;
}


/*contents*/

#wrapper{
	width:100%;
}

.parallax_img{
  width: 100%;
  height: 65vw;
  min-height: 500px;
  overflow: hidden;
  position:relative;
}

.icon{
	width:200px;
	position:absolute;
	z-index:1;
    top: 50%;
    left: 50%;
    margin-right: -50%;
    transform: translate(-50%, -50%);
}

.contents_1{
	background-color:#F6F2ED;
	padding-bottom:300px;
}

.contents_2, .contents_3{
	background-color:#fff;
}

.contents_4{
	background-color:#F6F2ED;
	padding:20px 0;	
}

.contents_2{
	margin-bottom:-5px;
}

.contents_2 .caption-box{
	position:relative;
	top:-7vw;
}

.contents_1 h1, .contents_2 h1{
	line-height:2!important;
	margin-bottom:15px;
	text-align: center;
}

.contents_3{
	padding:20px 0 60px;	
}

.mid-wrapper, .double-wrapper, .map-flex{
	margin:0 auto;
	box-sizing: border-box;
	padding-top:50px;
	display:flex;
	height:auto;
}

.mid-wrapper, .double-wrapper{
	align-items: center;
}

.mid-wrapper{
	justify-content:space-around;
	width:90%;
}

.double-wrapper, .map-flex{
	justify-content:space-around;
	width:80%;
}

.img-box, .caption-box{
	width:45%;
	box-sizing: border-box;
	/*background-color:#ccc;*/
}

.img-box_middle{
	width:45%;
}

.img-box_small{
	width:30%;
}

.p-box{
	font-weight:400;
	width:85%;
	margin:auto;
	padding:10px 30px;
}

.p-box p, .contents_4 .caption-box p{
	font-size:1.4rem;
	margin-bottom:20px;
	text-align: justify;
}

.reverse{
	flex-direction: row-reverse;
}

.top-up{
	position:relative;
	margin-top:-13vw;
	top:-5vw;
	margin-bottom:-3vw;
	align-items:flex-end!important;
}

.center-img{
	width:45%;
	margin:30px auto 0;
}

.contents_4 .caption-box{
	margin:50px auto 10px;
	box-sizing: border-box;
	padding:30px 0;
}

.contents_4 .center-img{
	mix-blend-mode: multiply;
}

.contents_4 h1{
	text-align: center;
}

/*.bold-link{
	text-align: center;
}*/

.contents_4 .p-box{
	margin:0 auto;
	width:62%;
}

.map{
	width:100%;
}

.map-flex{
	align-items: flex-start;
}

.map iframe, .m-flex-container iframe{
	height:500px;
}

.m-flex-container p{
	margin-top:15px;
}

.m-container{
	width:60%;
	padding-bottom:20px;
	margin:30px auto;
}

.m-flex-container{
	width:45%;
	padding-bottom:20px;
	margin:30px auto;
}

.justify{
	text-align: justify;
	box-sizing: border-box;
	padding:0 20px;
}

.m-left{
	margin-left:15px;
}

.company_info{
	width:40%;
	margin:30px auto;
	padding:0 0 30px;
}

.company_info dl {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}

.company_info dt {
  width: 30%;
  padding-bottom: 5px;
  margin-bottom: 10px;
}

.company_info dd {
  width: 70%;
  padding-bottom: 5px;
  margin-bottom: 10px;
}


/* form */
.form_area {
	width:40%;
	margin:30px auto;
	box-sizing: border-box;
	padding:40px 0;
}

.form_area h2{
	font-size:1.5rem;
	margin-bottom:15px;
}

.form_area label{
	font-weight:bold;
	margin-bottom:3px;
}

.form_area .caution{
	font-size:1.1rem;
	color:#D20003;
	margin-left:5px;
}

.form_area input[type="text"],
.form_area select, .form_area textarea{
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-appearance: button;
	appearance: none;
	border-radius: 0;
	width:100%;
	font-size:1.2rem;
	border:1px solid #aaa;
	padding:10px;
	margin-bottom:15px;
}

.submit{
	display:block;
	width:70%;
	background: #000;
	color:#fff;
	font-size:1.4rem;
	font-weight:bold;
	padding: 5px 20px;
	margin: 10px auto;
}

.submit:hover{
	background-color:#666;
	transition: .3s;
}

/* footer */
footer{
	background-color:#fff;
}

.footer{
	box-sizing: border-box;
	padding:60px 0 60px;
}

.logoimg{
	width:120px;
	margin:30px auto 10px;
	box-sizing: border-box;
	padding:30px 0 20px;
}

.sns-icon{
	margin:10px auto;
	text-align: center;
}

.sns-icon li{
	display:inline-block;
	color:#000;
	font-size:4rem;
	margin:0 15px;
}

/*スライド*/

.top-slide{
	display: flex;
	height:auto;
}

.slick div{
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  min-height:100vh;
  margin: 0;
}

.slick{
	width:50%;
	height:100vh;
}

.slick div.img01{
	background-image: url("../img/slide_bg_01.jpg");
}

.slick div.img02{
	background-image: url("../img/slide_bg_02.jpg");
}

.slick div.img03{
	background-image: url("../img/slide_bg_03.jpg");
}

.slick div.img04{
	background-image: url("../img/slide_bg_04.jpg");
}

.slick div.img05{
	background-image: url("../img/slide_bg_05.jpg");
}

.slick div.img06{
	background-image: url("../img/slide_bg_06.jpg");
}

.slick div.img07{
	background-image: url("../img/slide_bg_07.jpg");
}

.slick div.img08{
	background-image: url("../img/slide_bg_08.jpg");
}


/*タブレット用*/
@media screen and (max-width: 820px){

	.pc, .sp-phone{
		display:none;
	}
	
	.sp{
		display:block;
		margin-top:-5px;
	}

	.icon{
		width:300px;
	}

	.parallax_img{
	  height: 65vw;
	  min-height: 350px;
	  overflow: hidden;
	}

	.mid-wrapper{
		width:720px;
	}
	
	.img-box{
		width:50%;
	}
	
	.caption-box{
		width:49%;
	}
	
	.caption-box h1{
		text-align: center;
		line-height:2;
	}
	
	.big_serif{
		font-size:3.5rem;
	}

	.middle_sansserif{
		font-size:2rem;
		display: block;
	}
	
	.p-box{
		width:90%;
		margin:20px 0 10px 10px;
	}
	
	.top-up{
		margin-top:-10vw;
		top:-20vw;
		margin-bottom:-30vw;
	}
	
	.top-up .img-box img{
		position:relative;
		top:-50vw;
	}
	
	.contents_2 h1{
		margin-right:0;
	}
	
	.contents_3 .img-box{
		width:48%;
	}
	
	.contents_3 .mid-wrapper{
		padding:40px 0;
	}

	.contents_4 .p-box{
		width:100%;
	}
	
	.company_info{
		width:70%;
	}
	
	.form_area{
		width:80%;
	}

	.bold-sansserif{
		font-size:1.7rem;
	}
	
	/*スライドテスト*/

	.top-slide{
		display: block;
		height:auto;
		height:100vh;
	}

	.slick div{
	  min-height:50vh;
	}

	.slick{
		width:100%;
		height:50vh;
	}



}

/*スマホ用*/
@media screen and (max-width:640px){

	#loading .kvArea .img_box {
	  width:280px;
	}

	.icon{
		width:230px;
	}
	
	.icon img, .pc, .no-phone{
		display:none;
	}
	
	.sp-phone{
		display:block;
		
	}
	
	.sp-phone a{
		font-family: 'Lora', serif;
		text-decoration:underline;
	}

	.parallax_img{
	  height: 60vw;
	  min-height: 250px;
	  overflow: hidden;
	}
	
	.mid-wrapper, .double-wrapper, .map-flex{
		width:320px;
		margin:auto;
		display:block;
	}
	
	.p-box{
		width: 90%;
		padding: 10px 5px 10px 10px;
	}
	
	.img-box, .caption-box, .img-box_middle, .img-box_small, .m-container, .m-flex-container{
		width:100%;
	}
	
	.img-box_small{
		margin-top:40px;
	}

	.caption-box{
		margin-top:20px;
	}
	
	.contents_1{
		padding-bottom:70px;
	}
	
	.center-img{
		width:80%;
		margin-top:10px;
	}
	
	.top-up{
		margin-top:10vw;
		top:15vw;
		margin-bottom:-20vw;
	}
	
	.contents_2 .caption-box{
		top:-45vw;
	}

	
	.contents_3 .img-box{
		width:100%;
	}
	
	.contents_3 .img-box:first-of-type{
		margin-bottom:20px;
	}

	.contents_4 .p-box{
		width:79%;
	}
	
	.bold-sansserif{
		font-size:1.9rem;
	}

	.footer{
		box-sizing: border-box;
		padding:30px 20px 30px;
	}
	
	.map-flex{
		padding-bottom:40px;
	}
	
	.m-container{
		margin-bottom:50px;
	}
	
	.m-container iframe{
		height:300px;
	}
	
	.logoimg{
		width:100px;
		padding:15px 0;
	}
	
	.address p, .credit p, .map p{
		font-size:1.1rem;
	}
	
	.sns-icon li{
		font-size:3rem;
	}
	
	.pc-margin-sp-block{
		margin-left:0;
		display:block;
	}
	
	.slick div{
	  min-height:50vh;
	}

	.slick{
		width:100%;
		height:50vh;
	}
	
	.company_info dt, .company_info dd{
	  width: 100%;
	}
	
	.company_info dt{
	  margin-bottom: 5px;
	  font-weight:bold;
	  text-align: center;
	}
	
	.company_info dd{
		text-align: justify;
	}
	
	.company_info h3, .form_area h2{
		text-align: center;
	}

	
	#p-top{
		padding:6%;
	}


}

/* CSS Document */

