/*** 下層ページ ***/

h2{
    font-size: 38px;
    font-family: var(--mincho);
    line-height: 1.8;
    position: relative;
    text-align: center;
    letter-spacing: 0.06em;
    padding-bottom: 15px;
    margin-bottom: 50px;
    border-bottom: 2px solid #f3f1ec;
}
h2::after{
    content: "";
    width: 220px;
    height: 2px;
    background-color: #134a49;
    position: absolute;
    bottom: -2px;
    left: 0;
}
h3{
    font-size: 30px;
    font-family: var(--mincho);
    line-height: 1.3;
    position: relative;
    text-align: center;
    letter-spacing: 0.02em;
    padding-bottom: 20px;
    margin-bottom: 35px;
}
h3::after{
    content: "";
    width: 220px;
    height: 2px;
    background-color: #426e6d;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
}

.url-box{
    width: 260px;
    height: 50px;
    border-radius: 100px;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    font-size: 15px;
    font-weight: 300;
    letter-spacing: 0.08em;
    position: relative;
}
.url-box::after{
    content: "";
    display: inline-block;
    background-image: url(../img/common/icon-arrow-right--white.png);
    background-size: contain;
    background-repeat: no-repeat;
    width: 15px;
    height: 15px;
    margin-left: 8px;
    transition: 0.3s;
}
.ml-minus{
    margin-left: -25px;
    margin-right: -15px;
    display: inline-block;
}
.br{display: block;}
.in-bk{display: inline-block;}

@media screen and (max-width: 1365px){
    h2{
        font-size: 34px;
    }
    h3{
        font-size: 26px;
    }
}
@media screen and (max-width: 1023px){

}
@media screen and (max-width: 767px){
    h2{
        font-size: 4.6vw;
        margin-bottom: 30px;
        line-height: 1.5;
    }
    h2::after{
        width: 120px;
    }
    h3{
        font-size: 4vw;
        margin-bottom: 25px;
    }
    h3::after{
        width: 120px;
    }
    .url-box{
        width: 240px;
        height: 42px;
        font-size: 14px;
    }
    .url-box::after{
        width: 14px;
        height: 14px;
        margin-left: 6px;
    }
}
@media screen and (max-width: 399px){
    h2{
        font-size: 5.5vw;
    }
    h3{
        font-size: 5vw;
    }

}

/* 私たちについて */
.about-page{
    margin-top: -20px;
}
.about-info{
    width: 100%;
    background: #e9efeb;
    padding: 60px;
    margin-bottom: 60px;
    border-radius: 20px;
}
.about-info-title{
    font-size: 20px;
    font-family: var(--mincho);
    text-align: center;
    line-height: 1.8;
    font-weight: 500;
    margin: -10px 0 40px;
}
.about-number-flex{
    width: 100%;
    display: flex;
    justify-content: space-around;
}
.about-number-flex-box{
    width: 215px;
    height: 215px;
    background-color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    font-size: 30px;
    font-family: var(--mincho);
    line-height: 1;
    font-weight: 500;
}
.about-number-flex-box span{
    font-size: 75px;
    color: #c45c0b;
    font-weight: bold;
    position: relative;
    line-height: 1;
    display: block;
}
.about-number-flex-box span::after{
    content: "名";
    font-size: 26px;
    color: #000;
    position: absolute;
    bottom: 5px;
    right: -25px;
}
.about-number-flex-box div:last-child{
    /*font-size: 26px;*/
    font-size: 0;
}
.about-number-info{
    text-align: right;
    font-size: 14px;
    font-weight: 300;
    margin: 15px 0 -5px;
}
.about-lawyer{
    width: 100%;
    background-image: url(../img/lower/about/about-bg.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    padding: 50px 60px 40px;
    margin-bottom: 80px;
}
.about-lawyer-title{
    font-size: 28px;
    text-align: center;
    font-family: var(--mincho);
    line-height: 1.3;
}
.about-lawyer-list{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 20px 0 5px;
}
.about-lawyer-list li{
    width: 48%;
    max-width: 324px;
    background-color: #fff;
    margin-bottom: 20px;
    padding: 20px 30px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.about-lawyer-list-img{
    width: 86px;
    height: auto;
    display: inline-block;
}
.about-lawyer-list-content{
    max-width: 164px;
    width: 80%;
    font-weight: normal;
    line-height: 1.5;
    padding-left: 10px;
}
.about-lawyer-list-content .post{
    font-size: 15px;
}
.about-lawyer-list-content .name{
    font-size: 14px;
}
.about-lawyer-list-content .name .name-lawyer{
    font-size: 19px;
    font-family: var(--mincho);
    margin-left: 8px;
}
.about-lawyer-list-content .belong{
    font-size: 13px;
}
.office-info{
    font-size: 35px;
    font-family: var(--mincho);
    text-align: center;
    font-weight: 500;
    line-height: 1.2;
}
.info_base_comm{
    font-size: 85px;
    color: #c45c0b;
    margin-right: 10px;
    margin-left: 5px;
}
.office-info-note{
    font-size: 14px;
    font-family: "NotoSansCJKjp", sans-serif;
    font-weight: 300;
    letter-spacing: 0.08em;
}
.about-office-list{
    margin: 40px auto 0;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 30px 40px;
    max-width: 680px;
}
.about-office-list li{
    max-width: 100px;
    width: 20%;
    text-align: center;
}
.about-office-list li .title{
    font-size: 14px;
    line-height: 1;
    margin-top: 12px;
    font-weight: 300;
    position: relative;
}
.about-office-list li .title::after{
    content: "";
    width: 8px;
    height: 8px;
    border-right: 2px solid #c45c0b;
    border-bottom: 2px solid #c45c0b;
    position: absolute;
    top: 50%;
    right: -10px;
    transform: translateY(-50%) rotate(-45deg);
}
@media screen and (max-width: 1365px){
    .about-number-flex{
        justify-content: center;
        gap: 20px;
    }
    .about-lawyer-list{
        justify-content: center;
        gap: 20px;
        margin-bottom: 20px;
    }
    .about-lawyer-list li{
        margin-bottom: 0;
    }
}
@media screen and (max-width: 1023px){
    .about-info {
        padding: 60px 40px;
    }
    .about-info-title{
        font-size: 18px;
    }
    .about-number-flex-box{
        font-size: 26px;
        width: 200px;
        height: 200px;
    }
    .about-number-flex-box span{
        font-size: 60px;
    }
    .about-number-flex-box span::after{
        font-size: 20px;
    }
}
@media screen and (max-width: 767px){
    .about-info {
        padding: 40px 25px;
    }
    .about-info-title {
        font-size: 3.5vw;
        text-align: left;
    }
    .about-number-flex{
        flex-wrap: wrap;
        gap: 0 4vw;
    }
    .about-number-flex-box {
        font-size: 4vw;
        width: 32vw;
        height: 32vw;
    }
    .about-number-flex-box span {
        font-size: 10vw;
    }
    .about-number-flex-box span::after {
        font-size: 4.5vw;
        bottom: 0.5vw;
        right: -5vw;
    }
    .about-number-info{
        font-size: 12px;
    }
    .about-lawyer{
        padding: 40px 25px 30px;
    }
    .about-lawyer-title {
        font-size: 4.5vw;
    }
    .about-lawyer-list {
        gap: 2vw;
        margin-bottom: 20px;
    }
    .about-lawyer-list li{
        padding: 15px 10px;
        box-sizing: border-box;
    }
    .about-lawyer-list-img {
        width: 14vw;
    }
    .about-lawyer-list-content .post {
        font-size: 2.5vw;
    }
    .about-lawyer-list-content .name {
        font-size: 2.6vw;
    }
    .about-lawyer-list-content .name .name-lawyer {
        font-size: 3vw;
        margin-left: 0.5vw;
    }
    .about-lawyer-list-content .belong {
        font-size: 2vw;
    }
    .office-info {
        font-size: 5vw;
    }
    .info_base_comm{
        font-size: 12vw;
        margin-right: 8px;
        margin-left: 3px;
    }
    .office-info-note{
        font-size: 12px;
    }
}
@media screen and (max-width: 520px){
    .about-lawyer-list li{
        width: 100%;
        max-width: none;
        padding: 15px 10vw;
    }
    .about-lawyer-list-img {
        width: 18vw;
    }
    .about-lawyer-list-content {
        max-width: none;
        width: 60%;
        padding-left: 0;
    }
    .about-lawyer-list-content .post {
        font-size: 3.5vw;
    }
    .about-lawyer-list-content .name {
        font-size: 3.2vw;
    }
    .about-lawyer-list-content .name .name-lawyer {
        font-size: 4.5vw;
        margin-left: 0.5vw;
    }
    .about-lawyer-list-content .belong {
        font-size: 3vw;
    }
}
@media screen and (max-width: 399px){
    .about-info {
        padding: 40px 5vw;
    }
    .about-info-title{
        font-size: 4.2vw;
        margin-bottom: 20px;
    }
    .about-number-flex-box {
        font-size: 5vw;
        width: 36vw;
        height: 36vw;
    }
    .about-number-flex-box span {
        font-size: 12vw;
    }
    .about-number-flex-box span::after {
        font-size: 5vw;
        bottom: 0.9vw;
        right: -4.5vw;
    }
    .about-lawyer {
        padding: 40px 5vw 30px;
    }
    .about-lawyer-title {
        font-size: 4.8vw;
    }
    .office-info {
        font-size: 6vw;
    }
    .info_base_comm {
        font-size: 14vw;
    }
    .about-office-list{
        margin: 30px auto 0;
        gap: 30px 6vw;
    }
    .about-office-list li{
        width: 28%;
    }
}

/* 弁護士費用 */
.fee-info-box{
    width: 100%;
    margin-bottom: 60px;
    border: 10px solid #e8efeb;
    padding: 35px 0;
    text-align: center;
    font-family: var(--mincho);
}
.fee-info-title{
    width: 260px;
    height: 40px;
    background-color: #134949;
    color: #fff;
    border-radius: 6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    font-weight: bold;
    line-height: 1;
}
.fee-info-pr{
    font-size: 44px;
    color: #c45c0b;
    font-weight: bold;
    line-height: 1.2;
}
.fee-info-note{
    font-size: 20px;
    font-weight: 500;
    line-height: 1.5;
    margin-top: 10px;
}
.fee-info-table{
    width: 100%;
    margin-bottom: 90px;
    font-family: var(--mincho);
    font-size: 22px;
    border-collapse:collapse 
}
.fee-info-table .inbl{
    display: inline-block;
}
.fee-info-table .block{
    display: block;
}
.fee-info-table th,
.fee-info-table td{
    padding: 15px 20px;
    line-height: 1.8;
}
.fee-info-table th{
    font-size: 32px;
    border-bottom: 2px solid #fff;
    background-color: #134949;
    color: #fff;
}
.fee-info-table th.sub{
    font-size: 22px;
    background: #e8edf0;
    color: #134949;
}
.fee-info-table th.sub .small{
    display: block;
    font-size: 14px;
}
.fee-info-table td{
    padding: 20px 30px;
    border-bottom: 2px solid #f3f1ec;
    border-right: 2px solid #f3f1ec;
    border-left: 2px solid #f3f1ec;    
}
.fee-info-table td.title{
    width: 30%;
    background-color: #f3f1ec;
    padding: 20px 15px;
    border-bottom: 2px solid #fff;
    text-align: center;
}
.fee-info-table td.title .small{
    display: block;
    font-size: 14px;
}
.fee-info-table td p{
    font-size: 14px;
    line-height: 1.8;
}
.fee-info-table td p{
    margin-top: 0.8em;
}
.fee-info-table td p.mt0{
    margin-top: 0 !important;
}

@media screen and (max-width: 1365px){
    
}
@media screen and (max-width: 1023px){
    .fee-cost-box{
        font-size: 20px;
    }
    .fee-cost-title{
        font-size: 26px;
        height: 64px;
    }
    .fee-info-table th{
        font-size: 28px;
    }
}
@media screen and (max-width: 767px){
    .fee-info-box{
        margin-bottom: 40px;
        border: 8px solid #e8efeb;
        padding: 25px 0;
    }
    .fee-info-title{
        width: 200px;
        height: 32px;
        font-size: 18px;
    }
    .fee-info-pr{
        font-size: 36px;
    }
    .fee-info-note{
        font-size: 16px;
        margin-top: 8px;
    }
    .fee-info-table{
        font-size: 20px;
    }
    .fee-info-table th{
        font-size: 26px;
    }
    .fee-info-table th.sub{
        font-size: 20px;
    }
    .fee-info-table td.title{
        padding: 20px 15px;
    }
    .fee-info-table td p{
        font-size: 12px;
    }
}
@media screen and (max-width: 499px){
    .fee-info-box{
        padding: 20px 15px;
    }
    .fee-info-title {
        width: 160px;
        height: 30px;
        font-size: 17px;
    }
    .fee-info-pr{
        font-size: 32px;
    }
    .fee-info-note{
        font-size: 14px;
    }
    .fee-info-table{
        margin-bottom: 60px;
        font-size: 18px;
    }
    .fee-info-table th, .fee-info-table td{
        display: block !important;
        width: 100% !important;
        padding: 15px;
    }
    .fee-info-table th{
        font-size: 20px;
    }
    .fee-info-table th.sub{
        font-size: 18px;
    }
    .fee-info-table td.title{
        padding: 10px;
    }

}