@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@500&display=swap');
/*==============
    about
===============*/
:root {
    --jpMin : 'Noto Serif JP', serif;
}
section{
    margin-bottom: 0 !important;
}
table {
    width: 100%;
    table-layout: fixed;
    word-break: break-all;
}
#about h2.logo{
    max-width: clamp(300px, calc(300px + 300 * ((100vw - 320px) / 1120)), 600px);
    width: 100%;
    margin: 0 auto;
    margin-bottom: clamp(40px, calc(40px + 40 * ((100vw - 320px) / 1120)), 80px);
}
#about h3{
    font-size: clamp(2rem, 5.3vw, 3.6rem);
    font-family: var(--jpMin);
    text-align: center;
    border-bottom: none;
    font-weight: initial;
    letter-spacing: 0.2em;
    padding-bottom: 0;
    margin-bottom: 16px;
    font-family: var(--jpMin);
}
#about .lead{
    padding-bottom: 80px;
    margin-bottom: 80px;
    border-bottom: 1px solid #e5e5e5;
}
#about .lead p.txt{
    font-size: clamp(1.6rem, 4.26666667vw, 1.8rem);
    line-height: 2;
    margin-bottom: 40px;
    text-align: center;
}
#about .more.wide{
    width: 50%;
    text-align: center;
    margin: 0 auto;
    display: block;
}
#about .more.jpMin{
    font-family: var(--jpMin);
}
#about .detail .txt{
    font-size: clamp(1.6rem, 4.26666667vw, 1.8rem);
    line-height: 2;
    text-align: center;
    margin-bottom: 40px;
}
#about .detail .rank-tag{
    margin-top: 10px;
    display: flex;
    gap: 8px;
    justify-content: right;
}
#about .detail .rank-tag li{
    background: linear-gradient( 90deg, rgb(238,208,112) 0%, rgb(169,115,50) 100%);
    padding: 2px 10px;
    color: #fff;
    font-family: var(--jpMin);
    font-size: 1.2rem;
    display: inline-block;
}
#about .detail .rank-tag li.nomal{
    background: #aaa;
}
#about .detail .benefits{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    row-gap: 40px;
}
#about .detail .benefits .inner{
    width: 31.57%;
}
#about .detail .benefits .inner .ttl{
    padding: 24px 0;
    text-align: center;
    color: #fff;
    font-family: var(--jpMin);
    font-size: 1.6rem;
    font-weight: initial;
    letter-spacing: 0.2em;
    background: var(--color1);
    margin-bottom: 24px;
    position: relative;
}
#about .detail .benefits .inner .ttl::before{
    position: absolute;
    content: '';
    top: 100%;
    left: 0;
    border: none;
    border-bottom: solid 15px transparent;
    border-right: solid 20px #828282;
}
#about .detail .benefits .inner img{
    border: solid 1px #e6e6e6;
    margin-bottom: 16px;
}
#about .detail .benefits .inner .txt{
    font-size: clamp(1.4rem, 3.733333333vw, 1.6rem);
    text-align: left;
    line-height: 1.5;
    margin-bottom: 0 !important;
}
#about .detail .more{
    margin-top: 40px;
}
#about .detail{
    margin-bottom: 120px;
}
#about .faq{
    padding: 120px 0;
    background: #f5f5f5;
}
/* accordion */
.accordion-list:not(:first-child) {
    margin-top: 10px;
}
.accordion-title {
    cursor: pointer;
    font-size: clamp(1.4rem, 3.733333333vw, 1.6rem);
    padding: 32px 24px 32px 40px;
    position: relative;
    border-bottom: 1px solid #cccccc;
}
.accordion-title span{
    position: absolute;
    left: 0;
    font-family: var(--jpMin);
    font-size: 1.8rem;
    font-weight: initial;
}
.accordion-title:before {
    position: absolute;
    content: '';
    top: 50%;
    right: 0;
    height: 1px;
    width: 15px;
    background: #333;
    transform: rotate(90deg);
    transition: all .3s ease-in-out;
}
.accordion-title:after {
    position: absolute;
    content: '';
    top: 50%;
    right: 0;
    height: 1px;
    width: 15px;
    background: #333;
    transition: all .3s ease-in-out;
}
  .accordion-title.open:before {
    transform: rotate(180deg);
}
  .accordion-title.open:after {
    opacity: 0;
}
.accordion-text {
    display: none;
    padding: 32px 24px 32px 40px;
    position: relative;
}
.accordion-text span{   
    position: absolute;
    left: 0;
    font-family: var(--jpMin);
    font-size: 1.6rem;
    font-weight: initial;
}
.pc-on{
    display: block;
    margin-bottom: 80px;
}
.sp-on{
    display: none;
}
@media screen and (max-width: 1000px){
    .pc-on{
        display: none;
    }
    .sp-on{
        display: block;
    }
    #about .rank li{
        margin-bottom: 24px;
    }
    #about .rank li:last-child{
        margin-bottom: 0;
    }
    #about .rank li .inner{
        padding: 24px;
        width: calc(100% - 48px);
        background: #f5f5f5;
    }
    #about .rank li .rank p{
        padding: 16px 10px;
        text-align: center;
        font-family: var(--jpMin);
        font-size: 1.6rem;
        font-weight: initial;
        color: #fff;
        width: calc(100% - 20px);
    }
    #about .rank li .rank.flex p{
        width: 50%;
    }
    #about .rank.sp-on li .price{
        border: none;
        padding: 0;
        width: 100%;
    }
    #about .rank li .inner .rank-detail ul{
        display: flex;
        flex-wrap: wrap;
        background: #e3e3e3;
        padding: 20px;
        row-gap: 1rem;
        margin-top: 24px;
    }
    #about .rank li .inner .rank-detail ul li{
        width: calc(100% / 3);
        margin-bottom: 0;
        font-size: 1.rem;
    }
    #about .detail .rank-detail{
        margin-top: 0;
        margin-bottom: 0;
    }
    #about .detail .benefits{
        margin-top: 80px;
    }
    #about .detail .benefits .inner {
        width: 48%;
    }
}
@media screen and (max-width: 768px){
    #about .rank li .inner .rank-detail ul li {
        width: 100%;
        font-size: 1.3rem;
    }
    #about .rank li .inner .rank-detail ul {
        row-gap: 0.5rem;
    }
    #about .detail .txt {
        text-align: left;
    }
    #about .more.wide {
        font-size: 1.6rem;
        padding: 24px 36px;
        width: 80%;
    }
    #about .lead {
        padding-bottom: 56px;
        margin-bottom: 40px;
    }
    #about .detail .benefits {
        margin-top: 56px;
    }
    #about .detail .benefits .inner {
        width: 100%;
    }
    #about .detail {
        margin-bottom: 80px;
    }
    #about .faq {
        padding: 80px 0;
    }
    #about .rank.sp-on li .price a {
        width: 100%;
    }
}
/* 231114 */
.accordion-text span.indent {
    position: inherit;
    font-size: inherit;
    font-family: inherit;
  }
  .accordion-list a {
    text-decoration: underline;
  }
/* 1117 */
#about .taright{
    text-align: right;
    font-size: 1.6rem;
}
#about .rank-detail ul li span{
    font-size: 1.4rem;
}
#about .rank-detail .cap{
    margin-top: 10px;
}
/* 1223 */
.rank-wrap{
    margin-bottom: 32px;
}
.rank-wrap h4{
    background: #ccc;
    padding: 24px 10px;
    text-align: center;
    margin-bottom: 10px;
    font-family: var(--jpMin);
}
.rank-wrap.gold h4{
    background: linear-gradient( 90deg, rgb(238,208,112) 0%, rgb(169,115,50) 100%);
}
.rank-wrap .cap{
    text-align: center;
    font-size: 13px;
    color: red;
}
.rank-wrap .detail{
    margin-bottom: 10px !important;
    display: flex;
    gap: 24px;
}
.rank-wrap .detail li{
    width: 100%;
}
.rank-wrap .detail li .ttl{
    background: #e7e7e7;
    font-family: var(--jpMin);
    font-size: 1.6rem;
    text-align: center;
    padding: 16px 10px;
}
.rank-wrap .detail li .price{
    padding: 24px 10px;
    text-align: center;
    background: #f3f3f3;
}
.rank-wrap.gold .detail li .ttl{
    background: #e8e2d3;
}
.rank-wrap.gold .detail li .price{
    background: #f5f1e6;
}