@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/lp/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/lp/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/lp/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/lp/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/lp/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/lp/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/lp/bg_sec01_sp.svg)no-repeat bottom -.2rem center,
    url(../img/lp/bg_blue.png)no-repeat top 14.4rem center,
    url(../img/lp/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/lp/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/lp/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/lp/arrow_orange.svg)no-repeat right 2.7rem center #F87928;
    background-size: 2.9rem auto;
    color: #fff;
    border-radius: 1rem;
}

.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/lp/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/lp/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/lp/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/lp/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/lp/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/lp/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/lp/bg_sec08_sp.png)no-repeat top center,
    url(../img/lp/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/lp/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/lp/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/lp/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/lp/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/lp/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/lp/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/lp/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/lp/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/lp/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;
    white-space: nowrap;
    flex-shrink: 0;
    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;
}

/* 対象外エリア注釈（住所ラジオボタン下） */
.smf-radio-buttons-control__control.is-address-control::after {
    content: "【対象外エリア】旧東予市・丹原町・小松町";
    display: block;
    width: 100%;
    font-size: 1.2rem;
    color: rgba(51, 51, 51, 0.65);
    margin-top: 6px;
}