@charset "UTF-8";

a{
    transition: .2s;
}

.news-text .date {
    letter-spacing: 1.4px;
    font-family: 'fHV';
}

.first-block{
    width: 100%;
    height: 100%;
    background: linear-gradient(180deg, #eef316, #22BBBB, #bc66ff);
    background-size: 200% 200%;
    animation: GradientBackground 10s ease infinite;
}

@keyframes GradientBackground {
    0% {
        background-position: 50% 0%;
    }

    50% {
        background-position: 50% 100%;
    }

    100% {
        background-position: 50% 0%;
    }
}

.mv{
    position: sticky;
    position: relative;
}

.mv-video-wrap{
    position: relative;
    display: block;
    width: 100%;
    height: auto;
    mask-image: url("../img/top/top_01.png");
    mask-repeat: no-repeat;
    mask-position: top right;
    mask-size: 100% 84dvh;
}

.mv-video{
    position: fixed;
    left: 0;
	width: 100%;
}

.mv-sound-wrap{
    position: absolute;
    top: 120px;
    right: 28px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    gap: 2px;
    cursor: pointer;
    z-index: 9;
}

.mv-sound{
    display: none;
}

.sound-on,
.mv-sound:checked + label .sound-off{
    display: block;
}

.sound-off,
.mv-sound:checked + label .sound-on{
    display: none;
}

.mv-sound img{
    width: 100%;
}

.mv-sound span{
    color: #fff;
}

.mv-note{
    position: absolute;
    bottom: 60px;
    left: 0;
    width: 100%;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding: 0 28px;
}

.mv-note-title{
    color: #fff;
}

.mv-note-title h1{
    opacity: .6;
    font-size: 120px;
    line-height: 1;
}

.mv-note-title span{
    font-family: "Roboto", sans-serif;
    display: inline-block;
    padding: 10px 10px 20px;
    font-size: 22px;
    letter-spacing: 1px;
}

.mv-note-bnr{
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 370px;
    margin-bottom: 4px;
    padding: 12px 10px;
    border: 1px solid #fff;
    backdrop-filter: blur(10px);
    border-radius: 10px;
    text-decoration: none;
    transition: .4s;
}

.mv-note-bnr + .follow{
	display: inline-block;
	width: 100%;
	padding-left: 20px;
	text-align: left;
	font-size: 12px;
	color: #fff;
}

.mv-note-bnr .text{
    padding-left: 10px;
    color: #fff;
    font-size: 20px;
    line-height: 1.6;
    text-align: center;
}

.mv-note-bnr .text span{
    display: block;
    font-size: 13px;
}

.mv-note-bnr .image{
    width: 154px;
    height: 100%;
    object-fit: cover;
    transition: .4s;
}

.mv-note-right{
    color: #fff;
}


.mv-note-copy{
    font-size: 46px;
    font-weight: bold;
}

.mv-note-copy span{
    display: block;
    font-size: 24px;
}

.mv-note-count{
    margin: 30px 26px 0 0;
    float: right;
}

.mv-note-text{
    font-size: 30px;
}

.mv-note-right .date-wrap{
    display: flex;
    align-items: flex-end;
    overflow: hidden;
}

.mv-note-right .date{
    display: flex;
    align-items: center;
    line-height: 1;
    font-size: 200px;
}

.mv-note-right .date li{
    position: relative;
}

.mv-note-right .date-wrap > span:nth-child(2){
    font-size: 80px;
}

.date li{
    width: 120px;
}

.count-first{
    display: inline-block;
    transition: 2s;
}

.count-second{
    display: inline-block;
    position: absolute;
    top: 0;
    left: 0;
    transform: translateY(-100%);
    width: 100%;
    height: 100%;
    transition: 1s;
}

.isCount .count-first{
    transform: translateY(400px);
}

.isCount li:nth-child(2) .count-first,
.isCount li:nth-child(2) .count-second{
    transition-delay: .3s;
}

.isCount li:nth-child(3) .count-first,
.isCount li:nth-child(3) .count-second{
    transition-delay: .6s;
}

.isCount .count-second{
    transform: translateY(0);
}

@media screen and (max-width: 900px) {
    .mv-note{
        padding: 0 10px;
    }
    .mv-note-count{
        margin: 0;
    }
    .date li{
        width: 100px;
    }
    .mv-note-right .date{
        font-size: 160px;
    }
}

@media screen and (max-width: 768px) {
	.mv-note-bnr + .follow{
		padding-left: 10px;
	}
    .mv-note{
        position: relative;
        margin-top: -160px;
        flex-direction: column-reverse;
        justify-content: flex-end;
        width: 100%;
        padding: 0 20px;
    }
    .mv-note-count{
        text-align: left;
        margin: 20px 0 0 0;
    }
    .mv-note-right{
        text-align: right;
    }
    .mv-note-copy {
        font-size: 20px;
    }
    .mv-note-copy span {
        font-size: 18px;
    }
    .mv-note-text {
        font-size: 14px;
    }
    .mv-video-wrap{
        width: 100%;
        height: 400px;
        mask-image: url("../img/top/top_01-sp.png");
        mask-size: 100%;
    }
    .mv-video{
        height: 400px;
        object-fit: cover;
    }
    .mv-note-bnr {

        width: 100%;
        justify-content: center;
    }
    .mv-note-right .date{
        font-size: 80px;
    }
    .mv-note-right .date-wrap > span:nth-child(2) {
        font-size: 30px;
    }
    .mv-note-bnr .image {
        width: 104px;
    }
    .mv-note-bnr .text{
        padding-left: 0;
        padding-right: 10px;
    }
    .mv-sound {
        top: 80px;
        right: 22px;
        width: 66px;
        height: 66px;
        border-radius: 9999px;
        background-color: rgba(0, 0, 0, .7);
    }
    .mv-note-left{
        margin-top: 20px;
        width: 100%;
    }
    .mv-sound-wrap{
        top: 370px;
        right: unset;
        left: 10px;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        width: 80px;
        height: 80px;
        gap: 2px;
        cursor: pointer;
    }
    .mv-sound-wrap.b2{
        top: 370px;
    }
    .mv-note-bnr .text{
        font-size: 16px;
    }
    .date li{
        width: 50px;
    }
    .ig-block{
        padding-top: 40px;
    }
    .ig{
        gap: 40px;
    }
    .ig-list {
        gap: 6px;
    }
    .ig-list li {
        width: calc((100% - 12px) / 3);
    }
}

@media screen and (max-width: 320px) {
    .mv-sound-wrap,.mv-sound-wrap.b2{
        top: 366px;
    }
    .mv-note-copy {
		font-size: 18px;
	}
}

.first-note{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 80px 0 60px;
    gap: 40px;
    color: #fff;
}

.first-icon{
    display: inline-block;
    width: 128px;
    height: 128px;
    background: url("../img/common/icon_concept01.svg") center/contain no-repeat;
    animation: fadeIn 8s step-start infinite;
}

@keyframes fadeIn {
    0% {
        background-image: url("../img/common/icon_concept01.svg");
    }
    33% {
        background-image: url("../img/common/icon_concept02.svg");
    }
    66% {
        background-image: url("../img/common/icon_concept03.svg");
    }
    100% {
        background-image: url("../img/common/icon_concept01.svg");
    }
  }


.first-title{
    display: flex;
    flex-direction: column;
    gap: 20px;
    align-items: center;
}

.first-title .en{
    font-size: 30px;
}

.first-title h2{
    font-size: 60px;
    letter-spacing: 2px;
    line-height: 1.2;
    font-weight: 500;
}

.first-text{
    font-size: 18px;
    line-height: 1.7;
}

.title h2{
    line-height: 1;
}

.concept{
    padding-top: 40px;
}

.concept-link{
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    width: 100%;
}

.concept-list-wrap{
    position: relative;
}

.concept-list{
    position: absolute;
    left: 50%;
    bottom: -150px;
    display: flex;
    width: 100%;
    max-width: 1360px;
    gap: 0 40px;
    z-index: 9;
    transform: translateX(-50%);
}

.concept-item a{
    display: flex;
    flex-direction: column;
    padding: 20px 30px 24px;
    gap: 16px 0;
    border-radius: 10px;
    background-color: rgba(0, 0, 0, 0.7);
    color: #fff;
    text-decoration: unset;
}

.concept-item .title{
    display: flex;
    flex-direction: column;
    gap: 8px 0;
}

.concept-item .image,.concept-item .image img{
    width: 100%;
    height: 150px;
    background-color: #fff;
}

.concept-item .image img{
    object-fit: cover;
}

.concept-item .title .en{
    font-size: 20px;
    font-weight: 500;
}

.concept-item .title .jp{
    font-size: 12px;
}

.concept-item .note{
    position: relative;
    font-size: 14px;
    padding-right: 20px;
    line-height: 1.8;
}

.concept-item .note::after{
    content: "";
    display: inline-block;
    position: absolute;
    right: 0;
    bottom: 0;
    width: 10px;
    height: 10px;
    background: url("../img/common/icon_link-arrow.svg") center/contain no-repeat;
    transition: .2s;
}

.concept-bk{
    margin-top: -120px;
    width: 100%;
    mask-image: url("../img/common/top_02.svg");
    mask-repeat: no-repeat;
    mask-position: top;
    mask-size: cover;
}

@media screen and (max-width: 768px) {
    .first-title h2{
        text-align: center;
        font-size: 40px;
    }
    .first-text{
        font-size: 16px;
    }
    .first-note{
        padding: 40px 20px;
    }
    .concept {
        padding-top: 0;
    }
    .concept-list-wrap{
        display: flex;
        flex-direction: column-reverse;
        background: linear-gradient(180deg, #22bbbb00 0%, #22BBBB 120px, #22BBBB 200px);
    }
    .concept-bk {
        margin-top: -60px;
        width: 100%;
        height: 400px;
        object-fit: cover;
    }
    .concept-list{
        margin-top: -60px;
        padding: 0 20px;
        display: flex;
        flex-direction: column;
        position: static;
        gap: 20px;
        z-index: 9;
        transform: unset;
    }
    .concept-item .title{
        display: flex;
        justify-content: center;
        width: calc(100% - 120px);
    }
    .concept-item .image, .concept-item .image img{
        width: 120px;
        height: 84px;
    }
    .concept-item a{
        flex-direction: row;
        flex-wrap: wrap;
    }
    .concept-item .title .en {
        font-size: 28px;
    }
}

@media screen and (max-width: 320px) {
    .first-title h2 {
		font-size: 38px;
	}
    .concept-item .title .en {
		font-size: 20px;
	}
    .concept-item a{
        padding: 20px 20px 24px;
    }
}


.pr-block{
    padding: 90px 0;
}

.pr,.news{
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    max-width: 1128px;
    margin: 0 auto;
    gap: 80px 0;
}

.pr-block{
    position: relative;
    padding-top: 270px;
    background: linear-gradient(180deg, #22BBBB 0%, #22BBBB 120px, #6F8EDD 200px);
}

.pr-block::before{
    content: "";
    position: absolute;
    top: 80px;
    right: 0;
    width: 100%;
    height: 180px;
    background: url("../img/common/top_03.svg") top right/cover no-repeat;
}

.pr .title,.news .title{
    text-align: center;
}

.pr .title{
    color: #fff;
}

.pr .title .en{
    font-size: 26px;
}

.pr .title h2{
    padding-top: 20px;
    font-size: 42px;
    font-weight: 400;
}

.pr-movie{
    width: 100%;
}

.pr-movie iframe{
    width: 100%;
    aspect-ratio: 16/9;
    border-radius: 10px;
}

@media screen and (max-width: 768px) {
    .pr,.news{
        gap: 40px 0;
    }
    
    .pr-block{
        position: relative;
        padding-top: 80px;
        background: linear-gradient(180deg, #22BBBB 0%, #6F8EDD 200px);
    }
    .pr-block::before{
        display: none;
    }
    .pr .title h2{
        padding-top: 20px;
        font-size: 28px;
        line-height: 1.4;
    }
}

.news{
    position: relative;
    padding-top: 36px;
}

.news-date{
    display: inline-block;
    width: 96px;
    font-size: 14px;
}

.news-tag{
    display: inline-block;
    width: auto;
    margin: 0 auto 0 0;
    padding: 4px 20px 6px;
    color: #fff;
    font-size: 12px;
    vertical-align: middle;
    background-color: #3BADFF;
    text-decoration: none;
}

.news-tag.important{
    background-color: #FF3D00;
}

.news-tag.column01{
    background-color: #0FB800;
}

.news-tag.press{
    background-color: #4557F7;
}

.news-report{
    display: flex;
    margin-top: 0;
    width: 100%;
    border-radius: 10px;
}

.news-block .links{
    display: flex;
    gap: 20px;
    align-items: center;
}

.news-report-text{
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 40px;
    width: calc(100% - 400px);
    background: linear-gradient(-45deg, #DDF675 50%, #91E4A2 100%);
    border-radius: 0 10px 10px 0;
}

.news-report-text .date{
    display: flex;
    align-items: center;
    gap: 0 10px;
}

.news-report-text .news-title{
    text-align: left;
    font-size: 20px;
    color: #000;
    cursor: pointer;
    text-decoration: none;
}

.news-report-text .link-blk{
    margin-left: auto;
    font-size: 14px;
    width: 170px;
    height: 46px;
}

.news-list{
    display: flex;
    margin-top: 20px;
    width: 100%;
    gap: 0 20px;
}

.news-list li{
    display: flex;
    flex-grow: 1;
    width: calc((100% - 80px) / 5);
}

.news-link{
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 196px;
    border-radius: 10px;
    text-decoration: none;
    gap: 20px 10px;
    padding: 20px;
    background: linear-gradient(-45deg, #A8F5FF 20%, #9DFE8B 100%);
}

.press .news-link{
    background: linear-gradient(-45deg, #EDC5FF 20%, #8AFBD5 100%);
}

.news-list .news-text{
    display: flex;
    flex-direction: column;
    color: #222;
}

.news-text .date{
    font-size: 13px;
}

.news-text .news-title{
    padding-top: 6px;
    font-size: 14px;
    text-align: left;
}

.news-report-thum{
    width: 400px;
    height: 300px;
}

.news-report-thum img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 10px 0 0 10px;
}

.news-block{
    padding: 80px 0;
}

.news .title h2{
    font-size: 44px;
    font-weight: bold;
}

.important-list{
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: 100%;
}

.important-link{
    display: flex;
    align-items: center;
    text-decoration: none;
    gap: 0 22px;
    color: #222;
}

.important-link .news-tag{
    display: flex;
    justify-content: center;
    align-items: center;
    width: 122px;
    height: 30px;
    margin: 0;
    padding: 0;
}

.important-link .news-title{
    width: calc(100% - 262px);
}

.event-block{
    position: relative;
    padding: 80px 0 240px;
    background-color: #F2F2F2;
}

.event{
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    gap: 80px;
    width: 100%;
    max-width: 750px;
    z-index: 1;
}

.event .title{
    text-align: center;
}

.event .title .en{
    font-size: 26px;
}

.event .title h2{
    padding-top: 20px;
    font-size: 42px;
    font-weight: 400;
}

.event-list{
    display: flex;
    flex-direction: column;
    gap: 20px 0;
}

.event-link{
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    text-decoration: none;
    gap: 0 20px;
    color: #222;
}

.event-block .bottom-grd{
    position: absolute;
    bottom: 0;
    width: 100%;
    z-index: -1;
}

/*.end-block{
    background: linear-gradient(0, #22BBBB 20%, #C8CA44 100%);
}*/

.event-link .news-date{
    line-height: 1.8;
}

.event-link .news-text{
    width: calc(100% - 118px);
}

@media screen and (max-width: 768px) {
    .important-link,
    .news-list,
    .news-report{
        flex-direction: column;
    }
    .news-report-thum {
        width: 100%;
        height: auto;
        aspect-ratio: 4 / 3;
    }
    .news {
        padding-top: 0;
    }
    .news .title h2 {
        font-size: 32px;
    }
    .important-list{
        padding: 0 20px;
    }
    .important-link{
        flex-direction: row;
        justify-content: flex-start;
        flex-wrap: wrap;
        gap: 8px 12px;
    }
    .important-link .news-tag{
        order: 1;
    }
    .important-link .news-date{
        order: 2;
        width: calc(100% - 134px);
    }
    .important-link .news-title{
        order: 3;
        width: 100%;
    }
    .news-report{
        margin-top: 40px;
    }
    .news-report-thum img{
        border-radius: 0;
    }
    .news-report-text{
        width: 100%;
        padding: 40px 20px;
        gap: 12px;
    }
    .news-report-text .link-blk{
        margin: 0 auto;
        width: 280px;
        justify-content: space-between;
        padding: 0 20px;
    }
    .news-block .links{
        flex-direction: column;
    }
    .news-list{
        flex-direction: row;
        flex-wrap: wrap;
        padding: 0 20px;
        gap: 20px;
    }
    .news-list li{
        width: calc(50% - 10px);
    }
    .news-list li:first-child{
        width: 100%;
    }
    .news-link{
        min-height: 136px;
        height: auto;
        gap: 10px;
    }
    .news-tag {
        padding: 4px 10px 6px;
    }
    .event-block{
        padding: 80px 0 100px;
    }
    .event .title h2 {
        font-size: 40px;
    }
    .event-list{
        mask-size: 100%;
        padding: 0 20px;
    }
    .event-link {
        flex-direction: column;
    }
}

.ig-block{
    background-color: #22BBBB;
}

.ig{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    padding: 0 0 80px;
    gap: 80px;
    width: 100%;
    max-width: 750px;
}

.ig  .title{
    text-align: center;
}

.ig .title-icon{
    width: 82px;
    height: 82px;
}

.ig h2{
    padding-top: 18px;
    color: #fff;
    font-size: 18px;
}

.ig-list{
    display: flex;
    width: 100%;
    gap: 10px;
}

.ig-list li{
    display: flex;
    width: calc((100% - 20px) / 3);
    gap: 10px;
}

.ig-list a{
    width: 100%;
    aspect-ratio: 1;
}

.ig_media{
    width: 100%;
    height: 100%;
    object-fit: cover;
}

@keyframes fadeIn2 {
    0% {
        background-image: url("../img/common/icon_concept01-2.svg");
    }
    25% {
        background-image: url("../img/common/icon_concept02-2.svg");
    }
    50% {
        background-image: url("../img/common/icon_concept03-2.svg");
    }
    75% {
        background-image: url("../img/common/icon_concept04-2.svg");
    }
    100% {
        background-image: url("../img/common/icon_concept01-2.svg");
    }
}

.top-none{
    display: none;
}

.mv-note-left{
    display: flex;
	flex-direction: column;
    align-items: center;
    gap: 0;
	padding-bottom: 10px;
}

.nankai-bnr-top{
    position: absolute;
    top: 0;
    right: 0;
    display: flex;
	flex-direction: column;
	align-items: center;
	width: 340px;
	gap: 80px 0;
    backdrop-filter: blur(10px);
}

.nankai-bnr-top a{
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding: 10px 40px 14px;
    text-align: center;
    background: linear-gradient(-45deg, rgba(251, 219, 204, .96) 0%, rgba(255, 241, 204, .96) 100%);
    border: 1px solid #fff;
	border-radius: 10px;
}

.nankai-bnr-top img:not(.icon){
    width: 100%;
}

@media screen and (max-width: 1000px) {
    .nankai-bnr-top{
        width: 300px;
    } 
}

@media screen and (max-width: 768px) {
    .nankai-bnr-top{
        position: static;
        margin: 30px auto 0;
        padding: 0 20px;
        width: auto;
    }
    .nankai-bnr-top a{
        height: 99px;
        padding: 0 20px;
    }
    .nankai-bnr-top img{
        height: 75px;
        width: auto;
    }
    .nankai-bnr-top .icon{
        height: 12px;
        top: 52%;
        right: 10px;
    }
    .mv-note-left{
        flex-direction: column;
    }
}

@media (hover: hover) {
    .nankai-bnr-top a:hover{
        opacity: 1;
        transform: translate(2px,1px);
    }
    .news-report-text .news-title:hover{
        text-decoration: underline;
    }
    .mv-note-bnr:hover{
        background-color: rgba(255, 255, 255, .2);
    }
    .mv-note-bnr:hover .image{
        transform: scale(.98);
    }
    .concept-item a:hover .note::after{
        right: -2px;
        bottom: -2px;
    }
}

.important-link[target="_blank"] .news-title::after,
.event-link[target="_blank"] .news-title::after,
.news-link[target="_blank"] .news-title::after{
    content: "";
    display: inline-block;
    margin-left: 4px;
    width: 14px;
    height: 13px;
    background: url("/relocation/img/common/icon_window-re.svg") no-repeat center / contain;
}

@media screen and (max-width: 768px) {
    .important-link[target="_blank"] .news-title::after,
    .event-link[target="_blank"] .news-title::after,
    .news-link[target="_blank"] .news-title::after{
        margin-left: 2px;
    }
}

.bnr_new_checkin{
	display: inline-block;
	width: 100%;
	margin: 0 auto 20px;
	border-radius: 10px;
	overflow: hidden;
}

.bnr_new_checkin img{
	width: 100%;
}