@charset "utf-8";

/*-----------------------------------------------
    secTop
-----------------------------------------------*/
.secTop {
    background: url(../img/staff/bgTop.jpg) center bottom / cover no-repeat;
    height: 55rem;
    display: flex;
    justify-content: center;
    color: var(--whiteColor);
    align-items: center;
}

.secTop .cmnTopTopWrapper {
    padding-top: 6rem;
}

.secTop .engTit {
    font-size: var(--pcFontSize100);
    margin-bottom: 3rem;
}

.secTop .engTitSub {
    font-size: var(--pcFontSize13);
    letter-spacing: var(--pcLetterSpacing13_200);
    margin-bottom: 2.7rem;
}

.secTop .jpTit {
    font-size: var(--pcFontSize18);
    letter-spacing: var(--pcLetterSpacing18_150);
}


@media only screen and (max-width:1215px) {
    .secTop {
        background: url(../img/staff/bgTop_sp.jpg) center bottom / cover no-repeat;
        height: 24rem;
    }

    .secTop .cmnTopTopWrapper {
        padding-top: 3.2rem;
    }

    .secTop .engTit {
        font-size: var(--spFontSize40);
        margin-bottom: 1.7rem;
    }

    .secTop .engTitSub {
        font-size: var(--spFontSize10);
        letter-spacing: var(--spLetterSpacing10_100);
        margin-bottom: 1.7rem;
    }

    .secTop .jpTit {
        font-size: var(--spFontSize14);
        letter-spacing: var(--spLetterSpacing14_50);
    }
}

/*-----------------------------------------------
    secBrandLinkStaff
-----------------------------------------------*/
.secBrandLinkStaff {
    margin-top: 6rem;
}
.secBrandLinkStaff .listBrandStaff {
    display: flex;
    gap: 2rem;
    flex-wrap: wrap;
}
.secBrandLinkStaff .btnBrandStaff {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 0.8rem;
    width: 24.6rem;
    height: 8rem;
    border-radius: 0.5rem;
    border: 0.1rem solid var(--keyColor);
    color: var(--keyColor);
    text-align: center;
    background: var(--whiteColor);
    transition: 0.3s;
}
.secBrandLinkStaff .btnBrandStaff .jpTit {
    font-size: var(--pcFontSize18);
    letter-spacing: var(--pcLetterSpacing18_50);
}
.secBrandLinkStaff .btnBrandStaff .note {
    font-size: var(--pcFontSize12);
    letter-spacing: var(--pcLetterSpacing12_50);
}
.secBrandLinkStaff .btnBrandStaff.is-current {
    background: var(--keyColor);
    color: var(--whiteColor);
}
.secBrandLinkStaff .btnBrandStaff.is-current .note {
    opacity: 0.9;
}
.secBrandLinkStaff .btnBrandStaff:hover {
    background: var(--keyColor);
    color:var(--whiteColor);
}

@media only screen and (max-width:1215px) {
    .secBrandLinkStaff {
        margin-top: 3rem;
    }
    .secBrandLinkStaff .listBrandStaff {
        gap: 1rem 2.975%;
    }
    .secBrandLinkStaff .btnBrandStaff {
        gap: 0.4rem;
        width: 100%;
        height: 100%;
        border-radius: 0.4rem;
    }
    .secBrandLinkStaff .itemBrandStaff {
        width: 31.35%;
        height: 7rem;
    }
    .secBrandLinkStaff .btnBrandStaff .jpTit {
        font-size: var(--spFontSize12);
        letter-spacing: 0;
        line-height: var(--spLineHeight13_16);
    }
    .secBrandLinkStaff .btnBrandStaff .note {
        font-size: var(--spFontSize10);
        letter-spacing: var(--spLetterSpacing10_50);
        line-height: var(--spLineHeight10_15);
    }
}

/*-----------------------------------------------
    secListStaff
-----------------------------------------------*/
.secListStaff .listNews {
    display: flex;
    flex-wrap: wrap;
    gap: 7rem 3.47%;
    margin-top: 6rem;
    padding-bottom: 7rem;
    border-bottom: 0.1rem solid var(--borderColor);
}
.secListStaff .itemNews {
    width: 31.02%;
    max-width: 49rem;
}

.secListStaff .linkNews {
    display: flex;
    gap: 2.2rem;
    align-items: center;
    position: relative;
    flex-direction: column;
}

.secListStaff .linkNews .boxLeft {
    flex-shrink: 0;
    width: 100%;
    position: relative;
    border-radius: 0.4rem;
    overflow: hidden;
    box-shadow: 0 0 2rem 0.3rem rgba(0, 0, 0, 0.2);
}

.secListStaff .linkNews .boxRight {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
}

.secListStaff .linkNews .imgNews {
    aspect-ratio: 490 / 490;
}

.secListStaff .linkNews .boxName {
    display: flex;
    gap: 1.6rem;
    align-items: center;
    flex-wrap: wrap;
}
.secListStaff .linkNews .txtName {
    font-size: var(--pcFontSize25);
    line-height: var(--pcLineHeight25_36);
    letter-spacing: var(--pcLetterSpacing25_150);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.secListStaff .linkNews .txtNameEng {
    font-size: var(--pcFontSize13);
    letter-spacing: var(--pcLetterSpacing13_200);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.secListStaff .linkNews .tagList {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 1.3rem;
}
.secListStaff .linkNews .titTag {
    font-size: var(--pcFontSize13);
    letter-spacing: var(--pcLetterSpacing13_200);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: inline;
}
.secListStaff .linkNews .titTag .iconHash {
    display: inline-block;
    width: 2rem;
    height: 2rem;
    margin-right: 8px;
    vertical-align: middle;
    object-fit: contain;
}

.secListStaff .linkNews .txtMore {
    font-size: var(--pcFontSize12);
    transition: 0.3s;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
}

.secListStaff .linkNews .txtMore::after {
    position: absolute;
    content: "";
    width: calc(100% - 7.2rem);
    height: 0.7rem;
    left: 7.2rem;
    top: calc(50% - 0.4rem);
}

.secListStaff.lazyloaded .linkNews .txtMore::after {
    background: url(../img/common/iconMoreArrowLong.png) center right / cover;
}

.secListStaff .iconNew {
    position: absolute;
    top: 4rem;
    left: 2rem;
    width: 4.4rem;
    height: 4.4rem;
    border-radius: 50%;
    background: var(--colorNewIcon);
    font-size: var(--pcFontSize10);
    color: var(--whiteColor);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
}

.secListStaff:not(:has(.secCmnIndexPager)) {
    padding-bottom: 7rem;
}

@media only screen and (max-width:1215px) {
    .secListStaff .linkNews .boxLeft {
        width: 100%;
        border-radius: 0rem;
        box-shadow: 0 0 0.5rem 0.1rem rgba(0, 0, 0, 0.2);
    }
    .secListStaff .listNews {
        display: flex;
        flex-wrap: wrap;
        gap: 3rem 4.47%;
        margin-top: 3rem;
        padding-bottom: 3rem;
    }

    .secListStaff .linkNews {
        padding: 0;
        gap: 1rem;
    }

    .secListStaff .itemNews {
        width: 47.762%;
        max-width: unset;
    }

    .secListStaff .linkNews .boxRight {
        min-height: auto;
        padding-bottom: 2.5rem;
    }

    .secListStaff .linkNews .txtName {
        font-size: var(--spFontSize16);
        letter-spacing: var(--spLetterSpacing16_150);
    }

    .secListStaff .linkNews .txtNameEng {
        font-size: var(--spFontSize11);
        letter-spacing: var(--spLetterSpacing11_100);
    }

    .secListStaff .linkNews .titTag {
        font-size: var(--spFontSize11);
        letter-spacing: var(--spLetterSpacing11_50);
    }

    .secListStaff .linkNews .txtMore {
        font-size: var(--spFontSize10);
        right: 3rem;
    }

    .secListStaff .linkNews .txtMore::after {
        position: absolute;
        content: "";
        width: 6rem;
        height: 0.7rem;
        right: 0rem;
        left: unset;
        top: calc(50% - 0.4rem);
    }
    .secListStaff .iconNew {
        position: absolute;
        top: 1.8rem;
        left: 0.5rem;
        width: 3.4rem;
        height: 3.4rem;
    }
    .secListStaff .linkNews .boxName {
        gap: 0.6rem;
    }
    .secListStaff .linkNews .titTag .iconHash {
        margin-right: 4px;
    }

    .secListStaff:not(:has(.secCmnIndexPager)) {
        padding-bottom: 5rem;
    }
}


/*-----------------------------------------------
    details
-----------------------------------------------*/
#container.details{
    background: linear-gradient(
    0deg,
    rgba(227, 221, 202, 0.8) 0%,
    rgba(227, 221, 202, 0.502) 50%,
    rgba(227, 221, 202, 0) 100%
    );
}
/*-----------------------------------------------
    secStaffDetails
-----------------------------------------------*/
.secStaffDetails {
    margin-top: 10rem;
}
.secStaffDetails .boxTop {
    display: flex;
    gap: 7.24%;
    margin-bottom: 8.5rem;
}
.secStaffDetails .boxLeft {
    width: 50.725%;
    max-width: 70rem;
    flex-shrink: 0;
}
.secStaffDetails .boxRight {
    width: 42.035%;
    margin-top: 14rem;
}

.secStaffDetails .imgBox {
    width: 100%;
    border-radius: 0.4rem;
    overflow: hidden;
    box-shadow: 0 0 0.8rem 0.2rem rgba(0, 0, 0, 0.2);
}
.secStaffDetails .imgBox .img{
    aspect-ratio: 700 / 700;
}
.secStaffDetails .boxName {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1.6rem;
}
.secStaffDetails .txtName {
    font-size: var(--pcFontSize30);
    line-height: var(--pcLineHeight30_36);
    letter-spacing: var(--pcLetterSpacing30_150);
}
.secStaffDetails .txtNameEng {
    font-size: var(--pcFontSize15);
    line-height: var(--pcLineHeight15_26);
    letter-spacing: var(--pcLetterSpacing15_200);
}
.secStaffDetails .tagList {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 1.3rem;
    align-items: center;
}
.secStaffDetails .tagList .titTag {
    font-size: var(--pcFontSize13);
    letter-spacing: var(--pcLetterSpacing13_200);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: inline;
}
.secStaffDetails .tagList .titTag .iconHash {
    display: inline-block;
    width: 2rem;
    height: 2rem;
    margin-right: 8px;
    vertical-align: middle;
    object-fit: contain;
}

.secStaffDetails .listIntroduction{
    margin-top: 4rem;
}
.secStaffDetails .listIntroduction .itemIntroduction{
    display: flex;
    border-bottom: 0.1rem solid var(--borderColor);
    padding: 0.5rem 0;
    gap: 1rem;
}
.secStaffDetails .listIntroduction .itemIntroduction:first-child{
    border-top: 0.1rem solid var(--borderColor);
}
.secStaffDetails .listIntroduction .titIntroduction{
    font-size: var(--pcFontSize16);
    line-height: var(--pcLineHeight16_50);
    letter-spacing: var(--pcLetterSpacing16_50);
    width: 14rem;
    flex-shrink: 0;
}
.secStaffDetails .listIntroduction .txtIntroduction{
    font-size: var(--pcFontSize16);
    line-height: var(--pcLineHeight16_50);
    letter-spacing: var(--pcLetterSpacing16_50);
}
.secStaffDetails .underIntroduction .item{
    margin-bottom: 10rem;
}
.secStaffDetails .underIntroduction .num{
    font-size: var(--pcFontSize30);
    color: var(--keyColor);
    margin-bottom: 1.5rem;
}
.secStaffDetails .underIntroduction .tit{
    font-size: var(--pcFontSize30);
    line-height: var(--pcLineHeight30_60);
    letter-spacing: var(--pcLetterSpacing30_100);
    margin-bottom: 0.8rem;
}
.secStaffDetails .underIntroduction .txt{
    font-size: var(--pcFontSize16);
    line-height: var(--pcLineHeight16_50);
    letter-spacing: var(--pcLetterSpacing16_50);
}

@media only screen and (max-width:1215px) {
    .secStaffDetails {
        margin-top: 4rem;
    }
    .secStaffDetails .boxTop {
        display: block;
        margin-bottom: 3.5rem;
    }
    .secStaffDetails .boxLeft {
        width: 100%;
        max-width: unset;
        padding: 0 2rem;
    }
    .secStaffDetails .boxRight {
        width: 100%;
        margin-top: 2.5rem;
    }
    .secStaffDetails .txtName {
        font-size: var(--spFontSize18);
        letter-spacing: var(--spLetterSpacing18_150);
        text-align: center;
    }
    .secStaffDetails .txtNameEng {
        font-size: var(--spFontSize12);
        line-height: var(--spLineHeight12_20);
        letter-spacing: var(--spLetterSpacing12_100);
        text-align: center;
    }
    .secStaffDetails .boxName {
        gap: 1.6rem;
        justify-content: center;
    }
    .secStaffDetails .tagList {
        gap: 0.6rem;
        margin-top: 1.5rem;
        align-items: center;
        justify-content: center;
    }
    .secStaffDetails .tagList .titTag {
        font-size: var(--spFontSize11);
        letter-spacing: var(--spLetterSpacing11_50);
    }
    .secStaffDetails .listIntroduction .titIntroduction {
        font-size: var(--spFontSize12);
        line-height: var(--spLineHeight12_24);
        letter-spacing: var(--spLetterSpacing12_100);
        width: 9rem;
        flex-shrink: 0;
    }
    .secStaffDetails .listIntroduction .txtIntroduction {
        font-size: var(--spFontSize12);
        line-height: var(--spLineHeight12_24);
        letter-spacing: var(--spLetterSpacing12_100);
    }
    .secStaffDetails .listIntroduction .itemIntroduction {
        padding: 1.3rem 0;
    }

    .secStaffDetails .underIntroduction .num {
        font-size: var(--spFontSize16);
        margin-bottom: 0.2rem;
    }
    .secStaffDetails .underIntroduction .tit {
        font-size: var(--spFontSize18);
        line-height: var(--spLineHeight18_34);
        letter-spacing: var(--spLetterSpacing18_100);
        margin-bottom: 0.3rem;
    }
    .secStaffDetails .underIntroduction .txt {
        font-size: var(--spFontSize11);
        line-height: var(--spLineHeight11_24);
        letter-spacing: var(--spLetterSpacing11_100);
    }
    .secStaffDetails .listIntroduction {
        margin-top: 2.8rem;
    }
    .secStaffDetails .underIntroduction .item {
        margin-bottom: 3rem;
    }
}

/*-----------------------------------------------
    secDetailsPager
-----------------------------------------------*/
.secDetailsPager{
    padding-top: 5rem;
    padding-bottom: 15rem;
    border-top: 0.1rem solid var(--borderColor);
}
.secDetailsPager .boxBtnPager{
    display: flex;
    align-items: center;
    gap: 18.2%;
    margin-bottom: 7rem;
}
.secDetailsPager .boxBtnPager:not(:has(.boxBtnPrev)){
    justify-content: flex-end;
}
.secDetailsPager .linkPager{
    display: flex;
    align-items: center;
    gap: 3.5rem;
}
.secDetailsPager .linkPager.btnNext{
    flex-direction: row-reverse;
}
.secDetailsPager .boxBtnBox{
    width: 40.9%;
    max-width: 54rem;
}
.secDetailsPager .imgBox{
    width: 20rem;
    position: relative;
    flex-shrink: 0;
    box-shadow: 0 0 0.8rem 0.2rem rgba(0, 0, 0, 0.2);
}
.secDetailsPager .imgBox .img{
    aspect-ratio: 200 / 200;
}
.secDetailsPager .txtBox {
    flex: 1;
    min-width: 0;
}
.secDetailsPager .boxName {
    display: flex;
    gap: 1rem;
    align-items: center;
    flex-wrap: wrap;
    min-width: 0;
}
.secDetailsPager .txtName {
    font-size: var(--pcFontSize20);
    line-height: var(--pcLineHeight20_36);
    letter-spacing: var(--pcLetterSpacing20_150);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}
.secDetailsPager .txtNameEng {
    font-size: var(--pcFontSize13);
    letter-spacing: var(--pcLetterSpacing13_200);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.secDetailsPager .tagList {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 0.3rem;
    margin-left: 0.2rem;
}
.secDetailsPager .titTag {
    font-size: var(--pcFontSize13);
    letter-spacing: var(--pcLetterSpacing13_150);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: inline;
}
.secDetailsPager .titTag .iconHash {
    display: inline-block;
    width: 2rem;
    height: 2rem;
    margin-right: 8px;
    vertical-align: middle;
    object-fit: contain;
}

.secDetailsPager .txtMore{
    font-size: var(--pcFontSize12);
    letter-spacing: var(--pcLetterSpacing12_60);
    transition: 0.3s;
    position: relative;
    display: inline-block;
    margin-top: 1.5rem;
}

.secDetailsPager .txtMore::after {
    position: absolute;
    content: "";
    width: 10.2rem;
    height: 0.8rem;
    right: -11.2rem;
    top: calc(50% - 0.4rem);
}

.secDetailsPager.lazyloaded .txtMore::after {
    background: url(../img/common/iconMoreArrow.png) center right / cover;
}


.secCmnDetailsBtn .btnInner {
    width: 70rem;
    height: 8rem;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.4rem;
    border:0.1rem solid var(--colorDetailsPager);
}

.secCmnDetailsBtn .btnInner .txtBtn{
    font-size: var(--pcFontSize13);
    position: relative;
}
.secCmnDetailsBtn .btnInner .txtBtn::after {
    position: absolute;
    content: "";
    width: 10.2rem;
    height: 0.8rem;
    right: -11.2rem;
    top: calc(50% - 0.4rem);
}
.secCmnDetailsBtn.lazyloaded .btnInner .txtBtn::after {
    background: url(../img/common/iconMoreArrow.png) center right / cover;
}
@media only screen and (max-width:1215px) {
    .secDetailsPager .linkPager {
        gap: 1.4rem;
        flex-direction: column;
    }
    .secDetailsPager .linkPager.btnNext {
        flex-direction: column;
    }
    .secDetailsPager .deyTit {
        font-size: var(--spFontSize11);
        letter-spacing: var(--spLetterSpacing11_50);
        margin-bottom: 1rem;
    }
    .secDetailsPager .tit {
        font-size: var(--spFontSize13);
        line-height: var(--spLineHeight13_26);
        letter-spacing: var(--spLetterSpacing13_50);
        margin-bottom: 1rem;
        max-height: calc((var(--spLineHeight13_26) * var(--spFontSize13)) * 2);
    }
    .secDetailsPager .imgBox {
        width: 100%;
        box-shadow: 0 0 0.5rem 0.1rem rgba(0, 0, 0, 0.2);
    }
    .secDetailsPager .txtMore {
        font-size: var(--spFontSize10);
        letter-spacing: var(--spLetterSpacing10_50);
        margin-top: 2.5rem;
    }
    .secDetailsPager .txtMore::after {
        position: absolute;
        content: "";
        width: 2.1rem;
        height: 0.8rem;
        right: -3rem;
        top: calc(50% - 0.4rem);
    }
    .secDetailsPager .boxBtnBox {
        width: 44.78%;
        max-width: 15rem;
        padding-top: 1.7rem;
        padding-bottom: 0.8rem;
    }
    .secDetailsPager .boxBtnPager {
        gap: 10.4%;
        margin-bottom: 3rem;
        position: relative;
        justify-content: space-between;
    }
    .secDetailsPager .boxBtnPager::before {
        position: absolute;
        content: '';
        height: 100%;
        width: 0.1rem;
        background: var(--borderColor);
        top: 0;
        left: 50%;
    }
    .secDetailsPager {
        padding-top: 0rem;
        padding-bottom: 8rem;
    }
    .secCmnDetailsBtn .btnInner {
        width: 91.05%;
        max-width: 30.5rem;
        height: 5rem;
    }
    .secCmnDetailsBtn .btnInner .txtBtn {
        font-size: var(--spFontSize10);
        letter-spacing: var(--spLetterSpacing10_50);
        padding-right: 6rem;
    }
    .secCmnDetailsBtn .btnInner .txtBtn::after {
        position: absolute;
        content: "";
        width: 6.1rem;
        height: 0.8rem;
        right: -1rem;
        top: calc(50% - 0.4rem);
    }
    .secDetailsPager .txtName {
        font-size: var(--spFontSize16);
        letter-spacing: var(--spLetterSpacing16_150);
        max-width: 100%;
    }
    .secDetailsPager .txtNameEng {
        font-size: var(--spFontSize11);
        letter-spacing: var(--spLetterSpacing11_100);
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        max-width: 100%;
    }
    .secDetailsPager .boxName {
        gap: 0.2rem;
        align-items: flex-start;
        flex-direction: column;
        min-width: 0;
        width: 100%;
    }
    .secDetailsPager .titTag {
        font-size: var(--spFontSize11);
        letter-spacing: var(--spLetterSpacing11_50);
    }
    .secDetailsPager .titTag .iconHash {
        width: 1.8rem;
        height: 1.8rem;
        margin-right: 5px;
    }
    .secDetailsPager .txtBox {
        width: 100%;
    }
    .secDetailsPager .tagList {
        margin-top: 1.3rem;
    }
}

.txtNone{
    font-size: var(--pcFontSize20);
    line-height: var(--pcLineHeight20_34);
    letter-spacing: var(--pcLetterSpacing20_100);
    text-align: center;
    padding: 14rem 0;
}
@media only screen and (max-width:1215px) {
    .txtNone{
        padding: 8rem 0;
        font-size: var(--spFontSize13);
        line-height: var(--spLineHeight13_26);
        letter-spacing: var(--spLetterSpacing13_50);
    }
}