html {
    font-size: 62.5%;
}
body {
    font-size: 1.6rem;
    font-weight: 500;
    font-family: "Noto Sans Japanese","Noto Sans","Noto Sans CJK JP",'Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3',"NotoSans",'MS PGothic',arial,helvetica,sans-serif;
    color: #222;
    text-rendering: optimizeLegibility;
    font-kerning: normal;
    font-variant-ligatures: common-ligatures contextual;
    font-feature-settings: "kern","liga","clig","calt";
}
/*
 * display
 */
 .tmp-show{
    display: inherit;
  }
  .tmp-show-pc{
      display: inherit;
  }
  .tmp-show-sp{
      display: none;
  }
  @media screen and (max-width: 767px) {
      .tmp-show-pc{
          display: none;
      }
      .tmp-show-sp{
          display: inherit;
      }
  }
  /*
 * base
 */
.wrapper {
    width: 100%;
    overflow: hidden;
}



.mainvisual {
    overflow: hidden;
    width: 100%;
    height: 950px;
    -o-object-fit: cover;
    object-fit: cover;
    background: url(../../assets/img/FV.png) no-repeat;
    background-size: cover;
    background-position:0% 78%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: bold;
}
.mainvisual-inner{
    position: relative;
    width: 680px;
    height: 680px;
    background-color: #fff;
    border-radius: 30px;
    box-shadow: 4px 4px 8px #acaeb1;
}
.mainvisual-point{
    background-color: #f0ff00;
    width: 240px;
    height: 240px;
    border-radius: 50%;
    position: absolute;
    right: -70px;
    top: -80px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    color:#120bac;
    font-size: 2.3rem;
    line-height: 1.4;
}
.mainvisual_ttl{
    text-align: center;
    font-size: 7.2rem;
    line-height: 1.4;
    margin: 60px 0 30px;
}
.mainvisual_txt{
    text-align: center;
    font-size: 2.8rem;
}
.mainvisual-img{
    text-align: center;
    margin: 40px 0;
}

@media screen and (max-width: 768px){
.mainvisual{
    height: 550px;
    padding: 0 10px;
}
.mainvisual-inner{
    width: 380px;
    height: 440px;
}
.mainvisual-point {
    width: 200px;
    height: 200px;
    right: -20px;
    top: -110px;
    font-size: 1.8rem;
    line-height: 1.4;
}
.mainvisual_ttl {
    font-size: 3.8rem;
    margin: 60px 0 20px;
}
.mainvisual_txt {
    text-align: center;
    font-size: 2rem;
}
.mainvisual-img img{
    width: 340px;
}
}
/* ::::::::::::::::::::::: ▼ what ::::::::::::::::::::::::: */
.what{
width: 100%;
background-color: #120bac;
color: #fff;
}
.what-inner{
max-width: 1040px;
margin: auto;
padding: 100px 0px;
}
.what-ttl{
    font-size: 5rem;
    text-align: center;
    font-weight: bold;
}
.what-txt{
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.7;
    text-align: center;
    margin: 70px 0;
}
.yellow_txt{
    color: #f0ff00;
}
.what-ttl_merit{
    font-size: 4rem;
    text-align: center;
    font-weight: bold;
    margin: 50px 0;
}
.flow-list {
    max-width: 1040px;
    width: 100%;
    display: flex;
    justify-content: space-between;
    margin: 80px auto 0;
}
ul, ol, li, .list {
    margin: 0;
    padding: 0;
    list-style: none;
}
.flow-list-item {
    width: 100%;
    max-width: 250px;
    text-align: center;
    position: relative;
}
.flow-list-item-card {
    position: relative;
    height: 269px;
    margin-bottom: 88px;
}
.flow-list-item:first-child .flow-list-item-card-inner {
    color: #67b8e0;
}
.flow-list-item-card-inner {
    width: 100%;
    height: auto;
    padding: 20px;
    border-radius: 12px;
    background: #fff;
}

.flow-list-item-title {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 2.8em;
    font-size: 2.2rem;
    font-weight: bold;
    line-height: 1.4;
    position: relative;
}
.flow-list-item:first-child .flow-list-item-title::after {
    background: url(../../assets/img/merit_1.png);
    width: 60px;
    height: 25px;
}

.flow-list-item-step {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    margin: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
    position: absolute;
    top: -16%;
    left: 30%;
}
.flow-list-item-step {
    background: #f0ff00;
}
.flow-list-item-step span {
    position: relative;
    font-size: 3.5rem;
    color: #120bac;
    line-height: 1;
    text-align: center;
    font-weight: bold;
}
.flow-list-item-step span::before {
    content: "メリット";
    font-size: 1.2rem;
    display: block;
    line-height: 1;
    margin-bottom: 5px;
}
.merit_img{
    padding-top: 60px;
    padding-bottom: 25px;
}
.merit_txt{
    color: #120bac;
    text-align: center;
    /* position: relative; */
    padding: 0px;
    display: flex;
    justify-content: center;
    min-height: 2.0em;
    font-size: 2.6rem;
    font-weight: bold;
    line-height: 1.6;
}
.merit_4{
    color: #120bac;
    text-align: center;
    /* position: relative; */
    padding: 0px;
    display: flex;
    justify-content: center;
    min-height: 2.0;
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.6;
}
.what-cart-btn{
    margin: 80px auto 0px;
    border: 3px solid #fff;
    padding: 20px 30px;
    max-width: 580px;
    text-align: center;
    border-radius: 30px;
    position: relative;
    font-size: 2.3rem;
    line-height: 1.4;
}
.what-cart-btn::after{
    content: "";
    display: inline-block;
    width: .5em;
    height: .5em;
    border-top: 3px solid #ffffff;
    border-right: 3px solid #ffffff;
    transform: rotate(45deg);
    position: absolute;
    top: 0;
    bottom: 0;
    right: 35px;
    margin: auto;
}

@media screen and (max-width: 768px){
    .what-inner {
        padding: 40px 0px;
    }
    .what-ttl , .what-ttl_merit{
        font-size: 2.6rem;
        line-height: 1.5;
    }
    .what-txt {
        font-size: 1.5rem;
        margin: 40px 0;
    }
    .what-img{
        text-align: center;
    }
    .what-img img{
        width: 300px;
    }
    
.flow-list {
    flex-direction: column;
    align-items: center;
}
.flow-list-item {
    padding-bottom: 20px;
}
.what-cart-btn {
    margin: 0px auto 0px;
    padding: 18px 30px;
    max-width: 380px;
    font-size: 1.7rem;
}
}
/* ::::::::::::::::::::::: ▼ servis ::::::::::::::::::::::::: */
.servis{
    /* background-image: url(/office/assets/img/servis_img.png); */
    /* background-size: cover; */
    position: relative;
}
.servis::before{
    content: "";
    background-image: url(../../assets/img/servis_img.png);
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top:0;
    right: 10%;
    width: 100%;
    height: 100%;
    z-index: -1;
}
.servis-inner{
    max-width: 1040px;
    margin: auto;
    padding: 100px 0px;
}
.servis-ttl{
    font-size: 5rem;
    text-align: center;
    font-weight: bold;
    padding-bottom: 80px;
}
.about-list-ttl-back-color{
    background-color: #120bac;
    padding: 10px 80px;
    border-radius: 30px;
}
.about-list {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.about-list-card {
    background: #fff;
    box-shadow: 0 6px 8px rgb(0 0 0 / 16%);
    border: 5px solid #737373;
    border-radius: 20px;
    padding: 30px 28px;
    margin-bottom: 30px;
    width: 50%;
    max-width: 500px;
    padding: 28px;
    text-align: center;
}
.about-list-card-icon {
    text-align: center;
    margin-bottom: 20px;
}
.about-list-card-icon img{
    width:200px;
}
.about-list-card-title {
    min-height: 2.5em;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 15px;
    font-size: 2.8rem;
    font-weight: bold;
    text-align: center;
    color: #fff;
}
.about-list-card-text {
    font-size: 2.2rem;
    font-weight: bold;
    line-height: 1.5;
    min-height: 5em;
}
.point_ttl{
    margin-bottom:20px;
    text-align: left;
    font-size: 2.2rem;
    font-weight: bold;
}
.point_ttl span{
    border-bottom: 3px solid #120bac;
}
.point_list_item{
    display: flex;
    align-items: center;
    margin-bottom: 10px;
    color:#120bac;
    font-size: 1.8rem;
    font-weight: bold;
}
.point-number{
    position: relative;
    display: inline-block;
    width: 30px;
    height: 30px;
    margin-right: 5px;
}
.point-number::before{
    width: 30px;
    height: 30px;
    background-color: #f0ff00;
    border-radius: 50%;
    border: 2px #120bac solid;
    display: block;
    position: absolute;
    text-align: center;
    line-height: 30px;
    font-weight: bold;
}
.point_list_item:first-child .point-number::before{
    content: "1";
}
.point_list_item:nth-child(2) .point-number::before{
    content: "2";
}
.point_list_item:nth-child(3) .point-number::before{
    content: "3";
}
.point_list_item-3txt{
    font-size: 1.8rem;
}
.servis-about-list-price{
    display: flex;
    align-items: center;
}
.servis-about-list-price-area{
    display: flex;
    margin: 20px 0;
}
.servis-about-list-dt{
    margin-right: 7px;
    border: 2px solid #333;
    border-radius: 5px;
    padding: 6px;
    font-size: 1.8rem;
}
.servis-about-list-price:first-child{
    margin-right: 20px;
}
.servis-about-list-dd{
    font-size: 1.8rem;
    font-weight: bold;
}
.servis-about-list-caution{
    color: #f73400;
    text-align: left;
    font-weight: bold;
}
.servis-nomal-price-wrap{
    padding: 80px;
}
.servis-nomal-price-sub{
    min-height: 2.5em;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 15px;
    font-size: 2rem;
    font-weight: bold;
    text-align: center;
    color: #fff;
}
.servis-nomal-price-sub-back-color{
    background-color: #120bac;
    padding: 10px 80px;
    border-radius: 30px;
}
.servis-nomal-price-ttl{
    text-align: center;
    font-size: 2.6rem;
    font-weight: bold;
}
.servis-nomal-price-area{
    display: flex;
    margin: 20px 0;
    justify-content: center;
}
.servis-nomal-price-box{
    display: flex;
    align-items: center;
}
.servis-nomal-price-box:first-child{
    margin-right: 30px;
}
.servis-nomal-price-dt{
    margin-right: 7px;
    border: 2px solid #333;
    border-radius: 5px;
    padding: 6px;
    font-size: 2.5rem;
}
.servis-nomal-price-dd{
    font-size: 2.4rem;
    font-weight: bold;
}

@media screen and (max-width: 768px){
    .servis::before {
        background-size: cover;
        width: 90%;
        height: 50%;
    }
    .servis-inner {
        padding: 50px 0px;
    }
    .servis-ttl {
        font-size: 2.6rem;
        padding-bottom: 40px;
    }
    .about-list {
        display: flex;
        justify-content: space-between;
        flex-wrap: nowrap;
        flex-direction: column;
        align-items: center;
    }
    .about-list-ttl-back-color {
        padding: 10px 32px;
    }
    .about-list-card {
        width: 83%;
    }
    .about-list-card-title {
        font-size: 2.4rem;
    }
    .about-list-card-text {
        font-size: 1.6rem;
        min-height: 6em;
        text-align: left;
    }
    .about-list-card-icon img {
        width: 150px;
    }
    .point_list_item {
        font-size: 1.5rem;
        text-align: left;
    }
    .point-number {
        margin-right: 10px;
    }
    .servis-about-list-caution {
        font-size: 1.3rem;
    }
    .servis-nomal-price-wrap {
        padding: 10px 30px;
    }
    .servis-nomal-price-sub {
        font-size: 2rem;
    }
    .servis-nomal-price-ttl {
        font-size: 2.4rem;
    }
    .servis-nomal-price-dt {
        font-size: 1.5rem;
        text-align: center;
    }
    .servis-nomal-price-dd {
        font-size: 1.5rem;
        text-align: center;
    }
    .servis-nomal-price-box:first-child {
        margin-right: 30px;
        margin-bottom: 10px;
    }
    .servis-nomal-price-area {
        display: flex;
        margin: 20px 0 20px 50px;
        justify-content: center;
        flex-direction: column;
    }
}
/* ::::::::::::::::::::::: ▼ campaign ::::::::::::::::::::::::: */
.campaign{
    position: relative;
    background-color: #f0ff00;
    padding: 0 50px 0;
}
.campaign::before{
    content: '';
    position: absolute;
    top:-170px;
    left: 0;
    border-bottom: 10vw solid #f0ff00;
    border-left: 100vw solid transparent;
}
.campaign::after{
    content: '';
    position: absolute;
    top:-170px;
    left: 0;
    border-bottom: 10vw solid #f0ff00;
    border-right: 100vw solid transparent;
}
.campaign-inner{
    max-width: 1040px;
    margin: auto;
    padding: 100px 0px;
}
.campaign_subtxt{
    text-align: center;
    font-size: 2.3rem;
    font-weight: bold;
}
.campaign-img{
    text-align: center;
    margin: 50px 0;
}
.campaign-maintxt{
    text-align: center;
    font-size: 3rem;
    font-weight: bold;
    line-height: 1.8;
    margin-bottom: 60px;
}
.campaign-caution{
    color:#120bac;
    padding: 0 150px;
}
.campaign-caution-ttl{
    font-size: 2.7rem;
    font-weight: bold;
}
.campaign-caution-ttl::before{
    content: '';
    display: inline-block;
    width: 50px;
    height: 50px;
    background-image: url(../../assets/img/caution.png);
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
}
.campaign-caution-li{
    font-size: 2rem;
    line-height: 1.8;
    font-weight: bold;
}

@media screen and (max-width: 768px){
    .campaign-inner {
        padding: 40px 0px;
    }
    .campaign::before {
        top: -36px;
    }
    .campaign::after {
        top: -36px;
    }
    .campaign-img img{
        width: 220px;
    }
    .campaign-maintxt {
        text-align: left;
        font-size: 2rem;
        line-height: 1.4;
        margin-bottom: 30px;
    }
    .campaign-caution {
        padding: 0px;
    }
    .campaign-caution-ttl::before {
        width: 30px;
        height: 30px;
    }
    .campaign-caution-ttl {
        font-size: 2rem;
    }
    .campaign-caution-li {
        font-size: 1.4rem;
        line-height: 1.6;
    }
}
/* ::::::::::::::::::::::: ▼ other ::::::::::::::::::::::::: */
.other{
    padding: 50px 0;
}
.other-inner{
    max-width: 1040px;
    margin: auto;
}
.other-ttl{
    text-align: center;
    font-size: 4rem;
    font-weight: bold;
    margin: 50px 0;
}
.other-img-logo{
    text-align: center;
    padding-bottom: 50px;
}
.other-img-logo img{
    width: 50%;
}
.other-txt{
    text-align: center;
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.6;
    padding-bottom: 50px;
}
.other-txt-redtxt{
    color:#f73400;
}
.other-img-box{
    display: flex;
    text-align: center;
}
.other-img-box img{
    width: 95%;
}

@media screen and (max-width: 768px){
    .other {
        padding: 50px 0;
    }
    .other-inner {
        padding: 0 20px;
    }
    .other-ttl {
        font-size: 2.3rem;
    }
    .other-img-logo {
        padding: 20px;
    }
    .other-img-logo img {
        width: 70%;
    }
    .other-txt {
        text-align: left;
        font-size: 1.7rem;
        padding-bottom: 10px;
    }
    .other-img-box {
        display: flex;
        text-align: center;
        flex-direction: column;
        align-items: center;
    }
    .other-img-box img {
        width: 75%;
    }
    .other-img-box img:last-child{
        margin-top: 20px;
    }
}
/* ::::::::::::::::::::::: ▼ qa ::::::::::::::::::::::::: */
.qa{
    background-color: #120bac;
    padding: 50px 0;
}
.qa-fontsize{
    font-size: 2rem;
}
.qa-inner{
    max-width: 1040px;
    margin: auto;
}
.qa-ttl{
    text-align: center;
    font-size: 4rem;
    font-weight: bold;
    margin: 50px 0;
    color: #fff;
}
.qa-question {
    padding: 25px 20px 25px 25px;
    border-bottom: none;
    position: relative;
    display: block;
    transition: 300ms;
    cursor: pointer;
    margin-top: 30px;
}
.qa-question-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.qa-question-text, .qa-answer-text {
    padding-left: 62px;
    position: relative;
    color: #fff;
    font-weight: bold;
    font-size: 1.rem;
}
.qa-question-text::before, .qa-answer-text::before {
    background: #fff;
    color: #333;
    text-align: center;
    width: 42px;
    height: 42px;
    line-height: 42px;
    font-size: 1.8rem;
    border-radius: 50%;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
}
.qa-question-text::before {
    content: "Q";
}
.qa-answer {
    padding: 0 50px 25px 25px;
}
.qa-answer-text {
    padding-top: 25px;
    font-weight: normal;
    color: #f0ff00;
    font-weight: bold;
    margin-top: -20px;
}
.qa-question-text, .qa-answer-text {
    padding-left: 62px;
    position: relative;
}
.qa-answer-text::before {
    content: "A";
    background: #ffffff;
    top: 28px;
    bottom: auto;
    font-weight: bold;
    color: #e83836;
}

@media screen and (max-width: 768px){
    .qa {
        padding: 40px 0;
    }
    .qa-ttl {
        font-size: 2.3rem;
        margin: 0px 0;
    }
    .qa-question {
        margin-top: 10px;
    }
    .qa-answer {
            padding: 0 50px 5px 25px;
            font-size: 1.2rem;
    }
    .qa-question {
        font-size: 1.2rem;
    }
    .qa-question-text, .qa-answer-text {
        padding-left: 52px;
    }
}
/* ::::::::::::::::::::::: ▼ footer ::::::::::::::::::::::::: */
.footer{
    background-color: #333;
    padding: 50px 0;
    color: #fff;
    text-align: center;
    font-weight: bold;
}
.footer-ttl{
    font-size: 3rem;
    margin: 50px 0;
}
.footer-txt{
    font-size: 2.3rem;
    margin-bottom: 20px;
}
.free-tel{
    font-size: 3.6rem;
    margin-bottom: 20px;
}
.free-tel::before{
    content: '';
    display: inline-block;
    width: 50px;
    height: 50px;
    background-image: url(../../assets/img/free-tel.png);
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
    margin-right: 10px;
}

@media screen and (max-width: 768px){
    .footer {
        padding: 20px 0;
    }
    .footer-ttl {
        font-size: 2rem;
        margin: 0 0 20px 0;
    }
    .footer-txt {
        font-size: 1.4rem;
        margin-bottom: 20px;
    }
    .free-tel {
        font-size: 1.9rem;
        margin-bottom: 10px;
    }
    .free-tel::before {
        width: 30px;
        height: 30px;
        margin-right: 8px;
    }
    .footer-logo img{
        width: 20%;
    }
    .servis-about-list-price-area {
        display: flex;
        margin: 20px 0;
        flex-direction: column;
    }
    .servis-about-list-price:first-child {
        margin-right: 20px;
        margin-bottom: 10px;
    }
    .servis-about-list-dt {
        margin-right: 7px;
        border: 2px solid #333;
        border-radius: 5px;
        padding: 6px;
        font-size: 1.6rem;
    }
    .servis-about-list-dd {
        font-size: 1.6rem;
        font-weight: bold;
    }
}
