*{
    margin: 0;
    padding: 0;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

html {
    font-size: 62.5%;
}

body{
    font-size: 1.4rem;
    line-height: 1.4;
    font-family: "Noto Sans JP", serif;
}

ul,ol{
    list-style: none;
}

a{
    text-decoration: none;
}

img{
    max-width: 100%;
}

.fade {
    -webkit-transition: .3s ease-in-out;
    -moz-transition: .3s ease-in-out;
    -o-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
}

.main{
    width: 1280px;
    max-width: 90%;
    margin: 0 auto;
}

.br_480{
    display: none;
}


.bg-linear-gradient01,
.bg-linear-gradient02{
    position: relative;
    z-index: 0;
    overflow: hidden;
}

.bg-linear-gradient01::before,
.bg-linear-gradient02::before{
    content: '';
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 1;
    -webkit-transition: .3s ease-in-out;
    -moz-transition: .3s ease-in-out;
    -o-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
}

.bg-linear-gradient01:hover::before,
.bg-linear-gradient02:hover::before{
    opacity: 0;
}

.bg-linear-gradient01{
    background-color: #017eac;
}

.bg-linear-gradient01::before {
    background: linear-gradient(90deg, #017eac 0%, #059db0 100%);
}

.bg-linear-gradient02{
    background-color: #0EBBD2;
}

.bg-linear-gradient02::before{
    background: linear-gradient(90deg, #0EBBD2 0%, #57CCA7 100%);
}

.common-tit01{
    text-align: center;
}

.common-tit01>span{
    display: inline-block;
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.4;
    color: #64CFB9;
    padding: 0 42px;
    background: url("../img/common-line01-left.png") left center no-repeat,url("../img/common-line01-right.png") right center no-repeat;
}

.part-img-sp{
    display: none;
}

.part_title{
    text-align: center;
}

.part_title h2,
.part_title h3{
    color: #0078a4;
    font-weight: bold;
    line-height: 1.4;
}

.part_title h2 {
    font-size: 4.2rem;
}

.part_title h3 {
    font-size: 3.6rem;
}

.common-padding01{
    padding: 40px 0 80px;
}

.common-section{
    padding: 40px 0;
    background-color: #E6F2F6;
}

.common-section .tit{
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.4;
    color: #0078A4;
    text-align: center;
    margin-bottom: 19px;
}

.common-section .link-line{
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 11px;
    column-gap: 40px;
}

.common-section .link-line>a{
    width: 344px;
    max-width: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    column-gap: 20px;
    padding: 22px 36px;
    font-size: 2.8rem;
    font-weight: bold;
    line-height: 1.3;
    color: #fff;
    -webkit-border-radius: 90px;
    -moz-border-radius: 90px;
    border-radius: 90px;
}

.common-annotation01{
    display: flex;
    font-size: 1.4rem;
    line-height: 1.7;
    color: #000;
}

.common-annotation01::before{
    content: '・';
    flex: none;
}

@media only screen and (min-width: 769px){
    #contact{
        width: 1280px;
        max-width: 90%;
        margin: 0 auto;
    }
}

/*-------------site-header----------------*/

.site-header {
    position: fixed;
    z-index: 999;
    left: 0;
    right: 0;
    top: 0;
    margin: auto;
    display: flex;
    flex-wrap: wrap;
    column-gap: 24px;
    justify-content: space-between;
    align-items: center;
    padding: 18px 40px 24px;
    border-top: 6px solid #0078a4;
    background-color: #fff;
    font-size: 0;
}

.site-header.header_border{
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}

.site-header .company-status-box{
    flex: auto;
    display: flex;
    align-items: center;
    column-gap: 16px;
}

.site-header .company-status {
    color: #000;
    font-size: 1rem;
    line-height: 1.35;
}

.site-header .fold-list{
    display: inline-flex;
    column-gap: 24px;
    align-items: center;
}

.site-header .link-box{
    display: flex;
    column-gap: 16px;
}

.site-header .contact-link {
    width: 132px;
    display: inline-block;
    padding: 16px 24px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    border-radius: 100px;
    color: #fff;
    text-decoration: none;
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 1.3;
    text-align: center;
}

.site-header .nav-item:hover{
    background: #E7F1F5;
}


.site-header .link-list{
    display: flex;
    column-gap: 24px;
}

.site-header .link-list>li a{
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1.3;
    color: #404040;
}

.site-header .panel-btn {
    display: none;
}

/*-------------fv-section----------------*/

.fv-section{
    position: relative;
}

.fv-section::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(to right, #017EAC, #fff);
    opacity: 0.2;
    z-index: -1;
}

.fv-section .fv-inner {
    width: 992px;
    max-width: 90%;
    display: flex;
    justify-content: center;
    margin: 0 auto;
}

.fv-section .fv-left,
.fv-section .fv-right{
    display: flex;
    flex-direction: column;
    width: 50%;
    row-gap: 40px;
}

.fv-section .fv-left{
    align-items: flex-start;
    justify-content: space-between;
    padding: 16px 0 36px;
}

.fv-section .fv-right{
    padding: 32px 0;
    align-items: center;
}

.fv-section .txt01{
    font-size: 1.8rem;
    line-height: 1.35;
    color: #000;
}

.fv-section .tit01{
    font-size: 3.6rem;
    font-weight: bold;
    line-height: 1.5;
    color: #0078A4;
    margin-bottom: 16px;
}

.fv-section .link-line{
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 11px;
    column-gap: 16px;
}

.fv-section .link-line>a{
    display: flex;
    align-items: center;
    justify-content: center;
    column-gap: 8px;
    padding: 16px 24px;
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.3;
    color: #fff;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    border-radius: 30px;
}

.fv-section .link-line>a>img{
    margin: 5px;
}

.fv-section .fv-right .txt-list>li{
    width: 360px;
    max-width: 100%;
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.35;
    color: #0078A4;
    padding: 8px 8px 8px 24px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    border-left: 8px #0078A4 solid;
    background-color: #fff;
}

.fv-section .fv-right .txt-list>li:not(:last-of-type){
    margin-bottom: 8px;
}

/*-------------auto-payment-section----------------*/

.auto-payment-section .grayBox{
    padding: 24px;
    background-color: #F5F5F5;
    -webkit-border-radius: 16px;
    -moz-border-radius: 16px;
    border-radius: 16px;
    margin-top: 40px;
}

.auto-payment-section .grayBox .card-list{
    display: flex;
    column-gap: 40px;
}

.auto-payment-section .grayBox .card-list>li{
    width: calc(100% / 3);
    background-color: #fff;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    border-radius: 8px;
    overflow: hidden;
}

.auto-payment-section .grayBox .card-list>li .card{
    display: flex;
    align-items: flex-start;
    padding: 24px;
}

.auto-payment-section .grayBox .card-list>li .card p{
    font-size: 2rem;
    line-height: 1.4;
    color: #404040;
    margin-left: 16px;
}

.auto-payment-section .auto-payment-arrow{
    display: block;
    margin: 16px auto 40px;
}

.auto-payment-section .grayBox .card-list>li .tit{
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 2.4rem;
    font-weight: bold;
    color: #fff;
    text-align: center;
    line-height: 1.4;
    padding: 8px;
}

.auto-payment-section .grayBox .card-list>li .tit+.card{
    padding: 16px;
}

.one-stop-section{
    background-color: #F5F5F5;
}

.one-stop-section .one-stop-img{
    display: block;
    margin: 40px auto 0;
}

/*-------------price-section----------------*/

.price-section{
    background-color: #F4F4F7;
}

.price-section .main{
    width: 1088px;
}

.price-section .txt{
    line-height: 1.4;
    color: #000;
    text-align: center;
    margin-top: 16px;
}


.price-section .txt,
.price-section .card-list>li .tit,
.price-section .card-list>li .txt02{
    font-size: 2.4rem;
}

.price-section .card-list{
    display: flex;
    justify-content: space-between;
    margin-top: 40px;
}

.price-section .card-list>li:first-of-type{
    width: 268px;
}

.price-section .card-list>li:nth-of-type(odd){
    background-color: #fff;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    border-radius: 8px;
    overflow: hidden;
}

.price-section .card-list>li:nth-of-type(even){
    position: relative;
    width: 40px;
    flex: none;
}

.price-section .card-list>li:nth-of-type(even)::before,
.price-section .card-list>li:nth-of-type(even)::after{
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    background-color: #0078A4;
}

.price-section .card-list>li:nth-of-type(even)::before{
    width: 24px;
    height: 4px;
}

.price-section .card-list>li:nth-of-type(even)::after{
    width: 4px;
    height: 24px;
}

.price-section .card-list>li .tit{
    display: flex;
    justify-content: center;
    align-items: center;
    line-height: 1.4;
    font-weight: bold;
    color: #fff;
    padding: 8px;
    text-align: center;
}

.price-section .card-list>li .txtBox{
    font-weight: bold;
    color: #0078A4;
    text-align: center;
    padding: 8px 16px;
}

.price-section .card-list>li .num{
    font-size: 6.4rem;
}

.price-section .card-list>li .txt01{
    font-size: 4rem;
}

.price-section .common-annotation01{
    margin-top: 16px;
}

/*-------------discount-section----------------*/

.discount-section{
    background-color: #E6F2F6;
}

.discount-section img{
    display: block;
    margin: 40px auto 0;
}

/*-------------comparison-section----------------*/

.comparison-section{
    background-color: #F5F5F5;
}

.comparison-section img{
    display: block;
    margin: 40px auto 0;
}

/*-------------distinction-section----------------*/

.distinction-table-section .distinction-wrapper{
    width: 960px;
    max-width: 100%;
    margin: 40px auto 0;
}

.distinction-table-section .distinction-table{
    width: 100%;
    text-align: center;
    color: #737373;
    border-collapse: collapse;
}

.distinction-table-section .distinction-table tr td:first-of-type{
    width: 180px;
}

.distinction-table-section .distinction-table tr td:not(:first-of-type){
    width: 260px;
}

.distinction-table-section .distinction-table tbody tr td:first-of-type,
.distinction-table-section .distinction-table thead tr:last-of-type td{
    background-color: #F5F5F5;
    font-size: 1.6rem;
    line-height: 1.5;
    font-weight: bold;
}

.distinction-table-section .distinction-table thead tr:first-of-type td:nth-of-type(2){
    background-color: #0078A4;
    color: #fff;
    font-weight: bold;
}

.distinction-table-section .distinction-table thead tr.distinction-table-empty td{
    height: 24px;
}
.distinction-table-section .distinction-table thead tr:last-of-type td:not(:nth-of-type(2)){
    height: 56px;
}

.distinction-table-section .distinction-table tr:not(.distinction-table-empty) td{
    border-bottom: 1px solid #0078A4;
}

.distinction-table-section .distinction-table td:nth-of-type(2){
    border-left: 3px solid #0078A4;
    border-right: 3px solid #0078A4;
    color: #0078A4;
    background-color: #E6F2F6;
}

.distinction-table-section .distinction-table tbody tr:last-of-type td:nth-of-type(2){
    border-bottom: 3px solid #0078A4;
}

.distinction-table-section .distinction-table thead tr:last-of-type td:nth-of-type(2){
    border-right: none;
    color: #737373;
}

.distinction-table-section .distinction-table tbody td{
    height: 80px;
}

.distinction-table-section .distinction-table tbody td:not(:first-of-type),
.distinction-table-section .distinction-table thead tr:first-of-type td:nth-of-type(2){
    font-size: 2rem;
}

.distinction-table-section .distinction-table td .txt01{
    font-size: 1.2rem;
}

.distinction-table-section .distinction-table td .txt02{
    font-size: 1.4rem;
    line-height: 1.4;
    color: #fff;
    padding: 2px 16px;
    background-color: #0078A4;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    border-radius: 30px;
}

.distinction-table-section .distinction-table-only-pc{
    display: none;
}

.distinction-table-section .distinction-table-fwb{
    font-weight: bold;
}

/*-------------functions-glance-section----------------*/

.functions-glance-section{
    background-color: #F4F4F7;
}

.functions-glance-section .functions-glance-list{
    width: 1048px;
    max-width: 100%;
    margin: 40px auto 0;
    display: flex;
    flex-wrap: wrap;
    column-gap: 40px;
    row-gap: 24px;
}

.functions-glance-section .functions-glance-list>li{
    width: calc(50% - 20px);
    padding: 18px 16px 16px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    background-color: #fff;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    border-radius: 8px;
}

.functions-glance-section .functions-glance-list>li .fgl-topBox{
    display: flex;
    align-items: center;
    column-gap: 16px;
    padding-bottom: 9px;
    border-bottom: 2px solid #0078A4;
}

.functions-glance-section .functions-glance-list>li .fgl-topBox>.fgl-icon{
    flex: none;
    width: 40px;
    height: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #66AEC8;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
}

.functions-glance-section .functions-glance-list>li .fgl-tit{
    font-size: 2.8rem;
    font-weight: bold;
    line-height: 1.4;
    color: #0078A4;
}

.functions-glance-section .functions-glance-list>li .fgl-txt{
    padding: 12px 8px 0;
    font-size: 2rem;
    line-height: 1.4;
    color: #404040;
}

/*-------------effect-section----------------*/

.effect-section img {
    display: block;
    margin: 40px auto 0;
}

/*-------------step-section----------------*/

.step-section{
    background-color: #E6F2F6;
}

.step-section .step-list{
    margin-top: 40px;
}

.step-section .step-list>li{
    display: flex;
    column-gap: 24px;
    padding: 12px 16px 16px;
    background-color: #fff;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    border-radius: 8px;
}

.step-section .step-list>li:not(:last-of-type){
    margin-bottom: 40px;
}

.step-section .step-list>li .step-circle{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    row-gap: 2px;
    width: 54px;
    height: 54px;
    color: #fff;
    line-height: 1;
    background-color: #66AEC8;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
}

.step-section .step-list>li .step-circle .step-circle-tit{
    font-size: 1rem;
}

.step-section .step-list>li .step-circle .step-circle-num{
    font-size: 2.4rem;
    font-weight: bold;
}

.step-section .step-list>li:not(:last-of-type) .step-circle-box::after{
    content: '';
    display: block;
    width: 40px;
    height: 40px;
    margin: 12px auto 0;
    background: url("../img/step-arrow01.png") no-repeat center center;
}

.step-section .step-list>li .step-content{
    flex: auto;
}

.step-section .step-list>li .step-con-tit{
    font-size: 2.8rem;
    font-weight: bold;
    color: #0078A4;
    line-height: 1.4;
    padding: 8px 0;
    border-bottom: 2px solid #0078A4;
}

.step-section .step-list>li .step-con-txt{
    font-size: 2rem;
    line-height: 1.4;
    color: #404040;
    margin-top: 12px;
}

/*-------------qa-section----------------*/

.qa-section .question-answer-list{
    margin-top: 40px;
}
.qa-section .question-answer-container {
    border-radius: 16px;
    border: 3px solid #f5f5f5;
    background: #fff;
    line-height: 1.4;
}

.qa-section .question-answer-container:not(:last-of-type){
    margin-bottom: 24px;
}

.qa-section .qa-content-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    gap: 24px;
    justify-content: flex-start;
    padding: 21px 74px 21px 32px;
}

.qa-section .question-indicator {
    font-size: 2.4rem;
    color: #0078A4;
    font-weight: bold;
    width: 20px;
    height: 40px;
    flex: none;
    padding-bottom: 3px;
}

.qa-section .question-text {
    font-size: 2rem;
}

.qa-section .question-content .question-text {
    color: #0078A4;
    font-weight: bold;
}


.qa-section .answer-content {
    display: none;
}

.qa-section .answer-content .qa-content-wrapper{
    padding-top: 22px;
    align-items: flex-start;
}

.qa-section .question-icon {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 32px;
    margin: auto;
    width: 40px;
    height: 40px;
    cursor: pointer;
}

.qa-section .question-icon::before,
.qa-section .question-icon::after{
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    background-color: #0078A4;
}

.qa-section .question-icon::before{
    width: 23px;
    height: 3px;
}

.qa-section .question-icon::after{
    width: 3px;
    height: 23px;
}

.qa-section .question-answer-container.openStatus{
    background-color: #E6F2F6;
}

.qa-section .question-answer-container.openStatus .answer-content .question-text{
    color: #404040;
}

.qa-section .question-answer-container.openStatus .question-icon::after{
    display: none;
}

/*-------------footer-section----------------*/

.footer-section {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 40px;
    border-top: 6px solid #0078a4;
    width: 100%;
    flex-wrap: wrap;
    gap: 30px;
    font-size: 0;
}

.footer-section .footer-logo{
    margin-right: 40px;
}

.footer-section .footer-nav {
    display: flex;
    gap: 40px;
    align-items: center;
    flex-wrap: wrap;
}

.footer-section .footer-nav-link {
    color: #0078a4;
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 20px;
    letter-spacing: 0.75px;
    text-decoration: underline;
    text-align: center;
    cursor: pointer;
}

.footer-section .footer-nav-link:hover{
    font-weight: bold;
}

.footer-section .footer-copyright {
    flex: auto;
    color: #898989;
    font-size: 1.2rem;
    font-weight: 300;
    line-height: 20px;
    letter-spacing: 0.6px;
    text-align: right;
}

@media only screen and (max-width: 1400px){

    /*-------------site-header----------------*/

    .site-header {
        padding: 10px 20px 16px;
    }

    .site-header .fold-list{
        width: 100%;
        margin-top: 8px;
    }

    .site-header .link-box {
        position: absolute;
        right: 20px;
        top: 50%;
        transform: translate(0,-50%);
    }

    /*-------------auto-payment-section----------------*/

    .auto-payment-section .grayBox .card-list {
        column-gap: 30px;
    }

    .auto-payment-section .grayBox .card-list>li .card{
        flex-direction: column;
        align-items: center;
        row-gap: 15px;
    }

    .auto-payment-section .grayBox .card-list>li .card p {
        margin: 0;
    }

}

@media only screen and (max-width: 1200px){

    /*-------------price-section----------------*/

    .price-section .card-list>li:first-of-type {
        width: 240px;
    }

    .price-section .txt,
    .price-section .card-list>li .tit,
    .price-section .card-list>li .txt02{
        font-size: 2.2rem;
    }

    .price-section .card-list>li .num {
        font-size: 5vw;
    }

    .price-section .card-list>li .txt01 {
        font-size: 3.4vw;
    }

}

@media only screen and (max-width: 1024px) {

    /*-------------common----------------*/

    .common-section .link-line {
        column-gap: 20px;
    }

    .common-section .link-line>a {
        font-size: 2.6rem;
    }

    /*-------------part_title----------------*/
    .part_title h2 {
        font-size: 3.8rem;
    }

    .part_title h3 {
        font-size: 3.2rem;
    }

    /*-------------site-header----------------*/

    .site-header{
        column-gap : 20px;
    }

    .site-header .company-status-box {
        column-gap: 12px;
    }

    .site-header .link-list {
        display: flex;
        column-gap: 15px;
    }

    .site-header .link-box{
        width: 132px;
        flex-wrap: wrap;
        row-gap: 5px;
    }

    .site-header .contact-link{
        padding: 8px 10px;
    }

    /*-------------fv-section----------------*/

    .fv-section .fv-inner{
        column-gap: 20px;
    }

    .fv-section .tit01{
        font-size: 3.4rem;
    }

    /*-------------auto-payment-section----------------*/

    .auto-payment-section .grayBox {
        padding: 18px;
    }

    .auto-payment-section .grayBox .card-list {
        column-gap: 18px;
    }

    .auto-payment-section .grayBox .card-list>li .card {
        padding: 18px;
    }

    /*-------------price-section----------------*/

    .price-section .card-list>li .txtBox {
        padding: 8px;
    }

    .price-section .txt,
    .price-section .card-list>li .tit,
    .price-section .card-list>li .txt02 {
        font-size: 2rem;
    }

    .price-section .card-list>li .num {
        font-size: 4.8vw;
    }

    .price-section .card-list>li .txt01 {
        font-size: 3.2vw;
    }

    .price-section .card-list>li:first-of-type {
        width: 220px;
    }

    /*-------------functions-glance-section----------------*/

    .functions-glance-section .functions-glance-list {
        column-gap: 30px;
    }

    .functions-glance-section .functions-glance-list>li {
        width: calc(50% - 15px);
    }

    .functions-glance-section .functions-glance-list>li .fgl-tit {
        font-size: 2.4rem;
    }

    .functions-glance-section .functions-glance-list>li .fgl-topBox {
        column-gap: 10px;
    }

    .functions-glance-section .functions-glance-list>li .fgl-txt {
        font-size: 1.8rem;
    }

    /*-------------step-section----------------*/

    .step-section .step-list>li {
        column-gap: 18px;
    }

    .step-section .step-list>li .step-con-tit {
        font-size: 2.4rem;
    }

    .step-section .step-list>li .step-con-txt {
        font-size: 1.8rem;
    }

    .step-section .step-list>li .step-circle .step-circle-num {
        font-size: 2.2rem;
    }

}

@media only screen and (max-width: 1023px) {


    /*-------------fv-section----------------*/

    .fv-section .fv-inner{
        align-items: center;
    }

    .fv-section .link-line{
        flex-direction: column;
        row-gap: 10px;
    }

    .fv-section .link-line>a{
        width: 80%;
    }

    .fv-section .tit01 br{
        display: none;
    }

    /*-------------auto-payment-section----------------*/

    .auto-payment-section .grayBox .card-list>li br{
        display: none;
    }

    /*-------------price-section----------------*/

    .price-section .card-list>li:first-of-type {
        width: 22%;
    }

    .price-section .txt,
    .price-section .card-list>li .tit,
    .price-section .card-list>li .txt02{
        font-size: 1.8rem;
    }


}

@media only screen and (max-width: 768px) {

    /*-------------common----------------*/

    .common-padding01 {
        padding: 40px 0 60px;
    }

    .common-section .link-line {
        flex-direction: column;
        row-gap: 20px;
    }

    .common-section .link-line>a{
        max-width: 100%;
    }

    /*-------------part_title----------------*/
    .part_title h2 {
        font-size: 3.4rem;
    }

    .part_title h3 {
        font-size: 2.8rem;
    }

    /*-------------fv-section----------------*/

    .fv-section .tit01{
        font-size: 3.2rem;
    }

    .fv-section .fv-left{
        width: 60%;
    }

    .fv-section .fv-right{
        width: 40%;
    }

    /*-------------auto-payment-section----------------*/

    .auto-payment-section .grayBox .card-list>li .tit {
        font-size: 2rem;
    }

    .auto-payment-section .grayBox .card-list>li .card p{
        font-size: 1.8rem;
    }

    /*-------------functions-glance-section----------------*/

    .functions-glance-section .functions-glance-list>li .fgl-tit {
        font-size: 2.2rem;
    }

    /*-------------step-section----------------*/

    .step-section .step-list>li .step-con-tit {
        font-size: 2.2rem;
    }

    .step-section .step-list>li .step-circle .step-circle-num {
        font-size: 2rem;
    }

    .step-section .step-list>li .step-circle {
        width: 50px;
        height: 50px;
    }

    .step-section .step-list>li:not(:last-of-type) .step-circle-box::after {
        background-size: 18px auto;
    }


    /*-------------qa-section----------------*/

    .qa-section .qa-content-wrapper {
        padding: 20px 64px 20px 24px;
        gap: 20px;
    }

    .qa-section .question-icon {
        right: 20px;
    }

    .qa-section .answer-content .qa-content-wrapper {
        padding-top: 12px;
        gap: 20px;
    }

    .qa-section .question-text{
        font-size: 1.8rem;
    }

    /*-------------footer-section----------------*/

    .footer-section{
        padding: 40px 5%;
    }
}

@media only screen and (max-width: 767px) {

    /*-------------site-header----------------*/

    .site-header{
        display: block;
        padding: 12px 20px 18px;
    }

    .site-header .company-status-box {
        margin-top: 15px;
    }

    .site-header .link-box{
        width: 100%;
        flex-wrap: nowrap;
        justify-content: center;
        position: static;
        transform: none;
        padding-top: 18px;
    }

    .site-header .contact-link {
        padding: 16px 24px;
    }

    .site-header .fold-list{
        display: none;
    }

    .site-header .fold-list .link-list{
        display: block;
    }

    .site-header .fold-list .link-list>li {
        display: block;
        width: 100%;
        border-right: none;
        text-align: center;
        padding: 22px 5%;
        border-bottom: 1px solid #f0f0f0;
    }

    .site-header .logo-position{
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    .site-header .panel-btn {
        display: flex;
        justify-content: center;
        align-items: center;
        position: relative;
        width: 40px;
        height: 40px;
        cursor: pointer;
    }

    .site-header .panel-btn-icon {
        position: relative;
        display: block;
        width: 30px;
        height: 4px;
        background: #0078A4;
        transition: .2s;
    }

    .site-header .panel-btn-icon:before,
    .site-header .panel-btn-icon:after {
        display: block;
        content: "";
        position: absolute;
        top: 50%;
        left: 0;
        width: 30px;
        height: 4px;
        background: #0078A4;
        transition: .3s;
    }

    .site-header .panel-btn-icon:before {
        margin-top: -12px;
    }

    .site-header .panel-btn-icon:after {
        margin-top: 8px;
    }

    .panel-btn .close {
        background: transparent;
    }

    .site-header .panel-btn .close:before,
    .site-header .panel-btn .close:after {
        margin-top: 0;
    }

    .site-header .panel-btn .close:before {
        -ms-transform: rotate(-45deg);
        -moz-transform: rotate(-45deg);
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
    }

    .site-header .panel-btn .close:after {
        -ms-transform: rotate(-135deg);
        -moz-transform: rotate(-135deg);
        -webkit-transform: rotate(-135deg);
        transform: rotate(-135deg);
    }

    /*-------------fv-section----------------*/

    .fv-section .fv-inner{
        flex-direction: column;
    }

    .fv-section .fv-left,
    .fv-section .fv-right{
        width: 540px;
        max-width: 100%;
        margin: 0 auto;
    }

    .fv-section .link-box{
        align-self: center;
    }

    .fv-section .fv-left {
        padding: 16px 0 52px;
    }

    .fv-section .fv-right{
        padding-top: 0;
        padding-bottom: 40px;
    }

    .fv-section .fv-right .txt-list{
        width: 100%;
    }

    .fv-section .fv-right .txt-list>li{
        width: 100%;
    }

    /*-------------auto-payment-section----------------*/

    .auto-payment-section .grayBox{
        width: 500px;
        max-width: 100%;
        margin-left: auto;
        margin-right: auto;
    }

    .auto-payment-section .grayBox .card-list {
        flex-direction: column;
        row-gap: 18px;
    }

    .auto-payment-section .grayBox .card-list>li {
        width: 100%;
    }

    .auto-payment-section .grayBox .card-list>li .card {
        flex-direction: row;
        align-items: flex-start;
    }

    .auto-payment-section .grayBox .card-list>li .card p {
        margin-left: 16px;
    }

    .auto-payment-section .grayBox .card-list>li br{
        display: block;
    }

    /*-------------price-section----------------*/

    .price-section .card-list{
        width: 500px;
        max-width: 100%;
        margin-left: auto;
        margin-right: auto;
        flex-direction: column;
        row-gap: 24px;
    }

    .price-section .card-list>li:first-of-type {
        width: 100%;
    }

    .price-section .card-list>li:nth-of-type(even){
        width: 100%;
        height: 40px;
    }

    .price-section .txt,
    .price-section .card-list>li .tit,
    .price-section .card-list>li .txt02 {
        font-size: 2rem;
    }

    .price-section .card-list>li .num {
        font-size: 5rem;
    }

    .price-section .card-list>li .txt01 {
        font-size: 3.5rem;
    }

    /*-------------distinction-section----------------*/

    .distinction-table-only-pc{
        display: block;
    }

    .distinction-table-section .distinction-table thead{
        display: none;
    }

    .distinction-table-section .distinction-table td{
        display: flex;
        justify-content: center;
        align-items: stretch;
        width: 100% !important;
    }

    .distinction-table-section .distinction-table td:first-of-type{
        font-size: 2.2rem !important;
        display: flex;
        justify-content: center;
        align-items: center;
        padding: 5px;
    }

    .distinction-table-section .distinction-table td:first-of-type br{
        display: none;
    }

    .distinction-table-section .distinction-table tbody td:nth-of-type(2) {
        font-size: 2rem;
    }

    .distinction-table-section .distinction-table tbody td:not(:first-of-type):not(:nth-of-type(2)),
    .distinction-table-section .distinction-table tbody td:nth-of-type(2) .distinction-table-only-pc{
        font-size: 1.8rem;
    }

    .distinction-table-section .distinction-table td>div{
        width: 50%;
        padding: 5px;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
    }

    .distinction-table-section .distinction-table td>div:first-of-type{
        font-weight: bold;
        background-color: #E5E5E5;
    }

    .distinction-table-section .distinction-table tr:not(:last-of-type) td:last-of-type{
        margin-bottom: 40px;
    }

    .distinction-table-section .distinction-table td:nth-of-type(2){
        border: 3px solid #0078A4 !important;
    }

    .distinction-table-section .distinction-table td:nth-of-type(2) .distinction-table-only-pc{
        color: #fff;
        background-color: #0078A4;
    }

    /*-------------functions-glance-section----------------*/

    .functions-glance-section .functions-glance-list>li{
        width: 100%;
    }

}

@media only screen and (max-width: 640px) {

    /*-------------footer-section----------------*/

    .footer-section {
        flex-direction: column;
        align-items: flex-start;
        gap: 24px;
    }
    .footer-section .footer-nav {
        flex-direction: column;
        align-items: flex-start;
        gap: 15px;
        margin-bottom: 16px;
    }
    .footer-section .footer-nav-link {
        text-align: left;
    }
}

@media only screen and (max-width: 480px) {

    /*-------------common----------------*/

    /* The client gave us the sp design, so the width went according to the design. */
    .main {
        max-width: calc(100% - 32px);
    }

    .common-tit01>span {
        font-size: 2.2rem;
        padding: 0 26px;
    }

    .common-section .link-line>a {
        font-size: 2.4rem;
    }

    /*-------------part_title----------------*/
    .part_title h2 {
        font-size: 3rem;
    }

    .part_title h3 {
        font-size: 2.6rem;
    }

    /*-------------site-header----------------*/

    .site-header {
        padding: 12px 16px 18px;
    }

    .site-header .logo-box{
        width: 124px;
    }

    .site-header .panel-btn{
        width: 32px;
        height: 32px;
    }

    .site-header .panel-btn-icon,
    .site-header .panel-btn-icon:before,
    .site-header .panel-btn-icon:after{
        width: 24px;
        height: 2px;
    }

    .site-header .panel-btn-icon {
        margin: 0;
    }

    .site-header .panel-btn-icon:after {
        margin-top: 6px;
    }

    .site-header .panel-btn-icon:before {
        margin-top: -8px;
    }

    .site-header .contact-link{
        width: 50%;
    }

    .site-header .company-status-box>img{
        width: 130px;
    }

    /*-------------fv-section----------------*/

    .fv-section .fv-left, .fv-section .fv-right {
        row-gap: 20px;
    }

    .fv-section .tit01 {
        font-size: 2.8rem;
    }

    .fv-section .fv-left {
        padding: 16px 0 40px;
    }

    .fv-section .link-line>a{
        width: 100%;
    }

    .fv-section .txt01 {
        font-size: 1.6rem;
    }

    .fv-section .fv-right .txt-list>li{
        font-size: 1.6rem;
        border-left: 6px #0078A4 solid;
    }

    /*-------------auto-payment-section----------------*/

    .auto-payment-section .grayBox{
        margin-top: 30px;
    }

    .auto-payment-section .grayBox {
        padding: 16px;
    }

    .auto-payment-section .grayBox .card-list {
        row-gap: 8px;
    }

    .auto-payment-section .grayBox .card-list>li .card>img{
        width: 80px;
    }

    .auto-payment-section .grayBox .card-list>li .card p {
        font-size: 1.6rem;
    }

    .auto-payment-section .auto-payment-arrow {
        width: 150px;
        margin: 16px auto 30px;
    }

    /*-------------one-stop-section----------------*/

    .one-stop-section .one-stop-img {
        margin: 30px auto 0;
    }

    /*-------------price-section----------------*/

    .price-section .card-list{
        margin-top: 30px;
        row-gap: 20px;
    }

    .price-section .txt,
    .price-section .card-list>li .tit,
    .price-section .card-list>li .txt02 {
        font-size: 1.8rem;
    }

    .price-section .card-list>li .num {
        font-size: 4.2rem;
    }

    .price-section .card-list>li .txt01 {
        font-size: 2.8rem;
    }

    /*-------------discount-section----------------*/

    .discount-section img {
        margin: 30px auto 0;
    }

    /*-------------comparison-section----------------*/

    .comparison-section img {
        margin: 30px auto 0;
    }

    /*-------------distinction-table-section----------------*/

    .distinction-table-section .distinction-table td:first-of-type{
        font-size: 2rem !important;
    }

    .distinction-table-section .distinction-table tbody td:nth-of-type(2) {
        font-size: 1.8rem;
    }

    .distinction-table-section .distinction-table tbody td:not(:first-of-type):not(:nth-of-type(2)),
    .distinction-table-section .distinction-table tbody td:nth-of-type(2) .distinction-table-only-pc{
        font-size: 1.7rem;
    }

    .distinction-table-section .distinction-table td .txt02 {
        font-size: 1.2rem;
    }

    .distinction-table-section .distinction-table tbody td{
        height: 62px;
    }

    /*-------------functions-glance-section----------------*/

    .functions-glance-section .functions-glance-list{
        margin-top: 30px;
    }

    .functions-glance-section .functions-glance-list>li .fgl-tit {
        font-size: 2rem;
    }

    .functions-glance-section .functions-glance-list>li .fgl-txt {
        font-size: 1.6rem;
    }

    /*-------------effect-section----------------*/

    .effect-section img {
        margin: 30px auto 0;
    }

    /*-------------step-section----------------*/

    .step-section .step-list>li {
        column-gap: 15px;
    }

    .step-section .step-list {
        margin-top: 30px;
    }

    .step-section .step-list>li .step-con-tit {
        font-size: 2rem;
    }

    .step-section .step-list>li .step-circle .step-circle-num {
        font-size: 1.8rem;
    }

    .step-section .step-list>li .step-con-txt {
        font-size: 1.6rem;
    }

    /*-------------qa-section----------------*/

    .qa-section .question-answer-list {
        margin-top: 30px;
    }

    .qa-section .qa-content-wrapper {
        padding: 16px 64px 16px 16px;
        gap: 16px;
    }

    .qa-section .question-icon {
        right: 16px;
    }

    .qa-section .answer-content .qa-content-wrapper {
        padding-top: 12px;
        gap: 20px;
    }

    .qa-section .question-text{
        font-size: 1.6rem;
    }

    .qa-section .question-icon::before{
        width: 20px;
        height: 2px;
    }

    .qa-section .question-icon::after{
        width: 2px;
        height: 20px;
    }

    .qa-section .question-indicator {
        font-size: 2.2rem;
    }

    .qa-section .question-answer-container:not(:last-of-type){
        margin-bottom: 20px;
    }

}

/*-------------thanks-section----------------*/

@media (max-width: 1000px) {
    .thanks-sp-hidden {
        display: none !important;
    }
}
@media (min-width: 1001px) {
    .thanks-pc-hidden {
        display: none !important;
    }
}

.thanks-down-arrow {
    position: relative;
    margin-top: 10px;
}

.thanks-down-arrow::before{
    content: '';
    position: absolute;
    top: -20px;
    left: 0;
    right: 0;
    margin: auto;
    width: 0;
    height: 0;
    border-top: 28px solid #EDEDED;
    border-bottom: 28px solid transparent;
    border-left: 37px solid transparent;
    border-right: 37px solid transparent;
}


/*-------------hubspot----------------*/

form {
    width: 80%;
    margin: auto;;
    padding-left: 20px;
    padding-right: 20px;
  }
  
  form > div:first-child {
    margin-bottom: 40px;
  }
  
  .hs-input {
    border-width: 1px !important;
    margin: 0 !important;
    font-family: arial, helvetica, sans-serif !important;
    color: rgba(102, 102, 102, 1.0) !important;
    background-color: rgba(245, 248, 250, 1.0) !important;
    border-color: rgba(149, 148, 148, 1.0) !important;
    border-style: solid !important;
    border-radius: 3px !important;
    padding: 10px !important;
    font-size: 1em !important;
    width: 100% !important;
    box-sizing: border-box !important;
    transition: box-shadow .2s ease !important;
  }
  
  .hs-error-msg {
    font-family: arial, helvetica, sans-serif !important;
    font-size: 1em !important;
    color: #e51520 !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
  }
  
  .hs-form-field label {
    margin: 0;
    font-family: arial, helvetica, sans-serif;
    font-size: 1.0em;
    color: rgba(33,45,58,1.0);
    display: block;
    word-break: break-word;
    overflow-wrap: break-word;
    margin-bottom: 10px;
  }
  
  .hs-form-field {
    margin-bottom: 10px;
  }
  
  .hs-field-desc {
    font-size: .8em;
    font-family: arial, helvetica, sans-serif;
    word-break: break-word;
    overflow-wrap: break-word;
    color: rgba(81, 99, 131, 0.89);
    margin-bottom: 10px;
  }
  
  .hs-form-required {
    color: #e51520;
  }
  
  form .actions {
    text-align: center;
    margin-top: 20px;
    margin-bottom: 20px;
  }
  
  form .actions input {
    width: auto;
    font-family: arial, helvetica, sans-serif;
    font-size: 1em;
    color: rgba(255, 255, 255, 1.0);
    padding: 12px 24px;
    border-radius: 3px;
    background-color: #0078A4;
    background-image: none;
    box-shadow: none;
    font-weight: 700;
    position: relative;
    text-align: center;
    transition: transform .2s ease-out, filter .2s linear, box-shadow .2s;
    cursor: pointer;
    border: 0;
    margin: 0;
    word-break: break-word;
    overflow-wrap: break-word;
  }
  
  .hbspt-form > .submitted-message {
    text-align: center;
    height: 200px;

  }