

.fv2{
    position: relative;
    background: #000;
    width: 100%;
    height: auto;
    padding:5.5em 4em;
    overflow: hidden;
}
.fv2::before{
    content: "";
    display: block;
    background: url(../../img/top/mv_bgcircle2.png) no-repeat left top;
    background-size: contain;
    width: 60em;
    height: 60em;
    position: absolute;
    right:-23em;
    bottom:-24em;
    z-index: 1;
}
.fv2::after{
    content: "";
    display: block;
    background: url(../../img/top/mv_bgcircle1.png) no-repeat left top;
    background-size: contain;
    width: 42em;
    height: 42em;
    position: absolute;
    left:-13em;
    top:12em;
    z-index: 1;
}
.fv2 *{
    font-family: "Noto Sans JP", sans-serif !important;
}
.fv2 .mv_bg{
    position: absolute;
    right:0;
    top:0;
    width: 80%;
    z-index: 1;
}
.slick-img img {
  width: 100%;
}
@keyframes zoomUp {
  0% {
    transform: scale(1) translate(0,0);
  }
  100% {
    transform: scale(1) translate(30px,0); /* 拡大率 */
  }
}
.add-animation {
  animation: zoomUp 10s linear 0s normal both;
}
.fv2 .txt{
    margin-right: auto;
    width: 55%;
    text-align: center;
    position: relative;
    z-index: 2;
}

.fv2 .txt .flex1{
    display: flex;
    justify-content: center;
    padding-bottom:1.5em;
}
.fv2 .txt .flex1 span{
    display: block;
    font-size: 1.2em;
    font-weight: 500;
    background: rgba(0, 0, 0, 0.5);
    border: solid 1px #fff;
    color:#fff;
    text-align: center;
    width: 12em;
    padding:0.3em 0 0.5em;
    margin:0 0.3em;
}
.fv2 .txt h2{
    padding-bottom:1em;
}
.fv2 .txt .box1{
    background: #000;
    border-radius: 0.8em;
    padding:1.5em 1em 1em;
    text-align: center;
    width: 55%;
    margin:0 auto 3em;
    color:#fff;
}
.fv2 .txt .box1 p{
    font-weight: 700;
    font-size: 1.2em;
}
.fv2 .txt .box1 .mvprice{
    font-weight: 500;
    color:#fff;
    font-size: 0.8em;
}
.fv2 .txt .box1 .mvprice em{
    color:#94DE59;
    font-weight: 700;
    font-size: 3em;
}
.fv2 .txt .mvbtn{

}
.fv2 .txt .mvbtn p{
    font-family: "Noto Serif JP", serif !important;
    font-weight: 600;
    color:#F8FE4C;
    font-size: 1.1em;
    padding-bottom:0.7em;
}
.fv2 .txt .mvbtn h3{
    display: inline-block;
    position: relative;
    color:#fff;
    font-weight: 500;
    font-size: 1.4em;
    padding:0 0.9em 1em;
    margin-bottom:0.5em;
}
.fv2 .txt .mvbtn h3::before,
.fv2 .txt .mvbtn h3::after{
    content: "";
    display: block;
    width: 1px;
    height: 2em;
    background: #fff;
    position: absolute;
    top:0;
}
.fv2 .txt .mvbtn h3::before{
    left:0;
    transform: rotate(-35deg);
}
.fv2 .txt .mvbtn h3::after{
    right:0;
    transform: rotate(35deg);
}
.fv2 .txt .mvbtn .btn{
    width: 58%;
    margin:0 auto;
}
.fv2 .mvstaff{
    position: absolute;
    right:0;
    top:4em;
    width: 48%;
    z-index: 3;
}
.fv2 .fv2f{
    padding-top:5em;
    position: relative;
    z-index: 3;
}
.fv2 .fv2f .fv_free{
    background: url(../../img/top/mv_bg2.png) no-repeat center top;
    background-size: cover;
    border-radius: 0.8em;
    padding:1.5em;
    color:#fff;
    text-align: center;
}
.fv2 .fv2f .fv_free p{
    font-size: 1.15em;
    font-weight: 500;
    line-height: 1.7;
}
.fv2 .fv2f .fv_free p em{
    font-weight: 500;
    font-size: 1.4em;
    color:#F8FE4C;
}
.slick-track{display: flex;}

.fv2 .mtel{
    text-align: center;
    color:#fff;
}
.fv2 .mtel a{
    display: inline-block;
    font-weight: bold;
    font-size: 1.3em;
    background: url(../../img/common/ico_tel_white.svg) no-repeat left center;
    background-size: 0.7em auto;
    padding:0.5em 0;
    padding-left: 1em;
    color:#fff;
}


    .SP{display: none;}
@media only screen and (max-width: 750px) {
    .PC{display: none;}
    .SP{display: block;}
@keyframes zoomUp {
  0% {
    transform: scale(1.15) translate(0,0);
  }
  100% {
    transform: scale(1.15) translate(30px,0); /* 拡大率 */
  }
}    
.fv2{
    padding:4em 0.6em;
    overflow: hidden;
}
.fv2::before{
    content: "";
    display: block;
    background: url(../../img/top/mv_bgcircle2.png) no-repeat left top;
    background-size: contain;
    width: 50em;
    height: 50em;
    position: absolute;
    right:-26em;
    bottom:-15em;
    z-index: 1;
}
.fv2::after{
    content: "";
    display: block;
    background: url(../../img/top/mv_bgcircle1.png) no-repeat left top;
    background-size: contain;    
    width: 90vw;
    height: 90vw;
    position: absolute;
    left: 4vw;
    top: 24em;
    z-index: 1;
}

.fv2 .mv_bg{
    position: absolute;
    right:0;
    top:0;
    width: 100%;
    z-index: 1;
}

.fv2 .txt{
    margin-right: auto;
    width: 100%;
    text-align: center;
    position: relative;
    z-index: 2;
}

.fv2 .txt .flex1{
    display: flex;
    justify-content: center;
    padding-bottom:.5em;
}
.fv2 .txt .flex1 span{
    display: block;
    font-size: 0.75em;
    font-weight: 500;
    margin:0 0.3em;
}
.fv2 .txt h2{
    padding-bottom:0;
}
.fv2 .mvstaff{
    position: relative;
    right:0;
    top:0;
    width: 100%;
    z-index: 3;
    margin-top:-0.4em;
}
.fv2 .txt .box1{
    border-radius: 0.3em;
    padding:1.2em 1em 1em;
    text-align: center;
    width: 100%;
    margin:0 auto 1.5em;
}

.fv2 .txt .mvbtn{

}
.fv2 .txt .mvbtn p{
    font-size: 1.1em;
    line-height: 1.6;
    padding-bottom:0.7em;
}
.fv2 .txt .mvbtn h3{
    display: inline-block;
    position: relative;
    color:#fff;
    font-weight: 500;
    font-size: 1.4em;
    line-height: 1.4;
    padding:0 0.7em 1em;
    margin-bottom:0.5em;
}
.fv2 .txt .mvbtn h3 .SP{display: inline-block;}
.fv2 .txt .mvbtn h3::before,
.fv2 .txt .mvbtn h3::after{
    content: "";
    display: block;
    width: 1px;
    height: 1.7em;
    top:auto;
    bottom:0;
}

.fv2 .txt .mvbtn .btn{
    width: 100%;
    margin:0 auto;
}

.fv2 .fv2f{
    padding:0;
    padding-top:2em;
    position: relative;
    z-index: 3;
}
.fv2 .fv2f .fv_free{
    padding:1em;
}
.fv2 .fv2f .fv_free p em{
    font-weight: 500;
    font-size: 1.5em;
    line-height: 1.3;
}
}

@media only screen and (max-width: 750px) {
.fixfoot{
    display: none;
}
.header__box a.header__btn01{
    order: 1;
        margin: 0 0 1.25rem;
}
.header__box a.header__btn02{
    order: 2;
        margin: 0;
}
}