@charset "UTF-8";

.fc-white{
    color: #fff;
}

.nav-bread{
    padding: 32px 40px;
}

.nav-bread ol{
    display: flex;
}

.nav-bread li{
    font-size: 14px;
    display: flex;
    align-items: center;
}

.nav-bread a{
    color: #222;
}

.nav-bread li:not(:first-child)::before{
    content: "/";
    padding: 0 20px;
    color: #D3D3D3;
}

.link-btn-wrap{
    margin-top: 40px;
    display: flex;
    align-items: center;
    gap: 20px
}

.link-btn-wrap.center{
    justify-content: center;
}

.link-btn-wrap.right{
    justify-content: flex-end;
}

.link-btn,
.ancher-btn{
    display: flex;
    justify-content: center;
    align-items: center;
    border: 2px solid #22BBBB;
    width: 212px;
    height: 48px;
    border-radius: 9999px;
    padding: 0 32px;
    text-decoration: none;
    gap: 4px;
    color: #22BBBB;
    transition: .4s;
}

.link-btn::after{
    content: "";
    display: inline-block;
    margin-top: 4px;
    width: 16px;
    height: 16px;
    background: url("../img/common/icon_btn01.svg") no-repeat;
    transition: .4s;
}

.link-btn.-blue{
    color: #317AA4;
    border-color: #317AA4;
}

.link-btn.-white{
    background-color: #fff;
}

.link-btn.-blue::after{
    background-image: url("../img/common/icon_btn01blue.svg");
}

.link-text{
    display: inline;
    text-decoration: underline;
    color: #317AA4;
}

.access-ancher{
    width: 100%;
}

.ancher-btn{
    position: relative;
    width: calc(100% / 3);
    max-width: 360px;
    height: 68px;
    justify-content: space-between;
    padding: 0 24px 0 44px;
    font-size: 16px;
}

.ancher-btn::before,
.ancher-btn::after{
    content: "";
    display: inline-block;
    width: 16px;
    height: 16px;
}

.ancher-btn::before{
    position: absolute;
    top: 50%;
    left: 20px;
    transform: translateY(-50%);
}

.walk.ancher-btn::before{
    background: url("../img/common/icon_walk.svg") no-repeat center / contain;
}

.train.ancher-btn::before{
    background: url("../img/common/icon_train.svg") no-repeat center / contain;
}

.car.ancher-btn::before{
    background: url("../img/common/icon_car.svg") no-repeat center / contain;
}

.ancher-btn::after{
    margin-top: 4px;
    background: url("../img/common/icon_anker.svg") no-repeat center / contain;
}

@media screen and (max-width: 768px) {
    .nav-bread{
        padding: 5px 20px;
        margin-bottom: 20px;
    }
    
    .nav-bread ol{
        overflow-x: scroll;
        word-break: keep-all;
        white-space: nowrap;
        padding: 10px 0;
    }

    .access-ancher{
        margin-top: 0;
        flex-direction: column;
        padding: 0 20px;
    }

    .ancher-btn{
        width: 100%;
        max-width: 360px;
        height: 68px;
        justify-content: space-between;
        padding: 0 24px 0 44px;
        font-size: 16px;
    }
}

@media (hover: hover) {
    .pers-sort .pers-icon:hover{
        opacity: .9;
    }
    .link-btn:hover{
        background-color: #22BBBB;
        color: #fff;
    }
    .link-btn.-blue:hover{
        background-color: #317AA4;
    }
    .link-btn:hover::after{
        background-image: url("../img/common/icon_btn01white.svg");
    }
    .access .info-ex .link-btn:hover{
        background-color: #22BBBB;
    }
    .access .info-ex .link-btn:hover::after{
        margin-top: 2px;
        background: url(../img/common/icon_window-w.svg) center / contain no-repeat;
    }
    .map-wrap a:hover img{
        transform: scale(1.02);
    }
}


.mv{
    position: relative;
    display: flex;
}

.mv-note,.mv-title{
    display: flex;
    flex-direction: column;
}


.mv-image{
    transition: .4s;
}

@media screen and (min-width: 769px) {
    .mv{
        position: relative;
        height: 700px;
    }
    .mv.wide,
    .wide .mv-image{
        height: 460px;
    }
    .mv-note {
        position: relative;
        width: 100%;
        padding: 40px;
        background-color: #fff;
    }
    .mv-title,.mv-text{
        position: relative;
        z-index: 3;
    }
    .mv-title span{
        font-size: 24px;
    }
    .mv-title h1{
        margin-top: 20px;
        font-size: 120px;
    }
    .mv-text{
        margin-top: 60px;
        font-size: 16px;
        width: 100%;
        max-width: 460px;
        line-height: 1.8;
    }
    .mv-image{
        position: absolute;
        top: 0;
        right: 0;
        max-width: 940px;
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: top left;
        aspect-ratio: 3 / 4;
        z-index: 2;
    }
    .page-features .mv{
        background: linear-gradient(0deg, rgba(210,152,255,1) 0%, rgba(210,152,255,1) 60%, rgba(210,152,255,0) 100%);
    }
    .page-concept .mv{
        background: linear-gradient(0deg, rgba(34,187,187,1) 0%, rgba(34,187,187,1) 60%, rgba(34,187,187,0) 100%);
    }
    .wide .mv-text{
        margin-top: 40px;
    }
}

@media screen and (max-width: 1440px) {
    .mv-image,
    .wide .mv-image{
        opacity: .2;
    }
    .mv-text{
        max-width: 520px;
        border-radius: 4px;
        padding: 10px 16px 11px;
        background-color: rgba(255, 255, 255, .8);
    }
}

@media screen and (max-width: 768px) {
    .mv-title h1{
        font-size: 56px;
    }
    .mv-title span{
        font-size: 20px;
    }
    .mv-title,.mv-text{
        padding: 0 20px;
    }
    .mv-note{
        gap: 40px;
    }
    .mv-image,
    .wide .mv-image{
        opacity: 1;
    }
}

.section{
    padding: 80px;
}

.block{
    width: 100%;
    max-width: 1128px;
    margin: 0 auto;
}

.outline .block{
    max-width: 940px;
}

h2{
    text-align: center;
    font-size: 44px;
}

@media screen and (max-width: 768px) {
    .section{
        padding: 80px 0;
    }
    h2{
        font-size: 28px;
    }
}


/* outline */
.table-wrap{
    margin-top: 80px;
}

.table{
    width: 100%;
    font-size: 16px;
    table-layout: fixed;
}

tr{
    border-bottom: 1px solid #EBEBEB;
}

th,td{
    padding: 12px 18px;
    line-height: 1.8;
}

th{
    font-weight: bold;
}

.th240 th{
    width: 240px;    
}

.col-2.th240 td{
    width: calc(100% - 240px);
}

.th140 th{
    width: 140px;
}

.col-4.th140 td{
    width: calc((100% - 140px) / 3);
}

.thead-gray{
    border-top: 1px solid #EBEBEB;
    background-color: #F2F2F2;
}

.borderbottom-none{
    border-bottom: none;
}

.map-wrap{
    position: relative;
    margin-top: 80px;
    border: 1px solid #EBEBEB;
    border-radius: 0 10px 10px 10px;
}

.map-wrap > span{
    position: absolute;
	top: -36px;
    color: #fff;
    background-color: #22BBBB;
    font-size: 12px;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 8px 20px;
    border-radius: 10px 10px 0 0;
    z-index: 2;
}

.map-wrap .icon{
    width: 20px;
    height: 20px;
    margin-right: 10px;
    object-fit: contain;
    border: none;
}

.map-wrap a{
    display: block;
	overflow: hidden;
}

.map-wrap a img{
    width: 100%;
    transition: .4s;
}

.section.walk{
    background-color: #F2F2F2;
}

.walk-text{
    margin-top: 40px;
}

.walk-text p{
    text-align: center;
    font-size: 18px;
}

.walk-text .link-btn{
    width: auto;
    background-color: #fff;
}

.title-icon{
    text-align: center;
}

.title-icon img{
    width: 40px;
    height: 40px;
}

.root_list{
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    gap: 40px 50px;
    counter-reset: number 0;
    margin-top: 40px;
}

.root_list li{
    position: relative;
    width: calc((100% - 100px) / 3);
    padding: 20px;
    background-color: #fff;
    border-radius: 12px;
}

.root_list li::before{
    content: counter(number);
    counter-increment: number 1;
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    width: auto;
    padding: 8px 20px;
    background-color: #22BBBB;
    color: #fff;
    z-index: 2;
    border-radius: 12px 0 0 0;
}

.root_list .root-mdl{
    display: flex;
    flex-direction: column;
    gap: 12px;
    text-decoration: none;
}

.root_list .text{
    position: relative;
    font-size: 14px;
    color: #222;
}

.root_list li::after{
    content: "";
    display: inline-block;
    position: absolute;
}

.root_list .image{
    width: 100%;
    cursor: pointer;
}

.root_list li.root_escalator{
    display: none;
    width: 100%;
    background-color: unset;
    background-color: rgba(34, 34, 34, .8);
}

.root_escalator .root_list{
    margin-top: 0;
}

.root_list li.root_escalator::before,
.root_list li.root_escalator::after{
    display: none;
}

.btn-escalator{
    display: flex;
    align-items: flex-end;
    margin-top: 10px;
    height: 20px;
    font-size: 18px;
    color: #22BBBB;
    text-decoration: underline;
    z-index: 9999;
}

@media screen and (min-width: 769px) {
    .root_list li:not(:nth-child(3),:nth-child(6),:nth-child(9),:nth-child(14),:nth-child(17),.last)::after{
        top: 50%;
        right: -36px;
        transform: translateY(-50%);
        width: 24px;
        height: 24px;
        background: url("../img/common/icon_right.svg") no-repeat center / contain;
    }
    .root_list li.last{
        width: calc(((100% - 25px) / 3) * 2);
    }
}

@media screen and (max-width: 768px) {
    .access .section,
    .access .section + .section{
        padding: 80px 0 0;
    }
    .root_list{
        gap: 30px;
        padding: 20px 20px 40px;
    }
    .root_list li.root_escalator{
        padding: 0;
    }
    .root_escalator .root_list{
        margin-top: 0;
        padding: 10px;
    }
    .root_list li{
        width: 100%;
    }
    .root_list li::after{
        bottom: -28px;
        left: 50%;
        transform: translateX(-50%);
        width: 24px;
        height: 24px;
        background: url("../img/common/icon_bottom.svg") no-repeat center / contain;
    }
    .root_list li:last-child:after{
        display: none;
    }
    .map-wrap .icon{
        margin-right: 0;
    }
	.map-wrap > span{
		top: 0;
		border-radius: 0;
	}
}

.root-train{
    display: flex;
    flex-direction: row;
    margin-top: 80px;
    gap: 40px;
}

.root-train li{
    width: calc((100% - 80px) / 3);
}

.root-train h3{
    font-weight: 500;
    text-align: center;
}

.root-train .image{
    margin-top: 40px;
    width: 100%;
}

.zoom-text{
    margin-top: 40px;
}

.message-wrap{
    display: flex; 
    margin-top: 80px;
}

.message-note{
    display: flex;
    flex-direction: column;
    gap: 40px 0;
    width: calc(100% - 300px);
    padding-right: 40px;
}

.message-note p{
    display: flex;
    flex-direction: column;
    gap: 20px 0;
    line-height: 1.8;
}

.message-note .name{
    display: block;
    text-align: right;
    font-weight: bold;
}

.message-image + .message-note{
    padding-right: 0;
    padding-left: 40px;
}

.message-note h3{
    font-size: 30px;
    line-height: 1.2;
}

.message-image{
    width: 100%;
    max-width: 300px;
    height: 100%;
    max-height: 420px;
    aspect-ratio: 1 / 1.4;
    border-radius: 12px;
    object-fit: cover;
}

@media screen and (max-width: 768px) {
    .table-wrap{
        margin-top: 40px;
    }
    .table-wrap + .table-wrap{
        margin-top: 80px;
    }
    .table{
        font-size: 14px;
    }
    th,td{
        padding: 10px;
        line-height: 1.8;
    }
    th:first-of-type{
        padding-left: 20px;
    }
    td:last-of-type{
        padding-right: 20px;
    }
    .th240 th{
        width: 100px;    
    }
    .col-2.th240 td{
        width: calc(100% - 100px);
    }
    .th140 th{
        width: 72px;
    }
    .col-4.th140 td{
        width: calc((100% - 72px) / 3);
    }
    .outline-about th{
        text-align: center;
        vertical-align: middle;
    }
    .map-wrap{
        margin-top: 40px;
    }
    .message-wrap{
        flex-direction: column;
    }
    .message-note h3{
        font-size: 22px;
    }
    .message-note,
    .message-image + .message-note{
        width: 100%;
        padding: 0 20px;
    }
    .message-image{
        margin: 40px auto 0;
    }
    .message-wrap:nth-child(odd){
        flex-direction: column-reverse;
    }
    .root-train{
        flex-direction: column;
        margin-top: 40px;
        gap: 80px;
        padding: 0 20px;
    }
    .root-train li{
        width: 100%;
    }
    .root-train h3{
        font-weight: 500;
        text-align: center;
    }
    .root-train .image{
        margin-top: 40px;
        width: 100%;
    }
    .zoom-text{
        padding: 0 20px;
    }
}

.footer-grd-wrap{
    position: relative;
    margin-top: -140px;
    z-index: -1;
}

.footer-grd{
    width: 100%;
    object-fit: contain;
}

@media screen and (max-width: 768px) {
    .footer-grd-wrap{
        margin-top: 0;
    }
}

.pr-youtube,
.pr-youtube + h2{
    margin-top: 80px;
}

.pr-youtube iframe{
    width: 100%;
    aspect-ratio: 16 / 9;
    border-radius: 12px;
}

@media screen and (max-width: 768px) {
    .pr-youtube,
    .pr-youtube + h2{
        margin-top: 40px;
    }
}

.schedule-image{
    margin-top: 80px;
}

@media screen and (max-width: 768px) {
    .schedule-image{
        margin-top: 40px;
    }
}

.w100{
    width: 100%;
}

.access-map{
    margin-top: 80px;
}

.access-map h3{
    font-size: 30px;
    text-align: center;
    font-weight: 400;
}

.access-map .map-wrap{
    margin-top: 40px;
}

.access-map-detail{
    margin-top: 20px;
}

.access-map-detail h4{
    padding: 20px;
    font-size: 26px;
	text-align: center;
	font-weight: 400;
}

.access-map-detail dd{
    padding: 0 20px;
    border-top: 2px solid #22BBBB;
}

.access-map-detail dd:last-child{
    border-bottom: 2px solid #22BBBB;
}

.map-detail-list{
    margin: 20px auto 10px;
    max-width: 740px;
}

.map-detail-list li{
    line-height: 2;
    text-indent: -1rem;
    padding-left: 1rem;
}

.map-detail-list li::before{
    content: "・";
}

.map-detail-cont .link-btn-wrap{
    margin: 10px auto 20px;
}

.ac-btn{
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    font-size: 18px;
    letter-spacing: .6px;
    padding: 20px 40px 20px 0;
}

.ac-btn::before,
.ac-btn::after {
	content: "";
	position: absolute;
	top: 50%;
    right: 0;
	width: 20px;
	height: 2px;
	background-color: #22BBBB;
    transform: translateY(-50%);
    transition: .4s;
}

.ac-btn::before {
	transform: rotate(-90deg);
}

.is-open.ac-btn::before {
	transform: rotate(-45deg);
}

.is-open.ac-btn::after {
	transform: rotate(45deg);
}

.ac-cont{
    height: 0;
    padding: 0 20px;
    transition: .4s;
    overflow: hidden;
}

.is-open + .ac-cont{
    height: auto;
    padding-bottom: 20px;
    overflow: unset;
}

@media screen and (max-width: 768px) {
    .access-map {
        margin-top: 40px;
        padding-bottom: 80px;
    }
    .access-map h3{
        font-size: 22px;
    }
    .access-map .map-wrap{
        margin-top: 20px;
    }
    .access-map-detail{
        margin-top: 20px;
    }
    .access-map-detail h4{
        padding: 0 20px 20px;
        font-size: 20px;
    }
    .ac-btn{
        font-size: 16px;
        padding: 14px 20px 14px 0;
    }
    .ac-btn::before,
    .ac-btn::after {
        width: 14px;
    }
    .ac-cont{
        padding: 0 10px;
    }
}

.pers-wrap{
    position: relative;
}

.pers-lists{
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    gap: 40px 20px;
    margin-top: 40px;
}

.pers-lists li{
    position: relative;
    width: calc((100% - 40px) / 3);
    cursor: pointer;
}

.pers-text{
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 8px 20px;
    border-radius: 10px 0 0 0;
    font-size: 12px;
    color: #fff;
    background-color: rgba(34, 34, 34,.9);
}

.pers-image{
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: 10px;
}

.pers-icons{
    display: flex;
    justify-content: flex-end;
    gap: 4px;
    font-size: 14px;
    color: #fff;
}

.pers-sort{
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}

.pers-sort .pers-icon{
    display: flex;
    justify-content: flex-end;
    gap: 4px;
    padding: 12px 20px;
    font-size: 14px;
    color: #fff;
    border-radius: 40px;
    background-color: rgba(34, 34, 34,.9);
    transition: .4s;
}

.pers-lists .pers-icons{
    display: none;
}

.pers-lists li.follow{
    width: 100%;
    font-size: 14px;
    text-align: right;
    font-weight: 400;
    z-index: 2;
}

@media screen and (max-width: 768px) {
    .pers-lists li{
        padding: 0 10px;
        width: 100%;
    }
    .pers-text{
        left: 10px;
    }
    .pers-sort{
        margin-top: 40px;
        padding: 0 10px;
    }
    .pers-lists li.follow{
        font-size: 14px;
        text-align: left;
        text-indent: -1rem;
        padding-left: 1.6rem;
    }
    .features_bk .section{
        padding-top: 40px;
    }
}

.pers-sort .pers-icon.is-current{
    color: #222;
    background-color: rgba(255, 255, 255, 0.6);
}

.features_bk{
    background: rgb(200,202,68);
    background: linear-gradient(0deg, rgba(200,202,68,1) 0%, rgba(200,202,68,1) 40%, rgba(210,152,255,1) 100%);
}

.concept_bk{
    padding: 160px 80px 80px;
    background: #22BBBB;
    background: linear-gradient(0deg, rgba(200,202,68,1) 0%, rgba(34,187,187,1) 100%);
}

.concept_bk + .section{
    position: relative;
}

.concept_bk + .section .block{
    padding-top: 320px;
}

.concept_bk + .section::before{
    content: "";
    display: block;
    position: absolute;
    top: -2px;
    left: 0;
    width: 100%;
    height: 100%;
    background: url("../img/common/grd01-top.svg") no-repeat top / contain;
}

.page-features .footer-grd-wrap{
    z-index: 0;
    background-color: rgb(200,202,68);
}

.concept_list{
    margin-top: 40px;
    display: flex;
    width: 100%;
    gap: 20px;
}

.concept_list > li{
    width: 100%;
    padding: 20px 24px 24px;
    border-radius: 12px;
    background-color: rgba(255, 255, 255, .8);
}

.concept-title{
    display: flex;
    flex-direction: column;
    padding: 0 0 14px;
    gap: 6px 0;
}

.concept-title .en{
    font-weight: 600;
    font-size: 12px;
}

.concept-title h3{
    font-size: 26px;
}

.concept-image img{
    width: 100%;
    height: 200px;
    object-fit: cover;
}

.concept-notes{
    margin-top: 20px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.concept-notes li{
    text-indent: -1rem;
    padding-left: 1rem;
}

.concept-notes li::before{
    content: "・";
    display: inline;
    font-size: 1rem;
}

.green em{
	color: #3eac6e!important
}

.pink em{
	color: #eb8696!important
}

.orange em{
	color: #f19274!important
}

@media screen and (max-width: 768px) {
    .concept_bk{
        padding: 0 20px;
    }
    .concept_bk + .section .block{
        padding-top: 80px;
    }
    .concept_list{
        flex-direction: column;
        padding: 0;
    }
    .concept_bk{
        margin-top: -80px;
        padding: 120px 20px 40px;
    }
    .concept_bk h2 {
		font-size: 24px;
	}
}

.about-symbol,
.concept-about{
    display: flex;
    align-items: center;
}

.concept-about dt{
    width: 300px;
}

.concept-about dt img{
    width: 100%;
}

.concept-about dd{
    padding-left: 40px;
    font-size: 18px;
    width: calc(100% - 300px);
}

.about-symbol{
    padding: 10px 20px;
    margin-left: auto;
    width: calc(100% - 340px);
    border: 1px solid #222;
}

.about-symbol dt{
    width: 80px;
}

.about-symbol dd{
    padding-left: 20px;
    width: calc(100% - 80px);
}

.square-list{
    margin-top: 40px;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 40px;
}

.square-list li{
    display: flex;
    flex-direction: column;
    width: calc((100% - 80px) / 3);
    gap: 10px;
}

.square-image{
    margin-top: auto;
}

@media screen and (max-width: 768px) {
    .concept .section{
        padding: 40px 0 0;
    }
    .concept-about{
        flex-direction: column;
        gap: 40px;
        padding: 0 20px;
    }
    .about-symbol,
    .concept-about dt,.concept-about dd{
        width: 100%;
    }
    .concept-about dd{
        padding-left: 0;
    }
    .about-symbol{
        margin-top: 40px;
        width: calc(100% - 40px);
        margin: 0 auto;
    }
    .about-symbol{
        margin-top: 40px;
    }
    .about-symbol .image{
        width: 40px;
    }
    .about-symbol .text{
        width: calc(100% - 40px);
    }
    .square-list{
        flex-direction: column;
    }
    .square-list li{
        gap: 20px;
        width: 100%;
    }
    .square-title,.square-notes{
        padding: 0 20px;
    }
}

.report-wrap{
    display: flex;
    flex-direction: column;
    gap: 40px;
    margin: 80px auto 0;
    width: 100%;
    max-width: 1128px;
}

.report-wrap img{
    width: 100%;
}

.access .info-ex{
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 40px;
    margin: 0 auto;
    background: linear-gradient(-45deg, rgba(251, 219, 204, .96) 0%, rgba(255, 241, 204, .96) 100%);
}

.access h2 + .info-ex{
    margin-top: 40px;
}

.access .info-ex + .section{
    padding-top: 60px;
}

.access .info-ex h2{
	font-size: 36px;
}

.access .info-ex .icon{
    position: absolute;
    top: 50%;
    right: 40px;
    transform: translateY(-50%);
}

.access .info-ex-note{
    margin-top: 20px;
    font-size: 18px;
}

.access .info-ex-note li{
    margin-top: 6px;
    text-indent: -1rem;
    padding-left: 1rem;
    font-size: 18px;
}

.access .info-ex-note li::before{
    content: "・";
}

.access .info-ex .link-btn{
    background-color: #fff;
}

.access .info-ex .link-btn::after{
    margin-top: 2px;
    background: url(../img/common/icon_window-g.svg) center / contain no-repeat;
    transition: .2s;
}

.al-center{
    text-align: center;
}

@media screen and (max-width: 768px) {
    .access .info-ex{
        padding: 40px 20px;
        margin: 0 auto;
    }
    .access .info-ex h2{
        font-size: 24px;
    }
    .access .info-ex-note ul{
        margin-top: 20px;
    }
    .access .info-ex-note li{
        font-size: 16px;
    }
    .access .link-btn-wrap{
        margin-top: 30px;
    }
}

.mfp-image-holder .mfp-content{
   max-width: 1300px!important;
}
.mfp-bg,.mfp-wrap{
    z-index: 10000!important;
}

.iframe-gm{
    width: 100%;
    height: 440px;
    border: 1px solid #EBEBEB;
	border-radius: 2px;
}

.iframe-gm-wrap{
    margin: 30px 0 60px;
}

@media screen and (max-width: 768px) {
    .iframe-gm-wrap{
        margin: 20px 0;
    }
    .iframe-gm {
        aspect-ratio: 1;
        height: auto;
    }
}

.rootvideo-block{
    margin-top: 80px;
}

.rootvideo{
    width: 100%;
    aspect-ratio: 16 / 9;
    border-radius: 12px;
}

.rootvideo-text h3{
    font-size: 30px;
    text-align: center;
    font-weight: 400;
}

.rootvideo-text p{
    padding-top: 20px;
    text-align: center;
}

@media screen and (max-width: 768px) {
    .rootvideo-block{
        margin-top: 0;
        padding-bottom: 80px;
    }
    .rootvideo-text h3{
        font-size: 20px;
    }
}

.floormap-wrap h2 + p{
    text-align:center;
	margin-top: 30px;
}

.floormap-slick{
	margin-top: 10px;
}

.floormap-slick .slick-slide{
	padding: 0 60px;
}

.floormap-slick .slick-slide img{
	width: 100%;
}

.floormap-slick .slick-arrow{
	position: absolute;
	top: 50%;
	height: 50px;
	width: 50px;
	border-radius: 50%;
	font-size: 0;
	transform: translateY(-50%);
	z-index: 10;
	background: rgba(0, 0, 0, .8) url("../img/common/icon_link-arrow02.svg") center no-repeat;
	transition: .4s;
}

.floormap-slick .slick-arrow.slick-prev{
	transform: translateY(-50%) rotate(180deg);
}

.floormap-slick .slick-arrow.slick-next{
	right: 0;
}

.slick-dots{
	margin-top: 10px;
	display: flex;
	width: 100%;
	justify-content:center;
	gap: 10px;
}

.slick-dots button{
	width: 40px;
	height: 40px;
	font-size: 20px;
	color: #fff;
	background: rgba(0, 0, 0, .8);
	border-radius: 2px;
	transition: .4s;
}

.slick-active button{
	color: #222;
	background: rgb(255 255 255 / 80%);
}

.slick-dots button::after{
	content: "F";
}

@media (hover: hover) {
  .slick-dots button:hover,
  .floormap-slick .slick-arrow:hover {
    opacity: .75;
  }
}

@media screen and (max-width: 768px) {
	.floormap-slick .slick-slide{
		padding: 0 10px;
	}
	.floormap-slick .slick-arrow{
		display: none;
	}
	.slick-dots{
		padding: 0 40px;
		flex-wrap: wrap;
	}
	.slick-dots button{
		font-size: 14px;
	}
}