@charset "utf-8";

/*==========================
QA
==========================*/

.redBox {
    width: 22px;
    height: 64px;
    background-color: var(--red);
}

.btnBox {
    display: flex;
    justify-content: center;
}


.toggle-btn {
    background: none;
    border: none;
    font-size: 1.5em;
    cursor: pointer;
}


.main {
    padding: 34px 6%;
}

.title_QA {
    width: 190px;
    margin: 0 auto 61px;
}

.Q {
    color: #A02D2D;
    font-size: 1.6rem;
    width: 84.7%;
    bottom: 2px;
    position: relative;
    margin-right: 21px;
    padding-left: 5px;
}

    
.Qicon {
    width: 22px;
    height: 22px;
    margin-right: 4px;
}

.A {
    font-size: 1.4rem;
    width: 89.7%;
    padding-left: 4px;
}

.Aicon {
    width: 22px;
    height: 22px;
    margin-right: 4px;
}

.QA {
    margin-top: 61px;
}

.Qdiv {
    display: flex;
}

.Adiv {
    display: none; /* 初期状態で非表示 */
    margin-top: 12px;
}

.flexBoxA {
    display: flex;
}

.QBox::after {
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    background-color: #A02D2D;
    margin: 18px auto 54px;
}


.contactBtn::before {
    content: '';
    display: block;
    width: 0;
    height: 0;
    border-left: 6px solid #32393A;
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    position: absolute;
    bottom: 28px;
    left: 198px;
}

.contact__txt {
    font-size: 1.4rem;
    text-align: center;
}

.contact {
    text-align: center;
}

.btnBox {
    margin-top: 33px;
}

.move {
    margin: 4px auto 28px;
    text-align: right;
    width: 221px;
}


/* btncolor ***********************/


.contactBtn::after {
    background: var(--red);
    position: absolute;
    top: 0;
    left: 0;
    content: '';
    width: 100%;
    height: 101%;
    transform: scale(0, 1);
    transform-origin: left top;
    transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
    z-index: -1;
}

.contactBtn:hover {
    color: #fff;
}

.contactBtn:hover::after {
    transform: scale(1, 1);
}

.contactBtn:hover::before {
    border-left: 6px solid #fff;
    transition: .2s cubic-bezier(0.45, 0, 0.55, 1);

}


/* btncolor end *******************/









/* QA pc */

@media screen and (min-width:769px) {

    .navespace {
        height: 5.2vw;
    }

    .redBox {
        width: 1.528vw;
        height: 4.458vw;
        background-color: var(--red);
    }

    .main {
        padding: 5.72vw 23.19vw;
    }
    
    .Q {
        font-size: 1.25vw;
        bottom: -0.138vw;
    }

    .Adiv {
        margin-top: 1.425vw;
    }
    
    .Qicon {
        width: 2.36vw;
        height: 2.36vw;
        margin-right: 1.25vw;
    }
    
    .title_QA {
        width: 20.1vw;
    }
    
    .contact__txt {
        margin: 2.98vw 0 1.52vw;
        font-size: 0.97vw;
    }

    .A {
        font-size: 1.111vw;
    }



    .contactBtn {
        font-size: 1.11vw;
        padding: 1.25vw 2.77vw 1.38vw 1.38vw;
        transition: all .4s;
        height: 4.458vw;
    }
    .contactBtn::before {
        bottom: 1.9138vw;
        left: 13.75vw;
    }

    .move {
        margin:  0.278vw auto 1.944vw;
        text-align: right;
        width: 18.047vw;
        font-size: 1.11vw;
    }

    .QBox::after {
        margin: 2.222vw auto;
    }

    





}

/* title　１４５０以上 */

@media screen and (min-width:1450px) {
    .title_QA{
        width: 390px;
    }

    .QImg {
        max-width: 160%;
        width: 20vw;
    }
    
}


/* pc 769px */



/*==========================
resrevation
==========================*/
.resrevationTitle {
    width: 200px;
    margin: 48px auto 0;
}

.resrevation__txt {
    text-align: center;
    font-size: 1.6rem;
    font-weight: 400;
    margin-top: 18px;
}

.resrevationImgBox{
    margin: 34px auto 0;
    text-align: center;
}

.resrevationImg {
    width: 280px;
}

.btnBox {
    text-align: center;
    margin-top: 52px;
    margin-left: 17px;
}

.BtnBoxposi {
    display: flex;
    justify-content: center;
}

.redBox {
    width: 22px;
    height: 64px;
    background-color: var(--red);
}

.priceBtn::before {
    content: '';
    display: block;
    width: 0;
    height: 0;
    border-left: 6px solid #32393A;
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    position: absolute;
    bottom: 28px;
    left: 198px;
}

/* btncolor */


.priceBtn {
    border: 1px solid #A02D2D;
    background: #FDFDFD;
    text-align: center;
    font-size: 1.6rem;
    font-weight: 600;
    padding: 18px 48px 20px 28px;
    position: relative;
    transition: all .4s;
    height: 64px;
    display: inline-block;
    overflow: hidden;
    position: relative;
    z-index: 1;
}

.priceBtn::after {
    background: var(--red);
    position: absolute;
    top: 0;
    left: 0;
    content: '';
    width: 100%;
    height: 101%;
    transform: scale(0, 1);
    transform-origin: left top;
    transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
    z-index: -1;
}

.priceBtn:hover {
    color: #fff;
}

.priceBtn:hover::after {
    transform: scale(1, 1);
}

.priceBtn:hover::before {
    border-left: 6px solid #fff;
    transition: .2s cubic-bezier(0.45, 0, 0.55, 1);

}


/* btncolor end */

.resrevation__btnBox {
    margin-top: 33px;
}

.resrevation__btn {
    border: 1px solid #A02D2D;
    background: #FDFDFD;
    text-align: center;
    font-size: 1.6rem;
    font-weight: 600;
    padding: 18px 40px 20px 21px;
    color: #32393A;
    position: relative;
    transition: all .4s;
    display: inline-block;
    height: 64px;
}



.resrevation__btn::before {
    content: '';
    display: block;
    width: 0;
    height: 0;
    border-left: 6px solid #A02D2D;
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    position: absolute;
    bottom: 27px;
    left: 238px;
}


/* btncolor02 */


.resrevation__btn {
    border: 1px solid #A02D2D;
    background: #FDFDFD;
    text-align: center;
    font-size: 1.6rem;
    font-weight: 600;
    padding: 18px 62px 20px 42px;
    position: relative;
    transition: all .4s;
    height: 64px;
    display: inline-block;
    overflow: hidden;
    position: relative;
    z-index: 1; 
}

.resrevation__btn::after {
    background: var(--red);
    position: absolute;
    top: 0;
    left: 0;
    content: '';
    width: 100%;
    height: 101%;
    transform: scale(0, 1);
    transform-origin: left top;
    transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
    z-index: -1;
}

.resrevation__btn:hover {
    color: #fff;
}

.resrevation__btn:hover::after {
    transform: scale(1, 1);
}

.resrevation__btn:hover::before {
    border-left: 6px solid #fff;
    transition: .2s cubic-bezier(0.45, 0, 0.55, 1);

}


/* btncolor end */


.move {
    text-align: right;
    font-size: 1.1rem;
    font-weight: 400;
    width: 285px;
    margin: 4px auto 0;
}

.spnone {
    display: none;
}

.line_wImg02 {
    margin-top: 34px;
    width: 100vw;
}

.BtnBoxposipc {
    display: none;
}


/* resrevation pc */
@media screen and (min-width:769px) {

    .spnone {
    display: inline;
}

    .BtnBoxposipc {
        display: flex;
    }

    .qr {
        width: 8.264vw;
        height: 8.264vw;
    }

    .qrBox {
        width: 20.833vw;
        height: 10.972vw;
        border: 1px solid #A02D2D;
        background:#fff;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .qrTxt01 {
        font-size: 1.389vw;
        color: #32393A;
        margin-right: 37px;
    }


    .BtnBoxposisp {
        display: none;
    }

    .redBox {
        width: 2.361vw;
        height: 4.514vw;
    }

    .redBox01 {
        height: 10.972vw;
    }
    

    .resrevation {
        padding: 0vw 16.9vw 2.36vw 16.9vw ;
        padding-top: 4.3vw;
    }

    .resrevationTitle {
        width: 23.125vw;
    }

    .resrevation__txt {
        font-size: 1.388vw;
        margin-top: 1.25vw;
    }

    .resrevation__box {
        display: flex;
        flex-direction: row-reverse;
        margin-top: 0vw;
        margin-right: -7.1944vw;
    }

    .resrevationImg {
        width: 37.2vw;
        margin-top: 0;
    }

    .priceBtn {
        font-size: 1.389vw;
        padding: 1.11vw 4.86vw 1.11vw 3.47vw;
        display: block;
        height: 4.5vw;
    }

    .resrevation__btn {
        font-size: 1.389vw;
        padding: 1.111vw 6.042vw 1.111vw 4.722vw;
        display: block;
        height: 4.5vw;
    }

    .move {
        font-size: 0.972vw;
        margin: 0.4vw auto 2.54vw;
        width: 22.39vw;
    }

    .btnBox{
        margin-top: 13.4vw;
        margin-left: 2.08vw;
    }

    .resrevation__btnBox {
        margin-top: 2.58vw;
    }
    
    .resrevation__btn::before {
        top: 1.975vw;
        left: 17.847vw;
    }

    
    .priceBtn::before {
        top: 1.975vw;
        left: 17.847vw;
    }
    
    

}

/* pc 769px */


