@charset "UTF-8";
.aboutP__mv{
    width: 100vw;
    height: 290px;
    position: relative;

    background-image: url(../images/aboutPage_top.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}

.aboutP__mv__box{
    position: absolute;
    top: 112px;
    left: 13.5%;
}

.aboutP__mv__sub{
    font-size: 2rem;
    margin-top: 20px;
}

/* ===== about menu ===== */
.about__menu__flex{
    display: flex;
    justify-content: space-between;
    width: 72%;
    margin: 0 auto;
}

.about__menu{
    height: 500px;
    position: sticky;
    z-index: 1;
    top: 100px;
    left: 0;
}

.about__item{
    width: 214px;
    font-size: 2rem;
    margin: 18px 50px 0 0;
    padding: 10px 0;
    border: white 1px solid;
    background-color: rgba(42, 96, 172, 0.7);

    background-image: url(../images/arrow_small.png);
    background-repeat: no-repeat;
    background-size: 15px 15px;
    background-position: top 50% right 18px;

    position: relative;
    transition: 0.2s;
}

.about__item:hover{
    transform: scale(1.05);
    transition: 0.2s;
}

.about__item::after{
    content: '';
    position: absolute;
    top: 50%;
    left: 23px;
    transform: translateY(-50%);
    width: 15px;
    height: 15px;
    background-color: #fff;
}

.about__item a{
    width: 100%;
    height: 100%;
}

.letter__spacing{
    display: flex;
    justify-content: space-between;
    width: 120px;
    margin: 0 auto;
}

/* about menu responsive */
@media screen and (max-width:1280px) {
    .about__menu__flex{        
        width: 100%;
        flex-direction: column;
    }

    .about__menu{
        height: 70px;
        z-index: 100;
        top: 120px;
        margin: 0 auto;
    }

    .about__list{
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        gap: 10px 20px;
    }

    .about__item{
        margin: 0;
        font-size: 1.6rem;
        width: 150px;
        padding: 5px 0;
        background-position: top 50% right 5px;
    }

    .about__item::after{
        content: '';
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        background-color: #fff;
        
        width: 10px;
        height: 10px;
        left: 5px;
    }

    .letter__spacing{
        display: flex;
        justify-content: space-between;
        width: 100px;
        margin: 0 0 0 20px;
    }


}
@media screen and (max-width:767px) {
    .aboutP__mv{
        height: 200px;
        background-position: top left -280px;
    }

    .aboutP__mv__box{
        top: 100px;
    }

    .aboutP__mv__sub{
        font-weight: 700;
        margin-top: 0;
    }

    .about__menu{
        height: 120px;
        top: 90px;
        position: static;
    }
}
/* about menu responsive end */

/* ================================================================= main contents */
.aboutP__mainContents{
    width: 78%;
}
/* responsive */
@media screen and (max-width:1280px) {
    .aboutP__mainContents{
        margin: 0 auto;
    }
}
@media screen and (max-width:767px) {
    .aboutP__mainContents{
        width: 90%;
    }
}

.aboutP__section__title{
    font-size: 2rem;
    line-height: 2;
    letter-spacing: 3px;
    border-bottom: white 1px solid;
    padding-left: 25px;
    position: relative;
}

.aboutP__section__title::after{
    content: '';
    position: absolute;
    top: 50%;
    left: 5px;
    transform: translateY(-50%);
    width: 15px;
    height: 15px;
    background-color: #fff;
}

/* ================================================== greeting */
.greeting__title{
    margin-top: 0;
}

.greeting__txt{
    width: 96.5%;
    margin: 0 auto;
    line-height: 2.5;
    margin-top: 28px;
}

.greeting__sign{
    width: 96.5%;
    margin: 0 auto;
    line-height: 2.5;
    margin-top: 26px;
    text-align: right;
}

.greeting__name{
    margin-left: 23px;
    font-size: 2rem;
}

/* ================================================= profile */
.CPlist{
    display: flex;
    align-items: center;
    line-height: 1.87;
    padding: 28px 0 24px;
    border-bottom: 1px solid white;
}

.marginLeft{
    display: inline-block;
    margin-left: 10px;
}

.CPlist__title{
    margin: 0 40px 0 10px;
    width: 68px;
}

.CP__address__address{
    width: 86.8%;
}

.CP__map__flex{
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.CPlist__txt{
    width: 40%;
}

.CP__map{
    width: 50%;
    height: 180px;
}

.CP__address__tokyo{
    padding-bottom: 23px;
    border-bottom: 2px white dotted;
}

.CP__address__osaka{
    padding-top: 23px;
}

.CP__BusinessContents{
    align-items: flex-start;
}

/* profile responsive */
@media screen and (max-width:767px) {
    .CPlist{
        flex-direction: column;
        align-items: flex-start;
    }

    .CP__address__address{
        width: 100%;
    }

    .CPlist__title{
        margin: 0;
        width: 100%;
    }

    .CPlist__txt,
    .CPlist__item{
        width: 100%;
        font-weight: 200;
    }

    .shozaichi{
        padding-bottom: 5px;
        margin-bottom: 20px;
        border-bottom: 2px white dotted;
    }

    .CP__map__flex{
        flex-direction: column;
    }

    .CP__map{
        width: 100%;
        height: 124px;
        margin-top: 20px;
    }
}
/* profile responsive end */

/* ========================================== history */
.history__list{
    margin: 36px 0 0 122px;
}

.history__list__flex{
    display: flex;
    margin-top: 22px;
}

.history__dt{
    width: 90px;
    margin-right: 45px;
}

/* history responsive */
@media screen and (max-width:767px) {
    .history__list{
        margin: 36px 0 0 0;
    }
    
    .history__list__flex{
        flex-direction: column;
    }

    .history__dd{
        margin: 0 0 0 20px;
        font-weight: 200;
    }
}
/* history responsive end */

/* ========================================= group company */
.GroupCompany{
    margin-bottom: 100px;
}

.GC__list{
    width: 88.6%;
    margin-left: 11.3%;
}

.nakamoto{
    margin-top: 64px;
}

.GC__list__title{
    position: relative;
    padding-left: 20px;
    margin-bottom: 27px;
    border-bottom: 1px white solid;
}

.GC__list__title::after{
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: 14px;
    height: 14px;
    background-color: white;
}

.GC__address__box__flex{
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.GC__address{
    display: flex;
}

.GC__nakamoto__hokkaido{
    border-bottom: 2px white dotted;
    padding: 0 20px 17px 0;
}

.GC__nakamoto__tokyo{
    padding-top: 15px;
}

.marginTop{
    margin-top: 10px;
}

.GC__address__title{
    display: flex;
    justify-content: space-between;
    width: 96px;
    margin-right: 60px;
}

.GC__map__box{
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 45%;
}

.GC__map{
    width: 196px;
    height: 196px;
}

.GC__box{
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.toyu_s{
    margin-top: 17px;
}

.meigi_e{
    margin-top: 39px;
}

/* group company respondive */
@media screen and (max-width:1780px) {
    .GC__address__box{
        width: 100%;
    }

    .GC__map__box{
        width: auto;
        flex-direction: column;
    }

    .GC__address{
        min-height: 196px;
    }

    .map__hokkaido{
        width: auto;
        text-align: end;
        border-bottom: 2px white dotted;
        padding-bottom: 15px;
    }

    .map__tokyo{
        padding-top: 17px;
    }

    .map__txt{
        display: none;
    }
    
}
@media screen and (max-width:1280px) {
    .notSp{
        display: none;
    }

    .notPc{
        display: block;
    }

    .GC__list{
        width: 100%;
        margin-left: 0%;
        margin: 30px auto 0;
        position: relative;
        border: 1px white solid;
    }

    .GC__list__title{
        position: relative;
        height: 25px;
        padding-left: 0px;
        padding: 5px 0;
        margin-bottom: 15px;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    
    .GC__list__title::after{
        width: 0px;
        height: 0px;
    }

    .GC__address__box__flex{
        padding: 0 20px 20px 20px;
    }

    .GC__address{
        flex-direction: column;
        font-weight: 200;
        line-height: 2;
    }

    .GC__address__title{
        display: flex;
        justify-content: flex-start;
        width: auto;
        margin-right: 0px;
    }

    .GC__map{
        height: 200px;
        width: 100%;
        margin: 20px auto 0;
    }

    .map__hokkaido{
        border-bottom: none;
    }

    .GC__nakamoto__hokkaido{
        padding: 0;
    }

    .GC__box{
        flex-direction: column;
        padding: 0 20px 20px 20px;
        align-items: flex-start;
    }
}
/* group company respondive end */