@charset "UTF-8";

/*共通*/
body {
    background-color: #f1f1f1;
    position: relative;
    font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
p {
    line-height: 1.6;
    word-wrap: break-word;
    font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.wrapper {
    padding: 0;
    overflow: hidden;
    color: #111;
    background: #fff;
    width: 100%;
    max-width: 699px;
    margin: 0 auto;
    overflow: hidden;
}
.note{
    margin-right: 20px;
    font-size: 11px;
    text-align: center;
}
.contents{
    margin: 0 auto; 
}
a:link {
    color: #ff6c00;
    text-decoration: none;
}
a:hover{
    opacity: 0.6;
}
.pc_ds{
    display: block;
}
.pc_ds2{
    display: inline;
}
.sp_ds{
    display: none;
}
.mt20{
    margin-top:20px;
}
.w100{
    width:100%;
}
.w80{
    width:80%;
    margin: 0 auto;
}
.w65{
    width:65%;
    margin: 0 auto;
}
.w1200 {
    max-width: 1200px;
    margin: 0 auto;
}
img{
    width: 100%;
}
.ta_c {
    text-align: center;
}
.ta_c img{
    width: 20%;
}
@media screen and (max-width: 640px) { 
    .ta_c img{
        width: 38%;
    }
}
.ta_r {
    text-align: right;
}
.ta_l {
    text-align: left;
}
.comment {
    font-size: 26px;
    font-weight: bold;
}

.tex_bg{
    font-size: 160%; 
}

.tex_sm{
    font-size: 70%; 
}

.mark_y{
    background: rgba(0, 0, 0, 0)linear-gradient(transparent 70%, #feec0a 0%)repeat scroll 0 0;
    height: 20px;
    font-weight: bold;
}

.co_r{
	color: #d4160a;
}
.co_o{
	color: #ff6f28;
}
.co_y{
    color: #f6ff00;
}
/* padding */
.p20 {
    padding: 0 20px;
}
.pb30 {
    padding-bottom: 30px;
}
/*ポジション*/
.rel{
    position: relative;
}

.abs{
    position: absolute;
}

/*ポジション　画面中央*/
.po_ce{
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}

/*改行*/
@media screen and (min-width:640px){ 
    .br-sp { 
        display: none; 
    } 
}     
@media screen and (max-width: 640px) { 
.note{
    margin-right: 20px;
    font-size: 11px;
    text-align: right;
}
    .br-pc { display:none; } 
}

 /* パソコンで見たときは"pc"のclassがついた画像が表示される */ 
    .pc_no { display: block !important; } 
    .sp_no { display: none !important; } 

/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */ 
    @media only screen and (max-width: 640px) { 
        .pc_no { display: none !important; } 
        .sp_no { display: block !important; } 
    }

/*----------共通　sp------------*/
@media (max-width: 789px) { 
/*共通*/
.contents{
    width: 100%;
    padding: 0 5px; 
}

.sp_ds{
    display: block;
}

.pc_ds{
    display: none;
}

.pc_ds2{
    display: none;
}

.contents_wrapper {
    width: 92%;
}

.w80{
    width:100%;
}

.step_ma {
    margin: 7vw 0 8vw;
}
}

/*----------header----------*/
header {
    width: 100%;
    max-width: 699px;
    margin: 0 auto;
    padding: 5px 0px;
    background-color: #fff388;
    justify-content: space-between;
    align-items: center;
    z-index: 10;
    position: relative;
}
.head_flx {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0;
    padding: 1% 2%;
}
.head_btn {
    display: flex;
    max-width: 60px;
    flex-direction: row-reverse;
    max-width: 500px;
    width: 50%;
}
.head_btn img {
    width: 100%;
}
.head_btn a{
    position:relative;
    margin-left: 2px;
}
.head_logo {
    max-width: 50%;
    margin-right: 10%;
}
.head_logo p {
    font-size: 15.5px;
    font-weight: bold;
}
@media (max-width: 1450px) { 
    .head_logo {
        max-width: 281px;
    }
}
@media (max-width: 767px) { 
    .head_logo p {
        font-size: 11px;
    }
    .head_flx {
        margin: 0;
        padding: 1% 1%;
    }
    .head_logo {
        max-width: 50%;
        margin-right: 2%;
        margin-left: 1%;
    }

}
/*----------CTA---------*/
.cta_bg {
        background: #fff8de;
    background-repeat: no-repeat;
    background-position: top;
    background-size: cover;
    padding: 50px;
}
.cta_coupon{
    max-width: 700px;
    margin: 0 auto;
    padding: 22px 170px 22px 170px;
}
.timer{
    text-align: center;
    font-size: 1.5rem;
    font-weight: bold;
    color: #000;
    line-height: 1.3;
}
.cta_bg02 {
    background-image: url(../img/cta_bg02_pc.png);
    background-repeat: no-repeat;
    background-position: top;
    background-size: cover;
    padding: 50px;
}
.cta_inner {
    max-width: 1150px;
    margin: 0 auto;
    border-radius: 10px;
    padding: 1% 0%;
    position: relative;
}
.cta_flx {
    display: flex;
    justify-content: space-between;
    max-width: 76.5%;
    margin: 0 auto;
    position: absolute;
    top: 50%;
    left: 0;
    margin-left: 13.5%;
}
.cta_flx img {
    max-width: 95%;
}
.cta_flx p{
    position: absolute;
    bottom: 8%;
    left: 24%;
    margin: auto;
    font-weight: bold;
    color: #fff;
    font-size: 2.1rem;
}
.card {
    max-width: 800px;
    margin: 30px auto 0;
    padding: 0 50px;
}
.cta_inner2 {
    max-width: 1150px;
    margin: 0 auto;
    border-radius: 10px;
    padding: 8% 0 3%;
    position: relative;
}
.cta_flx2 {
    display: flex;
    justify-content: space-between;
    max-width: 76.5%;
    margin: 0 auto;
    position: absolute;
    top: 20%;
    left: 0;
    margin-left: 13.5%;
}
.follow_btn{
    display: flex;
    justify-content: space-between;
    position: relative;
    top: 0;
    left: 0;
}
.cta_flx2 img {
    max-width: 95%;
}
.cta_flx2 p{
    position: absolute;
    bottom: 8%;
    left: 24%;
    margin: auto;
    font-weight: bold;
    color: #fff;
    font-size: 2.1rem;
}
.mv_cta_form{
    position: relative;
}
/* 光 */
.shine{
    border: 2px solid transparent;
    position: relative;
    overflow: hidden;
}
/*.shine img {
    max-width: 95%;
}*/
.shine::before{
    content: '';
    width: 30px;
    height: 100%;
    background-color: #fff;
    animation: shine 3s ease-in-out infinite;
    position: absolute;
    top: -180px;
    left: 0;
    opacity: 0;
    transform: rotate(45deg);
}
/* 光の動き */
@keyframes shine{
  0% {
    transform: scale(0) rotate(45deg);
    opacity: 0;
  }
  80% {
    transform: scale(0) rotate(45deg);
    opacity: 0.5;
  }
  81% {
    transform: scale(4) rotate(45deg);
    opacity: 1;
  }
  100% {
    transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}
@media (max-width: 820px) { 
    .cta_flx p{
        font-size:1.3rem;
    }
}
@media (max-width: 767px) { 
    .cta_bg {
        background: #fff8de;
        padding: 3.5% 3.5% 44%;
    }
    .cta_bg02 {
        background-image: linear-gradient(133deg, rgba(140, 140, 140, 1), rgba(89, 89, 89, 1));        background-repeat: no-repeat;
        padding: 3.5%;
    }
    .cta_flx {
        display: block;
        justify-content: space-between;
        max-width: 92%;
        margin: 4% auto 0;
        top: 29%;
        left: 0;
        margin-left: 4.5%;
    }
    .cta_inner {
        border-radius: 3px;
        padding: 3% 0;
    }
    .cta_flx img {
        max-width: 97%;
        margin-bottom: 5%;
    }
    .cta_flx p{
        bottom: 27%;
        left: 29%;
        font-size: 1.6rem;
    }
    .mv_cta_form{
        margin-top: 2%;
    }
    .card {
        max-width: 88%;
        margin: 12px auto 5px;
        padding: 0;
    }
    .timer{
        font-size: 0.9rem;
        line-height: 1.3;
        margin-top: 3%;
    }
    .shine img {
        max-width: 100%;
    }
    .cta_flx2 {
        display: block;
        justify-content: space-between;
        max-width: 92%;
        margin: 6% auto 0;
        top: 0%;
        left: 0;
        margin-left: 3.5%;
    }
    .cta_inner2 {
        border-radius: 3px;
        padding: 15% 0;
    }
    .cta_flx2 img {
        max-width: 97%;
        margin-bottom: 5%;
    }
    .cta_flx2 p{
        bottom: 27%;
        left: 29%;
        font-size: 1.6rem;
    }
    
}
/* 点滅 */
.blinking{
	-webkit-animation:blink 1.5s ease-in-out infinite alternate;
    -moz-animation:blink 1.5s ease-in-out infinite alternate;
    animation:blink 1s ease-in-out infinite alternate;
}
@-webkit-keyframes blink{
    0% {opacity:0;}
    100% {opacity:1;}
}
@-moz-keyframes blink{
    0% {opacity:0;}
    100% {opacity:1;}
}
@keyframes blink{
    0% {opacity:0;}
    100% {opacity:1;}
}

/*-----------ctaアニメーション-----------*/
.btn_popup{
    display: block;
    z-index: 99;
}
.btn_popup a{
    display: block;
    position: relative;
    transition: .2s;
}
.btn_popup a::before,
.btn_popup a::after{
    content: "";
    position: absolute;
    z-index: -1;
    width: 100%;
    height: 100%;
    top: 0;
    left: -5%;
    right: 0;
    margin: 0 auto;
    border-radius: 23px;
    transform: translate3d(0,0,0);
  max-width: 700px;
}
.btn_popup a::before{
    animation: aura 3s ease-out infinite;
}
.btn_popup a::after{
    animation: aura 3s ease-out 1.5s infinite;
}
.btn_popup a::before,
.btn_popup a::after{
    background: #55c449;
    border: 1px solid #55c449;
}
@keyframes aura{
  0%{transform:scale(.95); opacity:1}
  90%{opacity:.1}to{transform:scale(1.1,1.3); opacity:0}
  }
  
@media screen and (max-width: 767px) {
    .hd-f{
       overflow: visible;
   }
   .btn_popup a::before,
   .btn_popup a::after{
        width: 100%;
        top: -5%;
        left: 0%;
    }
}

/*-----------実績---------*/
.jisseki_bg {
    background-color: #d4160a;
    padding: 60px 0;
    margin-top: 0;
}
.jisseki_inner01 {
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
    padding: 0 0 15px 0;
}
.jisseki_inner02{
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
}
@media (max-width: 767px) { 
    .jisseki_bg{
        padding: 50px 0;
    }
    .jisseki_inner01 {
        max-width: 90%;
        margin: 0 auto;
        padding: 0 0 15px 0;
    }
    .jisseki_inner02 {
        max-width: 90%;
        margin: 0 auto;
        padding: 0;
    }
}
/*-----------あらゆるトラブル---------*/
.trouble_bg {
    background-image: url(../img/trouble_bg.jpg);
    background-repeat: no-repeat;
    background-position: top;
    background-size: cover;
    padding: 30px 0 85px;
}
.trouble_bg .Annual_title{
    margin:15px 0 15px;
}
.trouble_ttl {
    width: 100%;
    margin: 0 auto;
    padding-bottom: 20px;
}
.trouble_flx {
    display: flex;
    flex-wrap: wrap;
    max-width: 680px;
    margin: 0 auto;
    justify-content: center;
    margin-top: 15px;
    padding: 0 20px;
    text-align: center;
}
.trouble_flx img {
    width: 100%;
    max-width: 280px;
    padding: 10px;
    margin-bottom: 15px;
}
.trouble_maker {
    max-width: 941px;
    padding: 0 50px;
    margin: 2% auto 0;
}
@media (max-width: 1075px) { 
    .trouble_flx img {
        padding: 10px;
        margin-bottom: 15px;
    }
}
@media (max-width: 926px) { 
    .trouble_flx img {
        padding: 10px;
        margin-bottom: 15px;
    }
}
@media (max-width: 767px) { 
    .trouble_ttl {
        padding-bottom: 20px;
    }
    .trouble_bg {
        padding: 23px 0 45px;
    }
    .trouble_flx {
        display: block;
        flex-wrap: nowrap;
        max-width: 100%;
        margin-top: 15px;
        padding: 0 10px;
    }
    .trouble_flx img {
        max-width: 100%;
        padding: 5px;
        margin-bottom: 7px;
    }
    .trouble_maker {
        max-width: 90%;
        padding: 0;
        margin-top: 18px;
    }
}
/* アコーディオン */
.trouble_accordion {
    max-width: 699px;
    margin: 0 auto 30px;
    width: 90%;
}
.trouble_accordion .toggle {
    display: none;
}
.trouble_accordion .Label {
    /*タイトル*/
    width: 70%;
    margin: 0 auto;
    padding: 13px;
    display: block;
    color: #000000;
    background: #ffffff;
    border: 2px #000000 solid;
    text-align: left;
    font-weight: bold;
    font-size: 19px;
    text-align: center;
    border-radius: 7px;
}
.trouble_accordion .Label::after {
    /*タイトル横の矢印*/
    content: "";
    width: 8px;
    height: 8px;
    border-top: 3px solid #000000;
    border-right: 3px solid #000000;
    -webkit-transform: rotate(45deg);
    position: absolute;
    top: calc(50% - 7px);
    right: 20px;
    transform: rotate(135deg);
}
.trouble_accordion .Label,
.trouble_accordion .content {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translateZ(0);
    transition: all 0.3s;
}
.trouble_accordion .content {
    /*本文*/
    height: 0;
    margin-bottom: 17px;
    padding: 0px;
    overflow: hidden;
    text-align: left;
}
.toggle:checked+.Label+.content {
    /*開閉時*/
    height: auto;
    padding: 0;
    transition: all .3s;
    width: 600px;
    margin: 0 auto;
    justify-content: center;
    text-align: center;
    display: flex;
    flex-wrap: wrap;
}
.toggle:checked+.Label::after {
    transform: rotate(-45deg) !important;
}

@media screen and (max-width:640px) {
    .trouble_accordion .Label::before {
        height: 25px;
        width: 25px;
        margin-right: 1px;
    }
    .trouble_accordion .Label {
        padding: 7px 35px 7px 42px;
        font-size: 20px;
    }
    .toggle:checked+.Label+.content {
        width: 100%;
        padding: 0;
    }
    .toggle:checked+.Label+.content p{
        font-size: 16px;
        line-height: 1.4;
    }
    .trouble_accordion .content {
        margin-bottom: 10px;
    }
}
/* アコーディオン 終*/


/*-----------選ばれる理由---------*/
.reason_bg {
    background-image: url(../img/reason_bg.jpg);
    background-repeat: no-repeat;
    background-position: top;
    background-size: cover;
    padding: 20px 0 70px;
}
.reason_ttl {
    width: 80%;
    max-width: 500px;
    margin: 50px auto 0;
}
.reason_flx {
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
    margin-top: 20px;
}
.reason_inner {
    padding:0;
    margin: 0 auto;
}
.reason_inner img {
    width: 100%;
}
.reason_inner_ttl, .reason_inner_ttl02 {
    /*border-left: solid 7px #ff2400;*/
    font-size: 25px;
    font-weight: bold;
    margin: 20px 0 10px;
    line-height: 1.1;
    padding-left: 15%;
}
img.abs_n {
    position: absolute;
    bottom: -0.5vw;
    left: 0vw;
    width: 15%;
}
.point_text {
    padding: 2vw 3vw 1.5vw;
    background: #eef9ff;
}
@media (max-width: 1260px) {
    .reason_inner_ttl, .reason_inner_ttl02 {
        font-size: 22px;
        padding-left: 12%;
    }
}
@media (max-width: 1158px) {
    .reason_inner_ttl, .reason_inner_ttl02 {
        font-size: 20px;
    }
}
@media (max-width: 767px) {
    .reason_bg {
        padding: 45px 0 30px;
    }
    .reason_ttl {
        max-width: 75%;
        margin:0 auto;
        padding: 0;
    }
    .reason_inner {
        width: 90%;
        padding: 5px;
        margin-bottom: 10px;
    }
    .reason_inner_ttl {
        /*border-left: solid 7px #ff2400;*/
        font-size: 20px;
        font-weight: bold;
        margin: 20px 0 10px;
        padding-left: 23%;
    }
    .reason_inner_ttl02 {
        /*border-left: solid 7px #ff2400;*/
        font-size: 20px;
        font-weight: bold;
        margin: 23px 0 13px;
        padding-left: 23%;
    }
    .reason_inner p {
        font-size: 16px;
    }
    img.abs_n {
       bottom: -1vw;
       left: -1vw;
       width: 25%;
}
}
/*-----------お客様の声---------*/
.voice_bg{
    background-color: #fff1f1;
}
.ttl_bg_or {
    padding: 55px 0 100px;
}
.voice_ttl {
    max-width: 550px;
    margin: 0 auto;
}
.voice-contents{
    padding: 8px 0 4% 0;
    margin-top: -136px;
}
.slick-prev:before, .slick-next:before{
    opacity: 1;
}
.slick-dots li.slick-active button:before {
    opacity: 1 !important;
    color: #DC0000 !important;
}
@media screen and (max-width:767px){ 
    .ttl_bg_or {
        padding: 45px 0 55px;
    }
    .voice_ttl {
        max-width: 85%;
        margin: 0 auto;
        padding: 20px 0;
    }
    li.slide_contents{
        width: 83vw!important;
        padding: 22px 20px 20px;
    }
    .voice-contents{
        padding: 4% 0;
        margin-top: -50px;
    }
}
/*===========スライダー============*/
.slider {/*横幅94%で左右に余白を持たせて中央寄せ*/
    width: 100%;
    margin:168px auto 0;
}

.slick-slide img {
    display: inline-block;
    padding: 0;
    margin: 0 auto;
    width: 100%;
    max-width: 500px;
}

.slider .slick-slide {
    transform: scale(0.8);/*左右の画像のサイズを80%に*/
    transition: all .5s;/*拡大や透過のアニメーションを0.5秒で行う*/
    opacity: 0.5;/*透過50%*/
}

.slider .slick-slide.slick-center{
    transform: scale(1);/*中央の画像のサイズだけ等倍に*/
    opacity: 1;/*透過なし*/
}

.slick-list {
    overflow: inherit;
}

/*矢印の設定*/
.slick-prev {/*戻る矢印の位置と形状*/
    left: 8.4% !important;
    z-index: 10 !important;
}

.slick-next {/*次へ矢印の位置と形状*/
    right: 14.2% !important;
}

/*ドットナビゲーションの設定*/

.slick-dots {
    text-align:center;
    margin:20px 0 0 0;
}

.slick-dots li {
    display:inline-block;
    margin:0 5px;
}

.slick-next:before {
    content: '▶' !important;
}
.slick-prev:before {
    content: '◀' !important;
}
.slick-prev:before, .slick-next:before{
    color: #DC0000 !important;
    font-size: 60px !important;
}
ul {
    padding-inline-start: 0px;
}
.slick-dots {
    position: absolute;
    bottom: -50px !important;
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;

    list-style: none;
    text-align: center;
}
@media (max-width: 1388px) {
    .slick-prev {/*戻る矢印の位置と形状*/
        left: 11.2% !important;
        z-index: 999 !important;
    }
    .slick-next {/*次へ矢印の位置と形状*/
        right: 14.2% !important;
    }
}
@media (max-width: 1200px) {
    .slick-prev {/*戻る矢印の位置と形状*/
        left: 10% !important;
        z-index: 10 !important;
    }
    .slick-next {/*次へ矢印の位置と形状*/
        right: 16.2% !important;
    }
}
@media (max-width: 1000px) {
    .slick-prev {/*戻る矢印の位置と形状*/
        left: 1% !important;
        z-index: 10 !important;
    }
    .slick-next {/*次へ矢印の位置と形状*/
        right: 7.2% !important;
    }
}
@media (max-width: 767px) {
    .voice{
        padding: 0% 2%;
    }

    .voice-contents p.tex_sm{
        margin: 20px 0 10px;
    }

    .slider {/*横幅94%で左右に余白を持たせて中央寄せ*/
        margin: 0 auto;
    }

    /*矢印の設定*/
    .slick-prev {/*戻る矢印の位置と形状*/
        z-index: 10;
    }

    .slick-next {/*次へ矢印の位置と形状*/
        right: 7% !important;
        z-index: 10;
    }
    .slick-prev:before, .slick-next:before{
        font-size: 40px !important;
    }
    .slick-dots {
        bottom: -25px !important;
    }
}
/*-----------ご利用の流れ---------*/
.nagare_ttl {
    background-image: url(../img/ttl_bg_all_pc.png);
    background-repeat: no-repeat;
    background-position: top;
    background-size: cover;
}
.nagare_ttl_inner {
    max-width: 440px;
    padding: 40px 250px;
    margin: 0 auto;
}
.nagare_bg {
    background-image: url(../img/bg_03_pc.png);
    background-repeat: no-repeat;
    background-position: top;
    background-size: cover;
}
.nagare_inner {
    margin: 0 auto;
    max-width: 1150px;
    padding: 80px 50px;
} 
@media (max-width: 767px) {
    .nagare_ttl_inner {
        max-width: 70%;
        padding: 25px 0;
        margin: 0 auto;
    }
    .nagare_inner {
        margin: 0 auto;
        max-width: 88%;
        padding: 40px 0;
    } 
    .nagare_bg {
        background-image: url(../img/bg_03_sp.png);
    }
}
/*-----------対応エリア---------*/
.area_bg{
    background-image: url(../img/area__bg.jpg);
    background-repeat: no-repeat;
    background-position: bottom;
    background-size: cover;
    padding: 70px 0;
}
.area_ttl {
    max-width: 310px;
    width: 80%;
    margin: 0 auto;
    margin-bottom: 30px;
}
.area_inner{
    max-width: 500px;
    margin: 0 auto;
}
.area_inner img{
    padding-bottom:20px;
}
@media (max-width: 767px) {
    .area_bg {
        padding: 45px 0 30px;
    }
    .area_ttl {
        max-width: 58%;
        margin: 0 auto 17px;
        padding: 0;
    }
    .area_inner {
        max-width: 80%;
        margin: 0 auto;
        padding: 0;
    }
}
/*-----------コロナ---------*/
.covid_bg {
    background-image: url(../img/corona_bg.jpg);
    background-repeat: no-repeat;
    background-position: top;
    background-size: cover;
    padding: 50px 0;
}
.covid_ttl {
    max-width: 500px;
    margin: 0 auto;
    padding: 0 150px;
}
.covid_txt {
    font-size: 21px;
    font-weight: bold;
    text-align: center;
    margin: 50px 0 30px;
}
.covid_inner {
    max-width: 650px;
    margin: 0 auto;
    padding: 0 50px;
}

@media (max-width: 767px) {
    .covid_ttl {
        max-width: 85%;
        margin: 0 auto;
        padding: 0;
    }
    .covid_txt {
        font-size: 16px;
        margin: 25px 0 20px;
    }
    .covid_inner {
        max-width: 90%;
        margin: 0 auto;
        padding: 0;
    }
}
/*-----------QA---------*/
.QA_bg{
    background-color: #e2e2e2;
    padding: 70px 0;
}
.QA_ttl {
    max-width: 380px;
    width: 80%;
    margin:0 auto;
    padding-bottom: 30px;
}
.QA_ttl_inner {
    max-width: 600px;
    width: 90%;
    margin: 0 auto;
}
.toggle_title ,.toggle_title2 {
    border-radius: 10px 10px 0 0;
    margin-top: 30px;
    position: relative;
    padding: 3% 3% 3% 8.3%;
    cursor: pointer;
    font-size: 1.2rem;
    text-align: left;
    line-height: 1.4;
    font-weight: bold;
    color: #fff;
    background-color: #ff9600;
    max-height: 999999px;  /*Androidブラウザフォントバグ対策*/
}
.toggle_btn {
    position: absolute;
    top: 45%;
    right: 2%;
    transform: translateY(-50%);
    display: block;
    width: 32px;
    height: 32px;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    border-radius: 50%;
}
.toggle_btn:before {
    display: block;
    content: '▼';
    background-repeat: no-repeat;
    position: absolute;
    top: 50%;
    left: 20%;
    transform: translate(-50%, -50%);
}
.toggle_btn:before {
    width: 2px;
    height: 15px;
}
.toggle_title .toggle_btn:before {
    content: normal;
}
.toggle_title2 .toggle_btn:before {
    content: normal;
}
.toggle_contents dd {
    display: none;
    margin-inline-start:0;
}
.toggle_contents:first-of-type dd {
    display: block;
}
.toggle_contents dd p{
    margin: auto ;
    font-size: 1rem;
    line-height: 1.3rem;
    padding: 2%;
    box-sizing: border-box;
    color: #595959;
    position: relative;
    margin-left: 50px;
}
.qa{
    max-width: 842px;
    margin: 70px auto 50px;
    padding: 3%;
    padding-top: 0;
}
.toggle_title::before{
    position: absolute;
    content: "Q";
    top: 0;
    left: 2%;
    content: "Q";
    font-size: 2rem;
    font-weight: bold;
    border-radius: 5px;
    margin-top: 1.5%;
    margin-left: 0.8%;
    color: #f4e144;
}
.toggle_title2::before{
    position: absolute;
    content: "Q";
    top: 0;
    left: 2%;
    content: "Q";
    font-size: 2rem;
    font-weight: bold;
    border-radius: 5px;
    margin-top: 1.5%;
    margin-left: 0.8%;
    color: #f4e144;
}
.toggle_txt::before{
    position: absolute;
    content: "A";
    top: 7%;
    left: -4%;
    content: "A";
    font-size: 2rem;
    font-weight: bold;
    border-radius: 5px;
    margin-top: 1.5%;
    margin-left: 0.5%;
    color: #ff9600;
}
.qa_txt_waku {
    border: #ff9600 solid 3px;
    border-radius: 0 0 10px 10px;
}
@media screen and (max-width:767px){ 
    .QA_bg{
        background-color: #e2e2e2;
        padding: 50px 0;
    }
}

/*-----------問い合わせフォーム　タイトルのみ---------*/
.form_bg {
    background-color: #FFD914;
    padding-bottom: 85px;
}
.form_ttl {
    background-color: #000;
    padding: 40px 0;
}
.form_ttl_inner{
    width: 80%;
    max-width: 500px;
    margin: 0 auto;
}
.toiawase {
    width: 85%;
    max-width: 535px;
    margin: 40px auto;
    background-color: #fff;
    border: 2px #000000 solid;
    border-radius: 10px;
    padding: 15px;
}
@media (max-width: 767px) { 
    .form_ttl {
        padding: 30px 0;
    }
}
/*-----------フッター---------*/
footer {
    padding: 55px ;
    font-size: 14px;
    margin-top: 98px;
}
.foot_kaisya {
    font-weight: bold;
    margin-bottom: 6px;
}
@media (max-width: 767px) { 
    footer {
        margin-top: 64px;
        padding: 30px;
    }
}
/*-----------追従---------*/
.follow_inner{
    bottom: 0;
    /*position: fixed;*/
    width: 100%;
    padding: 10px 0 15px;
    max-width: 699px;
}
.follow_innerp{
    text-align: center;
    font-weight: bold;
    font-size: 1.5rem;
}
@media (max-width: 767px) { 
    .follow_innerp{
    font-size: 0.9rem;
}
}
.follow_w {
    max-width: 550px;
    padding: 0 15px;
    margin: 0 auto;
}
.follow_flx {
    display: flex;
    justify-content: space-between;
}
.follow_flx img{
    width: 97%;
}
.shiny_btn{
	position: relative;
	overflow: hidden;
}
.shiny_btn::after {
    animation-name: shiny;
    animation-duration: 3s;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
}
.shiny_btn::after {
    content: "";
    position: absolute;
    top: -100px;
    left: -100px;
    width: 50px;
    height: 50px;
    background-image: linear-gradient(100deg, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 1) 100%, rgba(255, 255, 255, 0) 0%);
}
@keyframes shiny {
	0% {
		transform: scale(0) rotate(25deg);
		opacity: 1;
	}
	
	50% {
		transform: scale(1) rotate(25deg);
		opacity: 1;
	}
	
	100% {
		transform: scale(50) rotate(25deg);
		opacity: 0;
	}
}

@media (max-width: 1022px) {
    .follow_flx img{
        width: 97%;
    }
    .follow_btn p{
        left: 25%;
        font-size: 1.3rem;
    }
}
@media (max-width: 789px) { 
    .follow_w {
        max-width: 70%;
        padding: 0 15px;
        margin: 0 auto;
        margin-bottom: 10px;
    }
    .follow_flx img{
        width: 97%;
    }
    .follow_inner {
        padding: 8px 0 6px;
    }
        .follow_btn p{
        top: 50%;
    left: 26%;
        font-size:3.8vw;
    }
}
@media (max-width: 630px) { 
    .follow_w {
        max-width: 90%;
        padding: 0 15px;
        margin: 0 auto;
        margin-bottom: 10px;
    }
    .follow_flx img{
        width: 97%;
    }
    .follow_inner {
        padding: 3px 0 6px;
    }
}

/*お問い合わせフォーム*/
.content-area{
    background-color: #fff;
}

.content-area h3{
    margin: 2% auto;
    font-size: 2em;
    padding: 2%;
    line-height: 1.2;
    text-align: center;
    font-weight: bold;
}

.content-main {
    max-width: 700px;
    margin: 0 auto;
    background-color: #fff;
}
#content {
    margin: 0 2%;
}

@media (max-width: 767px) {
.content-area h3 {
    font-size: 1.4em;
    margin: 10% auto 6%;
    
}
.form_tbl td {
    display: block;
    width: 100%;
    border: none!important;
    margin-bottom: 23px;
    padding-left: 10px;
    margin-top:10px;
}

#content {
    padding-bottom: 20%;
}
}
/*-------------悪徳業者に注意-------------*/
section.caution {
    padding: 3% 0;
    background: #000000;
}
.caution_inner{
    margin: 5%;
    padding: 3%;
    background-color: #fff;
}
.caution h2{
    width: 90%;
    max-width: 600px;
    margin: 0 auto;
}
.caution h2 img{
    margin: 0 auto;
}
.caution img {
    margin: 30px auto;
    /*max-width:85%;*/
}
.com {
    text-align: center;
    margin-top: 15px;
    font-weight: bold;
    font-size: 1.3em;
}
.red{
    color:#f12c2c;
}
.point {
    display: block;
    margin: 10px auto 0;
    text-align: center;
    background-color: #0f65c8;
    width: 570px;
    padding: 12px 0;
    font-size: 24px;
    font-weight: bold;
    color: #ffffff;
    border-radius: 25px;
}
.caution_contents {
    justify-content: center;
}
.caution_item {
    background-color: #fff;
    border: 3px solid #000000;
    border-radius: 15px;
    padding: 0;
    margin: 3% 1% 0;
    flex: 1;
    position: relative;
}
.caution_item .h4_area {
    height:43px;
    width:43px;
    border-radius:50%;
    line-height:50px;
    text-align:center;
    background:#ffffff;
    border: solid 2px #000000;
    font-size:26px;
    margin: -13px 0px 0px -18px;
    position: absolute;
    top: 0;
}
.area_com{
    padding: 10px;
}
.caution_item h4{
    color: #000000;
    font-weight: bold;
    text-align: center;
    /*padding-top: 11px;*/
}
.s_ttl{
    background-color: #000;
    font-weight: bold;
    text-align: center;
    margin-bottom: 10px;
    font-size: 19px;
    margin-top: 0px;
    border-radius: 10px 10px 0 0;
    padding: 5px 0;
}
.marker{
    background:linear-gradient(transparent 60%, #ff6 60%);
}
.inside_width {
    max-width: 600px;
    width: 100%;
    margin: auto;
}
@media screen and (max-width:740px){
    .com{
        font-size: 1em;
        margin-top: 9px;
    }
    .caution_contents {
        display:block;
    }
    .caution .inside_width {
        width: 95%;
        margin: auto;
    }
    
    .caution_item {
        padding: 0;
        margin: 3% 1% 7%;
    }
    .point {
        width: 330px;
        margin-bottom: 15px;
        padding: 12px 0;
        font-size: 16px;
        border-radius: 25px;
    }
}



/*230517*/
.compare_table{
    background-color: #ffd200;
    padding: 7% 0 13%;
}
.compare_table img{
    display: block;
}
.compare_table img:first-child{
    width: 80%;
    max-width: 450px;
    margin:0 auto 4%;
}
.compare_table img:last-child{
    width: 90%;
    max-width: 600px;
    margin: 0 auto;
}
.trouble_flex_wrapper{
    background-image: url('../img/trouble_flex_bg.jpg');
    background-size: cover;
    padding: 5% 0;
}
.trouble_flex_wrapper img{
    display: block;
}
.trouble_flex_wrapper>.ttl{
    width: 95%;
    max-width: 600px;
    margin: 0 auto;
}
.trouble_flex_wrapper .trouble_flex{
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
}
.trouble_flex_wrapper .trouble_flex{
    width: 95%;
    max-width: 1100px;
    margin: 2% auto 0;
}
.trouble_flex_wrapper .trouble_flex .trouble_flex_child{
    width: 24%;
    position: relative;
}
.trouble_flex_wrapper .trouble_flex .trouble_flex_child>img{
    width: 100%;
}
.trouble_flex_wrapper .trouble_flex .trouble_flex_child>ul{
    position: absolute;
    width: 90%;
    top: 50%;
    left: 5%;
    right: 5%;
}
.trouble_flex_wrapper .trouble_flex .trouble_flex_child>ul li{
    display: flex;
    align-items: flex-start;
    margin-bottom: 10px;
}
.trouble_flex_wrapper .trouble_flex .trouble_flex_child>ul li img{
    width: 25px;
    margin-right: 5px;
    position: relative;
    top: 5px;
}
.trouble_flex_wrapper .trouble_flex .trouble_flex_child>ul li p{
    font-size: 20px;
    text-align: justify;
}
@media screen and (max-width:740px){
    .trouble_flex_wrapper .trouble_flex{
        flex-wrap: wrap;
    }
    .trouble_flex_wrapper .trouble_flex .trouble_flex_child{
        width: 49%;
        margin-bottom: 15px;
    }
    .trouble_flex_wrapper .trouble_flex .trouble_flex_child>ul li p{
        font-size: 14px;
    }
    .trouble_flex_wrapper .trouble_flex .trouble_flex_child>ul li img{
        width: 20px;
        top: 2px;
    }
    .compare_table img:first-child{
        margin: 3% auto 6%;
    }
}

.none {
    display: none;
}

.mt { 
    margin-top:50px;
}
@media screen and (max-width:740px){
    .mt { 
        margin-top:30px;
    }
}
.sec{
    min-height: 125px;
    text-align: center;
    background-repeat: no-repeat;
    background-position: center top;
    background-size: auto 100%;
    background-image: url(../img/trouble02_back.jpg);
}
.inner{
    display: block;
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
    max-width: 1000px;
    box-sizing: content-box;
}
@media screen and (max-width:790px){
    .inner{
    display: block;
    margin: 0;
    padding-left: 0px;
    padding-right: 0px;
    max-width: 1000px;
    box-sizing: content-box;
}
}

/*240411*/
.cta_bg{
    background-image: url(../img/cta_bg.jpg);
    background-repeat: no-repeat;
    background-position: top;
    background-size: cover;
    padding: 20px 0;
}
.cta_inner3 {
    width: 86%;
    max-width: 650px;
    margin: 0 auto;
    border-radius: 10px;
    padding: 2% 0 8%;
    position: relative;
}
.btn_popup2{
    display: block;
    z-index: 99;
}
.btn_popup2 a{
    display: block;
    position: relative;
    transition: .2s;
}
.btn_popup4{
    display: block;
    z-index: 99;
}
.btn_popup4 a{
    display: block;
    position: relative;
    transition: .2s;
    margin-top: 20px;
}

.cta_inner3 p {
    position: absolute;
    bottom: 2%;
    left: 21%;
    margin: auto;
    font-weight: bold;
    color: #fff;
    font-size: 4.3rem;
}
@media screen and (max-width:790px){
    .cta_bg{
        padding: 10px 0;
    }
    .cta_inner3 {
    padding: 1% 0 4%;
}
.cta_inner3 p {
    position: absolute;
    bottom: 8%;
    left: 25%;
    margin: auto;
    font-weight: bold;
    color: #fff;
    font-size: 1.6rem;
}
.btn_popup2 a::before, .btn_popup2 a::after {
    height: 77%;
}
.btn_popup4 a::before, .btn_popup4 a::after {
    height: 77%;
}
}
.reason_bg{
    background-image: url(../img/reason_bg.jpg);
    background-repeat: no-repeat;
    background-position: top;
    background-size: cover;
}
.flow_bg{
    background-image: url(../img/flow_bg.jpg);
    background-repeat: no-repeat;
    background-position: top;
    background-size: cover;
}
.flow{
    width: 100%;
    max-width: 550px;
    padding: 55px 0 65px;
    margin: 0 auto;
}
.step_flx {
    display: flex;
    gap: 15px;
    align-items: flex-start;
    margin-top: 20px;
}
.step_flx>img {
    width: 25%;
    margin-left: 5px;
}
.step_ttl{
    font-size: 30px;
    font-weight: bold;
    color: #DC0000;
}
.step_txt{
    font-size: 20px;
}

.head_pc {
    position: relative;
    margin-left: 2px;
}

.popup2_pc {
    display: block;
    position: relative;
    transition: .2s;
}

@media screen and (max-width:790px){
.flow{
    width: 95%;
    padding: 40px 0 50px;
}
.step_flx>img {
    width: 25%;
    margin-left: 5px;
}
.step_ttl{
    font-size: 20px;
    font-weight: bold;
    color: #DC0000;
}
.step_txt{
    font-size: 14px;
}

.pc_only {
    display: none;
}
}

@media screen and (min-width: 790px){
    .sp_only {
        display: none;
    } 
}

/*240904*/
/*cta*/
.static-bg {
    background-color: #000000; /* または任意の固定色 */
    padding: 10px;
}

.static-time {
    color: #ffffff;
}
.blinking {
    animation: blink-text 2s linear infinite;
}

@keyframes blink-text {
    0% { opacity: 1; }
    50% { opacity: 0; }
    100% { opacity: 1; }
}


.static-time {
    /* 必要に応じて追加のスタイリング */
    margin:0 auto;
}


@media screen and (max-width: 480px) {
    .guide-available {
        font-size: 14px;
    }
    .static-time .time-numbers {
        color: #ffe600; /* 青色の例。希望の色に変更してください */
        font-weight: bold;
        font-size: 18px;
    }
    .guide-available {
        color: #ff9d0b;
        font-size: 18px; /* デフォルトサイズ */
    }
}

@media screen and (min-width: 481px) and (max-width: 768px) {
    .guide-available {
        font-size: 16px;
    }
    .static-time .time-numbers {
        color: #ffe600; /* 青色の例。希望の色に変更してください */
        font-weight: bold;
        font-size: 20px;
    }
    .guide-available {
        color: #ff9d0b;
        font-size: 20px; /* デフォルトサイズ */
    }
    .btn_popup2 img {
        box-shadow: 0 8px 0 0 #073508;
        animation: hekomu2 2s infinite;
        border-radius: 32px;
    }
    .btn_popup4 img {
        box-shadow: 0 8px 0 0 #830c0a;
        animation: hekomu4 2s infinite;
        border-radius: 32px;
    }
}

@media screen and (min-width: 769px) {
    .guide-available {
        font-size: 18px;
    }
    .static-time .time-numbers {
        color: #ffe600; /* 青色の例。希望の色に変更してください */
        font-weight: bold;
        font-size: 30px;
    }
    .guide-available {
        color: #ff9d0b;
        font-size: 30px; /* デフォルトサイズ */
    }
}

@media screen and (min-width: 650px) {
    .btn_popup2 img {
        box-shadow: 0 8px 0 0 #073508;
        animation: hekomu2 2s infinite;
        border-radius: 32px;
    }
    .btn_popup4 img {
        box-shadow: 0 8px 0 0 #830c0a;
        animation: hekomu4 2s infinite;
        border-radius: 32px;
    }
}

@media screen and (max-width: 650px) and (min-width: 480px) {
    .btn_popup2 img {
        box-shadow: 0 8px 0 0 #073508;
        animation: hekomu2 2s infinite;
        border-radius: 26px;
    }
    .btn_popup4 img {
        box-shadow: 0 8px 0 0 #830c0a;
        animation: hekomu4 2s infinite;
        border-radius: 26px;
    }
}

@media screen and (max-width: 480px) {
    .btn_popup2 img {
        box-shadow: 0 8px 0 0 #073508;
        animation: hekomu2 2s infinite;
        border-radius: 20px;
    }
    .btn_popup4 img {
        box-shadow: 0 8px 0 0 #830c0a;
        animation: hekomu4 2s infinite;
        border-radius: 20px;
    }
}

@keyframes hekomu2 {
    0% {
        box-shadow: 0 8px 0 #073508;
        top: 0px;
    }
    10% {
        box-shadow: none;
        position: relative;
        top: 8px;
    }
    20% {
        box-shadow: 0 8px 0 #073508;
        top: 0px;
    }
    30% {
        box-shadow: none;
        position: relative;
        top: 8px;
    }
    40% {
        box-shadow: 0 8px 0 #073508;
        top: 0px;
    }
}
@keyframes hekomu4 {
    0% {
        box-shadow: 0 8px 0 #830c0a;
        top: 0px;
    }
    10% {
        box-shadow: none;
        position: relative;
        top: 8px;
    }
    20% {
        box-shadow: 0 8px 0 #830c0a;
        top: 0px;
    }
    30% {
        box-shadow: none;
        position: relative;
        top: 8px;
    }
    40% {
        box-shadow: 0 8px 0 #830c0a;
        top: 0px;
    }
}

.follow_flx img {
    width: 97%;
}

.follow_flx img[src*="follow_cta_tel.png"] {
    box-shadow: 0 8px 0 0 #073508;
    animation: hekomu2 2s infinite;
    border-radius: 26px;
}

.follow_flx img[src*="follow_cta_mail.png"] {
    box-shadow: 0 8px 0 0 #830c0a; 
    animation: hekomu_red 2s infinite;
    border-bottom-left-radius: 26px;
    border-bottom-right-radius: 26px;
}

@keyframes hekomu_red {
    0% {
        box-shadow: 0 8px 0 #830c0a;
        top: 0px;
    }
    10% {
        box-shadow: none;
        position: relative;
        top: 8px;
    }
    20% {
        box-shadow: 0 8px 0 #830c0a;
        top: 0px;
    }
    30% {
        box-shadow: none;
        position: relative;
        top: 8px;
    }
    40% {
        box-shadow: 0 8px 0 #830c0a;
        top: 0px;
    }
}

@media screen and (max-width: 650px) and (min-width: 480px) {
    .follow_flx img[src*="follow_cta_tel.png"] {
        border-radius: 20px;
    }
    .follow_flx img[src*="follow_cta_mail.png"] {
        border-bottom-left-radius: 20px;
        border-bottom-right-radius: 20px;
    }
}

@media screen and (max-width: 480px) {
    .follow_flx img[src*="follow_cta_tel.png"] {
        border-radius: 14px;
        box-shadow: 0 5px 0 0 #073508; /* 影の幅を8pxから5pxに変更 */
        animation: hekomu_tel_small 2s infinite; /* 新しいアニメーションを適用 */
    }
    .follow_flx img[src*="follow_cta_mail.png"] {
        border-bottom-left-radius: 14px;
        border-bottom-right-radius: 14px;
        box-shadow: 0 5px 0 0 #830c0a; /* 影の幅を8pxから5pxに変更 */
        animation: hekomu_mail_small 2s infinite; /* 新しいアニメーションを適用 */
    }
}

/* 小さい画面用の新しいアニメーション */
@keyframes hekomu_tel_small {
    0% {
        box-shadow: 0 5px 0 #073508;
        transform: translateY(0);
    }
    10% {
        box-shadow: 0 0 0 #073508;
        transform: translateY(5px);
    }
    20%{
        box-shadow: 0 5px 0 #073508;
        transform: translateY(0);
    }
    30% {
        box-shadow: 0 0 0 #073508;
        transform: translateY(5px);
    }
    40% {
        box-shadow: 0 5px 0 #073508;
        transform: translateY(0);
    }
    
}

@keyframes hekomu_mail_small {
    0% {
        box-shadow: 0 5px 0 #830c0a;
        transform: translateY(0);
    }
    10% {
        box-shadow: 0 0 0 #830c0a;
        transform: translateY(5px);
    }
    20% {
        box-shadow: 0 5px 0 #830c0a;
        transform: translateY(0);
    }
    30% {
        box-shadow: 0 0 0 #830c0a;
        transform: translateY(5px);
    }
    40% {
        box-shadow: 0 5px 0 #830c0a;
        transform: translateY(0);
    }
}

/*mv*/
.mv_wrapper {
    position: relative;
    width: 100%;
}

.mv_move {
    position: relative;
}

.base-image {
    width: 100%;
    display: block;
}

.overlay-images {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.mm01, .mm02, .mm03 {
    position: absolute;
}

.mm01 {
    bottom: 0;
    left: 0;
    width: 20%; /* 画面幅の20%のサイズ */
    max-width: 150px; /* 最大サイズを制限 */
    animation: mv_other 0.6s linear forwards;
}

.mm02 {
    top: 16%;
    right: 3%;
    width: 27%;
    max-width: 186px;
    opacity: 0; /* 初期状態では非表示 */
    animation: mv_track 1.2s linear 0.2s forwards;
}

.mm03 {
    bottom: 21%;
    left: 38%;
    transform: translateX(-50%);
    width: 60%;
    max-width: 422px;
    animation: mv_track 1.2s linear forwards;
}

.mm01 img, .mm02 img, .mm03 img {
    width: 100%;
    height: auto;
}

/* メディアクエリを使用して、小さい画面サイズでの調整 */
@media screen and (max-width: 768px) {
    .mm01 {
        width: 20%;
        max-width: 143px;
    }

    .mm02 {
        width: 27%;
        max-width: 186px;
    }

    .mm03 { width: 60%;
        max-width: 422px;

    }
}


@keyframes slide_in_top_bounce {
    0% {
        top: -100%;
        transform: scale(1);
    }
    50% {
        top: 20%; /* 少し下まで降りる */
        transform: scale(1);
    }
    70% {
        top: 10%; /* 少し上に戻る */
        transform: scale(0.9); /* 少し縮む */
    }
    85% {
        top: 17%; /* 再び下がる */
        transform: scale(1.1); /* 少し膨らむ */
    }
    100% {
        top: 15%; /* 最終位置 */
        transform: scale(1); /* 元のサイズに戻る */
    }
}

/* 他の要素のスタイルは変更なし */

@keyframes mv_other {
    0% {
        transform: scale(0.8, 1.1) translate(0, -1000px);
    }
    85% {
        transform: scale(1.1, 0.9) translate(0, 30px);
    }
    100% {
        transform: scale(1) translate(0, 0);
    }
}

@keyframes mv_track {
    0% {
        transform: scale(0.8, 1.4) translate(0%, -100%);
        opacity: 0;
    }
    10% {
        transform: scale(0.8, 1.4) translate(0%, -15%);
        opacity: 1;
    }
    20% {
        transform: scale(1.4, 0.6) translate(0%, 30%);
        opacity: 1;
    }
    30% {
        transform: scale(0.9, 1.1) translate(0%, -10%);
        opacity: 1;
    }
    40% {
        transform: scale(0.95, 1.2) translate(0%, -30%);
        opacity: 1;
    }
    50% {
        transform: scale(0.95, 1.2) translate(0%, -10%);
        opacity: 1;
    }
    60% {
        transform: scale(1.1, 0.9) translate(0%, 5%);
        opacity: 1;
    }
    70% {
        transform: scale(1, 1) translate(0%, 0%);
        opacity: 1;
    }
    100% {
        transform: scale(1, 1) translate(0%, 0%);
        opacity: 1;
    }
}

/* 他の要素のスタイルは変更なし */
@keyframes bounce {
    0% {
        transform: scale(1, 1) translate(0%, 0%);
    }
    40% {
        transform: scale(0.95, 1.2) translate(0%, -10%);
    }
    50% {
        transform: scale(1.1, 0.9) translate(0%, 5%);
    }
    60% {
        transform: scale(0.95, 1.05) translate(0%, -3%);
    }
    70% {
        transform: scale(1.05, 0.95) translate(0%, 3%);
    }
    80% {
        transform: scale(1, 1) translate(0%, 0%);
    }
    100% {
        transform: scale(1, 1) translate(0%, 0%);
    }
}

.mv_wrapper .mv_move .mm01 img {
    animation: bounce 2s 0.8s linear infinite;
}

.mv_wrapper .mv_move .mm02 img {
    animation: bounce 2s 1.2s linear infinite;
}

.mv_wrapper .mv_move .mm03 img {
    animation: bounce 2s 1.6s linear infinite;
}   

/*対応地域アコーディオン*/
/*ベース*/
.accordion {
    margin: 0 auto;
    margin-bottom: 10%;
}

.toggle {
	display: none;
}
.Label {		/*タイトル*/
	padding: 1em 0;
	display: block;
	color: #fff;
	background:#000;
    margin: 0 auto;
    text-align: center;
    width: 90%;
}
.Label::before{		/*タイトル横の矢印*/
	content:"";
	width: 6px;
	height: 6px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	-webkit-transform: rotate(45deg);
	position: absolute;
	top:calc( 50% - 3px );
	right: 20px;
	transform: rotate(135deg);
}
.Label,
.content {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translate(0);
	transition: all 0.3s;
}
.content {		/*本文*/
	height: 0;
	margin-bottom:10px;
	overflow: hidden;
    background-color: #fff;
    width: 90%;
}

.content p {
    margin: 2%;
}

.toggle:checked + .Label + .content {	/*開閉時*/
	height: auto;
	transition: all .5s;
    margin-bottom: 20px;
    width: 90%;
}
.toggle:checked + .Label::before {
	transform: rotate(-45deg) !important;
}