@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200..900&display=swap');
@import url('https://cdn.jsdelivr.net/npm/yakuhanjp@4.1.1/dist/css/yakuhanmp.css');

/* ============================================
汎用
============================================ */

#main{
    background: #fff;
    overflow: unset;
}

#main .cSection02__head{
    width: 90%;
    max-width: 1280px;
    margin: 0 auto;
}
#main .cSection02__title .en {
    font-family: 'Inter Tight', sans-serif;
    font-weight: 900;
    font-size: clamp(18px, 17.296px + 0.188vw, 20px);
    line-height: 150%;
}
#main .cSection02__title .ja {
    display: block;
    text-indent: -9999px;
}



/* ============================================
タイトル部分
============================================ */

#main.ataglance .cPagetitle__catchcopy{
    height: 154px;
    width: auto;
}
#main.ataglance .cPagetitle__catchcopy img{
    height: 100%;
    width: auto;
}
#main .cPageMv__inner {
    padding: 0 20px 5%;
}
#main .cPageMv__title span{
    font-weight: 900;
    font-size: 48px;
    line-height: 100%;
    letter-spacing: 0;
    text-align: right;
}



/* ============================================
ページ本文
============================================ */


#main .aPurpose{
    margin: 68px  0 0;
    padding: 0 0 clamp(80px, 57.465px + 6.009vw, 144px);;
}
#main .aPurpose .cSection02__title .ja {
    height: 134px;
    aspect-ratio: 554 / 134;
    background: url(/recruit/ataglance/images/rn02/ataglance_title02.svg) left center / contain no-repeat;
}
.aPurposeWrap{
    margin: clamp(40px, 25.915px + 3.756vw, 80px) 0 0;
    aspect-ratio: 1440 / 1456;
    width: 100%;
    max-height: 1456px;
    background: url(/recruit/ataglance/images/rn02/ataglance_img02.webp) center / cover no-repeat;
    font-family: "Noto Serif JP", serif;
    color: #fff;
    text-align: center;
    padding: clamp(128px, 102.648px + 6.761vw, 200px) 3%;
}
#main .aPurposeWrap h3{
    font-size: clamp(36px, 26.141px + 2.629vw, 64px);
    font-weight: 600;
    line-height: 140%;
    font-family: YakuHanMP, "Noto Serif JP", "Hiragino Mincho ProN", "Yu Mincho", YuMincho, serif;
    text-align: center;
    color: inherit;
}
#main .aPurposeWrap h3 + p{
    margin: 44px 0 0;
    font-weight: 700;
    font-size: clamp(16px, 14.592px + 0.376vw, 20px);
    line-height: 220%;
    font-family: YakuHanMP, "Noto Serif JP", "Hiragino Mincho ProN", "Yu Mincho", YuMincho, serif;
}
#main .aPurposeLink{
    margin: clamp(64px, 58.366px + 1.502vw, 80px) 0 0;
}
#main .aPurposeLink .cLinkBtn_text{
    font-family: 'Noto Sans JP', sans-serif;
    text-align: left;
}
.aPurposeCont{
    max-width: 1280px;
    width: 90%;
    margin:clamp(64px, 41.465px + 6.009vw, 128px) auto 0;
    display: flex;
    flex-wrap: wrap;
    gap: 12px 24px;
}
.aPurposeContItem{
    display: block;
    width: calc((100% - 24px) / 2);
    aspect-ratio: 628 / 418;
    overflow: hidden;
    border-radius: 8px;
    position: relative;
}
.aPurposeContImage{
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}
.aPurposeContImage picture,
#main .aPurposeContImage img{
    display: block;
    width: 100%;
    height: 100%;
}
#main .aPurposeContImage img{
    object-fit: cover;
}
.aPurposeContImage:after{
    content: "";
    position: absolute;
    z-index: 2;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}
.aPurposeContItem:nth-of-type(1) .aPurposeContImage:after{
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.25) 41.83%, rgba(0, 0, 0, 0.5) 100%);
}
.aPurposeContItem:nth-of-type(2) .aPurposeContImage:after{
    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.125) 65.87%, rgba(0, 0, 0, 0.25) 100%);
}
#main .aPurposeContText{
    position: absolute;
    z-index: 2;
    color: #fff;
    left:clamp(16px, 10.366px + 1.502vw, 32px);
    right: clamp(72px, 46.648px + 6.761vw, 144px);
    bottom:clamp(16px, 10.366px + 1.502vw, 32px);
    font-family: 'Noto Sans JP', sans-serif;
}
#main .aPurposeContText h4{
    font-weight: 700;
    font-size: clamp(20px, 15.775px + 1.127vw, 32px);
    line-height: 135%;
    letter-spacing: 0.03em;
    font-feature-settings: 'palt' on;
    color: #fff;
}
#main .aPurposeContText p{
    margin: 16px 0 0;
    font-weight: 500;
    font-size: clamp(14px, 13.296px + 0.188vw, 16px);
    line-height: 180%;
    letter-spacing: 0.03em;
    font-feature-settings: 'palt' on;
    text-align: justify;
}
#main .aPurposeContArrow{
    position: absolute;
    z-index: 3;
    bottom: clamp(16px, 10.366px + 1.502vw, 32px);
    right: clamp(16px, 10.366px + 1.502vw, 32px);
    width: clamp(24px, 15.549px + 2.254vw, 48px);
    height: clamp(33px, 21.028px + 3.192vw, 67px);
}
#main .aPurposeContItem:hover .aPurposeContArrow{
}

#main .aHistory{
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    aspect-ratio: 1440 / 720;
    background: url(/recruit/ataglance/images/rn02/ataglance_img05.webp) center / cover no-repeat;
    position: relative;
}
#main .aHistory .cSection02__title .en{
    position: absolute;
    left: clamp(24px, 4.282px + 5.258vw, 80px);
    top: 64px;
    font-family: 'Inter Tight';
    font-weight: 900;
    font-size: 24px;
    line-height: 150%;
    letter-spacing: 0;
}
#main .aHistory .cSection02__title .ja{
    height: 134px;
    aspect-ratio: 445 / 134;
    background: url(/recruit/ataglance/images/rn02/ataglance_title03.svg) left center / contain no-repeat;
    bottom: 106px;
    left: clamp(24px, 4.282px + 5.258vw, 80px);
    position: absolute;
    z-index: 2;
    width: calc(445 / 1440 * 100vw);
}
.aHistoryText{
    color: #fff;
    position: absolute;
    right: clamp(40px, -5.714px + 5.952vw, 80px);
    bottom: 80px;
    z-index: 2;
}
#main .aHistoryText > p{
    font-weight: 500;
    font-size: clamp(16px, 15.296px + 0.188vw, 18px);
    line-height: 180%;
    letter-spacing: 0.03em;
    font-feature-settings: 'palt' on;
    max-width: 510px;
}
.aHistoryLink{
    display: flex;
    align-items: center;
    margin: 32px 0 0;
}
.aHistoryLink__link-icon {
    display: inline-block;
    width: 32px;
    border-radius: 50%;
    height: 32px;
    background-image: url(/recruit/common/images/rn02/icon_arrow-red.svg);
    background-size: 10px 10px;
    background-position: 50% 50%;
    background-repeat: no-repeat;
    background-color: #fff;
}
#main .aHistoryLink__text {
    display: inline-block;
    font-size: clamp(14px, 13.296px + 0.188vw, 16px);
    letter-spacing: 0.03em;
    font-feature-settings: 'palt' on;
    line-height: 140%;
    font-weight: 600;
    margin-left: 10px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);
    color: #fff;
}
.aHistoryArrow{
    position: absolute;
    bottom: 0;
    left: 0;
    width: 35%;
    z-index: 1;
}

#main .aBusiness{
    padding: clamp(80px, 57.465px + 6.009vw, 144px) 0 0;
}
#main .aBusiness .cSection02__title .ja{
    height: 67px;
    aspect-ratio: 557 / 67;
    background: url(/recruit/ataglance/images/rn02/ataglance_title04.svg) left center / contain no-repeat;
}
#main .aBusinessWrap{
    width: 90%;
    margin: clamp(24px, 15.549px + 2.254vw, 48px) auto 0;
    max-width: 1280px;
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
}
#main .aBusinessItem{
    width: calc(50% - 20px);
}
#main .aBusinessItemImg{
    display: block;
    width: 100%;
    overflow: hidden;
    border-radius: 4px;
    aspect-ratio: 1.7765;
}
#main .aBusinessItemImg img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
#main .aBusinessItemTitle{
    display: block;
    width: 100%;
    position: relative;
    font-weight: 700;
    font-size: clamp(20px, 15.775px + 1.127vw, 32px);
    line-height: 135%;
    letter-spacing: 0.03em;
    font-feature-settings: 'palt' on;
    padding: clamp(12px, 7.775px + 1.127vw, 24px) 0;
}
#main .aBusinessItemTitleArrow{
    display: block;
    width: 24px;
    height: 34px;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}
#main .aBusinessItemTitleArrow svg{
    width: 100%;
    height: 100%;
}
#main .aBusinessItemText{
    font-weight: 500;
    font-size: clamp(14px, 13.296px + 0.188vw, 16px);;
    line-height: 180%;
    letter-spacing: 0.03em;
    font-feature-settings: 'palt' on;
    text-align: justify;
}

.aGroup{
    padding: clamp(80px, 37.746px + 11.268vw, 200px) 0 clamp(72px, 46.648px + 6.761vw, 144px);;
}
.aGroupWrap{
    width: 100%;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
}
.aGroupLeft{
    width: calc(51.3888% - 40px)
}
.aGroupRight{
    width: 48.6111%;
}
#main .aGroupRight img{
    width: 100%;
    min-height: 736px;
    max-height: 854px;
    max-width: 693px;
    object-fit: cover;
}
.aGroupList{
    margin: clamp(48px, 38.845px + 2.441vw, 74px) 0 0;
    max-width: 510px;
}
.aGroupListItem{
    display: flex;
    align-items: center;
    width: 100%;
    gap: 24px;
    padding: 0 0 clamp(20px, 12.958px + 1.878vw, 40px);
    border-bottom: 1px solid rgba(0,0,0,0.3);
}
.aGroupListItem + .aGroupListItem{
    margin: clamp(20px, 12.958px + 1.878vw, 40px) 0 0;
}
.aGroupListItem .icon{
    width: 120px;
}
.aGroupListItem .text{
    width: calc(100% - 144px);
    position: relative;
    font-weight: 700;
    font-size: clamp(18px, 15.887px + 0.563vw, 24px);
    line-height: 140%;
    letter-spacing: 0.03em;
    font-feature-settings: 'palt' on;
}
.aGroupListItem .text .aGroupListIcon{
    display: block;
    width: clamp(24px, 21.183px + 0.751vw, 32px);
    height: clamp(24px, 21.183px + 0.751vw, 32px);
    border-radius: 50%;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}
#main .aGroup .cSection02__head{
    width: 100%;
}
#main .aGroup .cSection02__title .ja{
    width:90%;
    max-width: 498px;
    height: auto;
    aspect-ratio: 498 / 134;
    background: url(/recruit/ataglance/images/rn02/ataglance_title05.svg) left center / contain no-repeat;
}
