@charset "UTF-8";
.location-top{
	/* background: url(../images/location/image-01.webp) no-repeat top center / cover; */
    /* padding-bottom: 26%; */
		overflow: hidden;
}
.location-top .secondary-heading{
	margin-bottom: 1em;
}
.location-top .secondary-heading .large-text{
	font-size: 125%;
	display: inline-block;
	line-height: 1.2;
}
.location-top .inner{
	position: relative;
	z-index: 1;
	padding-top: 6vw;
	padding-bottom: 36vw;
}
.location-top .fit-img{
	position: absolute;
	bottom: 0;
}
.loc-section{
	position: relative;
}
.loc-wrap{
	margin: 0 0 0 auto;
	display: flex;
	flex-wrap: wrap;
	gap: 48px;
	padding: 0 0 0 calc((100% - 1016px) / 2);

}
.loc-wrap .loc-head{
	padding-top: 60px;
	border-top: 4px solid #C1A170;
	max-width: 500px;
	width: 100%;
}
.loc-wrap .loc-head .secondary-heading{
	margin-bottom: .4em;
}
.loc-wrap .thumb{
	width: calc(100% - 548px);
}
.loc-under{
	margin: 60px auto 0;
	max-width: 1000px;
	width: calc(100% - 32px);
}
.loc-detail{
	margin-top: .8em;
	font-size: 2.2rem;
}
.loc-section.reverse .loc-wrap{
	margin: 0 auto 0 0;
	padding: 0 calc((100% - 1016px) / 2) 0 0;
	flex-direction: row-reverse;
}
.loc-text{
	position: absolute;
	top: 0;
	width: 12.5vw;
}
.loc-text.left{
	left: 0;
}
.loc-text.right{
	right: 0;
}

@media screen and (max-width: 1450px) {
	.loc-wrap {
			margin: 0 0 0 auto;
			padding: 0;
			width: 83vw;
	}
	.loc-wrap .loc-head{
		padding-top: 32px;
		width: 50%;
		max-width: 100%;
	}
	.loc-wrap .thumb{
		width: calc(50% - 48px);
	}
	.loc-section.reverse .loc-wrap {
    padding: 0;
	}
}
@media screen and (max-width: 767px) {
	.location-top .secondary-heading{
		line-height: 1.9;
		font-size: 1.8rem;
	}
	.location-top .inner{
	padding-top: 40px;
	padding-bottom: 0;
	}
	.loc-text {
    width: 18.5vw;
	}
	.loc-wrap {
		flex-direction: column;
		width: calc(100% - 32px);
		margin: 0 auto;
		gap: 12px;
	}
	.loc-wrap .thumb{
		width: 100%;
	}
	.loc-wrap .thumb .img-wrapper{
		margin-left: -16px;
		margin-right: -16px;
	}
	.loc-wrap .loc-head{
		padding-top: 24px;
		width: calc(100% - 20vw);
		margin-left: 20vw;
	}
	.loc-wrap .loc-head .lead{
		font-size: 1.4rem;
	}
	.loc-section.reverse .loc-wrap{
		width: calc(100% - 32px);
		margin: 0 auto;
		flex-direction: column;
	}
	.loc-section.reverse .loc-wrap .loc-head{
		margin-left: 0;
	}
	.loc-section.reverse .loc-wrap .thumb .img-wrapper {
        margin-right: -16px;
        margin-left: -16px;
	}
	.loc-under {
		margin-top: 32px;
	}
	.loc-under-container .loc-item{
		margin-right: 16px;
				transform: translateX(-64%);
	}
	.loc-under-container{
		    margin-right: -16px;
	}
	.location-top{
    padding-bottom: 16px;
	}
	.location-area{
		margin-top: -32px;
		position: relative;
	}
	.location-area-wrap{
		isolation: isolate;
		overflow-x: scroll;
		direction: rtl; 
	}
	.location-area-inner{
		isolation: isolate;
		direction: rtl; 
		background: url(../images/common/bg-key2.webp) no-repeat top center;
		background-size: cover;
		width: 170vw;
	}
	.location-area-inner .fit-img{
		position: static;
		direction: ltr;
		-webkit-mix-blend-mode: multiply;
		mix-blend-mode: multiply;
		display: block;
	}
	@keyframes accessScroll {
		0%{
			transform: translateX(0);
		}
		10%{
			transform: translateX(20px);
		}
		20%{
			transform: translateX(0);
		}
		30%{
			transform: translateX(20px);
		}
		40%,100%{
			transform: translateX(0);
		}
	}
	.wow-finished .scroll {
        animation: accessScroll 6s ease-in-out 0.8s both infinite;
    }
	.scroll{
		position: absolute;
		top: 60%;
		left: 35%;
		width: 30%;
		transform: translate(-50%, -50%);
		pointer-events: none;
		visibility: visible !important;
	}
	.slick-dots li{
		width: auto;
		margin: 0 4px;
	}
	.slick-dots li.slick-active button{
		background: #C1A170;
	}
	.slick-dots li button{
		border-radius: 50%;
		background: #c1c1c1;
		width: 8px;
		height: 8px;
	}
	.slick-dots li button::before{
		content: none;
		
	}
}

/* .secondary-heading{
    font-size: clamp(2rem, 3vw, 3rem);
} */
.fb-container{
	min-height: calc(100svh * 2);
	position: relative;
	&::after{
		content: "";
		height: 100svh;
		display: block;
	}
}
.fb{
	height: 100svh;
	background: url(../images/location/bg-fb.webp) no-repeat top center/ cover;
		/* &::after{
		content: "";
		height: 100svh;
		display: block;
	} */
}
.general-section .inner{
	&.inner-fb{
		max-width: 1500px;
		position: relative;
		&::before{
			content: "";
			width: auto;
			height: 86%;
			background: url(../images/location/fb-text.svg) no-repeat left center / contain;
			position: absolute;
			top: 50%;
            left: calc(10 / 1500 * 100vw);
			aspect-ratio: 63 / 812;
			transform: translateY(-50%);
		}
	}
	&.inner-fb2{
		padding-block: 0;
		padding-inline: calc(152 / 1680 * 100%) calc(106 / 1680 * 100%);
		max-width: 100%;
	}
}
.fb-contents-wrap{
	grid-template-columns: min(40vw, 550px) 1fr;
	align-items: end;
	gap: 120px;
	.lead{
		margin: 0 0 .5em 0;
		font-size: 2.1rem;
		font-weight: 500;
		.small-text{
			font-size: 88%;
		}
		& + .note{
			margin-bottom: 32px;
		}
	}
	.note{
		margin-block: 0 calc(90 / 640 * 100%)
	}
}
.fb-contents-wrap{
	height: 100%;
	section{
		display: flex;
		flex-direction: column;
        justify-content: flex-end;
        height: inherit;
		position: relative;
		/* &::before{
			content: attr(data-fb-num);
            text-align: right;
            display: block;
            position: absolute;
            top: 0;
            right: 0;
            color: var(--color-green);
			font-family: var(--en-font);
			font-size: 3.6rem;
			letter-spacing: .2rem;
		} */
		 &.justify-center{
			justify-content: center;
		 }
	}
}
.fb-grid{
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(4px, 1.6vw, 16px);
}
.fb-content-ttl{
	margin-bottom: clamp(.8em, 2.3vw, 1.3em);
	font-size: clamp(1.8rem, 2.2vw, 2.2rem);
}
.fb-progress {
  position: absolute;
  top: calc(76 / 5761 * 100%);
  right: 40px;
  width: 2px;
  height: min(640px, 80vh);
  background: rgba(0,0,0,.15);
  z-index: 1000;
  &:has(.is-active){
	position: fixed;
	top: 10%;
  }
  &:has(.is-last){
	position: absolute;
	top: 70%;
	/* top: 78%; */
  }
}

.fb-progress-bar {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 0%;
  background: var(--color-green);
  transform-origin: top;
}

.arena-lists-wrap{
	margin-bottom: 16px;
	padding-bottom: 16px;
	flex-wrap: nowrap;
	align-items: center;
	gap: 12px;
	border-bottom: 1px solid #707070;
	&:last-child{
		align-items: flex-start;
	}
}
.arena-ttl{
	padding: 6px;
	width: calc(20% - 6px);
	height: 32px;
	display: grid;
	place-items: center;
	background-color: var(--color-green);
	color: var(--color-white);
	font-size: 15px;
}
.arena-content{
	width: calc(80% - 6px);
}

@media screen and (max-width: 1200px) {
	.fb-progress {
		height: 70vh;
	}
	.fb-contents-wrap {
		grid-template-columns: 45vw 1fr;
		gap: 60px;
	}
	.general-section .inner{
		&.inner-fb{
			&::before{
				left: calc(45 / 1500 * 100vw);
			}
		}
	}
}
@media screen and (max-width: 890px) {
	.fb-contents-wrap {
        grid-template-columns: 2fr 1fr;
        gap: 40px;
		section{
			&::before{
				top: -20px;
			}
		}
	}
}
@media screen and (max-width: 767px) {
	.general-section .inner{
		&.inner-fb{
			padding-top: 72px;
			&::before{
				height: 75%;
                top: auto;
				left: -2%;
                transform: translateY(0);
			}
		}
		&.inner-fb2{
			margin-right: 0;
			padding-inline: calc(55 / 375 * 100% - 32px) 0;
		}
	}
	.fb-kv-wrap{
		position: relative;
		position: relative;
		/* &::before{
			content: attr(data-fb-sp-num);
            text-align: right;
            display: block;
            position: absolute;
            top: 4px;
            right: 4px;
            color: var(--color-white);
            font-family: var(--en-font);
            font-size: 2.4rem;
            letter-spacing: .2rem;
            z-index: 1;
		} */
	}
	.fb-contents-wrap{
		section{
			&::before{
				content: none;
			}
		}
		.note{
			margin-bottom: calc(30 / 619 * 100%);
		}
	}
	.fb-contents-wrap{
		grid-template-columns: auto;
		gap: 32px;
	}
	.fb-progress {
		right: 3%;
	}
	.sp-is-light{
		color: var(--color-white);
	}
	.fb-progress {
		display: none;
	}
}

.life{
	&.general-section .inner {
        &.inner-fb {
            &::before {
               content: none;
            }
        }
    }
}
.life-grid{
	grid-template-columns: 40% 1fr;
	align-items: start;
	gap:0;
	position: relative;
	.lead{
		margin-bottom: 2.4em;
		font-size: clamp(1.4rem, 1.6vw, 1.6rem);
	}
}
.life-grid2{
	padding: 100px 0;
	margin: 0 auto;
	grid-template-columns: repeat(2, 1fr);
	gap: 60px 48px;
	width: 75%;
}
.loc-heading{
	font-size: clamp(3.2rem, 4.2vw, 4.2rem);
	letter-spacing: .3rem;
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	text-align: center;
	justify-content: center;
	transform: translateY(-50%);
	z-index: 1;
}
.loc-title{
	font-size: 2rem;
	line-height: 1.3;
	margin-top: .6em;
	margin-bottom: .2em;
}
/* .is-sticky{
	position: sticky;
	top: 0;
	height: 100vh;
}
.is-sticky .img-wrapper{
	width: 100%;
	height: 100vh;
}
.is-sticky .img-wrapper::before{
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: #434B4D;
	opacity: .4;
	mix-blend-mode: multiply;
}
.is-sticky .img-wrapper .fit-img{
	width: 100%;
	height: 100%;
	object-fit: cover;
} */
.contents-l.is-sticky{
	position: relative;
}

.life-info{
	background: #f5efe6;
	.loc-heading{
		margin-bottom: 1em;
	}
}
.tab-container{
	margin-bottom: 1.3em;
}
.tab{
	padding: 4px;
	height: 60px;
	align-content: center;
	flex: 1;
	background-color: var(--color-white);
	transition: all .3s ease-out;
	cursor: pointer;
	border-right: 1px solid #707070;
	line-height: 1.3;
	&:last-child{
		border-right: none;
	}
	&.is-active,
	&:hover{
		background-color: var(--color-green);
		color: var(--color-white);
	}
}
.content {
    display: none;
	&.is-active{
		display: block;
	}
}
/* .li-grid{
	height: 100%;
	grid-template-columns: 1fr 320px;
	border: 1px solid var(--color-black);
} */
.li-lists-wrap{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
}
.li-lists{
	margin-top: clamp(10px, 2vw, 20px);
    width: 100%;
	flex-direction: column;
	flex-wrap: nowrap;
}
.li-item{
	padding: clamp(10px, 1.6vw, 16px) clamp(4px, .8vw, 8px) 6px;
	width: 100%;
	display: flex;
    justify-content: space-between;
    align-items: center;
	border-bottom: 1px solid #dcdcdc;
}
.loc-name{
	font-size: 14px;
	display: flex;
    align-items: center;
    justify-content: flex-start;
	position: relative;
	line-height: 1.6;
}
.loc-time{
	font-size: 13px;
}
.life-wrap{
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
}
.life-title{
	font-size: 1.6rem;
	padding-bottom: .6em;
	margin-bottom: .8em;
	color: #C1A170;
	border-bottom: 2px solid;
}
.life-subtitle{
	font-size: 1.4rem;
	margin-bottom: .8em;
	font-weight: 600;
}
.life-list dl{
	display: flex;
	justify-content: space-between;
	font-size: 1.4rem;
	line-height: 1.3;
}
.life-list dl + dl{
	margin-top: .4em;
}
.life-list dl dt{
	display: flex;
}
.life-list dl dd{
	width: 10em;
}
.life-list dl dt::before{
	position: relative;
	top: 6px;
	content: '';
	display: block;
	width: 6px;
	height: 6px;
	background: #C1A170;
	border-radius: 50%;
	margin-right: 8px;
}
.life-lists{
	display: flex;
	flex-direction: column;
	gap: 32px;
}
@media screen and (max-width: 767px) {
	.life{
		&.general-section .inner{
			&.inner-fb{
				padding-top: 32px;
			}
			&.inner-fb2{
				width: 100%;
				padding-inline: 0;
			}
		}
	}
	.life-grid2{
		padding: 40px 0;
		width: calc(100% - 32px);
		gap: 16px;
		height: auto;
	}
	.is-sticky .img-wrapper{
		width: 100%;
		height: auto;
		aspect-ratio: 1 / 1;
	}
	.contents-l.is-sticky{
			position: relative;
			height: auto;
		}
	.life-grid{
		grid-template-columns: auto;
		height: auto;
		.lead + figure{
			aspect-ratio: 5 / 3;
			img{
				height: 100%;
				object-fit: cover;
			}
		}
	}
	.tab{
		width: calc(100% / 3);
		flex: auto;
		font-size: 13px;
		&:nth-child(3){
			border-right: none;
		}
		&:nth-child(4),
		&:nth-child(5),
		&:last-child{
			border-top: 1px solid #707070;
		}
	}
	.li-lists-wrap {
		grid-template-columns: 1fr;
		gap: 0;
	}
	.li-lists + .li-lists{
		margin-top: 0;
	}
	.loc-name{
		&::before{
			width: 24px;
			height: 26px;
			line-height: 1.5;
			font-size: 14px;
		}
	}
	.sp-text-center{
		text-align: center;
	}

	.life-wrap{
		grid-template-columns: 1fr;
	}
	.loc-title {
    font-size: 1.6rem;
	}
	.loc-detail{
		font-size: 1.8rem;
	}
}

/* add */
.note{
	font-size: clamp(14px, 13.6px + 0.125vw, 16px);
}
.secondary-heading {
    margin-bottom: 1.5em;
    font-size: clamp(2rem, 1.6vw, 2.6rem);
    font-weight: 400;
    line-height: 1.7;
}
.has-gap .col-2.has-one {
    width: 80%;
	margin: 0 auto;
}
.col-2.has-float{
	width: 100%;
	margin-top: 32px;

}
.col-2.has-float img{
	width: 100%;
}
@media screen and (max-width: 767px) {
	.has-gap .col-2.has-one {
		width: 100%;
	}
}

.pc-none02{
		display: none;
	}
@media screen and (max-width: 1080px) {
    .sp-none02 {
        display: none;
    }
	.pc-none02{
		display: block;
	}
}

