/*!
Theme Name: newseum
Theme URI: https://newseum.me
Author: MESA
Author URI: https://mesas-design.com/
Description: for "newseum" wordpress theme.
Version: 1.0
	
*/

html{
	font-size:62.5%;
	font-family:'Noto Sans JP',"ヒラギノ角ゴ ProN W4","Hiragino Kaku Gothic ProN","游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic","メイリオ","Meiryo","ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;
	@font-face {
		  src: url("../common/fonts/notosans.woff") format("woff");
		  font-family: "Noto Sans JP";
		  font-style: normal;
		  font-display: swap;
	}
	line-height:1.8;
	-webkit-text-size-adjust:100%;
	overflow-x: hidden;
}

.proxima{
	font-family: "proxima-nova",'Noto Sans JP',"ヒラギノ角ゴ ProN W4","Hiragino Kaku Gothic ProN","游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic","メイリオ","Meiryo","ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;
	font-weight: 400;
	font-style: normal;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}


body{
	position:relative;
	overflow-x: hidden;
}

h3{
	font-size:1.8rem;
	letter-spacing: 0.04em;
	line-height:3rem;
	font-weight:400;
}

p,a,li,td,th,div,figure,figcaption{
	font-size:1.5rem;
	font-weight:400;
	line-height:3rem;
	letter-spacing: 0.04em;
	color:#292929;
}

p{
	color:#292929;
}

img{
	max-width:100%;
	height:auto;
	line-height:0;
	/* vertical-align: bottom; */
}

details > summary {
  list-style: none;
}

details > summary::marker {
  content: "";
}

details > summary::-webkit-details-marker {
  display: none;
}

.divider{
	display: none;
}

.sp{
	display:none;
}

.pc{
	display:block;
}

header#header{
	position:fixed;
	top:0;
	left:0;
	width:100%;
	height:6.6rem;
	background:#fff;
	transition: all .3s ease;
	z-index:9990;
}

header#header.active{
	background:#55654E;
}

header#header > .header-inner{
	width:100%;
	padding:1.6rem;
	position:relative;
	z-index:9998;
}

header#header > .header-inner h1{
	display:inline-block;
}

header#header > .header-inner h1 a{
	display:block;
	width:auto;
	height:100%;
}

header#header > .header-inner h1 a img{
	width:auto;
	max-width:15.2rem;
	height:100%;
}

.hmb {
	position:fixed;
	top:0;
	right:0;
	width: 6.6rem;
	height: 6.6rem;
	cursor: pointer;
	z-index: 9999;
	background: #FAFCF4;
	border: none;
	padding: 0;
	transition: all .3s ease;
}

.hmb span:nth-of-type(1),.hmb span:nth-of-type(2) {
  display: block;
  width:3.6rem;
  height: .3rem;
  background: #333;
  transition: all .3s ease;
  position: absolute;
  top: 1.85rem;
  left: 0;
  right: 0;
  margin:0 auto;
  opacity: 1;
  border-radius:100rem;
}

.hmb span:nth-of-type(1) {
}

.hmb span:nth-of-type(2) {
  top:2.85rem;
}

.hmb span:nth-of-type(3){
	position:absolute;
	font-size:1.3rem;
	letter-spacing:0.09em;
	line-height:1.6rem;
	bottom:1.5rem;
	left:0;
	right:0;
	margin:0 auto;
	text-align:center;
	color:#292929;
}

.hmb[aria-expanded=true]{
	background:#55654E;
}

.hmb[aria-expanded=true] span:nth-of-type(1) {
  transform: rotate(30deg);
  top:2.15rem;
  background:#fff;
}

.hmb[aria-expanded=true] span:nth-of-type(2) {
  transform: rotate(-30deg);
  top:2.15rem;
  background:#fff;
}

.hmb[aria-expanded=true] span:nth-of-type(3){
	color:#fff;
}

#nav {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: #55654E;
  /* padding: 6.6rem 0 0 0; */
  overflow-y: auto;
  z-index: 9997;
  opacity:0;
  transition: all .3s ease;
  display:flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  visibility: hidden;
}

#nav:before{
	position:absolute;
	content:"";
	width:100%;
	height:100%;
	background:center / cover no-repeat url(./img/nav_bg_pc.png);
	top:0;
	left:0;
}

#nav.active {
  opacity:1;
  visibility: visible;
}

#nav .nav-logo{
	width:50%;
	height:100%;
	position:relative;
}

#nav .nav-logo > img{
	position:absolute;
	top:0;
	bottom:0;
	right:6.5rem;
	margin:auto 0;
	width:19.7vw;
	height:10.33vw;
}

/* メニュー */
#nav ul {
	width:50%;
	list-style: none;
	padding: 0 0 0 8.2vw;
	margin: 0;
}

#nav ul li {
	margin-bottom: 3.2rem;
}

#nav ul li:last-of-type{
	margin-bottom:0;
}

#nav ul li a {
	position:relative;
	color: #fff;
	text-decoration: none;
	font-size: 16px;
	display:inline-block;
	font-size:1.8rem;
	line-height:3rem;
	letter-spacing: 0.04em;
	transition: all .3s ease;
	transform: translateX(0);
	padding:0 0 0 2rem;
}

#nav ul li a:before{
	position:absolute;
	content:"";
	background:center / contain no-repeat url(./img/nav_arrow.svg);
	width:1.732rem;
	height:1.24rem;
	margin:auto 0;
	top:.2rem;
	bottom:0;
	left:-3.12rem;
}

#nav ul li a:hover{
	font-weight:500;
	text-decoration: underline;
	transform: translateX(1rem);
}

.first-view{
	width:100%;
	position:relative;
}

.fv-inner{
	width:98%;
	max-width:103rem;
	margin:0 auto;
	position:relative;
	padding-top: 6.6rem;
}

.fv-inner:before{
	content:"";
	position:absolute;
	background:center / contain no-repeat url(./img/fv_bg.png);
	top:1.23rem;
	right:-9.8rem;
	width:42.45%;
	height:80%;
	z-index:-1;
}

.fv-image{
	width:67.57%;
	max-width:69.6rem;
	margin:5.87rem 0 10.5rem 0;
}

.fv-image img{
	width:100%;
	height:auto;
}

.fv-lead{
	padding-bottom:8rem;
}

.fv-lead p{
	font-size:1.8rem;
	line-height:4rem;
	letter-spacing: 0.12em;
}

.anker{
	width:100%;
	height:0;
	opacity:0;
}

section.common{
	position:relative;
	width:100%;
}

section.common .inner{
	width:98%;
	max-width:103rem;
	margin:0 auto;
	padding:8rem 0;
	z-index: 1;
    position: relative;
}

.section-title-box{
	display:flex;
	justify-content: flex-start;
	align-items: baseline;
	flex-wrap: wrap;
	margin-bottom:3.9rem;
}

.section-title-box .proxima{
	font-size:4rem;
	letter-spacing:0.09em;
	line-height:4.9rem;
	position:relative;
}

.section-title-box .proxima:before{
	position:absolute;
	content:"";
	background:center / contain no-repeat url(./img/title_logo.svg);
	width:5.962rem;
	height:4.081rem;
	bottom:.8rem;
	left:-6.9rem;
}

.section-title-box h2{
	font-size:1.6rem;
	font-weight:400;
	letter-spacing: 0.04em;
	line-height:2.4rem;
	margin-left:2.7rem;
}

.section-lead{
	margin-bottom:8.3rem;
}

.program-container{
	width:100%;
	position:relative;
}

.program .section-lead{
	margin-top:-1.2rem;
}

.program-container:before{
	position:absolute;
	content:"";
	background:center / contain no-repeat url(./img/box_logo.svg);
	width:7.7rem;
	height:4.25rem;
	top:-4rem;
	left:0;
	right:0;
	margin:0 auto;
}

.program-box{
	position: relative;
	width:100%;
	display:flex;
	justify-content: flex-start;
	align-items: flex-start;
	flex-wrap: wrap;
	padding:3.2rem;
	background:#FAFCF4;
}

.program-box:nth-of-type(2n){
	background:#fff;
}

.program-box:before{
	position:absolute;
	content:"";
	width:100%;
	height:.3rem;
	background:#292929;
	border-radius:100rem;
	top:0;
	left:0;
}

.program-box:last-of-type:after{
	position:absolute;
	content:"";
	width:100%;
	height:.3rem;
	background:#292929;
	border-radius:100rem;
	bottom:0;
	left:0;
}

.pb-left{
	width:32.92%;
	padding-right:3.2rem;
}

.pb-left img{
	width:8.162rem;
	height:auto;
	margin-bottom:2.32rem;
}

.pb-right{
	width:67.08%;
}

.anno{
	margin-top:1.6rem;
	font-size:1.3rem;
	line-height:2.2rem;
	padding:.8rem;
	background:#E7EBF2;
}

.pb-right .anno{
	background:#fff;
}

.program-box + .anno{
	text-align: center;
	margin-top:3.2rem;
	padding:.4rem .8rem;
}
.anno a{
	font-size:1.3rem;
	color:#55654E;
}

.anno a:hover{
	color:#292929;
	font-weight: 500;
}

section.common.feature{
	position:relative;
	background:#FAFCF4;
}

section.common.feature:before{
	position:absolute;
	content:"";
	background:center / contain no-repeat url(./img/feature_bg.png);
	width:100%;
	height:60%;
	top:0;
	left:0;
}

.feature-container{
	margin-top:7.9rem;
	background:#fff;
	display:flex;
	justify-content: center;
	flex-wrap: wrap;
	z-index:1;
}

.feature-box{
	position:relative;
	width:33.3%;
	padding:3.3rem 2.4rem;
}

.feature-box:before{
	position:absolute;
	content:"";
	width:.3rem;
	height:100%;
	background:#292929;
	border-radius:100rem;
	top:0;
	left:0;
}

.feature-box:last-of-type:after{
	position:absolute;
	content:"";
	width:.3rem;
	height:100%;
	background:#292929;
	border-radius:100rem;
	top:0;
	right:0;
}

.feature-box img{
	display: block;
	width:8.21rem;
	height:auto;
	margin:0 auto 1.7rem;
}

.feature-box h3{
	text-align: center;
	position:relative;
	margin-bottom:6.6rem;
}

.feature-box h3:after{
	position:absolute;
	content:"";
	width:.3rem;
	height:3.1rem;
	background:#292929;
	border-radius:100rem;
	bottom:-5rem;
	left:0;
	right:0;
	margin:0 auto;
}

section.common.access{
	position:relative;
	background:#fff;
}

section.common.access:before{
	position:absolute;
	content:"";
	background:center / contain no-repeat url(./img/access_bg.png);
	width:43.63%;
	height:85.49%;
	top:0;
	right:0;
}

.access-container{
	margin:7.9rem 0 8.6rem;
	width:100%;
	position:relative;
}

.access-container:before{
	position:absolute;
	content:"";
	background:center / contain no-repeat url(./img/box_logo.svg);
	width:7.7rem;
	height:4.25rem;
	top:-4rem;
	left:0;
	right:0;
	margin:0 auto;
}

.access-box{
	position: relative;
	width:100%;
	display:flex;
	justify-content: flex-start;
	align-items: flex-start;
	flex-wrap: wrap;
	padding:3.2rem;
	background:#FAFCF4;
}

.access-box:nth-of-type(2n){
	background:#fff;
}

.access-box:before{
	position:absolute;
	content:"";
	width:100%;
	height:.3rem;
	background:#292929;
	border-radius:100rem;
	top:0;
	left:0;
}

.access-box:last-of-type:after{
	position:absolute;
	content:"";
	width:100%;
	height:.3rem;
	background:#292929;
	border-radius:100rem;
	bottom:0;
	left:0;
}

.access-box dt{
	width:32.92%;
	padding-right:3.2rem;
}

.access-box dd{
	width:67.08%;
}

.access-box dd a{
	color:#55654E;
}

.access-box dd a:hover{
	color:#292929;
	font-weight: 500;
}

.map-container{
	margin-top:8.6rem;
}

.map-container iframe{
	width:100%;
	height:32rem;
}

section.common.flow{
	position:relative;
	background:#FAFCF4;
}

section.common.flow:before{
	position:absolute;
	content:"";
	background:center / contain no-repeat url(./img/feature_bg.png);
	width:100%;
	height:100%;
	top:0;
	left:0;
}

ul.flow-container{
	margin-top:8.6rem;
	display:flex;
	justify-content: center;
	flex-wrap: wrap;
	z-index:1;
}

.flow-box{
	position:relative;
	width:33.3%;
	padding:4.1rem 1.54rem;
	background:#fff;
}

.flow-box:nth-of-type(2){
	background:none;
}

.flow-box:before{
	position:absolute;
	content:"";
	width:.3rem;
	height:100%;
	background:#292929;
	border-radius:100rem;
	top:0;
	left:0;
}

.flow-box:last-of-type:after{
	position:absolute;
	content:"";
	width:.3rem;
	height:100%;
	background:#292929;
	border-radius:100rem;
	top:0;
	right:0;
}

.flow-box::marker{
	content:"";
}

.flow-box h3{
	text-align: center;
	position:relative;
	margin-bottom:6.6rem;
}

.flow-box h3:after{
	position:absolute;
	content:"";
	width:.3rem;
	height:3.1rem;
	background:#292929;
	border-radius:100rem;
	bottom:-5rem;
	left:0;
	right:0;
	margin:0 auto;
}

.flow-box h3:before{
	position:absolute;
	content:"";
	background:center / contain no-repeat url(./img/flow_num1.svg);
	width:5.2rem;
	height:5.2rem;
	top:-6.8rem;
	left:0;
	right:0;
	margin:0 auto;
}

.flow-box:nth-of-type(2) h3:before{
	background:center / contain no-repeat url(./img/flow_num2.svg);
}

.flow-box:nth-of-type(3) h3:before{
	background:center / contain no-repeat url(./img/flow_num3.svg);
}

.flow-box p a{
	color:#55654E;
}

.flow-box p a:hover{
	color:#292929;
	font-weight: 500;
}


.p-faq-answer {
  display: none;
}

section.common.faq{
	position:relative;
	background:#fff;
}

section.common.faq:before{
	position:absolute;
	content:"";
	background:center / contain no-repeat url(./img/faq_bg.png);
	width:51.83%;
	height:76.3rem;
	top:9.57%;
	left:4.39%;
}

.faq-container{
	/* margin:7.9rem 0 8.6rem; */
	margin:7.9rem 0 0;
	width:100%;
	position:relative;
}

.faq-container:before{
	position:absolute;
	content:"";
	background:center / contain no-repeat url(./img/box_logo.svg);
	width:7.7rem;
	height:4.25rem;
	top:-4rem;
	left:0;
	right:0;
	margin:0 auto;
}

.p-faq-item{
	position: relative;
	width:100%;
	background:#FAFCF4;
}

.p-faq-item:hover{
	cursor: pointer;
}

.faq-box:nth-of-type(2n) .p-faq-item{
	background:#fff;
}

.p-faq-item:before{
	position:absolute;
	content:"";
	width:100%;
	height:.3rem;
	background:#292929;
	border-radius:100rem;
	top:0;
	left:0;
}

.faq-box:nth-of-type(6) .p-faq-item:after{
	position:absolute;
	content:"";
	width:100%;
	height:.3rem;
	background:#292929;
	border-radius:100rem;
	bottom:0;
	left:0;
}

.p-faq-question::marker{
	content:"";
	display:none;
}

.p-faq-question{
	padding:3.2rem 3.3rem 3.2rem 11.1rem;
	position:relative;
	/* transition:all .3s ease; */
}

.p-faq-question:before{
	position:absolute;
	content:"";
	background:center / contain no-repeat url(./img/faq_icon.svg);
	width:5.2rem;
	height:5.2rem;
	top:2.2rem;
	left:3.2rem;
}

/* .p-faq-item[open] .p-faq-question{
	padding:4.1rem 3.3rem 3.2rem 11.1rem;
} */

.p-faq-qText{
	font-size:1.8rem;
	font-weight:400;
}

.p-faq-answer{
	position: relative;
	padding:2.2rem 3.3rem 3.2rem 11.1rem;
}

.p-faq-answer img{
	position: absolute;
	left:5.6rem;
	top:.4rem;
}

.faq-box{
	position:relative;
}

.p-faq-icon{
	position:absolute;
	content:"";
	background:center / contain no-repeat url(./img/faq_arrow.svg);
	width:2.86rem;
	height:1.58rem;
	top:3.8rem;
	right:3.4rem;
	transition:all .3s ease;
}

.p-faq-icon:hover{
	cursor: pointer;
}

.p-faq-item.is-open + .p-faq-icon{
	transform: rotate(180deg);
}

section.common.contact{
	position:relative;
	background:#fff;
}

section.common.contact:before{
	position:absolute;
	content:"";
	background:center / contain no-repeat url(./img/contact_bg.png);
	width:51.83%;
	height:86.3rem;
	top:9.57%;
	right:4.39%;
}

section.common.contact .inner{
	padding:8rem 1.2rem 0;
}

.contact .section-lead{
	margin-top:-2rem;
	margin-bottom:3.2rem;
}

.tel-container{
	position:relative;
	width:100%;
	background:#FAFCF4;
	padding:2.4rem 1.6rem;
	text-align:center;
}

.tel-container:before{
	position:absolute;
	content:"";
	width:100%;
	height:.3rem;
	background:#292929;
	border-radius:100rem;
	top:0;
	left:0;
}

.tel-container h3{
	font-weight:500;
	margin-bottom:3.2rem;
}

.tel-num{
	margin-bottom:1.5rem;
}

.tel-num a:not(.tel-anno){
	font-size:3.2rem;
	font-family: "proxima-nova",'Noto Sans JP',"ヒラギノ角ゴ ProN W4","Hiragino Kaku Gothic ProN","游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic","メイリオ","Meiryo","ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;
	font-weight: 700;
	font-style: normal;
	line-height:3.9rem;
	letter-spacing: 0.12em;
	text-decoration: none;
}

.tel-num a:not(.tel-anno):hover{
	text-decoration: underline;
	color:#55654E;
}

.tel-num a:not(.tel-anno) span{
	font-size:2.4rem;
	margin-right:.7rem;
}

.tel-anno{
	font-size:1.3rem;
	line-height:2.2rem;
}

.form-container{
	position:relative;
	width:100%;
	background:#fff;
	padding:3.2rem 1.6rem;
	text-align:center;
}

.form-container h3{
	font-weight:500;
	margin-bottom:2.3rem;
}

.form-container:before{
	position:absolute;
	content:"";
	width:100%;
	height:.3rem;
	background:#292929;
	border-radius:100rem;
	top:0;
	left:0;
}

.form-container:after{
	position:absolute;
	content:"";
	width:100%;
	height:.3rem;
	background:#292929;
	border-radius:100rem;
	bottom:0;
	left:0;
}

footer#footer{
	width:100%;
	background:#FAFCF4;
	padding:5rem 0;
	position:relative;
	z-index: 10;
}

footer#footer .inner{
	width:98%;
	max-width:103rem;
	margin:0 auto;
	text-align: center;
}

footer#footer .inner > a{
	display:block;
	margin:0 auto 3.2rem;
	width:60%;
	max-width:15rem;
	height:3.4rem;
}

footer#footer ul{
	list-style: none;
	display:flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	margin:0 auto 1rem;
}

footer#footer ul li a{
	display: block;
	text-decoration: none;
	color:#55654E;
}

footer#footer ul li a:hover{
	color:#292929;
	font-weight: 500;
	text-decoration: underline;
}

footer#footer nav#footer-nav1 ul li a{
	padding:.4rem .8rem;
}

footer#footer nav#footer-nav2 ul{
	margin:0 auto;
}

footer#footer nav#footer-nav2 ul li a{
	padding:0 .8rem;
	font-size:1.3rem;
	color:#555754;
}

footer#footer p.copy-right{
	margin-top:4.2rem;
}

@media(max-width:1170px){
	.section-title-box .proxima:before{
		display:none;
	}
}

@media(max-width:1050px){
	.fv-inner{
		width:100%;
		padding:0 1.2rem;
	}
	section.common .inner{
		width:100%;
		padding:8rem 1.2rem;
	}
}








@media(max-width:600px){
	p,a,li,td,th,div,figure,figcaption{
		font-size:1.5rem;
		line-height:2.4rem;
		letter-spacing: 0.09em;
	}
	.divider{
		width:16rem;
		height:.3rem;
		display: block;
		line-height:0;
		margin:0 auto;
	}
	#nav{
		top:6.6rem;
		flex-direction: column;
		justify-content: flex-start;
		flex-wrap: nowrap;
		overflow-y: scroll;
		padding:0 1.2rem 14.2rem;
		height:100vh;
	}
	#nav .nav-logo{
		width:100%;
		height:auto;
		order:2;
		text-align: center;
	}
	#nav ul{
		width:98%;
		max-width:19.6rem;
		margin:4.9rem auto 9.63rem;
		padding:0;
		height:auto;
		order:1;
	}
	#nav ul li a{
		padding:0;
	}
	#nav .nav-logo > img{
		position:relative;
		right:unset;
		top:unset;
		bottom: unset;
		width:47.18%;
		height:auto;
	}
	#nav:before{
		background:center / cover no-repeat url(./img/nav_bg_sp.png);
	}
	.sp{
		display: block;
	}
	.pc{
		display:none;
	}
	.fv-inner{
		padding:6.6rem 0 0;
	}
	.fv-inner:before{
		background:center / contain no-repeat url(./img/fv_bg_sp.png);
		width:17.4rem;
		height:34.2rem;
		top:40rem;
		right:0;
	}
	.fv-image{
		margin:8rem auto 8.98rem;
		width:60%;
		max-width:22.2rem;
	}
	.fv-lead{
		padding:0 1.2rem 5.5rem;
	}
	.fv-lead p{
		font-size:1.5rem;
		letter-spacing:0.1em;
		line-height:3rem;
	}
	section.common .inner{
		padding:6.57rem 1.2rem 5.5rem;
	}
	.section-title-box{
		display: block;
		margin:0 0 3.23rem 0;
	}
	.section-title-box .proxima{
		font-size:1.4rem;
		line-height:1.7rem;
		margin:0 0 0 3.5rem;
	}
	.section-title-box h2{
		font-size:2.2rem;
		line-height:3.2rem;
		margin:1.3rem 0 0 0;
	}
	.section-title-box .proxima:before{
		display:block;
		width:3.9rem;
		height:2.67rem;
		bottom: .2rem;
    	left: -3.4rem;
	}
	.section-lead{
		margin-bottom:7.15rem;
	}
	.program-box{
		padding:3.2rem 1.2rem;
	}
	.pb-left{
		width:100%;
		padding-right:0;
		text-align:center;
	}
	.pb-right{
		width:100%;
	}
	.pb-left img{
		width:12rem;
		margin:0 auto 1.8rem;
	}
	.pb-left h3{
		margin-bottom:2.4rem;
	}
	.anno{
		margin-top:1.8rem;
		letter-spacing: 0.063em;
	}
	.program-box + .anno{
		margin-top:1.8rem;
	}
	.feature-container{
		margin-top:3.23rem;
		display:block;
	}
	.feature-box{
		width:100%;
	}
	.feature-box:before{
		width:100%;
		height:.3rem;
	}
	.feature-box:last-of-type:after{
		width:100%;
		height:.3rem;
		bottom:0;
		top:unset;
	}
	.feature-box{
		padding:3.2rem 1.2rem;
	}
	.feature-box img{
		width:8rem;
		margin:0 auto 1.82rem;
	}
	.feature-box h3{
		margin-bottom:6.87rem;
	}
	.feature-box .anno{
		margin-top:1.6rem;
	}
	.access-container{
		margin:7.15rem 0 4.6rem;
	}
	.access-box{
		padding:2rem 1.2rem;
		display:block;
	}
	.access-box dt{
		padding:0;
		width:100%;
		margin-bottom:1.6rem;
		font-weight:500;
	}
	.access-box dd{
		width:100%;
	}
	.access-box dd a{
		font-weight:500;
	}
	.map-container{
		margin-top:0;
	}
	ul.flow-container{
		margin-top:3.18rem;
		display:block;
	}
	.flow-box{
		width:100%;
		padding:9.98rem 1.2rem 3.25rem 1.2rem;
	}
	.flow-box:before{
		width:100%;
		height:.3rem;
	}
	.flow-box:last-of-type:after{
		width:100%;
		height:.3rem;
		bottom:0;
		top:unset;
	}
	.flow-box:nth-of-type(2){
		background:#fff;
	}
	.flow-box h3{
		margin-bottom:6.87rem;
	}
	.faq-container{
		margin:7.15rem 0 0;
	}
	.p-faq-question{
		padding:10.3rem 1.2rem 6.4rem;
		text-align:center;
	}
	.p-faq-question:before{
		right:0;
		left:0;
		top:3.2rem;
		margin:0 auto;
	}
	.p-faq-icon.target{
		/* position:static;
		display:block; */
		transform: translateY(1.5rem) rotate(180deg);
		top:unset;
		bottom:3.2rem;
		left:0;
		right:0;
		width:2.6rem;
		height:1.3rem;
		margin:0 auto;
	}
	.p-faq-icon.target.visible{
		transform: translateY(0) rotate(180deg);
	}
	.p-faq-item.is-open .p-faq-icon.target.visible{
		transform: rotate(0deg);
	}
	.p-faq-answer{
		margin-top:-5.28rem;
		padding:0 1.2rem 7.68rem;
	}
	.p-faq-answer img{
		display:none;
	}
	/* .p-faq-item.is-open .p-faq-question{
		padding: 10.3rem 1.2rem 2.4rem;
	} */
	 .p-faq-item.is-open + .p-faq-icon{
		transform: rotate(0deg);
	}
	section.common.faq .divider{
		margin:0 auto .3rem;
	}
	.contact .section-lead{
		margin-top:0;
	}
	.tel-container h3{
		margin-bottom:1.66rem;
	}
	.form-container h3{
		margin-bottom:.4rem;
	}
	footer#footer{
		position:relative;
		padding:3.2rem 1.2rem 4.4rem;
		z-index:10;
	}
	footer#footer:before{
		position:absolute;
		content:"";
		background:center / contain no-repeat url(./img/footer_bg.png);
		width:100%;
		height:44.7rem;
		bottom:0;
		left:0;
		z-index:-1;
	}
	footer#footer .inner{
		width:100%;
	}
	footer#footer ul{
		padding:0;
		margin:0 auto 2.6rem;
	}
	footer#footer nav#footer-nav1 ul{
		flex-direction: column;
		justify-content: center;
		flex-wrap: nowrap;
	}
	footer#footer nav#footer-nav1 ul li a{
		padding:.8rem .4rem;
	}
	footer#footer p.copy-right{
		margin-top:4rem;
	}
	section.common.feature:before,section.common.access:before,section.common.flow:before,section.common.faq:before,section.common.contact:before{
		display:none;
	}
}



/* フェードインアニメーション */
.target{
	transition:all .3s ease;
	opacity:0;
	transform: translateY(1.5rem);
}

.target.visible{
	opacity:1;
	transform: translateY(0);
}


/* lottie */
#opening{
  position:fixed;
  inset:0;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:9999;
  opacity:1;
  transition:opacity .35s ease;
}
#opening.is-hide{ opacity:0; pointer-events:none; }

#openingLottie{
  width:min(100%,100vh);
  height:auto;
}

.fv-image,.fv-lead{
	opacity:0;
	transition:all .8s ease;
}

.first-view.visible .fv-image,.first-view.visible .fv-lead{
	opacity:1;
}

/* cf7 */
#formBox{
	width:100%;
  }
  
  .formTable{
	width: 100%;
	table-layout: fixed;
  }
  
  .formTable tr {
	/* border-bottom: 1px solid #F2E5E1; */
	display: block;
	/* padding: 10px 0 0; */
	/* margin-bottom:1.6rem; */
  }
  
  .formTable th, .formTable td{
	padding: 0;
	  width: 100%;
	  display: block;
	  text-align: left;
  }

  .formTable th{
	padding: 16px 16px 16px 0;
  }
  
  .formTable input,.formTable textarea{
	width:100%;
  }
  
  .require{
	background: #fff;
    border: .1rem solid #F15C47;
    padding: 1px 8px 0;
    color: #F15C47;
    border-radius: .3rem;
    margin-left:1rem;
  }
  
  .any{
	background: #fff;
	padding: 0px 8px;
	border: .1rem solid #B1B5AF;
	color:#6B6E6A;
	border-radius: .3rem;
	margin-left:1rem;
  }
  
  #submit{
	position:relative;
	text-align: center;
	margin:1.6rem auto 5.8rem;
	display:inline-block;
  }
  
  #submit > input[type="submit"]{
	position:relative;
	padding: 1.9rem 1rem;
    width: auto;
    min-width: 29rem;
    letter-spacing: .4rem;
	line-height:3rem;
    background-color: #fff;
    color: #292929;
    border: .1rem solid #B1B5AF;
    border-radius: 10rem;
    font-size: 1.8rem;
    transition: all .3s ease;
  }
  #submit > input[type="submit"]:hover{
	background-color:#292929;
	color:#fff;
  }
  #submit:after{
	position:absolute;
	content:"";
	background:center / contain no-repeat url(./img/submit_arrow.svg);
	width:1.732rem;
	height:1.24rem;
	right:5rem;
	top:0;
	bottom:0;
	margin:auto 0;
	pointer-events: none;
  }
  #submit:hover:after{
	background:center / contain no-repeat url(./img/submit_arrow_w.svg);
  }
  @media(min-width:768px) {
	#formBox{
		width:83%;
		max-width: 780px;
		margin:0 auto;
	  }
	  .formTable tr{
		/* display:table-row; */
		padding:0;
	  }
	  .formTable th{
		/* width:20%;
		display: table-cell;
		vertical-align: baseline; */
		/* padding: 16px 16px 16px 0; */
	  }
	  .formTable td{
		/* width:72.68%;
		display: table-cell;
		padding: 0; */
	  }
  }
  @media(min-width:601px){
	#submit{
		margin:1.6rem auto 5.8rem;
	}
  }
  .wpcf7-spinner{
	/* display:block !important;
	margin:1.2rem auto !important; */
	position:absolute !important;
  }
  .formTable input, .formTable textarea{
    background: #fff;
    border-radius: .3rem;
    padding: 1rem 1rem;
    margin-bottom: 1.6rem;
    border: .3rem solid #292929;
  }
  @media(max-width:600px){
	.formTable input, .formTable textarea{
		padding:.6rem 1rem;
	}
	.form-container{
		padding:3.2rem 0rem;
	}
	.contact-anno{
		font-size:1.2rem;
	}
	.require,.any{
		font-size:1.2rem;
		padding:0 .4rem;
	}
	.formTable th{
		padding:1.6rem 0;
	}
	.tel-num a:not(.tel-anno){
		font-size:3.0rem;
		letter-spacing: 0.04em;
	}
  }
  .wpcf7-not-valid-tip{
	margin-bottom:1.2rem;
  }
  #submit > input[type="submit"]{
	cursor:pointer;
  }