@charset "UTF-8";
/*
 * style_sp.css
 *
 *  version --- 1.0
 *  updated --- 2017/11/30
 */

.pc{display: none!important;}
/* !wrapper
---------------------------------------------------------- */
#wrapper {
	overflow: hidden;
	width: 100%;
	padding-top: 6.6rem;
}
.menuOpen{
	overflow: hidden;
	height: 100dvh;
}
.menuOpen #wrapper{
	position: fixed;
}
.overlay{
	display: none;
	position: fixed;
	left: 0;
	top: 0;
	width: 100vw;
	height: 100dvh;
	background: none;
	z-index: 97;
	text-indent: -999rem;
	pointer-events: auto;
}


.inner,
.inner02 {
	margin: 0 auto;
	width: 100%;
	padding: 0 1.5rem;
	position: relative;
	z-index: 3;
}
/* !header
---------------------------------------------------------- */
#header {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 99;
	width: 100%;
	transition: background .3s;
	background: #fff;
	box-shadow: 0 .3rem .8rem 0 rgba(0, 0, 0, 0.1);
}
#headerIn {
	display: flex;
	justify-content: center;
	align-items: flex-end;
	height: 6.6rem;
}
#headerLogo {
	width: 19.8rem;
}
#headerLogo img{
	width: 100%;
}

.fixed_list{
	position: fixed;
	right: 0;
	bottom: 0;
	width: 100%;
	display: flex;
}
.fixed_list li{
	width: 52.8%;
}
.fixed_list li+li{
	width: 47.2%;
}
.fixed_list a{
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	text-align: center;
	padding-left: 3.3rem;
	background: url(../img/icon_email.svg)no-repeat left 1.8rem center;
	background-size: 3rem auto;
	background-color: #253F77;
	color: #fff;
	font-size: 1.8rem;
	line-height: 1.3;
	font-weight: 700;
	width: 100%;
	height: 7.4rem;
}
.fixed_list a.fixed_list_tel{
	background: url(../img/icon_tel.svg)no-repeat left 1.3rem center;
	background-size: 3rem auto;
	background-color: #F87928;
	font-size: 1.1rem;
	font-weight: 500;
}
.fixed_list a.fixed_list_tel .number{
	font-size: 2.3rem;
	font-weight: 700;
}


.btnMenu {
	position: fixed;
	right: 0;
	top: 0;
	z-index: 99;
}
.btnMenu a {
  display: block;
  width: 5.4rem;
  height: 6.6rem;
  opacity: 1!important;
  box-sizing: border-box;
  position: relative;
}

.btnMenu a span {
  display: block;
  background: #253F77;
  width: 2.4rem;
  height: .2rem;
  position: absolute;
  left: 1.5rem;
  transition: all 0.4s;
  -webkit-transition: all 0.4s;
  -moz-transition: all 0.4s;
}

.btnMenu a span:first-child {
	top: 2.3rem;
}

.btnMenu a span:nth-child(2) {
	margin-top: -.2rem;
	top: 50%;
}

.btnMenu a span:last-child {
	bottom: 2.3rem;
	width: 1.4rem;
}

	
.btnMenu.active a span:first-child {
  -webkit-transform: translateY(.9rem) rotate(45deg);
  -moz-transform: translateY(.9rem) rotate(45deg);
  -ms-transform: translateY(.9rem) rotate(45deg);
  transform: translateY(.9rem) rotate(45deg);
}

.btnMenu.active a span:nth-child(2) {
  opacity: 0;
}

.btnMenu.active a span:last-child {
  width: 2.4rem;
  -webkit-transform: translateY(-.9rem) rotate(-45deg);
  -moz-transform: translateY(-.9rem) rotate(-45deg);
  -ms-transform: translateY(-.9rem) rotate(-45deg);
  transform: translateY(-.9rem) rotate(-45deg);
}

/* !gNavi
---------------------------------------------------------- */
#gNavi {
	position: fixed;
	top: 6.5rem;
	right: 0;
	width: 100%;
	height: calc(100dvh - 6.5rem);
	z-index: 98;
	box-sizing: border-box;
	padding: 5.5rem 1.5rem 8rem;
	overflow-x: hidden;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	opacity: 0;
	pointer-events: none;
	transition: opacity .3s,right .3s;

	background:  #fff;
}
#gNavi.active{
    opacity: 1;
    pointer-events: auto;
}	
.nav_list{
	display: grid;
	text-align: center;
	grid-gap: 2rem;
}
.nav_list li {
	
}
.nav_list li a {
	font-size: 1.8rem;
	line-height: 1.5;
	font-weight: 700;
	letter-spacing: .05em;
	color: #253F77;
}

.nav_list02{
	display: grid;
	grid-gap: 2rem;
	margin-top: 7rem;
}
.nav_list02 a{
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	text-align: center;
	padding-left: 3.3rem;
	background: url(../img/icon_email.svg)no-repeat left 4.4rem center;
	background-size: 3.8rem auto;
	background-color: #253F77;
	color: #fff;
	font-size: 2rem;
	line-height: 1.3;
	font-weight: 700;
	width: 100%;
	height: 7.8rem;
	border-radius: .6rem;
}
.nav_list02 a.fixed_list_tel{
	background: url(../img/icon_tel.svg)no-repeat left 4.5rem center;
	background-size: 3.5rem auto;
	background-color: #F87928;
	font-size: 1.2rem;
	font-weight: 500;
	padding-bottom: 1rem;
}
.nav_list02 a.fixed_list_tel .number{
	font-size: 2.7rem;
	font-weight: 700;
}
	
/* !mainVisual
---------------------------------------------------------- */
#mainVisual {
	padding: 0 1.5rem;
}
.mv_inner{
	position: relative;
	padding-bottom: 4.7rem;
}
.mv_img_list{
	display: grid;
	grid-template-areas: 'd d''b c''a a';
	grid-gap: 1rem;
}
.mv_img_item{
	overflow: hidden;
}
.mv_img_item img{
	width: 100%;
}
.mv_img_item:nth-of-type(1){
	border-radius: 3rem 0 3rem 0;
	grid-area: a;
}
.mv_img_item:nth-of-type(1) img{
	height: 15.8rem;
	object-fit: cover;
}
.mv_img_item:nth-of-type(2){
	border-radius: 3rem 0 3rem 0;
	grid-area: b;
}
.mv_img_item:nth-of-type(3){
	border-radius: 0 3rem 0 3rem;
	grid-area: c;
}
.mv_img_item:nth-of-type(4){
	border-radius: 0 3rem 0 3rem;
	grid-area: d;
}

.mv_cont{
	position: absolute;
	left: -1rem;
	bottom: 0;
	/*top: 20.9rem;*/
	z-index: 9;
	white-space: nowrap;
}
.mv_text01{
	text-align: center;
	margin-bottom: 1.1rem;
}
.mv_text01 img{
	width: 29.7rem;
}
.mv_text02{
	background: #fff;
	border-radius: .7em;
	padding: .2rem .7rem .2rem 1.3rem;
	font-size: 1.8rem;
	font-weight: 500;
	margin-bottom: .6rem;
}
.mv_text02 span{
	font-size: 3.2rem;
	color: #253F77;
	font-weight: 700;
}
.mv_text02 font{
	margin: 0 -.4em 0 -.2em;
}
.mv_text03{
	background: #fff;
	border-radius: .7rem;
	padding: .4rem .7rem .4rem 1.3rem;
	font-size: 1.6rem;
	font-weight: 500;
}
.mv_text03 span{
	font-size: 2.1rem;
	color: #253F77;
	font-weight: 700;
	letter-spacing: -0.08em;
}
.mv_text04{
	padding-left: .5rem;
	padding-top: 2.1rem;
}
.mv_text04 dt{
	display: flex;
	justify-content: center;
	align-items: center;
	width: 14.6rem;
	height: 4.7rem;
	border-radius: 4.8rem;
	background: #F87928;
	color: #fff;
	font-size: 1.4rem;
	font-weight: 700;
	border: .7rem solid #fff;
}
.mv_text04 dd{
	margin-top: .9rem;
	font-size: 1.8rem;
	line-height: 1.5;
	font-weight: 500;
	position: relative;
	display: inline-flex;
}
.mv_text04 dd span{
	position: absolute;
	left: 100%;
	bottom: .4rem;
	font-size: 1rem;
	line-height: 1.5;
	font-weight: 500;
}
/* !pageTop
---------------------------------------------------------- */
.pageTop {
	position: absolute;
	right: 1.5rem;
	bottom: calc(100% - 1px);
	z-index: 2;
	width: 21.1rem;	
}
.pageTop img{
	width: 100%;
}

/* !footer
---------------------------------------------------------- */
#footer {
	background: #253F77;
	color: #fff;
	padding: 3.5rem 0 10rem;
	text-align: center;
	position: relative;
}

#footer .footerIn {
	padding: 0 1.5rem;
}

.footer_logo img{
	width: 28.2rem;
}
.footer_addr{
	font-size: 1.4rem;
	line-height: 1.71;
	font-weight: 500;
	margin: 0.8rem 0 3.5rem;
}
.footer_link{
	margin-bottom: 3rem;
	display: grid;
	grid-gap: 1.5rem;
	text-align: center;
}
.footer_link a{
	font-size: 1.6rem;
	font-weight: 700;
	letter-spacing: .05em;
	color: #fff;
}
.footer_list{
	display: grid;
	grid-gap: 1.2rem;
}
.footer_list a{
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	padding-left: 4rem;
	background: url(../img/icon_email_blue.svg)no-repeat left 4.5rem center;
	background-size: 3.5rem auto;
	background-color: #fff;
	color: #253F77;
	font-size: 2rem;
	line-height: 1.3;
	font-weight: 700;
	width: 100%;
	height: 7.8rem;
	border-radius: .6rem;
}
.footer_list a.fixed_list_tel{
	background: url(../img/icon_tel.svg)no-repeat left 4.5rem center;
	background-size: 3.5rem auto;
	background-color: #F87928;
	color: #fff;
	padding-left: 3rem;
	padding-bottom: .7rem;
	font-size: 1.2rem;
	line-height: 1;
	font-weight: 500;
}
.footer_list a.fixed_list_tel .number{
	font-size: 2.7rem;
	line-height: 1.2;
	font-weight: 700;
}
	
#copyright {
	margin-top: 3rem;
	font-size: 1.1rem;
	letter-spacing: .05em;
	color: #E8E8E9;
}

/*top*/
.top_sec01{
	padding: 5.3rem 2rem 8.4rem;
	text-align: center;
	background: url(../img/bg_sec01_sp.svg)no-repeat bottom -.2rem center,
	url(../img/bg_blue.png)no-repeat top 14.4rem center,
	url(../img/bg_blue02.png)no-repeat bottom center;
	background-size: auto 8.4rem,100% auto,100% 25rem;
	overflow: hidden;
}
.top_sec01_title{
	font-size: 2rem;
	font-weight: 500;
	line-height: 1.3;
	margin-bottom: 9.5rem;
}
.top_sec01_title span{
	font-size: 3rem;

	background-image: linear-gradient(to right, #FFED69 0%, #FFED69 50%, #FFED69 50%);
	background-size: 100% 75%;
	background-position: top 65% center;
	background-repeat: no-repeat;
}
.top_sec01_box ul{
}
.top_sec01_box li{
	color: #fff;
	font-size: 1.6rem;
	line-height: 1.6;
	font-weight: 500;
	position: relative;
	padding: .9rem 0;
	border-bottom: 1px solid #F9FBFD;
	text-align: left;
}
.top_sec01_box li span{
	font-size: 1.6rem;
	font-weight: 700;
	color: #FFED69;
}
.top_sec01_box li br{
	display: none;
}

/*top_sec02*/
.top_sec02{
	padding: 5.7rem 0 6rem;
	background: url(../img/bg_sec02.png)repeat-y top center;
	background-size: 100% auto;
	overflow: hidden;
}
.top_sec02 .inner{
	max-width: 170rem;
}
.top_sec02_text{
	text-align: center;
	font-size: 1.6rem;
	line-height: 1.55;
	letter-spacing: .05em;
	font-weight: 500;
}
.top_sec02_text span{
	font-family: "Noto Serif JP", serif;
	font-size: 2.4rem;
	font-weight: 700;
	color: #F87928;
}
.top_sec02_text span.dot_span font{
	position: relative;
}
.top_sec02_text span.dot_span font:before{
	content: '';
	position: absolute;
	bottom: calc(100% + .4rem);
	left: 0;
	width: 100%;
	height: .5rem;
	background: url(../img/dot.svg)no-repeat top center;
	background-size: .5rem auto;
}

.top_sec02_categ{
	text-align: center;
	margin: 4.8rem 0 2.4rem;
}
.top_sec02_categ span{
	display: inline-flex;
	justify-content: center;
	align-items: center;
	height: 3.1rem;
	width: 28.8rem;
	max-width: 100%;
	border-radius: 2.5rem;
	font-size: 1.6rem;
	font-weight: 700;
	letter-spacing: .05em;
	color: #fff;
	background: #F87928;
}
.hd_m{
	text-align: center;
	font-size: 1.8rem;
	letter-spacing: .05em;
	font-weight: 700;
	line-height: 1;
	font-family: "Noto Serif JP", serif;
	margin: 0 -1rem;
}
.hd_m span{
	font-size: 2.4rem;
	color: #F87928;
}

.top_sec02_list{
	margin-top: 4.2rem;
	display: grid;
	grid-gap: 2.7rem;
}
.top_sec02_item{
	display: grid;
	position: relative;
}
.top_sec02_item dt{
	position: relative;
	z-index: 9;
	width: 29.2rem;
  -webkit-animation-name: fadeInLeft02;
  animation-name: fadeInLeft02;
}
.top_sec02_item dt img{
	width: 100%;
	height: 18.4rem;
	object-fit: cover;
	border-radius: 0 3rem 0 3rem;
}
.top_sec02_item dd{
	margin-top: -7rem;
	background: #fff;
	border-radius: 1.4rem;
	padding: 9.7rem 2rem 3rem;
}
.top_sec02_item .number{
	position: absolute;
	right: 0;
	top: 6.5rem;
	z-index: 11;
	font-size: 9rem;
	line-height: 1;
	font-weight: 500;
	color: #F87928;
}
.top_sec02_item .point{
	position: absolute;
	z-index: 11;
	right: .5rem;
	top: 14.8rem;
	width: 12rem;
}
.top_sec02_item .point img{
	width: 100%;
}
.top_sec02_item .title{
	font-size: 2rem;
	line-height: 1.5;
	color: #253F77;
	margin-bottom: 1.3rem;
	font-family: "Noto Serif JP", serif;
	font-weight: 700;
}
.top_sec02_item .text{
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.875;
}
.top_sec02_item .text p+p{
	margin-top: 1.1rem;
}

/*top_sec03*/
.top_sec03{
	padding: 6rem 0 0;
	overflow: hidden;
}
.hd_text{
	text-align: center;
	margin: 2rem 0 2.5rem;
	font-size: 1.6rem;
	line-height: 1.625;
	font-weight: 500;
}
.img_box {
    position: relative;
    width: 100%;
    padding-top: 66%;
    overflow: hidden;
}
.img_box img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 2;
    object-fit: cover;
    transition: transform .4s ease;
}

.top_sec03_slick{
	padding-bottom: 3.1rem;
	margin-top: 3.3rem;
}
.top_sec03_slick .slick-list{
	overflow: visible;
}
.top_sec03_item{
	margin: 0 .1rem;
	max-width: 20rem;
	width: 20rem;
	transform: scale(.87);
	transform-origin: bottom center;
	transition: transform .5s;
	position: relative;
}
.recommend:before{
	content: 'スタッフいちおし';
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	padding: .6rem;
	z-index: 9;
	width: 7.5rem;
	height: 7.5rem;
	border-radius: 50%;
	position: absolute;
	right: -1.3rem;
	top: -1.8rem;
	background: #EE5A5A;
	color: #fff;
	font-size: 1.4rem;
	font-weight: 700;
}
.top_sec03_item.slick-center,
.top_sec03_item.slick-active,
.top_sec03_item.slick-current{
	transform: scale(1);
}
.top_sec03_item .img_box{
	padding-top: 100%;
	border-radius: 0 3rem 0 3rem;
}
.top_sec03_item .title{
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 1.2;
	margin: 2rem 0 1rem;
	text-align: center;
	font-family: "Noto Serif JP", serif;
}

.top_sec03_item .title span {
	display: block;
	font-size: 1.08rem;
	margin-top: .36rem;
}

.top_sec03_item .price{
	display: flex;
	justify-content: center;
	align-items: center;
	grid-gap: .8rem;
}
.top_sec03_item .price dt{
	width: 10rem;
	height: 2.6rem;
	border-radius: 2rem;
	background: #253F77;
	color: #fff;
	font-size: 1.4rem;
	font-weight: 500;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
}
.top_sec03_item .price dd{
	font-size: 1.2rem;
	line-height: 1.3;
	font-weight: 700;
	letter-spacing: .05em;
	color: #253F77;
}
.top_sec03_item .price dd span{
	font-size: 2rem;
}

.top_sec03_btn{
	text-align: center;
	margin-top: 3rem;
}
.top_sec03_btn a{
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 126rem;
	max-width: 100%;
	height: 5.9rem;
	font-size: 1.8rem;
	font-weight: 500;
	letter-spacing: .05em;
	background: url(../img/arrow_orange.svg)no-repeat right 2.7rem center #F87928;
	background-size: 2.9rem auto;
	color: #fff;
	border-radius: 1rem;
}

/*.top_sec04{
	padding: 6rem 0;
	overflow: hidden;
}
.top_sec04_slick{
	padding-bottom: 3.5rem;
}
.top_sec04_slick .slick-list{
	overflow: visible;
}
.top_sec04_item{
	max-width: 31.5rem;
	width: 31.5rem;
	margin: 0 .75rem;
	position: relative;
}
.event_img img{
	width: 100%;
	height: 21.3rem;
    object-fit: cover;
	border-radius: 0 3rem 0 3rem;
}
.top_sec04_item .title{
	font-family: "Noto Serif JP", serif;
	font-size: 2rem;
	letter-spacing: .05em;
	font-weight: 700;
	color: #253F77;
	display: flex;
	grid-gap: 1.5rem;
	margin: 1.5rem 0 1rem;
}
.top_sec04_item .text{
	font-size: 1.6rem;
	line-height: 1.3;
	font-weight: 500;
	letter-spacing: .05em;
}
.top_sec04_item .tag{
	margin-top: 2rem;
	display: flex;
	justify-content: center;
	grid-gap: .7rem;
}
.top_sec04_item .tag span{
	display: inline-flex;
	justify-content: center;
	align-items: center;
	height: 3rem;
	padding: 0 1.8rem;
	border-radius: 2rem;
	font-size: 1.4rem;
	font-weight: 700;
	color: #253F77;
	border: 1px solid #253F77;
}*/


.twentytwenty-overlay:hover{
	background: none;
}
.twentytwenty-after-label,
.twentytwenty-before-label{
	opacity: 1!important;
}

.twentytwenty-horizontal .twentytwenty-before-label:before, 
.twentytwenty-horizontal .twentytwenty-after-label:before{
	width: 9.6rem;
	height: 3rem;
	border-radius: 3rem;
	font-size: 1.4rem;
	font-weight: 700;
	top: 1rem;
	margin-top: 0;
	text-transform: uppercase;
	display: flex;
	justify-content: center;
	align-items: center;
}
.twentytwenty-horizontal .twentytwenty-before-label:before{
	background: #888888;
	left: 1rem;
}
.twentytwenty-horizontal .twentytwenty-after-label:before{
	background: #F87928;
	right: 1rem;
}

.twentytwenty-handle{
	background: #fff;
	width: 3.2rem;
	height: 3.2rem;
	margin-left: -1.6rem;
	border: 0;
	box-shadow: none;
}
.twentytwenty-right-arrow,
.twentytwenty-left-arrow{
	margin: 0;
	transform: translateY(-50%);
	border: .5rem solid transparent;
}
.twentytwenty-right-arrow{
	border-right: .9rem solid #F87928;
	right: 57%;
}
.twentytwenty-left-arrow{
	border-left: .9rem solid #F87928;
	left: 57%;
}
.twentytwenty-horizontal .twentytwenty-handle:after,
.twentytwenty-horizontal .twentytwenty-handle:before{
	margin-bottom: 0;
	box-shadow: none;
	background: #fff;
	width: .3rem;
	margin-left: -.15rem;
}
.twentytwenty-horizontal .twentytwenty-handle:after{
	margin-top: 0;
}

.top_sec05{
	padding: 6rem 0;
	background: url(../img/bg_sec02.png)repeat-y top center;
	background-size: 100% auto;
}
.top_sec05 .inner{
	max-width: 136rem;
}
.top_sec05_box{
}
.top_sec05_left{
}
.top_sec05_left .hd_m{
}
.top_sec05_left .hd_text{
	margin-bottom: 7rem;
}
.top_sec05_slick{
	padding-bottom: 3.4rem;
}
.top_sec05_slick .slick-list{
	overflow: visible;
}
.top_sec05_item{
	width: 27.8rem;
	max-width: 27.8rem;
	margin: 0 1rem;
	position: relative;
}
.top_sec05_item .img{
	margin: 0 auto;
	width: 22.1rem;
	height: 17.4rem;
	border-radius: 0 3rem 0 3rem;
	background: #fff;
	display: flex;
	align-items: flex-end;
	justify-content: center;
}
.top_sec05_item .img img{
	height: 22.3rem;
}
.top_sec05_item .cont{
}
.top_sec05_item .title{
	font-size: 1.6rem;
	font-weight: 500;
	margin-bottom: 2rem;
	position: absolute;
	left: 0;
	top: -2rem;
	z-index: 9;
	writing-mode: vertical-lr;
	opacity: 0;
}
.top_sec05_item.slick-current .title{
	opacity: 1;
}

.top_sec05_item .title span{
	font-size: 2rem;
	font-weight: 700;
	color: #253F77;
	font-family: "Noto Serif JP", serif;
	display: block;
}
.top_sec05_item .text{
	background: #fff;
	padding: 2rem;
	border-radius: 1rem;
	font-size: 1.6rem;
	line-height: 1.3;
	font-weight: 500;
	position: relative;
	margin-top: 2.5rem;
}
.top_sec05_item .text:before{
	content: '';
	position: absolute;
	left: 50%;
	bottom: 100%;
	transform: translateX(-50%);
	border: .85rem solid transparent;
	border-bottom: 1.4rem solid #fff;
}

.top_sec06{
	padding: 5rem 0 0;
	overflow: hidden;
	background: url(../img/bg_sec06_sp.jpg)no-repeat center center;
	background-size: cover;
}
.top_sec06 .inner{
	max-width: 136rem;
}
.top_sec06_box{
	display: flex;
	flex-direction: column-reverse;
	position: relative;
}
.top_sec06_img{
	width: 37.5rem;
	margin: 1.1rem -1.5rem 0;
} 
.top_sec06_img img{
	width: 100%;
}
.top_sec06_cont{
}
.top_sec06_title{
	font-size: 2.4rem;
	font-weight: 700;
	color: #fff;
	font-family: "Noto Serif JP", serif;
	margin-bottom: 2rem;
	text-align: center;
}
.top_sec06_list{
	display: grid;
	grid-gap: 1.5rem;
	margin-bottom: 4rem;
}
.top_sec06_list li{
	background: #F9FBFD;
	color: #253F77;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 1rem;
	border-radius: 5rem;
	grid-gap: .6rem;
	font-size: 1.4rem;
	line-height: 1.1;
	font-weight: 500;
	letter-spacing: .05em;
}
.top_sec06_list li:last-of-type{
	flex-direction: column;
}
.top_sec06_list li span{
	font-size: 2rem;
	font-weight: 700;
	font-family: "Noto Serif JP", serif;
}
.top_sec06_border{
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.8;
	color: #fff;
	border: 2px solid #FFFFFF;
	border-top: 0;
	text-align: center;
}
.top_sec06_border p{
	overflow: hidden;
	position: relative;
	top: -1.2em;
	margin-bottom: -1rem;
}
.top_sec06_border p span{
	display: inline-block;
	padding: 0 .5rem;
	position: relative;
}
.top_sec06_border p span:before,
.top_sec06_border p span:after{
	content: '';
	position: absolute;
	left: 100%;
	height: 2px;
	top: 1.2em;
	background: #fff;
	width: 100%;
}
.top_sec06_border p span:before{
	left: auto;
	right: 100%;
}

.top_sec07{
	padding: 6rem 0 0;
}
.top_sec07 .inner{
	max-width: 136rem;
}
.top_sec07_head{
	text-align: center;
	font-size: 2.4rem;
	font-weight: 500;
	margin-bottom: 3.6rem;
}
.top_sec07_list{
	display: grid;
	grid-gap: 3.6rem;
}
.top_sec07_item{
	position: relative;
	border: .3rem solid #F87928;
	padding: 2.3rem 1.6rem;
	border-radius: 0 4rem 0 4rem;
	display: flex;
	align-items: center;
}
.top_sec07_item:nth-of-type(even){
	border-color: #253F77;
}

.top_sec07_step{
	position: absolute;
	left: 50%;
	top: 0;
	transform: translate(-50%,-50%);
	display: flex;
	justify-content: center;
	align-items: center;
	width: 23.5rem;
	height: 3.1rem;
	border-radius: 3rem;
	background: #F87928;
	color: #fff;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: .05em;
}
.top_sec07_item:nth-of-type(even) .top_sec07_step{
	background: #253F77;
}
.top_sec07_item_box{
	width: 100%;
}
.top_sec07_item_left{
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
} 
.top_sec07_dl{
	margin-top: 1.5rem;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column-reverse;
}
.top_sec07_icon{
	width: 5.1rem;
}
.top_sec07_icon img{
	width: 100%;
}
.top_sec07_title{
	color: #F87928;
	text-align: center;
	font-size: 1.6rem;
	line-height: 1.5625;
	font-weight: 700;
	margin-top: .5rem;
}
.top_sec07_item:nth-of-type(even) .top_sec07_title{
	color: #253F77;
}
.top_sec07_dl dd{
	font-size: 1.6rem;
	line-height: 1.875;
	font-weight: 500;
	width: 100%;
	margin-bottom: 1.5rem;
	display: none;
}
.top_sec07_dl dt{
	display: flex;
	align-items: center;
	height: 3.1rem;
	padding-left: 4.4rem;
	background: url(../img/icon_open.svg)no-repeat left center;
	background-size: 3.1rem auto;
	font-size: 1.6rem;
	font-weight: 500;
}
.top_sec07_dl dt.is_active{
	background: url(../img/icon_close.svg)no-repeat left center;
	background-size: 3.1rem auto;
}

.top_sec07_item:nth-of-type(even) .top_sec07_dl dt{
	background: url(../img/icon_open_blue.svg)no-repeat left center;
	background-size: 3.1rem auto;
}
.top_sec07_item:nth-of-type(even) .top_sec07_dl dt.is_active{
	background: url(../img/icon_close_blue.svg)no-repeat left center;
	background-size: 3.1rem auto;
}

.is_close{
	display: none;
}
.top_sec07_dl dt.is_active .is_close{
	display: block;
}
.top_sec07_dl dt.is_active .is_open{
	display: none;
}
/*top_sec08*/
.top_sec08{
	padding: 10.5rem 0 8rem;
	background: url(../img/bg_sec08_sp.png)no-repeat top center,
	url(../img/bg_gray.png)no-repeat top 10rem center;
	background-size: 100% auto,100% 100%;
	overflow: hidden;
}
.top_sec08 .inner{
	max-width: 106rem;
	max-width: 108rem;
}
.top_sec08_head{
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.4;
	text-align: center;
	margin-bottom: 4.4rem;
}
.top_sec08_head span{
	display: block;
	margin-bottom: 1rem;
}
.top_sec08_head font{
	font-size: 2.4rem;
	font-weight: 700;
	color: #F87928;
}
.smf-form,
.contactTable{
    width: 100%;
}
.smf-item{
	display: table-row;
}
.smf-item__col--label,
.smf-item__col--controls,
.contactTable th,
.contactTable td{
	display: block;
    font-size: 1.6rem;
    line-height: 1.5;
    font-weight: 500;
    padding-bottom: 1.8rem;
}
.smf-item__col--label,
.contactTable th{
	vertical-align: baseline;
    letter-spacing: .08em;
    padding-bottom: .7rem;
}
.ver_top .smf-item__col--label,
.contactTable th.ver_top{
}
.smf-item__label{
	display: flex;
}
.smf-item__label__text,
.contactTable th font{
	display: inline-block;
}
.any{
	font-size: 0;
}
.required,
.is_required .smf-item__label:before{
	content: '必須';
	display: inline-flex;
	justify-content: center;
	align-items: center;
	vertical-align: top;
	font-weight: 400;
	width: 5rem;
	height: 2.2rem;
	font-size: 1.4rem;
	font-weight: 400;
	border-radius: .3rem;
    margin-right: 1.5rem;
    background: #EE5A5A;
    color: #fff;
    margin-top: .1rem;
}
.contactTable input[type=text],
.contactTable input[type=tel],
.contactTable input[type=email],
.contactTable select,
.contactTable textarea{
    width: 100%;
    height: 4.5rem;
    border-radius: 0;
    border: 0;
    padding: 0 1.5rem;
    font-size: 1.5rem;
    line-height: 1.5;
    font-weight: 500;
    border: 1px solid #D9D9D9;
    background: #fff;
    color: #333;
    border-radius: .5rem!important;
}
.contactTable select {
    width: 33rem;
    background: url(../img/select.svg) no-repeat right 2.5rem center #fff;
    background-size: auto 1rem;
    padding: 0 5rem 0 3rem;
}
.contactTable textarea{
    display: block!important;
    resize: none;
    min-height: 20.5rem;
    padding: 1rem 1.5rem!important;
}
.contactTable input.zip_input{
}
.contactTable input.name_input{
}
.contactTable input[type=text][data-invalid="1"],
.contactTable input[type=tel][data-invalid="1"],
.contactTable input[type=email][data-invalid="1"],
.contactTable .errorLi input{
    background: #FFF0F0;
    border-color: #AD2E2A;
}
.smf-error-messages{
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.5;
	margin-top: .4rem;
}

.address_box .wp-block-group__inner-container{
	width: 100%;
	display: grid;
	grid-gap: .8rem;
}
.address_item{
	width: 100%;
	display: block!important;
}
.address_item .wp-block-column:first-of-type,
.address_item dt{
	white-space: nowrap;
	font-size: 1.6rem;
	margin-bottom: .7rem;
}
.address_item .wp-block-column:last-of-type,
.address_item dd{
	width: 100%;
}
.address_item:last-of-type{
	width: 100%;
}
.smf-complete-content{
	text-align: center;
}
.smf-complete-content,
.smf-system-error-content,
.smf-system-error-content-ready,
.formNote{
	font-size: 1.4rem;
	font-weight: 400;
	margin-top: 2rem;
}
.smf-action,
.formButton{
    margin-top: 1rem;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column-reverse;
    grid-gap: 3rem;
}
.smf-button-control,
.formButton .btn_confirm{
	width: 100%;
	display: block;
	text-align: center;
}
.smf-button-control__control,
.formButton .btn_form{
	border-radius: 1rem!important;
	text-align: center;
	width: 55.6rem;
	max-width: 100%;
	height: 8.2rem;
    background: url(../img/arrow_right.svg)no-repeat right 4.1rem center #202020!important;
    background-size: 2.9rem auto!important;
    color: #fff!important;
    border: 0!important;
    font-size: 1.6rem;
    letter-spacing: .05em;
    font-weight: 500;
    transition: opacity .3s!important;
    font-family: inherit;
}
.formButton .disabled{
    -webkit-filter: grayscale(100%);
    filter: grayscale(100%);
    opacity: .5;
    pointer-events: none;
}

.smf-button-control__control[data-action=complete] {
	background: url(../img/arrow_right_orange.svg)no-repeat right 4.1rem center #F87928!important;
  background-size: 2.9rem auto!important;
}

.smf-button-control__control[data-action=back] {
	background: url(../img/arrow_left.svg)no-repeat 4.1rem center #202020!important;
  background-size: 2.9rem auto!important;
}

.smf-radio-buttons-control__control,
.smf-checkboxes-control__control,
.formRadio,
.formRadio .wpcf7-radio,
.formCheckbox,
.formCheckbox .wpcf7-checkbox{
    display: flex;
    flex-wrap: wrap;
    grid-gap: .8rem 1rem;
}

.smf-label label,
.formRadio label,
.formCheckbox label {
    display: flex;
    font-size: 1.6rem;
    line-height: 1.5;
    font-weight: 500;
    color: #333;
    position: relative;
}

.smf-label label input[type="checkbox"],
.smf-label label input[type="radio"],
.formRadio label input[type="radio"],
.formCheckbox label input[type="checkbox"] {
    position: absolute;
    z-index: -1;
    left: 0;
    top: 0;
    opacity: 0;
}

.smf-radio-button-control__label,
.smf-checkbox-control__label,
.formRadio label span {
    position: relative;
    z-index: 2;
    padding-left: 2.2rem;
    display: inline-block;
}

.smf-radio-button-control__label:before,
.smf-checkbox-control__label:before,
.formRadio label span:before {
    position: absolute;
    left: 0;
    top: .5rem;
    width: 1.6rem;
    height: 1.6rem;
    border-radius: 0;
    background: url(../img/radio_no.svg)no-repeat;
    background-size: 100% auto;
    border: 0;
    content: '';
    z-index: 1;
}

.smf-radio-button-control__label:after,
.smf-checkbox-control__label:after,
.formRadio label span:after {
    position: absolute;
    left: 0;
    top: .5rem;
    width: 1.6rem;
    height: 1.6rem;
    background: url(../img/radio_on.svg)no-repeat;
    background-size: 100% auto;
    content: '';
    z-index: 2;
    opacity: 0;
}

.smf-label label input[type="checkbox"]:checked + .smf-radio-button-control__label:before ,
.smf-label label input[type="radio"]:checked + .smf-radio-button-control__label:before ,
.smf-label label input[type="checkbox"]:checked + .smf-checkbox-control__label:before ,
.smf-label label input[type="radio"]:checked + .smf-checkbox-control__label:before ,
.formRadio label input[type="radio"]:checked + span:before ,
.formRadio label input[type="checkbox"]:checked + span:before {
    opacity: 0;
}

.smf-label label input[type="checkbox"]:checked + .smf-radio-button-control__label:after ,
.smf-label label input[type="radio"]:checked + .smf-radio-button-control__label:after ,
.smf-label label input[type="checkbox"]:checked + .smf-checkbox-control__label:after ,
.smf-label label input[type="radio"]:checked + .smf-checkbox-control__label:after ,
.formRadio label input[type="radio"]:checked + span:after ,
.formRadio label input[type="checkbox"]:checked + span:after {
    opacity: 1;
}


.formCheckbox label{
    /*width: 100%;*/
}
.formCheckbox label span {
    position: relative;
    z-index: 2;
    padding-left: 2.2rem;
    display: inline-block;
}

.formCheckbox label span:before {
    position: absolute;
    left: 0;
    top: .5rem;
    width: 1.6rem;
    height: 1.6rem;
    border-radius: 0;
    background: url(../img/radio_no.svg)no-repeat;
    background-size: 100% auto;
    border: 0;
    content: '';
    z-index: 1;
}

.formCheckbox label span:after {
    position: absolute;
    left: 0;
    top: .5rem;
    width: 1.6rem;
    height: 1.6rem;
    background: url(../img/radio_on.svg)no-repeat center center;
    background-size: 100% auto;
    content: '';
    z-index: 2;
    opacity: 0;
}

.formCheckbox label input[type="radio"]:checked + span:before ,
.formCheckbox label input[type="checkbox"]:checked + span:before {
    /*opacity: 0;*/
}

.formCheckbox label input[type="radio"]:checked + span:after ,
.formCheckbox label input[type="checkbox"]:checked + span:after {
    opacity: 1;
}

.wpcf7-spinner{
	position: absolute;
	left: 100%;
	top: 10%;
	margin: 0 1.5rem;
}


/*animate*/
.wow{
	opacity: 0;
}
.animated{
	animation-duration:1s;
	opacity: 1;
}
@keyframes fadeInLeft02 {
  0% {
    -webkit-clip-path: inset(0 100% 0 0);
    clip-path: inset(0 100% 0 0);
  }
  60% {
    -webkit-clip-path: inset(0 0 0 0);
    clip-path: inset(0 0 0 0);
  }
  100% {
    -webkit-clip-path: inset(0 0 0 0);
    clip-path: inset(0 0 0 0);
  }
}
@-webkit-keyframes fadeInLeft02 {
  0% {
    -webkit-clip-path: inset(0 100% 0 0);
    clip-path: inset(0 100% 0 0);
  }
  60% {
    -webkit-clip-path: inset(0 0 0 0);
    clip-path: inset(0 0 0 0);
  }
  100% {
    -webkit-clip-path: inset(0 0 0 0);
    clip-path: inset(0 0 0 0);
  }
}

.fadeInLeft02{
	animation-duration:2s;
  -webkit-animation-name: fadeInLeft02;
  animation-name: fadeInLeft02;
}

@-webkit-keyframes fadeInRight02 {
  0% {
    -webkit-clip-path: inset(0 0 0 100%);
    clip-path: inset(0 0 0 100%);
  }
  60% {
    -webkit-clip-path: inset(0 0 0 0);
    clip-path: inset(0 0 0 0);
  }
  100% {
    -webkit-clip-path: inset(0 0 0 0);
    clip-path: inset(0 0 0 0);
  }
}
@keyframes fadeInRight02 {
  0% {
    -webkit-clip-path: inset(0 0 0 100%);
    clip-path: inset(0 0 0 100%);
  }
  60% {
    -webkit-clip-path: inset(0 0 0 0);
    clip-path: inset(0 0 0 0);
  }
  100% {
    -webkit-clip-path: inset(0 0 0 0);
    clip-path: inset(0 0 0 0);
  }
}
.fadeInRight02 {
	animation-duration:2s;
  -webkit-animation-name: fadeInRight02;
  animation-name: fadeInRight02;
}


.mv_img_item{
	animation-duration: 1.5s;
	-webkit-animation-name: fadeIn;
	animation-name: fadeIn;
}

.mv_text01{
	animation-delay: .8s;
}
.mv_text02{
	animation-delay: 1.3s;
	-webkit-animation-name: fadeInLeft02;
	animation-name: fadeInLeft02;
}
.mv_text03{
	animation-delay: 1.6s;
	-webkit-animation-name: fadeInLeft02;
	animation-name: fadeInLeft02;
}
.mv_text04{
	animation-delay: 2.1s;
}

.top_sec01_box li{
	animation-duration: 1s;
    -webkit-animation-name: fadeInUp;
    animation-name: fadeInUp;
}
.top_sec01_box li:nth-of-type(2){
	animation-delay: .5s;
}
.top_sec01_box li:nth-of-type(3){
	animation-delay: 1s;
}
.top_sec01_box li:nth-of-type(4){
	animation-delay: 1.5s;
}
.top_sec01_box li:nth-of-type(5){
	animation-delay: 2s;
}

.smf-action .smf-button-control+.smf-button-control{
	margin: 0!important;
}

.top_sec04{
	padding: 6rem 0;
	overflow: hidden;
}
.top_sec04_slick{
	padding: 1.8rem 0 3.5rem;
}
.top_sec04_slick .slick-list{
	overflow: visible;
}
.top_sec04_item{
	max-width: 31.5rem;
	width: 31.5rem;
	margin: 0 .75rem;
	position: relative;
	padding-bottom: .2rem;
}
.works_img {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 1.2rem;
	position: relative;
}

.works_img:before {
	width: 5.1rem;
	height: 4.6rem;
	content: '';
	background: url(../img/arrow_before_after.svg) center center no-repeat;
	background-size: 100% 100%;
	position: absolute;
	left: 50%;
	bottom: 5.35rem;
	transform: translateX(-50%);
	z-index: 2;
	content: '';
}

.works_img .before,
.works_img .after {
	width: calc((100% - 1.2rem) / 2);
	position: relative;
}

.works_img .before:before,
.works_img .after:before {
	width: 10.5rem;
	height: 3.375rem;
	display: flex;
	justify-content: center;
	align-items: center;
	border-radius: 1.6875rem;
	font-size: 1.5rem;
	color: #fff;
	line-height: 1;
	font-weight: bold;
	letter-spacing: .05em;
	position: absolute;
	left: 50%;
	top: 0;
	transform: translate(-50%,-50%);
	z-index: 2;
}

.works_img .before {
	height: 16.34rem;
}

.works_img .before:before {
	background: #888888;
	content: 'BEFORE';
}

.works_img .after {
	height: 21.3rem;
}

.works_img .after:before {
	background: #F87928;
	content: 'AFTER';
}

.works_img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 0 2.5rem 0 2.5rem;
}
.top_sec04_item .title{
	font-family: "Noto Serif JP", serif;
	font-size: 2rem;
	letter-spacing: .05em;
	font-weight: 700;
	color: #253F77;
	display: flex;
	grid-gap: 1.5rem;
	margin: 1.5rem 0 1rem;
}
.top_sec04_item .text{
	font-size: 1.6rem;
	line-height: 1.3;
	font-weight: 500;
	letter-spacing: .05em;
}
.top_sec04_item .tag{
	margin-top: 2rem;
	display: flex;
	justify-content: center;
	grid-gap: .7rem;
}
.top_sec04_item .tag span{
	display: inline-flex;
	justify-content: center;
	align-items: center;
	height: 3rem;
	padding: 0 1.2rem;
	border-radius: 2rem;
	font-size: 1.4rem;
	font-weight: 700;
	color: #253F77;
	border: 1px solid #253F77;
}

.plan_txt {
	display: inline-block;
	position: relative;
}

.plan_txt .plan_txt_notes {
	color: #A4A4A4;
	display: block;
}