@charset "UTF-8";

/* introMap
---------------------------------------------- */
.introMap {
	position: relative;
	padding-block: clamp(80px, 2.88rem + 9.06vw, 220px) clamp(100px, 3.22rem + 12.94vw, 300px);
	z-index: 1;
}

/* section
---------------------------------------------- */
.sectionTitle {
	text-align: center;
}

.colBox {
	margin-top: 140px;
}

.colBox__inner {
	gap: 30px calc(150 / 1920 * 100%);
}

.colBox__img {
	width: calc(860 / 1920 * 100%);
}

.colBoxBody {
	/* width: calc(660 / 1920 * 100%); */
	flex: 1;
}
.colBoxBody__inner {
	width: min(90%, 710px);
}
.colBox__inner.reverse .colBoxBody__inner {
	margin-left: auto;
}

.colBoxBody .sectionCopy-m {
	line-height: 1.8;
}
.colBoxBody .sectionCopy-m .small {
	font-size: 60%;
	letter-spacing: 0;
}

.colBoxBody .sectionText {
	max-width: 650px;
}
.colBoxBody .sectionCopy-m + * {
	margin-top: 30px;
}

.sliderBox {
	display: grid;
	grid-template-columns: 600px 1fr;
	column-gap: calc(120 / 1660 * 100%);
	width: 95%;
	max-width: 1660px;
	margin-top: 150px;
	margin-left: auto;
	overflow: hidden;
}

.locationSlider {
	position: relative;
	grid-area: 1/1/3/2;
	/* width: 600px; */
	/* max-width: 600px; */
	/* height: 360px; */
	padding-bottom: 80px;
	overflow: hidden;
	z-index: 0;
}
.locationSlider .swiper-slide {
	/* width: 600px; */
	/* width: calc(350 / 1660 * 100%); */
	/* width: 350px; */
	/* height: 210px; */
	/* margin-right: calc(20 / 1660 * 100%); */
	/* margin-right: 20px; */
	/* transform: scale(.58); */
	/* transform-origin: bottom; */
	/* transition: .4s ease; */
}
.locationSlider .swiper-slide-active {
	/* transform: scale(1); */
	/* margin-right: 120px; */
	/* margin-right: calc(120 / 1660 * 100%); */
}

.locationSlider .swiper-pagination {
	display: flex;
	gap: 35px;
	position: absolute;
	bottom: 0;
	left: 0;
	padding: 10px;
}

.locationSlider .swiper-pagination-bullet::before {
	content: '';
	position: absolute;
	top: 51%;
	left: 51%;
	transform: translate(-50%, -50%);
	width: 104px;
	aspect-ratio: 1;
	opacity: 0;
	background: url(../../img/common/figure_slider-dot-bg-green.png) center/contain no-repeat;
	visibility: hidden;
	z-index: 0;
}
.locationSlider .swiper-pagination-bullet-active {
	background-color: var(--color-green);
}
.locationSlider .swiper-pagination-bullet-active::before {
	opacity: 1;
	visibility: visible;
}

.contentsSlider {
	grid-area: 1/2/2/3;
	overflow: hidden;
}

.contentsSlider__name {
	position: relative;
	font-size: 24px;
	font-weight: 500;
	letter-spacing: 0.1em;
	line-height: 1.5;
	padding-left: 1.5em;
	z-index: 0;
}
.contentsSlider__name .small {
	display: block;
	font-size: 58.334%;
	font-weight: normal;
	letter-spacing: 0.1em;
}

.locationThumWrap {
	align-self: flex-end;
	grid-area: 2/2/3/3;
	margin-bottom: 80px;
	overflow: hidden;
}
.locationThumSlider {
	max-width: 350px;
}
.locationThumSlider .swiper-slide {
	width: 350px;
	margin-right: 20px;
	transition: .4s ease;
}
/* .locationThumSlider .swiper-slide:last-child {
	opacity: 0;
	visibility: hidden;
} */
.locationThumWrap .swiper-slide-prev {
	opacity: 0;
}

@media screen and (max-width: 1200px) {
	.sliderBox {
    grid-template-columns: 480px 1fr;
	}

	.contentsSlider__name {
    font-size: 18px;
    padding-left: 1.2em;
	}
	.contentsSlider__name::before {
    top: 10px;
    width: 9px;
	}
}

@media screen and (max-width: 960px) {
	.sliderBox {
		display: block;
		width: 100%;
		padding-bottom: 80px;
	}

	.locationSlider {
		width: 85%;
    max-width: 560px;
    margin-inline: auto;
		padding-bottom: 0;
		overflow: revert;
	}

	.locationSlider .swiper-pagination {
    bottom: -120px;
    left: auto;
    justify-content: center;
	}

	.contentsSlider {
		width: 85%;
    max-width: 560px;
    margin-top: 20px;
    margin-inline: auto;
	}

	.locationThumWrap {
		display: none;
	}
}

@media screen and (max-width: 768px) {
	.colBox {
		margin-top: 50px;
	}

	.colBox__inner.flex {
		align-items: flex-start;
		flex-direction: column;
	}

	.colBox__img {
		width: calc(350 / 375 * 100%);
	}
	.colBox__inner.reverse .colBox__img {
		margin-left: auto;
	}

	.colBoxBody {
		flex: revert;
		width: calc(320 / 375 * 100%);
		margin-inline: auto;
	}
	.colBoxBody__inner {
		width: 100%;
	}
	.colBox__inner.reverse .colBoxBody__inner {
		margin-inline: auto;
	}

	.sliderBox {
		margin-top: 50px;
	}
}

/* shopping
---------------------------------------------- */
.shopping {
	padding-bottom: clamp(100px, 4.58rem + 7.12vw, 210px);
}

.shopping .sectionCircle {
	top: -22%;
	right: 0;
	width: calc(1417 / 1920 * 100%);
	z-index: -1;
}

/* park
---------------------------------------------- */
.park {
	padding-bottom: clamp(70px, 2.4rem + 8.41vw, 200px);
	z-index: 2;
}

/* education
---------------------------------------------- */
.education {
	padding-block: clamp(70px, 1.64rem + 11.65vw, 250px) clamp(70px, 2.4rem + 8.41vw, 200px);
	z-index: 1;
}

.sectionHead {
	width: 95%;
	max-width: 1660px;
	margin-left: auto;
}

.sectionHeadTab {
	/* width: calc(650 / 1660 * 100%); */
	flex: 1;
	margin-top: 20px;
}

.sectionHeadTab .tablist {
	gap: calc(70 / 850 * 100%);
}
.sectionHeadTab .tab {
	display: flex;
	align-items: center;
	gap: .7em;
	position: relative;
	font-size: clamp(21px, 0.94rem + 0.78vw, 30px);
	font-weight: 500;
	color: #87d0f4;
	transition: .4s ease;
	z-index: 0;
}
.sectionHeadTab .tab.active {
	color: var(--color-orange);
}

.sectionHeadTab .tab[aria-controls="tabpanel-education"] .icon {
	-webkit-mask-image: url(../img/icon_education.svg);
	mask-image: url(../img/icon_education.svg);
}
.sectionHeadTab .tab[aria-controls="tabpanel-health"] .icon {
	-webkit-mask-image: url(../img/icon_health.svg);
	mask-image: url(../img/icon_health.svg);
}
.sectionHeadTab .tab[aria-controls="tabpanel-public"] .icon {
	-webkit-mask-image: url(../img/icon_public.svg);
	mask-image: url(../img/icon_public.svg);
}

.sectionHeadTab .tab.active .icon {
	background-color: var(--color-orange);
}

.sectionHeadTab .tab .text {
	position: relative;
	display: block;
	z-index: 0;
}

.sectionHeadTab .tab .click {
	position: absolute;
	top: -75px;
	right: -50%;
	width: clamp(130px, 8.8vw, 170px);
	height: 84px;
	z-index: 0;
}
.sectionHeadTab .tab .click::before,
.sectionHeadTab .tab .click::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	transition: .4s ease;
	z-index: 0;
}
.sectionHeadTab .tab .click::before {
	background: url(../img/txt_click.png) center/contain no-repeat;
}
.sectionHeadTab .tab .click::after {
	background: url(../img/txt_here.png) center/contain no-repeat;
	opacity: 0;
}
.sectionHeadTab .tab[aria-controls="tabpanel-education"] .click::before {
	right: -40%;
}
.sectionHeadTab .tab.active .click::before {
	opacity: 0;
}
.sectionHeadTab .tab.active .click::after {
	opacity: 1;
}
.sectionHeadTab .tab .icon {
	display: block;
	width: 26px;
	aspect-ratio: 1;
	background-color: #87d0f4;
	mask-size: contain;
	-webkit-mask-size: contain;
	mask-repeat: no-repeat;
	-webkit-mask-repeat: no-repeat;
	transition: .4s;
}

.sectionHeadBody {
	/* width: calc(920 / 1660 * 100%); */
	flex: 1;
}

.education .sectionTitle {
	font-size: clamp(40px, -1.26rem + 7.82vw, 130px);
}

.education .tabpanel {
	display: block;
	opacity: 0;
	visibility: hidden;
}
.education .tabpanel.active {
	opacity: 1;
	visibility: visible;
}

#tabpanel-health,
#tabpanel-public {
	position: absolute;
	bottom: clamp(70px, 2.4rem + 8.41vw, 200px);
	left: 0;
	width: 100%;
	z-index: 0;
}

.education .sectionCircle {
	bottom: 0;
	left: 0;
	width: calc(1417 / 1920 * 100%);
	z-index: -1;
}

@media screen and (max-width: 960px) {
	.sectionHead__inner {
		flex-direction: column;
		row-gap: 40px;
		align-items: center;
	}

	.sectionHeadTab {
		width: 100%;
	}
	.sectionHeadTab .tablist.flex {
		justify-content: center;
	}
}

@media screen and (max-width: 768px) {
	.sectionHead {
    width: calc(320 / 375 * 100%);
    max-width: 560px;
    margin-inline: auto;
	}

	.sectionHeadTab {
		width: calc(250 / 320 * 100%);
		margin-inline: auto;
	}
	.sectionHeadTab .tablist.flex {
		flex-direction: column;
		row-gap: 10px;
	}

	.sectionHeadTab .tab {
		gap: 0;
	}

	.sectionHeadTab .tab .icon {
    width: 18px;
		margin-right: 15px;
	}

	.sectionHeadTab .tab .click {
    position: relative;
		inset: auto;
    width: 120px;
    height: 50px;
	}
	.sectionHeadTab .tab .click::before {
    background-image: url(../img/txt_click_sp.png);
	}
	.sectionHeadTab .tab .click::after {
    background-image: url(../img/txt_here_sp.png);
	}

	.sectionHeadBody {
		flex: revert;
		width: 100%;
	}

	.education .sectionTitle {
		text-align: left;
	}

	.education .sliderBox {
		margin-top: 30px;
	}

	.education .sectionCircle {
		bottom: 75%;
		width: calc(250 / 375 * 100%);
	}
}

/* pickup
---------------------------------------------- */
.pickup__copy {
	margin-top: 2em;
	text-align: center;
}

.pickupBox01 {
	column-gap: calc(100 / 1400 * 100%);
	max-width: 1400px;
	margin-top: 130px;
}

.pickupBox01Head {
	flex: 1;
}

.pickupBox01Head .sectionText + .sectionText {
	margin-top: 1em;
}

.pickupBox01Body {
	width: calc(850 / 1400 * 100%);
}

.pickupBox01Body__caption {
	font-size: 12px;
	line-height: 1.4;
	margin-top: 1em;
	text-align: right;
}

.pickupBox02 {
	max-width: 1400px;
	margin-top: 100px;
}

.pickupBox02__item {
	width: calc((100% - 40px) / 2);
}

@media screen and (max-width: 960px) {
	.pickupBox01 {
		flex-direction: column;
		row-gap: 30px;
		max-width: 560px;
	}

	.pickupBox01Body {
		width: 100%;
	}
}

@media screen and (max-width: 768px) {
	.pickup__copy {
		width: 100%;
		font-size: 20px;
	}

	.pickupBox01 {
		margin-top: 20px;
	}

	.pickupBox01Head {
		flex: revert;
	}

	.pickupBox01Body__caption {
		font-size: 10px;
		text-align: left;
	}

	.pickupBox02 {
		row-gap: 10px;
		max-width: 560px;
		margin-top: 10px;
	}

	.pickupBox02__item {
		width: 100%;
	}
}

/* lifeinfo
---------------------------------------------- */
.lifeinfo {
  padding-block: clamp(80px, 3.18rem + 7.77vw, 200px);
}

.lifeinfo__ttl {
  font-size: clamp(20px, 0.41rem + 1.74vw, 40px);
	font-weight: 500;
  line-height: 1;
  color: #87d0f4;
  text-align: center;
}

.lifeInfoWrap {
  display: grid;
  grid-template-columns: calc(760 / 1400 * 100%) calc(540 / 1400 * 100%);
  column-gap: calc(50 / 1520 * 100%);
  max-width: 1400px;
  margin-top: 120px;
}

.lifeInfoTabWrap {
  grid-area: 1/1/1/3;
  margin-bottom: 80px;
}
.lifeInfoTab {
	border-bottom: 1px solid #ccc;
}
.lifeInfoTab__btn {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: calc(100% / 5);
  color: #999;
	font-family: YakuHanJP,'Noto Sans JP',sans-serif;
  font-size: clamp(15px, 0.81rem + 0.26vw, 18px);
  letter-spacing: 0.05em;
  line-height: 1.4;
  padding: 1em .2em;
  text-align: center;
  transition: 0.4s ease-in-out;
  z-index: 0;
}
.lifeInfoTab__btn::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 0;
	height: 1px;
	background-color: var(--color-orange);
	transition: .4s;
	z-index: 1;
}
.lifeInfoTab__btn.active,
.lifeInfoTab__btn:hover {
  color: var(--color-orange);
}
.lifeInfoTab__btn.active::before {
	width: 100%;
}

#map {
  grid-area: 2/1/3/2;
  position: relative;
  height: 600px;
}
.lifeInfoBody {
  grid-area: 2/2/3/3;
  height: 600px;
}
.lifeInfoBody__inner {
  height: 100%;
  /* padding-block: 30px; */
  overflow-y: auto;
}
.lifeInfoList {
  display: none;
  position: relative;
}
.lifeInfoList.active {
  display: block;
  animation: lifeinfolist 0.5s;
}
@keyframes lifeinfolist {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.lifeInfoList__list {
}
.lifeInfoList__list > li {
  position: relative;
  border-bottom: 1px dotted #ccc;
  cursor: pointer;
	font-family: YakuHanJP,'Noto Sans JP',sans-serif;
  padding-block: 1.5em;
}
.lifeInfoList__list > li .num {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 1.3em;
  width: 24px;
  aspect-ratio: 1;
  background: var(--color-orange);
  border-radius: 50%;
  color: #fff;
  font-size: 14px;
  text-align: center;
}
.lifeInfoList__list > li .txt {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .5em;
  padding-left: 2.5em;
}
.lifeInfoList__list > li .name {
  display: block;
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: 1.4;
}
.lifeInfoList__list > li .name .small {
  font-size: 14px;
}
.lifeInfoList__list > li .time {
  display: flex;
  justify-content: flex-end;
  font-size: 14px;
  letter-spacing: 0.05em;
  line-height: 1.4;
  margin-left: auto;
  text-align: right;
}

.lifeinfo .sectionCircle {
	bottom: 0;
	left: 0;
	width: calc(1238 / 1920 * 100%);
	z-index: -1;
}

@media screen and (max-width: 768px) {
  .lifeinfo__ttl {
    width: 100%;
    letter-spacing: .05em;
  }

  .lifeinfo .line {
    height: 50px;
  }

  .lifeInfoWrap {
    display: block;
    width: 100%;
    margin-top: 40px;
  }

  .lifeInfoTabWrap {
    margin-bottom: 20px;
  }

  .lifeInfoTab__btn {
    width: calc((100% / 3));
    height: 60px;
    font-size: 14px;
  }
  .lifeInfoTab__btn--sp-small {
    font-size: 13px;
  }

  #map {
    height: 330px;
  }

  .lifeInfoBody {
    height: 300px;
  }

  .lifeInfoBody__inner {
    padding-inline: 17.5px;
  }

	.lifeInfoList__list > li .name {
		font-size: 14px;
	}
	.lifeInfoList__list > li .name .small {
		font-size: 12px;
	}

	.lifeinfo .sectionCircle {
		bottom: 0;
		left: 0;
		width: calc(1238 / 1920 * 100%);
		z-index: -1;
	}
}