@charset "UTF-8";
/* CSS Document */


/* =======================================

LOADING

======================================= */
.loading {
  animation: fadeOut 1.5s 2.5s forwards;
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
	position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  width: 100vw;
  height: 100vh;
}
@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    visibility: hidden;
  }
}
.loading-logo {
  animation: logo_fade 6s 0.5s forwards;
  opacity: 0;
  width: 150px;
	height: auto;
	/*↓サイト開いた際のロゴサイズ変更*/
	aspect-ratio: 1 / 0.83;
}
@keyframes logo_fade {
  0% {
    opacity: 0;
    transform: translateY(0);
  }
  60% {
    opacity: 1;
    transform: translateY(-20px);
  }
  100% {
    opacity: 0;
    transform: translateY(-20px);
  }
}



/* =======================================

POP AD

======================================= */
#popup-ad {
	position: fixed;
	display: none;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background: rgba(0,0,0,0.5);
	z-index: 99;
	justify-content: center;
	align-items: center;
}
.popup-ad-inner {
	position: absolute;
	top: 50%;
	left: 50%;
	max-width: 700px;
	width: 50%;
	text-align: center;
	transform: translate(-50%, -50%);
}
#close-popup {
	position: absolute;
	top: -30px;
	right: 0;
	width: 35px;
	height: 20px;
	cursor: pointer;
	background: none;
	border: none;
}
#close-popup::before,
#close-popup::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	height: 2px;
	background: #FFF;
}
#close-popup::before {	
	transform: translate(-50%, -50%) rotate(-30deg);
}
#close-popup::after {	
	transform: translate(-50%, -50%) rotate(30deg);
}


/* =======================================

MAIN CONTENTS

======================================= */
.MV {
	position: relative;
	padding-bottom: 43px;
	margin-bottom: 80px;
}
.MV-inner ul,
.MV-inner ul li {
	width: 100%;
} 
.MV-swiper-pagination, .PT-swiper-pagination {
	position: absolute;
	left: 50%;
	bottom: 0;
	line-height: 1;
	transform: translateX(-50%);
}
.MV-swiper-pagination .swiper-pagination-bullet, .PT-swiper-pagination .swiper-pagination-bullet {
	width: 10px;
	height: 10px;
	margin: 0 10px;
}
.MV-swiper-pagination .swiper-pagination-bullet-active, .PT-swiper-pagination .swiper-pagination-bullet-active {
	background: #646464;
}


.circle-mv {
	position: relative;
	aspect-ratio: 1 / 0.6;
	margin-bottom: 40px;
	overflow: hidden;
}
.circle-mv.-noimg {
	height: auto;
	aspect-ratio: auto;
}
.circle-mv-photo, .circle-mv-bg {
	position: absolute;
	left: 50%;
	bottom: 0;
	width: 100%;
	height: 100%;
	transform: translateX(-50%);
}
.circle-mv-bg {
	background: #FFF;
}
.circle-mv-cov {
	position: absolute;
	left: 0;
	bottom: -1px;
	width: 100%;
}
.circle-mv.-noimg .circle-mv-cov {
	position: relative;
}
.circle-mv-cov svg {
	width: 100%;
	height: auto;
}


/* =======================================

INTRO

======================================= */
#INTRO {
	padding-bottom: 150px;
}
.intro-logos {
	padding-bottom: 40px;
}
.intro-logos p {
	margin-bottom: 40px;
}
.intro-txts {
	margin-bottom: 100px;
}
.intro-txts-head {
	margin-bottom: 20px;
	font-size: 32px;
	text-align: center;
	letter-spacing: .15em;
	line-height: 1.5;
	font-feature-settings: "palt";
}
.intro-txts-head p {
	display: inline-block;
	letter-spacing: .05em;
	margin-right: .35em;
}
.intro-txts-head strong.font-48 {
	line-height: 1.2;
}
.intro-txts-details {
	font-size: 29px;
	letter-spacing: .2em;
}
.intro-txts-details div {
	padding: 20px;
	border-bottom: 1px solid #B1CDD1;
	line-height: 1.4;
}
.intro-txts-details div.intro-txt-details-first div {
	width: 290px;
	padding: 0;
	margin: auto;
	border-bottom: none;
	line-height: 1.1;
}
.intro-txts-details div.intro-txt-details-first p.font-21 {
	letter-spacing: .1em;
}
.intro-txts-details-walk {
	font-size: 25px;
}
.intro-txts-details-walk.-inline {
	display: inline-block;
	margin-left: .8em;
}
.intro-txts-details-walk .num {
	font-size: 54px;
}

/* POINT */
#INTRO .content-slides {
	position: relative;
	width: calc(100% + 40px);
	margin: 0 -20px;
	padding-bottom: 43px;
}
.PT-inner {
	overflow: hidden;
}
.PT-swiper-box {
}
.PT-swiper-box.swiper-slide {
	width: 380px;
	height: auto;
	margin-left: 20px;
	margin-right: 20px;
}
.PT-swiper-box-txt {
	padding: 20px;
}
.PT-swiper-box-txt h3 {
	margin-bottom: 15px;
	text-align: center;
	font-size: 18px;
	line-height: 1.6;
}
.PT-swiper-box-txt h3 p {
	font-size: 20px;
}




/* =======================================

TOPICS

======================================= */
#TOPICS {
	padding: 120px 20px;
}
#TOPICS .contents-wrap {
	padding: 80px 0;
	background: #FFF;
}
.topic-box {
}
.topic-box.-sub {
	padding: 15px 0 0;
	border-bottom: 1px solid #B1CDD1;
}
.topic-box .date {
	font-size: 16px;
}
.topic-box-tx {
	padding-bottom: 20px;
	font-size: 14px;
	line-height: 1.6;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  	font-weight: bold;
}
.topic-box-tx a {
	color: #5B5756;
}
.topic-box-tx a:hover {
	opacity: .3;
}
.topic-box .lnkbtn {
	margin: 30px 60px;
}







/* =======================================

CONCEPT

======================================= */
#CONCEPT {
	overflow: hidden;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  	font-weight: bold;
}
#CONCEPT h2 p.en {
	 color: #FFF;
}
.concept-bg01 {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	background: #5B5756;
	z-index: -1;
}
.concept-bg02 {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	background: #5B5756;
	z-index: 0;
}
.concept-bg01 img, .concept-bg02 img {
	opacity: .3;
	display: block;
}
.concept-inner {
	text-align: center;
	color: #FFF;
}
.concept-txt-wrap {	
	position: relative;
	top: 50%;
	transform: translateY(-50%);
	z-index: 1;
}
.concept-subtitle {
	margin-bottom: 20px;
	font-size: 18px;
	line-height: 2;
}
.concept-txt {
	line-height: 2.9;
}
.concept-txt p {
	margin-bottom: 40px;
}
.concept-txt span {
	display: block;
}
.concept-logo {
	width: 240px;
	margin: auto;
	margin-top: 80px;
}







/* =======================================

TOWN DESIGN

======================================= */
#TOWNDESIGN .circle-mv {
	margin-bottom: 0;
}
#TOWNDESIGN h2 {
	margin-bottom: 80px;
}
.towndesign-intro {
	text-align: center;
	line-height: 1.4;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  	font-weight: bold;
}
#TOWNDESIGN .contents-wrap {
	padding: 40px 0 100px;
}







/* =======================================

AREA

======================================= */
#AREA {
	padding: 0;
}
#AREA h2 {
	width: 62%;
	margin: 0 auto 30px;
}
#AREA .sub-title {
	line-height: 2;
}
#AREA h3.sim-h2 {
	margin-top: 0;
}
.area-attn {
	position: relative;
	padding: 20px 20px 20px 70px;
	margin-bottom: 70px;
	border: 2px solid #DF857A;
	line-height: 1.8;
}
.area-attn span {
	top: 50%;
	left: 20px;
	transform: translateY(-50%);
}
#AREA .scroll-hint-text {
	display: none;
}
#AREA .impact-sub {
	font-size: clamp(14px, 3.8vw, 16px);
}
.area-map {
	width: calc(100% + 40px);
	margin: 0 -20px 50px;
}
.area-map-inner {
	position: relative;
	width: 100%;
	overflow-x: scroll;
	white-space: nowrap;	
}
.area-map-img {
	width: 745px;
}
.area-attn span, .area-map-btn {
	position: absolute;
	display: block;
	width: 30px;
	height: 30px;
	border-radius: 99px;
	background: #FFE800;
	z-index: 1;
}
.area-map-btn.-amb01 {
	top: 296px;
	left: 100px;
}
.area-map-btn.-amb02 {
	top: 71px;
	left: 277px;
}
.area-map-btn.-amb03 {
	top: 19px;
	left: 370px;
}
.area-map-btn img {
	vertical-align: top;
}
.area-map-btn-icon {
	cursor: pointer;
}
.area-map-btn-icon img {
	opacity: 1;
	transition: 1s cubic-bezier(0.28, 0.76, 0.37, 0.99);	
}
.area-map-btn-icon img:hover {
	opacity: .3;
}
.area-attn span::after,
.area-map-btn::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 200%;
	height: 200%;
	border-radius: 999px;
	background: rgba(223,133,122,.4);
	transform: translate(-50%, -50%);
	animation: mapicon-ef 2s linear infinite;
	z-index: -1;
}
@keyframes mapicon-ef {
	0% {
		opacity: 0;
		-webkit-transform: translate(-50%, -50%) scale(0);
		transform: translate(-50%, -50%) scale(0);
	}
	25% {
		opacity: .8;
		-webkit-transform: translate(-50%, -50%) scale(0.3);
		transform: translate(-50%, -50%) scale(0.3);
	}
	50% {
		opacity: 1;
		-webkit-transform: translate(-50%, -50%) scale(0.6);
		transform: translate(-50%, -50%) scale(0.6);
	}
	75% {
		opacity: .8;
		-webkit-transform: translate(-50%, -50%) scale(0.9);
		transform: translate(-50%, -50%) scale(0.9);
	}
	100% {
		opacity: 0;
		-webkit-transform: translate(-50%, -50%) scale(1.2);
		transform: translate(-50%, -50%) scale(1.2);
	}
}
.area-bnr ul li {
	margin-top: 30px;
}
.area-bnr ul li a:hover {
	opacity: .6;
}
.modal {	
	display: none;
	position: fixed;
	top: 50%;
	width: 460px;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.65);
	justify-content: center;
	align-items: center;
	transform: translateY(-50%);
	z-index: 98;
}
.modal-content {
	position: absolute;
	top: 50%;
	left: 50%;
	padding: 20px 17px;
	width: calc(100% - 6px);
	background-color: #FFF;
	transform: translate(-50%, -50%);
}
.modal-content-inner {
	position: relative;
	padding: 120px 20px;
	background: #FFF9F3;
}
.close-btn {
	position: absolute;
	top: 60px;
	right: 20px;
	width: 35px;
	height: 20px;
	cursor: pointer;
	background: none;
	border: none;
}
.close-btn::before,
.close-btn::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	height: 2px;
	background: #5B5756;
}
.close-btn::before {	
	transform: translate(-50%, -50%) rotate(-30deg);
}
.close-btn::after {	
	transform: translate(-50%, -50%) rotate(30deg);
}
.area-map-modal-title {
	text-align: center;
	margin-bottom: 10px;
}
.area-map-modal-title.fadeTxtAnm.anmActive div.forAnm::before {
    background: #FFF9F3;
}
.area-map-modal-img {
	aspect-ratio: 1 / 0.519;
	overflow: hidden;
	border-radius: 20px;
}
.modal .tag {
	margin: 25px auto 10px;
	text-align: center;
}
.modal .tag p {
	display: inline-block;
	padding: 12px 20px;
	font-size: 16px;
	line-height: 1;
	background: #FFF;
}
.modal .lnkbtn {
	margin: 30px 0 0;
	padding-top: 40px;
	padding-bottom: 40px;
}
.comingsoon {
	text-align: center;
	font-size: 35px;
}
body.modal-open {
	overflow: hidden;
}

.contents-wrap.-season1 {
	margin-top: 100px;
	padding: 65px 0 135px
}
.-season1 .content-slides {
    position: relative;
	margin: 20px auto 50px;
}
.TD-swiper-container {
	margin-bottom: 20px;
}
.TD-swiper-thumbs {	
	width: calc(100% + 20px);
	margin-right: -20px;
	overflow: hidden;	
}
.TD-thumbs-box.swiper-slide {
	width: 27.5%;
	transition: all 0.6s cubic-bezier(0.28, 0.76, 0.37, 0.99);
}
.TD-swiper-thumbs .swiper-slide-active {
	opacity: .4;
}
.-season1 .lnkbtn {
	line-height: 1.7;
	padding: 18px 14.5%;
}







/* =======================================

LOCATION

======================================= */
#LOCATION {
	padding-bottom: 150px;
}
#LOCATION h2 {
	margin-bottom: 70px;
}
#LOCATION .sub-title {
    line-height: 2;
	letter-spacing: .2em;
}
.locations {
	margin: 80px auto;
}
.locations-menu {
	margin-bottom: 80px;
}
.locations-menu ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.locations-menu ul li {
	position: relative;
	width: calc((100% - 20px) / 3);
	height: 70px;
	margin-bottom: 10px;
	padding: 12px 0;
	text-align: center;
	color: #FFF;
	border-radius: 10px;
	line-height: 1;
	opacity: 1;
	cursor: pointer;
    -webkit-transition: all 0.6s cubic-bezier(0.28, 0.76, 0.37, 0.99);
    transition: all 0.6s cubic-bezier(0.28, 0.76, 0.37, 0.99);	
}
.locations-menu ul li:hover {
	opacity: 1;
    -webkit-transition: all 0.6s cubic-bezier(0.28, 0.76, 0.37, 0.99);
    transition: all 0.6s cubic-bezier(0.28, 0.76, 0.37, 0.99);
}
.locations-menu ul li p {
	font-size: 16px;
}
.locations-menu ul li span {
	display: block;
	font-size: 12px;
	margin-top: 3px;
}
.locations-menu ul li .icon {
	position: absolute;
	left: 50%;
	bottom: 9px;
	width: 18px;
	transform: translateX(-50%);
}
.locations-menu ul li .icon svg {
	fill: #FFF;
}
.locations-menu ul li:nth-child(1) {
	background: #CBA286;
}
.location-box.-school .location-title p {
	color: #CBA286;
}
.locations-menu ul li:nth-child(2) {
	background: #B3C584;
}
.location-box.-park .location-title p {
	color: #B3C584;
}
.locations-menu ul li:nth-child(3) {
	background: #DF857A;
}
.location-box.-shopping .location-title p {
	color: #DF857A;
}
.locations-menu ul li:nth-child(4) {
	background: #DDB479;
}
.location-box.-gourmet .location-title p {
	color: #DDB479;
}
.locations-menu ul li:nth-child(5) {
	background: #B1CDD1;
}
.location-box.-hospital .location-title p {
	color: #B1CDD1;
}
.locations-menu ul li:nth-child(6) {
	background: #73839E;
}
.location-box.-public .location-title p {
	color: #73839E;
}
.location-box {
	display: none;
}
.location-box.location-active {
	display: block;
	animation: location-show 1s ease-in-out forwards;
}
@keyframes location-show {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
h3.location-title.sim-h2 span {
	margin-top: 0;
}
.location-title p span {
	display: inline;
}
.location-title p span.en {
	font-size: 24px;
	margin-right: 10px;
}
.location-box .subs {
	margin-top: 1em;
	font-size: 16px;
	line-height: 2;
}

.location-box-sub {
	margin-top: 50px;
}
.location-box-sub-img {
	position: relative;
}
.location-box-sub-img-impact {
	position: absolute;
	top: 0;
	left: 0;
	padding: 10px;
	font-size: 12px;
	line-height: 1;
	color: #FFF;
}
.location-box.-school .location-box-sub-img-impact {
	background: rgba(196,163,138,.9);	
}
.location-box.-park .location-box-sub-img-impact {
	background: rgba(183,196,139,.9);	
}
.location-box.-shopping .location-box-sub-img-impact {
	background: rgba(229,138,127,.9);	
}
.location-box.-gourmet .location-box-sub-img-impact {
	background: rgba(214,181,129,.9);	
}
.location-box.-hospital .location-box-sub-img-impact {
	background: rgba(183,204,208,.9);	
}
.location-box.-public .location-box-sub-img-impact, #ACCESS .location-box-sub-img-impact {
	background: rgba(118,131,156,.9);	
}
.location-box-sub-txt h4 {
	margin: 20px auto;
	text-align: center;
	font-size: 18px;
	line-height: 1.6;
}
.location-box-thumbs, 
.location-list dl {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	line-height: 1.6;
}
.location-box-thumbs-img {
	width: calc((100% - 20px) / 2);
	margin-top: 50px;
	text-align: center;
}
.location-box-thumbs-img p {
	font-size: 14px;
	margin-top: 5px;
} 
.location-list {
	margin-top: 50px;
}
.location-list dl dt{
	width: 50%;
	padding: 15px 0 10px;
	font-size: 14px;
	border-bottom: 1px solid #B1CDD1;
}
.location-list dl dd{
	width: 50%;
	padding: 15px 0 10px;
	text-align: right;
	border-bottom: 1px solid #B1CDD1;
}
#LOCATION .lnkbtn {
	margin-bottom: 80px;
}








/* =======================================

ACCESS

======================================= */
#ACCESS {
	padding-bottom: 150px;
}
#ACCESS .sub-title {
    line-height: 2;
	letter-spacing: .2em;
	margin-top: 70px;
}
#ACCESS .sub-title {
	font-size: clamp(14px, 3.8vw, 16px);
}
.access-map-inner {
	margin-top: 100px;
}
.access-stations {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 50px auto 80px;
}
.access-stations-box {
	width:calc((100% - 15px) / 2);
	margin-bottom: 20px;
	padding: 15px 0;
	text-align: center;
	line-height: 1.1;
	background: #EFEFEF;
	border-radius: 12px;
}
.access-stations-box strong.num {
	font-size: 54px;
}








/* =======================================

OVERVIEW

======================================= */
#OVERVIEW {
	padding-bottom: 150px;
}
#OVERVIEW .circle-mv {
	margin-bottom: 140px;
}
.overview-list {
	margin-top: 50px;
}
.overview-list dl {
	display: flex;
	padding: 10px 0;
	font-size: 10px;
	border-bottom: 1px solid #000;
	line-height: 1.6;
}
.overview-list dl dt {
	width: 115px;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  	font-weight: bold;
}
.overview-list dl dd {
	width: calc(100% - 115px);
}
.overview-txt {
	line-height: 2;
}
.overview-txt p {
	margin-top: 15px;
}

















@media (max-width: 1024px) {
	
	
	.topic-box .lnkbtn {
		margin: 30px 11%;
	}
	
	
	#INTRO .content-slides {
		width: calc(100% + 12.4%);
		margin: 0 -6.2%;
	}
	#TOPICS {
		padding: 120px 5.5%;
	}
	.TD-swiper-thumbs {
		width: calc(100% + 6.2%);
		margin-right: -6.2%;
	}
	.area-map {
		width: calc(100% + 12.4%);
		margin: 0 -6.2% 100px;
	}
	.modal {
		width: calc(100% - 390px);
		height: 100%;
	}
	.modal-content {
		padding: 20px 5%;
	}
	.modal-content-inner {
		padding: 120px 5.5%;
	}
	.close-btn {
		right: 5.5%;
	}
	
}




@media (max-width: 47.9375rem) {
	.loading-logo {
		width: 35%;
    	height: auto;
	}
	.popup-ad-inner {
		width: 80%;
	}
	
	
	#INTRO .content-slides {
		width: calc(100% + 11vw);
		margin: 0 -5.5vw;
	}
	.PT-swiper-box.swiper-slide {
		width: 340px;
		margin: 0 5.5vw;
	}
	.TD-swiper-thumbs {
		width: calc(100% + 5.5vw);
		margin-right: -5.5vw;
		overflow: hidden;
	}
	.area-map {
		width: calc(100% + 11vw);
		margin: 0 -5.5vw 50px;
	}
	.modal {
		top: 0;
		left: 0;
		width: 100%;
		transform: none;
	}
	.modal-content {
		position: relative;
		top: 80px;
		left: 0;
		margin: auto;
		max-height: 90vh;
		overflow-y: auto;
		transform: translateX(0);
		-webkit-overflow-scrolling: touch;
	}	
	.modal .lnkbtn {
		padding: 20px 5.5vw;
	}
	.modal .lnkbtn-icon {
		right: 5.5vw;
	}
	.modal .lnkbtn:hover .lnkbtn-icon {
		right: 2.5vw;
	}
	.scroll-hint-icon {
		z-index: 10;
	}
}


