@charset "utf-8";

/* ===== top.css ===== */
/* -- top_mv -- */
#top_mv {
    position: relative;
    margin: 52px auto 0;
    padding: 0 20px;
    max-width: 1298px;
}
#top_mv > * {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}
#top_mv .txtCnt {
    font-weight: bold;
    line-height: 1;
    color: #FFF;
    padding-bottom: 56px;
    width: 49%;
}
#top_mv .txtCnt .subTit {
    font-size: 40px;
    margin-bottom: 16px;
}
#top_mv .txtCnt h1 {
    font-size: 120px;
    letter-spacing: -.07em;
}
#top_mv .txtCnt h1 span {
    display: block;
}
#top_mv .imgCnt {
    cursor: pointer;
    position: relative;
    margin-right: 5.2%;
    padding: 0 30px 30px 0;
    width: 42.2%;
}
#top_mv .imgCnt .img {
    position: relative;
    width: 100%;
    padding-top: 100%;
    background: #FFF;
    border-radius: 40px;
}
#top_mv .imgCnt .img > * {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
}
#top_mv .imgCnt .img::before {
    position: absolute;
    top: 30px;
    bottom: -30px;
    right: -30px;
    left: 30px;
    margin: auto;
    background: #0058FF;
    border-radius: 40px;
    content: "";
    z-index: -10;
}
#top_mv .imgCnt .img::after {
    position: absolute;
    bottom: 5.8%;
    right: 6.6%;
    width: 37px;
    height: 37px;
    background: url(../img/top/top_mv_imgCnt_img_arrow.png) no-repeat 0 0 / 100% auto;
    content: "";
}
#top_mv .imgCnt .img img {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    width: auto;
    height: 64%;
    transform: translate(-50%,-50%);
}
#top_mv .imgCnt .btn {
    position: absolute;
    top: 50%;
    right: -9px;
    margin-top: -15px;
    transform: translateY(-50%);
} 
#top_mv .imgCnt .btn a {
    text-align: center;
    text-decoration: none;
    font-size: 14px;
    font-weight: bold;
    line-height: 1;
    color: #115680;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 2px 0 0;
    width: 80px;
    height: 80px;
    background: #E2FF00;
    border: 1px solid #E2FF00;
    border-radius: 50%;
    transition: color .6s, background .6s;
}
@media screen and ( min-width: 901px ) {
    /* hover */
    #top_mv .imgCnt .btn a:hover {
        color: #E2FF00;
        background: #115680;
        opacity: 1;
    }
}
@media screen and ( max-width: 900px ) {
    #top_mv {
        margin: 67px 10px 0;
        padding: 0;
    }
    #top_mv > * {
        display: block;
    }
    #top_mv .txtCnt {
        padding: 0 12px 39px;
        width: 100%;
    }
    #top_mv .txtCnt .subTit {
        font-size: 20px;
        margin-bottom: 24px;
    }
    #top_mv .txtCnt h1 {
        font-size: 69px;
    }
    #top_mv .imgCnt {
        margin-right: 0;
        padding: 0 20px 20px 0;
        width: 100%;
    }
    #top_mv .imgCnt .img {
        border-radius: 25px;
    }
    #top_mv .imgCnt .img::before {
        top: 20px;
        bottom: -20px;
        right: -20px;
        left: 20px;
        border-radius: 25px;
    }
    #top_mv .imgCnt .img::after {
        bottom: 6%;
        right: 6%;
    }
    #top_mv .imgCnt .img img {
        height: 51.7%;
    }
    #top_mv .imgCnt .btn {
        right: -1px;
        margin-top: -10px;
    }
    #top_mv .imgCnt .btn a {
        padding: 4px 0 0;
    }
}

/* -- top_linkList -- */
#top_linkList {
    font-weight: bold;
    line-height: 1;
    display: flex;
    flex-wrap: wrap;
    margin: 156px 30px 0;
}
#top_linkList > * {
    border-radius: 20px;
}
#top_linkList > * > * {
    text-decoration: none;
    color: #FFF;
    display: block;
    padding: 31px 40px 29px;
}
#top_linkList .subTit {
    text-align: right;
    font-size: 20px;
    letter-spacing: -.07em;
    transition: opacity .6s;
}
#top_linkList .tit {
    font-size: 60px;
    letter-spacing: -.07em;
    margin-top: 53px;
    transition: opacity .6s;
}
#top_linkList .subTxt {
    font-size: 30px;
    letter-spacing: -.07em;
    margin-top: 13px;
    transition: opacity .6s;
}
#top_linkList .img {
    text-align: center;
    margin-top: 36px;
    transition: opacity .6s;
}
#top_linkList .icon {
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: -10px -10px 0 auto;
    width: 80px;
    height: 80px;
    background: #E2FF00;
    border: 1px solid #E2FF00;
    border-radius: 50%;
    transition: background .6s;
}
#top_linkList .icon svg {
    width: 23px;
    fill: #115680;
    transition: fill .6s;
}
/* - about - */
#top_linkList .about {
    background: #4297CB;
}
#top_linkList .about .tit {
    font-size: 30px;
    letter-spacing: -.07em;
    margin-top: 50px;
}
#top_linkList .about .txt {
    font-size: 16px;
    line-height: 1.5;
    margin-top: 92px;
}
/* - nugget_profiler - */
#top_linkList .nugget_profiler {
    background: #42B6CB;
}
/* - seam_seeker - */
#top_linkList .seam_seeker {
    background: #42CB87;
}
@media screen and ( min-width: 901px ) {
    #top_linkList  > * {
        width: calc((100% - 60px) / 3);
    }
    #top_linkList  > *:not(:nth-child(3n)) {
        margin-right: 30px;
    }
    /* hover */
    #top_linkList > * > a:hover {
        opacity: 1;
    }
    #top_linkList a:hover .subTit,
    #top_linkList a:hover .tit,
    #top_linkList a:hover .subTxt,
    #top_linkList a:hover .img {
        opacity: .7;
    }
    #top_linkList a:hover .icon {
        background: #115680;
    }
    #top_linkList a:hover .icon svg {
        fill: #E2FF00;
    }
}
@media screen and ( max-width: 900px ) {
    #top_linkList {
        display: block;
        margin: 34px 10px 0;
    }
    #top_linkList > :not(:last-child) {
        margin-bottom: 20px;
    }
    #top_linkList > * > * {
        padding: 31px 31px 57px;
    }
    #top_linkList .subTit {
        font-size: 18px;
    }
    #top_linkList .tit {
        font-size: 40px;
        margin-top: 13px;
    }
    #top_linkList .subTxt {
        font-size: 24px;
        margin-top: 17px;
    }
    #top_linkList .img {
        margin: 31px auto 0;
        padding-right: 12px;
    }
    #top_linkList .img img {
        width: auto;
        max-height: 170px;
    }
    #top_linkList .icon {
        margin: -20px -1px -27px auto;
        width: 50px;
        height: 50px;
    }
    /* - about - */
    #top_linkList .about .tit {
        font-size: 24px;
        margin-top: 12px;
    }
    #top_linkList .about .txt {
        font-size: 14px;
        margin-top: 71px;
    }
    /* - seam_seeker - */
    #top_linkList .seam_seeker > * {
        padding-left: 41px;
    }
    #top_linkList .seam_seeker .img {
        margin-top: 55px;
        padding-right: 20px;
    }
}

/* -- top_info -- */
#top_info {
    display: flex;
    flex-wrap: wrap;
    margin: 31px 30px 30px;
    padding-bottom: 47px;
    border: 1px solid #FFF;
    border-radius: 20px;
}
#top_info > .tit {
    text-align: left;
    font-weight: bold;
    font-size: 20px;
    line-height: 1;
    letter-spacing: -.07em;
    color: #FFF;
    margin-top: 47px;
    padding: 0 48px;
    width: 16.65%;
}
#top_info > .cnt {
    display: flex;
    flex-wrap: wrap;
    margin-top: 49px;
    width: 72.05%;
    border-left: 1px solid rgba(255, 255, 255, .3);
}
#top_info > .cnt > * {
    padding: 0 3.116%;
    width: calc(100% / 3);
    border-right: 1px solid rgba(255, 255, 255, .3);
}
#top_info > .cnt > * > a {
    text-decoration: none;
}
#top_info > .cnt > * > a > * > .img {
    position: relative;
    overflow: hidden;
    padding-top: 66.54%;
    border-radius: 20px;
}
#top_info > .cnt > * > a > * > .img img {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    max-width: none;
    height: 100%;
    object-fit: cover;
    transform: translate(-50%,-50%);
}
#top_info > .cnt > * > a > * > .blogBox_catecory {
    color: #FFF;
    margin-top: 18px;
}
#top_info > .cnt > * > a > * > .blogBox_catecory li:not(:last-child) {
    margin-right: 16px;
}
#top_info > .cnt > * > a > * > .tit {
    font-weight: bold;
    color: #FFF;
    margin-top: 9px;
}
#top_info > .cnt > * > a > * > .blogBox_day {
    font-size: 12px;
    color: #7EAFCE;
    margin: 14px 0 -6px;
}
#top_info > .more {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    padding: 3.5% 4.2% 0;
    width: 11.3%;
}
#top_info > .more a {
    font-size: 12px;
    font-weight: bold;
    color: #FFF;
    text-decoration: none;
}
@media screen and ( max-width: 900px ) {
    #top_info {
        display: block;
        margin: 20px 10px 20px;
        padding: 47px 0 36px;
    }
    #top_info > .tit {
        margin-top: 0;
        padding: 0 38px;
        width: 100%;
    }
    #top_info > .cnt {
        display: block;
        margin-top: 30px;
        padding: 0 39px;
        width: 100%;
        border-top: 1px solid rgba(255, 255, 255, .3);
        border-left: none;
    }
    #top_info > .cnt > * {
        padding: 40px 0 42px;
        width: 100%;
        border-bottom: 1px solid rgba(255, 255, 255, .3);
        border-right: none;
    }
    #top_info > .cnt > * > a {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }
    #top_info > .cnt > * > a > *:nth-child(1) {
        width: 47.273%;
    }
    #top_info > .cnt > * > a > *:nth-child(2) {
        width: 45.46%;
    }
    #top_info > .cnt > * > a > * > .img {
        padding-top: 77%;
        border-radius: 10px;
    }
    #top_info > .cnt > * > a > * > .blogBox_catecory {
        display: block;
    }
    #top_info > .cnt > * > a > * > .blogBox_catecory li:not(:last-child) {
        margin-right: 0;
    }
    #top_info > .cnt > * > a > * > .tit {
        font-size: 16px;
        margin-top: -3px;
    }
    #top_info > .cnt > * > a > * > .blogBox_day {
        margin: 9px 0 0;
    }
    #top_info > .more {
        text-align: center;
        display: block;
        padding: 36px 0 0;
        width: 100%;
    }
}


/*
    js
*/
/* -- ロードアニメーション -- */
#top_mv .txtCnt .subTit,
#top_mv .txtCnt h1,
#top_mv .imgCnt {
    opacity: 0;
    transform: translateY(50px); 
    transition: opacity 0.6s, transform 0.6s;
}
header {
    opacity: 0;
    transition: opacity 0.6s;
}
#top_mv .txtCnt .subTit.on,
#top_mv .txtCnt h1.on,
#top_mv .imgCnt.on,
header.on {
    transform: translateY(0); 
    opacity: 1;
}

/* -- クリックで要素の切り替え -- */
/* txtCnt */
#top_mv .txtCnt .subTit,
#top_mv .txtCnt h1 {
    position: relative;
}
#top_mv .txtCnt .subTit > * {
    transition: opacity .6s, transform .6s;
}
#top_mv .txtCnt h1 > * {
    transition: opacity .6s .1s, transform .6s .1s;
}
#top_mv .txtCnt .subTit > :nth-child(2),
#top_mv .txtCnt h1 > :nth-child(2) {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    margin: 0 auto;
    opacity: 0;
    z-index: -10;
    transform: translateY(-50px);
}
/* imgCnt */
#top_mv .imgCnt .img img {
    transition: margin .6s .2s, opacity .6s .2s;
}
#top_mv .imgCnt .img > :nth-child(2) img {
    margin-top: -50px;
    opacity: 0;
}
#top_mv .imgCnt .btn > :nth-child(2) {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -10;
}
/* - open - */
/* txtCnt */
#top_mv.open .txtCnt .subTit > :nth-child(1),
#top_mv.open .txtCnt h1 > :nth-child(1) {
    opacity: 0;
    transform: translateY(-50px);
}
#top_mv.open .txtCnt .subTit > :nth-child(2),
#top_mv.open .txtCnt h1 > :nth-child(2) {
    opacity: 1;
    z-index: 10;
    transform: translateY(0);
}
/* imgCnt */
#top_mv.open .imgCnt .img > :nth-child(1) img {
    margin-top: -50px;
    opacity: 0;
}
#top_mv.open .imgCnt .img > :nth-child(2) img {
    margin-top: 0;
    opacity: 1;
}
#top_mv.open .imgCnt .btn > :nth-child(2) {
    z-index: 10;
}