/* html調整用に回答エリアを出力する場合はこちらを利用 */
/*
.answer-item{
    display: block !important;
}
 */


body{
}

b{
    font-weight: bold;
    color: #cc0000;
}

.question-text {
    font-size: 18px;
}

.quote-answer__list .q-btn>div {
    color: #333;
    font-weight: bold;
}
.quote-answer__list .q-btn {
    background: #fff;
    border-radius: 8px;
    color: #333;
    font-size: 1.5vw;
    font-weight: 700;
    padding: 10px 5px;
    width: 100%;
    max-width: inherit;
    margin-bottom: 15px;
    cursor: pointer;
    border: 3px solid #333;
    -webkit-box-shadow: 0 3px 5px rgba(0, 0, 0, .3);
    box-shadow: 0 3px 5px rgba(0, 0, 0, .3);
}


.q-btn span{
    font-weight: bold;
}
.q-tag input[type="number"]{
    text-align: center;
    width: 100px;
    padding: 10px;
    border-radius: 5px;
    display: inline-block;
    margin: 0 20px;
    transform: scale(1.2);
    font-size: 20px;
    border: 2px solid #eee;
}



.quote-answer__list .q-btn {
    width: 49%;
}



#q2 .quote-answer__list .q-img img{
    max-width: 100px;
    width: 100px;
    height:100px;
    object-fit: contain;
}
#q1 .quote-answer__list .q-btn {
    font-size: 18px;
}
#q2 .quote-answer__list .q-btn {
    font-size: 18px;
}
/*
@media (max-width: 600px) {
    #q1 .quote-answer__list .q-btn {
        width: 49%;
    }
    #q2 .quote-answer__list .q-btn {
        width: 49%;
    }


}

#q3 .quote-answer__list .q-btn {
    width: 100%;
}
#q3 .quote-answer__list:after{
    width: 24%;
    content:"";
}

#q4 .quote-answer__list .q-btn {
    width: 49%;
}

#q5 .quote-answer__list .q-btn {
    width: 49%;
}

#q6 .quote-answer__list .q-btn {
    width: 100%;
}
#q7 .quote-answer__list .q-btn {
    width: 100%;
}
#q8 .quote-answer__list .q-btn {
    width: 49%;
}

 */
.main-contents {
    background-color: inherit;
}



.result-ttl{
    font-size: 18px;
    font-weight: bold;
    background-color: #008fff;
    position: relative;
    padding: 20px;
    color: #fff;
    margin: -20px -20px 0;
}
.result-ttl span{
    font-size: 24px;
    font-weight: bold;
    display: block;
}
.mikomi{
    text-align: center;
    font-weight: bold;
    letter-spacing: .2em;
}
.seiyaku,
.apo{
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    padding: 0 30px;
    position: relative;
    margin: 30px 0;
    border-bottom: 1px solid #ccc;
}



/*
.seiyaku::before, .seiyaku::after,
.apo::before, .apo::after
{
    background-color: #008fff;
    border-radius: 100px;
    content: "";
    display: block;
    width: 3px;
    height: 40px;
    position: absolute;
    bottom: -10px;
}

.seiyaku::before,
.apo::before
{
    left: 0;
    transform: rotate(-30deg);
}
.seiyaku::after,
.apo::after
{
    right: 0;
    transform: rotate(30deg);
}
*/

.seiyaku .sub,
.apo .sub{
    font-weight: bold;
    margin-right: 10px;

}
.seiyaku .before,
.apo .before{
    font-weight: bold;
    font-size:20px;
}


.seiyaku .after,
.apo .after{
    font-size:50px;
    font-weight: bold;
    color: #008fff;
}
.seiyaku span,
.apo span{
    font-weight: bold;
}






    /*
    .result-ttl::before, .result-ttl::after {
        background-color: #008fff;
        border-radius: 100px;
        content: "";
        display: block;
        width: 3px;
        height: 40px;
        position: absolute;
        bottom: -10px;
    }

    .result-ttl::before {
        left: 0;
        top:0;
        transform: rotate(-30deg);
    }
    .result-ttl::after {
        right: 0;
        top:0;
        transform: rotate(30deg);
    }*/
.answer-item{
    display:block;
}
.result-txt{
    text-align: center;
    font-weight: bold;
    margin-top: 20px;
    line-height: 1.8em;
    padding: 20px;
    background-color: #f2f8fa;
    }
.result-img{
    margin-top: 30px;
}
.result-voice{
    display: flex;
    align-items: center;
    padding: 20px;
}
.result-voice .img{
    width: 20%;
}
.result-voice .info{
    width: 80%;
    padding-left: 20px;
    text-align: left;
}
.result-voice .ttl{
    font-weight: bold;
    font-size: 30px;
    border-bottom: 2px solid #fff;
}
.result-voice .ttl span{
    font-size: 40px;
    margin: 0 20px;
    color: #008fff;
    font-weight: bold;
}
.result-voice-prof{
    margin-top: 40px;
background-color: #008fff;
    padding: 20px;
    font-weight: bold;
    color: #fff;
}
.result-voice .txt{
    margin-top: 20px;
    font-size: 15px;
}

.result-voice .txt span{
    margin-top: 10px;
    display: block;
    color: #aeadad;
    text-align: right;
    font-size: 13px;
}
.consul-ttl{
text-align: center;
margin-top: 40px;
font-weight: bold;
color:#008fff;
position: relative;
display: inline-block;
padding: 0 30px;
    font-size: 15px;
}

.consul-ttl::before, .consul-ttl::after {
background-color: #008fff;
border-radius: 100px;
content: "";
display: block;
width: 3px;
height: 40px;
position: absolute;
bottom: -10px;
}

.consul-ttl::before {
left: 0;
transform: rotate(-30deg);
}
.consul-ttl::after {
right: 0;
transform: rotate(30deg);
}

.consul-ttl span{
    font-weight: bold;
    font-size: 20px;
}

.result-consul{
display: flex;
align-items: center;

max-width: 600px;
margin: 20px auto;
}

.result-consul .img{
width: 15%;
overflow: hidden;
border-radius: 50%;
}
.result-consul .img img{
width: 100%;
height: 100%;
object-fit: cover;
}
.result-consul .info{
width: 85%;
padding-left: 20px;
text-align: left;
}

.result-consul .txt{

font-size: 15px;
}

.result-consul .prof{
margin-top: 10px;
border-radius: 10px;
font-weight: bold;
font-size: 12px;
}

.marker {
font-weight: bold;
color: #0f81dc;
background: linear-gradient(transparent 60%, #ffff66 60%);
}

.to-init {
    margin-top: 20px;

}
.to-init a{
    font-weight: bold;
    color: #008fff;
    font-size: 18px;
    text-decoration: underline;
}

@media (max-width: 600px) {
    .quote-answer__list .q-btn {

        font-size: 3.5vw;

    }


    .seiyaku .sub,
    .apo .sub{
        width: 100%;

    }
    .seiyaku .before,
    .apo .before{

    }


    .seiyaku .after,
    .apo .after{

    }
    .seiyaku span,
    .apo span{

    }
    .seiyaku, .apo {
        padding: 0 0 20px;
    }


}
.safe-list{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.safe-list .item{
    width: 33%;

    text-align: left;
    background-color: #fff;
    padding:10px;
    margin-bottom: 10px;
}

.safe-list .item .img{
    width: 80px;
    height: 80px;
    margin:0 auto;
}

.safe-list .item .img img{
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.safe-list .item .info{
    width: 100%;
    padding-left: 0px;
}
.safe-list .item .info .ttl{
    font-weight: bold;
    text-align: center;
    margin-top: 20px;
}

.safe-list .item .info .txt{
    font-size:14px;
}

@media (max-width: 600px) {
    .safe-list .item {
        width: 100%;
        display: flex;
    }
    .safe-list .item .img{
        width: 50px;
    }

    .safe-list .item .img img{
        width: 100%;
    }
    .safe-list .item .info{
        width: calc(100% - 50px);
        padding-left: 10px;
    }
    .safe-list .item .info .ttl{
        font-weight: bold;
        margin-top: 0px;
        text-align: left;
    }

    .safe-list .item .info .txt{
        font-size:14px;
    }
}




.cmt-ttl{
    font-size: 20px;
    text-align: center;
    font-weight: bold;
}
.code{
    position: relative;

    height: 150px;
    width: 280px;
    margin: 0 auto;

}
.code .ttl{
    padding-top: 36px;
    font-family: '游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif!important;
    position: relative;
    z-index: 1;
    font-size: 30px;

    font-weight:bold;
    color: #da4e4e;
}
.code .ttl span{
    font-size: 18px;
}
.code .num{
    font-size: 15px;
    position: relative;
    z-index: 1;

}
.code .num span{
    font-size: 20px;
}
.coupon-img{
position: absolute;
    left: 0;
    top:0;
    height: 100%;
    width: 100%;
    z-index: 0;
}
.coupon-img img{
    width: 100%;
    height: 100%;
}



.thumb-img{}
.thumb-img img{
    height: 200px;
    width: 100%;
    object-fit: cover;
}

/* サイトcss流用 */
.c-service__content-list {
    width: 100%;
    padding: 0 5px
}

.c-service__content-list-item {
    width: 100%;
    border-top: 2px solid #85d4f5;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    padding: 10px
}

.c-service__content-list-item:first-child {
    border: none
}

.c-service__content-list-checkbox {
    width: 20px;
    height: 20px;
    border: 3px solid #85d4f5;
    position: relative;
    display: block;
    margin-right: 1em;
    border-radius: 5px;
    margin-bottom: .3em
}

.c-service__content-list-checkbox:before {
    content: '';
    display: block;
    position: absolute;
    top: -.2em;
    left: .2em;
    width: 20px;
    height: 10px;
    border-left: 3px solid #005ba6;
    border-bottom: 3px solid #005ba6;
    transform: rotate(-45deg)
}

@media screen and (min-width: 768px) {
    .c-service__content-list-checkbox {
        width:30px;
        height: 30px
    }

    .c-service__content-list-checkbox:before {
        width: 30px;
        height: 15px;
        border-left: 4px solid #005ba6;
        border-bottom: 4px solid #005ba6
    }
}

.c-service__content-list-trouble {
    font-size: 20px;
    font-size: 1.25rem;
    font-family: "Noto Sans JP",sans-serif;
    font-weight: 700;
    text-align: left;
    width: calc( 100% - 40px );
    margin-bottom: .5em
}

@media screen and (min-width: 576px) {
    .c-service__content-list-trouble {
        width:30%
    }
}

@media screen and (min-width: 768px) {
    .c-service__content-list-trouble {
        margin-right:10px;
        font-size: 30px;
        font-size: 1.875rem
    }
}

.c-service__content-list-web {
    font-size: 12px;
    font-size: .75rem;
    line-height: 1.2;
    font-family: "Noto Sans JP",sans-serif;
    font-weight: 700;
    width: 60px;
    height: 60px;
    background: #f6db59;
    position: relative;
    border-radius: 200px;
    align-self: center;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    margin-right: 10px
}

@media screen and (min-width: 768px) {
    .c-service__content-list-web {
        width:80px;
        height: 80px;
        font-size: 16px;
        font-size: 1rem;
        line-height: 1.2
    }
}

.c-service__content-list-price {
    font-size: 16px;
    font-size: 1rem;
    font-family: "Noto Sans JP",sans-serif;
    font-weight: 700;
    text-align: left;
    width: auto;
    flex: 1
}

@media screen and (min-width: 768px) {
    .c-service__content-list-price {
        font-size:22px;
        font-size: 1.375rem
    }
}

.c-service__content-list-price--before {
    display: block;
    text-decoration: line-through
}

.c-service__content-list-price--after {
    font-size: 16px;
    font-size: 1rem;
    display: block
}

@media screen and (min-width: 768px) {
    .c-service__content-list-price--after {
        font-size:30px;
        font-size: 1.875rem
    }
}

.c-service__content-list-price--red-big {
    font-size: 30px;
    font-size: 1.875rem;
    color: #f23a42;
    line-height: 1
}

@media screen and (min-width: 768px) {
    .c-service__content-list-price--red-big {
        font-size:60px;
        font-size: 3.75rem
    }
}

.c-service__content-list-price--red-small {
    font-size: 16px;
    font-size: 1rem;
    color: #f23a42
}


.c-service__content-fukidashi {
    display: inline-block;
    border: 5px solid #f6db59;
    border-radius: 100px;
    background: #fff;
    padding: .3em 1em;
    font-size: 24px;
    font-size: 1.5rem;
    font-weight: bold;
    font-size: 4.2vw;
    position: relative;
    margin-bottom: 20px;
}
.c-service__content-fukidashi img{
    width: 30px;
    margin-right: 5px;
    vertical-align: middle;
}

.c-service__content-fukidashi:before {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -36px;
    margin-left: -18px;
    border: 18px solid transparent;
    border-top: 18px solid #FFF;
    z-index: 2
}

@media screen and (min-width: 768px) {
    .c-service__content-fukidashi:before {
        bottom:-44px;
        margin-left: -22px;
        border: 22px solid transparent;
        border-top: 22px solid #FFF
    }
}

.c-service__content-fukidashi:after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -45px;
    margin-left: -20px;
    border: 20px solid transparent;
    border-top: 20px solid #f6db59;
    z-index: 1
}

@media screen and (min-width: 768px) {
    .c-service__content-fukidashi:after {
        bottom:-53px;
        margin-left: -24px;
        border: 24px solid transparent;
        border-top: 24px solid #f6db59
    }
}

@media screen and (min-width: 768px) {
    .c-service__content-fukidashi {
        font-size:24px;
    }
}

.c-service__content-fukidashi--red {
    color: #f23a42
}


.c-bottom__tel {
    margin-top: 20px;
    margin-bottom: 20px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    transition: .3s all ease;
    width: 100%;
    z-index: 10;
    padding: .3em .8em .3em;
    border-radius: 10px;
    border-left: 3px solid #fff;
    border-right: 3px solid #fff;
    border-top: 3px solid #fff;
    border-bottom: 3px solid #fff;
    background: repeating-linear-gradient(-45deg, rgba(255,255,255,0.1), rgba(255,255,255,0.1) 15px, rgba(255,255,255,0) 0, rgba(255,255,255,0) 30px),linear-gradient(0deg, #fd644f, #fd7a68);
    box-shadow: 1px -1px 5px rgba(0,0,0,0.2);
    color: #fff
}

@media screen and (min-width: 768px) {

}

.tel{
    max-width: 400px;
    margin: 0 auto;
}

.c-bottom__tel-catch {
    width: auto;
    display: inline-block;
    position: absolute;
    top: -4vw;
    font-family: "Noto Sans JP",sans-serif;
    font-weight: 700;
    font-size: 3vw;
    line-height: 1.2;
    text-align: center;
    border-radius: 100px;
    background: #f6db59;
    padding: .5em 1em;
    color: #f23a42;
    border: 2px solid #fff
}


.c-bottom__tel-caption {

    width: 100%;
    font-family: "Noto Sans JP",sans-serif;
    font-weight: 700;
    font-size: 3vw;
    line-height: 1.2;
    text-align: center
}



.c-bottom__tel-number {
    font-family: "Overpass",sans-serif;
    font-weight: 700;
    font-size: 6.8vw;
    margin-bottom: -5px
}

.c-bottom__tel-icon {
    width: 8vw;
    margin-right: .2em
}
@media screen and (min-width: 768px) {
    .c-bottom__tel-caption {
        font-size: 17px;
    }
    .c-bottom__tel-number {
        font-size: 2vw;
    }
    .c-bottom__tel-icon {
        width: 3vw;
    }
}

@media screen and (min-width: 768px) {
    .c-service__content-fukidashi {
        font-size:24px;
    }
}

.answer-info{
    text-align: left;
}
.answer-info h2{
    border-bottom: 1px solid #ccc;
    padding-bottom: 10px;
    margin-bottom: 10px;
    font-size: 18px;
    font-weight: bold;
    color: #008fff;
}
.answer-info p{
    margin-bottom:20px;
}

.card{
    display: flex;
    padding: 10px;
    border: 1px solid #ccc;
    color: #333;
    border-radius: 10px;
}
.card:hover{
    opacity: 0.7;
}
.card .img{
    width: 150px;
}
.card .info{
    padding-left: 10px;
    width: calc(100% - 150px);

}
.card .ttl{
    font-weight: bold;

}
.card .txt{
    margin-top: 10px;
    font-size: 15px;
}